@qualcomm-ui/mdx-vite 1.1.0 → 2.1.0
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.
- package/dist/cli.js +322 -230
- package/dist/cli.js.map +4 -4
- package/dist/docs-plugin/docs-plugin.d.ts.map +1 -1
- package/dist/docs-plugin/generate-page-map.d.ts +2 -0
- package/dist/docs-plugin/generate-page-map.d.ts.map +1 -0
- package/dist/docs-plugin/internal/search-indexer.d.ts +2 -2
- package/dist/docs-plugin/internal/search-indexer.d.ts.map +1 -1
- package/dist/docs-plugin/internal/services/markdown/markdown-file-reader.d.ts +1 -0
- package/dist/docs-plugin/internal/services/markdown/markdown-file-reader.d.ts.map +1 -1
- package/dist/docs-plugin/internal/services/markdown/markdown.types.d.ts +17 -1
- package/dist/docs-plugin/internal/services/markdown/markdown.types.d.ts.map +1 -1
- package/dist/docs-plugin/internal/services/nav-builder/nav-builder.d.ts.map +1 -1
- package/dist/docs-plugin/internal/services/nav-builder/page-map.d.ts.map +1 -1
- package/dist/docs-plugin/mdx-plugins.d.ts +2 -0
- package/dist/docs-plugin/mdx-plugins.d.ts.map +1 -1
- package/dist/docs-plugin/remark/remark-code-tabs.d.ts +16 -0
- package/dist/docs-plugin/remark/remark-code-tabs.d.ts.map +1 -1
- package/dist/docs-plugin/shiki/index.d.ts +3 -0
- package/dist/docs-plugin/shiki/index.d.ts.map +1 -0
- package/dist/docs-plugin/shiki/shiki-transformer-code-attribute.d.ts +20 -0
- package/dist/docs-plugin/shiki/shiki-transformer-code-attribute.d.ts.map +1 -0
- package/dist/docs-plugin/shiki/shiki-transformer-preview-block.d.ts +7 -0
- package/dist/docs-plugin/shiki/shiki-transformer-preview-block.d.ts.map +1 -0
- package/dist/docs-plugin/shiki/utils.d.ts +2 -0
- package/dist/docs-plugin/shiki/utils.d.ts.map +1 -0
- package/dist/index.js +204 -671
- package/dist/index.js.map +4 -4
- package/dist/open-web-ui-knowledge/generate-knowledge.d.ts.map +1 -1
- package/dist/react-demo-plugin/demo-plugin-utils.d.ts +0 -21
- package/dist/react-demo-plugin/demo-plugin-utils.d.ts.map +1 -1
- package/dist/react-demo-plugin/react-demo-plugin.d.ts +5 -1
- package/dist/react-demo-plugin/react-demo-plugin.d.ts.map +1 -1
- package/dist/react-demo-plugin/virtual.d.ts +0 -12
- package/dist/tsbuildinfo +1 -1
- package/package.json +3 -3
package/dist/index.js.map
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
|
-
"sources": ["../src/angular-demo-plugin/angular-demo-plugin.ts", "../src/docs-plugin/docs-plugin.ts", "../src/docs-plugin/internal/config-loader.ts", "../src/docs-plugin/internal/config-schema.ts", "../src/docs-plugin/internal/zod.ts", "../src/docs-plugin/internal/utils.ts", "../src/docs-plugin/internal/search-indexer.ts", "../src/docs-plugin/internal/services/doc-props/doc-props-indexer.ts", "../src/docs-plugin/internal/services/markdown/markdown-file-reader.ts", "../src/docs-plugin/internal/services/markdown/markdown-indexer.ts", "../src/docs-plugin/rehype/rehype-slug.ts", "../src/docs-plugin/remark/remark-alerts.ts", "../src/docs-plugin/internal/services/markdown/remark-remove-code-blocks.ts", "../src/docs-plugin/internal/services/markdown/remark-remove-jsx.ts", "../src/docs-plugin/internal/services/nav-builder/get-route-meta.ts", "../src/docs-plugin/internal/services/nav-builder/nav-builder.ts", "../src/docs-plugin/internal/services/nav-builder/page-map.ts", "../src/docs-plugin/internal/transform-route-meta-array.ts", "../src/docs-plugin/mdx-plugins.ts", "../src/exports.ts", "../src/docs-plugin/rehype/rehype-sectionize.ts", "../src/docs-plugin/remark/remark-code-tabs.ts", "../src/docs-plugin/remark/remark-self-link-headings.ts", "../src/docs-plugin/remark/remark-spoilers.ts", "../src/react-demo-plugin/demo-plugin-constants.ts", "../src/react-demo-plugin/demo-plugin-utils.ts", "../src/react-demo-plugin/react-demo-plugin.ts"],
|
|
4
|
-
"sourcesContent": ["// Copyright (c) Qualcomm Technologies, Inc. and/or its subsidiaries.\n// SPDX-License-Identifier: BSD-3-Clause-Clear\n\nimport {transformerRenderIndentGuides} from \"@shikijs/transformers\"\nimport chalk from \"chalk\"\nimport {type FSWatcher, watch} from \"chokidar\"\nimport {glob} from \"glob\"\nimport {existsSync} from \"node:fs\"\nimport {readFile, stat} from \"node:fs/promises\"\nimport {basename, dirname, join, relative, resolve} from \"node:path\"\nimport {\n createHighlighter,\n type Highlighter,\n type ThemeRegistration,\n type ThemeRegistrationRaw,\n type ThemeRegistrationResolved,\n} from \"shiki\"\nimport * as ts from \"typescript\"\nimport type {Plugin, ViteDevServer} from \"vite\"\n\nimport {\n type AngularDemoInfo,\n type ExtractedPreview,\n type PreviewContext,\n quiCustomDarkTheme,\n type SourceCodeData,\n} from \"@qualcomm-ui/mdx-common\"\n\nexport interface AngularDemoPluginOptions {\n demoPattern?: string | string[]\n /**\n * A mapping of <demoId, initialHtml>, which will be used for the initial\n * serverside render of each demo to prevent FOUC.\n */\n initialHtml?: Record<string, string>\n routesDir?: string\n theme?: {\n dark:\n | ThemeRegistrationRaw\n | ThemeRegistration\n | ThemeRegistrationResolved\n | string\n light:\n | ThemeRegistrationRaw\n | ThemeRegistration\n | ThemeRegistrationResolved\n | string\n }\n}\n\ninterface RelativeImport {\n resolvedPath: string\n source: string\n}\n\ninterface PathAlias {\n pattern: RegExp\n replacement: string\n}\n\nconst VIRTUAL_MODULE_ID = \"\\0virtual:angular-demo-registry\"\nconst VIRTUAL_MODULE_PREFIX = \"virtual:angular-demo-registry/\"\nconst LOG_PREFIX = \"[angular-demo]\"\n\nlet hasWatcherInitialized = false\n\n/**\n * Logs in dev mode only after the watcher has been initialized. Vite runs setup\n * hooks multiple times (once for each environment), so we use this approach to\n * ensure that certain messages are only logged once.\n */\nfunction logDev(...args: any[]) {\n if (!hasWatcherInitialized) {\n return\n }\n console.log(...args)\n}\n\nlet demoDimensionsCache: Record<string, DOMRect> = {}\nlet highlighter: Highlighter | null = null\nlet initCount = 0\nconst demoRegistry = new Map<string, AngularDemoInfo>()\n\nlet hotUpdateDemoIds: string[] = []\n\nexport function angularDemoPlugin({\n demoPattern = \"src/routes/**/demos/*.ts\",\n initialHtml,\n routesDir = \"src/routes\",\n theme = {\n dark: quiCustomDarkTheme,\n light: \"github-light-high-contrast\",\n },\n}: AngularDemoPluginOptions = {}): Plugin {\n let watcher: FSWatcher | null = null\n let devServer: ViteDevServer | null = null\n\n return {\n async buildEnd() {\n if (watcher) {\n await watcher.close()\n watcher = null\n hasWatcherInitialized = false\n }\n },\n\n async buildStart() {\n if (initCount === 0) {\n initCount++\n return\n }\n\n if (!highlighter) {\n try {\n highlighter = await createHighlighter({\n langs: [\"angular-ts\", \"angular-html\"],\n themes: [theme.dark, theme.light],\n })\n logDev(`${chalk.blue.bold(LOG_PREFIX)} Shiki highlighter initialized`)\n } catch (error) {\n console.warn(\n `${chalk.blue.bold(LOG_PREFIX)} Failed to initialize highlighter:`,\n error,\n )\n }\n }\n\n logDev(`${chalk.blue.bold(LOG_PREFIX)} Initializing Angular demo scanner`)\n await collectAngularDemos()\n\n if (process.env.NODE_ENV === \"development\") {\n if (!hasWatcherInitialized) {\n hasWatcherInitialized = true\n await setupAngularWatcher()\n } else {\n logDev(\n `${chalk.blue.bold(LOG_PREFIX)} Watcher already initialized by another instance`,\n )\n }\n }\n },\n\n configureServer(server) {\n devServer = server\n let dimensionUpdateTimeout: NodeJS.Timeout | null = null\n\n server.ws.on(\n \"custom:store-demo-dimensions\",\n (data: {demoId: string; dimensions: DOMRect}) => {\n const demoId = data.demoId\n demoDimensionsCache[demoId] = data.dimensions\n\n if (dimensionUpdateTimeout) {\n clearTimeout(dimensionUpdateTimeout)\n }\n\n dimensionUpdateTimeout = setTimeout(() => {\n const module = server.moduleGraph.getModuleById(VIRTUAL_MODULE_ID)\n if (module) {\n server.moduleGraph.invalidateModule(module)\n }\n }, 50)\n },\n )\n\n server.ws.on(\"custom:reset-demo-dimensions\", () => {\n demoDimensionsCache = {}\n const module = server.moduleGraph.getModuleById(VIRTUAL_MODULE_ID)\n if (module) {\n server.moduleGraph.invalidateModule(module)\n server.reloadModule(module)\n }\n })\n },\n\n async handleHotUpdate({file, server}) {\n if (!isAngularDemoFile(file)) {\n if (isCssAsset(file)) {\n return server.moduleGraph.getModulesByFile(file)?.values()?.toArray()\n } else if (file.endsWith(\"main.js\")) {\n const ids = [...hotUpdateDemoIds]\n server.ws.send({\n data: {\n demoInfo: ids.reduce(\n (acc: Record<string, AngularDemoInfo | undefined>, current) => {\n acc[current] = demoRegistry.get(current)\n return acc\n },\n {},\n ),\n },\n event: \"demo-bundle-updated\",\n type: \"custom\",\n })\n }\n return []\n }\n\n logDev(\n `${chalk.blue.bold(LOG_PREFIX)} Processing Angular demo change: ${chalk.cyan(file)}`,\n )\n\n const code = await readFile(file, \"utf-8\")\n const demoInfo = await parseAngularDemo(file, code)\n\n if (!demoInfo) {\n // might be an imported file\n const affectedDemos: AngularDemoInfo[] =\n await scanDemosForFileImport(file)\n\n if (affectedDemos.length > 0) {\n hotUpdateDemoIds = []\n const mainModule = server.moduleGraph.getModuleById(VIRTUAL_MODULE_ID)\n if (mainModule) {\n server.moduleGraph.invalidateModule(mainModule)\n await server.reloadModule(mainModule)\n }\n for (const demo of affectedDemos) {\n hotUpdateDemoIds.push(demo.id)\n }\n const pageIds = new Set(affectedDemos.map((demo) => demo.pageId))\n for (const pageId of pageIds) {\n const pageModuleId = `\\0${VIRTUAL_MODULE_PREFIX}${pageId}`\n const pageModule = server.moduleGraph.getModuleById(pageModuleId)\n if (pageModule) {\n server.moduleGraph.invalidateModule(pageModule)\n await server.reloadModule(pageModule)\n }\n }\n }\n\n server.ws.send({\n data: {\n ids: [...hotUpdateDemoIds],\n },\n event: \"demo-bundle-updating\",\n type: \"custom\",\n })\n\n return\n }\n\n delete demoDimensionsCache[demoInfo.id]\n demoRegistry.set(demoInfo.id, demoInfo)\n hotUpdateDemoIds = [demoInfo.id]\n\n server.ws.send({\n data: {\n ids: [...hotUpdateDemoIds],\n },\n event: \"demo-bundle-updating\",\n type: \"custom\",\n })\n\n const mainModule = server.moduleGraph.getModuleById(VIRTUAL_MODULE_ID)\n if (mainModule) {\n server.moduleGraph.invalidateModule(mainModule)\n await server.reloadModule(mainModule)\n }\n\n const pageModuleId = `\\0${VIRTUAL_MODULE_PREFIX}${demoInfo.pageId}`\n const pageModule = server.moduleGraph.getModuleById(pageModuleId)\n if (pageModule) {\n server.moduleGraph.invalidateModule(pageModule)\n await server.reloadModule(pageModule)\n }\n\n const demoModule = server.moduleGraph.getModuleById(file)\n if (demoModule) {\n server.moduleGraph.invalidateModule(demoModule)\n }\n\n return []\n },\n\n async load(id) {\n if (id === VIRTUAL_MODULE_ID) {\n return generateRegistryModule()\n }\n if (id.startsWith(`\\0${VIRTUAL_MODULE_PREFIX}`)) {\n const pageId = id.slice(`\\0${VIRTUAL_MODULE_PREFIX}`.length)\n return generatePageRegistryModule(pageId)\n }\n },\n\n name: \"angular-demo-plugin\",\n\n resolveId(id) {\n if (id === \"virtual:angular-demo-registry\") {\n return VIRTUAL_MODULE_ID\n }\n if (id.startsWith(VIRTUAL_MODULE_PREFIX)) {\n const pageId = id.slice(VIRTUAL_MODULE_PREFIX.length)\n return `\\0${VIRTUAL_MODULE_PREFIX}${pageId}`\n }\n },\n\n writeBundle() {\n console.log(\n `${chalk.blue.bold(LOG_PREFIX)} Successfully integrated ${chalk.green(demoRegistry.size)} component demos`,\n )\n },\n }\n\n async function collectAngularDemos() {\n if (demoRegistry.size) {\n logDev(\n `${chalk.magenta.bold(LOG_PREFIX)} Using cached ${chalk.cyanBright.bold(demoRegistry.size)} demos`,\n )\n return\n }\n\n const demoFiles = await glob(demoPattern)\n demoRegistry.clear()\n\n for (const filePath of demoFiles) {\n const code = await readFile(filePath, \"utf-8\")\n const demoInfo = await parseAngularDemo(filePath, code)\n if (demoInfo) {\n demoRegistry.set(demoInfo.id, demoInfo)\n }\n }\n }\n\n async function scanDemosForFileImport(\n file: string,\n ): Promise<AngularDemoInfo[]> {\n const affectedDemos: AngularDemoInfo[] = []\n for (const [demoId, demo] of demoRegistry.entries()) {\n if (demo.sourceCode.find((entry) => entry.filePath === file)) {\n logDev(\n `${chalk.blue.bold(LOG_PREFIX)} Re-parsing demo ${chalk.cyan(demoId)} due to imported file change: ${chalk.yellow(file)}`,\n )\n const code = await readFile(demo.filePath, \"utf-8\")\n const updatedDemo = await parseAngularDemo(demo.filePath, code)\n if (updatedDemo) {\n delete demoDimensionsCache[updatedDemo.id]\n demoRegistry.set(updatedDemo.id, updatedDemo)\n affectedDemos.push(updatedDemo)\n hotUpdateDemoIds.push(updatedDemo.id)\n }\n }\n }\n return affectedDemos\n }\n\n async function highlightCode(\n code: string,\n language: \"angular-ts\" | \"angular-html\" = \"angular-ts\",\n ): Promise<string> {\n if (!highlighter) {\n return code\n }\n\n try {\n return highlighter.codeToHtml(code, {\n defaultColor: \"light-dark()\",\n lang: language,\n themes: {\n dark: theme.dark,\n light: theme.light,\n },\n transformers: [transformerRenderIndentGuides()],\n })\n } catch (error) {\n console.warn(\n `${chalk.blue.bold(LOG_PREFIX)} Failed to highlight code with ${language} language:`,\n error,\n )\n return code\n }\n }\n\n function extractAngularPreviewsAndCleanSource(\n code: string,\n ): ExtractedPreview {\n const lines = code.split(\"\\n\")\n const previewBlocks: PreviewContext[] = []\n const cleanedLines: string[] = []\n let inPreview = false\n let currentBlock: string[] = []\n let startLine = -1\n let currentContext: \"template\" | \"typescript\" = \"typescript\"\n let inTemplate = false\n let templateDepth = 0\n let omitNextLine = false\n\n for (let i = 0; i < lines.length; i++) {\n const line = lines[i]\n const trimmedLine = line.trim()\n\n if (/template\\s*:\\s*[`\"']/.test(line)) {\n inTemplate = true\n templateDepth = 0\n }\n\n if (inTemplate && line.includes(\"`\")) {\n const backticks = (line.match(/`/g) || []).length\n templateDepth += backticks\n if (templateDepth % 2 === 0 && backticks > 0) {\n inTemplate = false\n }\n }\n\n if (inTemplate && /['\"]\\s*[,}]/.test(line)) {\n inTemplate = false\n }\n\n if (omitNextLine) {\n omitNextLine = false\n continue\n }\n\n if (isOmitNextLine(trimmedLine)) {\n omitNextLine = true\n continue\n }\n\n if (isPreviewLine(trimmedLine)) {\n if (inPreview) {\n const normalizedContent = normalizeIndentation(currentBlock)\n previewBlocks.push({\n content: normalizedContent,\n context: currentContext,\n endLine: i - 1,\n startLine,\n })\n currentBlock = []\n inPreview = false\n } else {\n inPreview = true\n startLine = i + 1\n currentContext = inTemplate ? \"template\" : \"typescript\"\n }\n } else {\n cleanedLines.push(line)\n if (inPreview) {\n currentBlock.push(line)\n }\n }\n }\n\n function normalizeIndentation(lines: string[]): string {\n if (lines.length === 0) {\n return \"\"\n }\n const nonEmptyLines = lines.filter((line) => line.trim().length > 0)\n if (nonEmptyLines.length === 0) {\n return lines.join(\"\\n\")\n }\n let minIndent = Infinity\n for (const line of nonEmptyLines) {\n const match = line.match(/^(\\s*)/)\n const indent = match ? match[1].length : 0\n minIndent = Math.min(minIndent, indent)\n }\n const normalizedLines = lines.map((line) => {\n if (line.trim().length === 0) {\n return line\n }\n return line.slice(minIndent)\n })\n return normalizedLines.join(\"\\n\")\n }\n\n const formattedPreview = previewBlocks.length\n ? previewBlocks.map((block) => block.content).join(\"\\n\")\n : \"\"\n\n return {\n formattedPreview,\n previewBlocks,\n sourceWithoutPreviews: cleanedLines.join(\"\\n\"),\n }\n }\n\n function isPreviewLine(trimmedLine: string): boolean {\n return (\n trimmedLine === \"// preview\" ||\n /^\\/\\*\\s*preview\\s*\\*\\/$/.test(trimmedLine) ||\n /^<!--\\s*preview\\s*-->$/.test(trimmedLine)\n )\n }\n\n async function extractRelativeImports(\n filePath: string,\n ): Promise<RelativeImport[]> {\n try {\n const content = await readFile(filePath, \"utf-8\")\n const sourceFile = ts.createSourceFile(\n filePath,\n content,\n ts.ScriptTarget.Latest,\n true,\n ts.ScriptKind.TS,\n )\n\n const relativeImports: RelativeImport[] = []\n\n function visit(node: ts.Node) {\n if (ts.isImportDeclaration(node)) {\n const moduleSpecifier = node.moduleSpecifier\n if (ts.isStringLiteral(moduleSpecifier)) {\n const source = moduleSpecifier.text\n if (isRelativeImport(source)) {\n const resolvedPath = resolveRelativeImport(source, filePath)\n relativeImports.push({resolvedPath, source})\n } else if (!isNodeBuiltin(source)) {\n const pathAliases = loadTsConfigPaths(filePath)\n if (isPathAliasImport(source, pathAliases)) {\n const resolvedPath = resolvePathAlias(source, pathAliases)\n if (resolvedPath) {\n relativeImports.push({resolvedPath, source})\n }\n }\n }\n }\n }\n ts.forEachChild(node, visit)\n }\n\n visit(sourceFile)\n return relativeImports\n } catch (error) {\n logDev(\n `${chalk.blue.bold(LOG_PREFIX)} ${chalk.yellowBright(\"Failed to extract imports from\")} ${chalk.cyan(filePath)}:`,\n error,\n )\n return []\n }\n }\n\n async function collectAllImports(\n filePath: string,\n visited = new Set<string>(),\n ): Promise<string[]> {\n if (visited.has(filePath)) {\n return []\n }\n visited.add(filePath)\n\n const directImports = await extractRelativeImports(filePath)\n\n for (const {resolvedPath} of directImports) {\n await collectAllImports(resolvedPath, visited)\n }\n\n return Array.from(visited).slice(1)\n }\n\n function stripImports(\n code: string,\n fileName: string,\n ): {\n imports: string[]\n strippedCode: string\n } {\n try {\n const sourceFile = ts.createSourceFile(\n fileName,\n code,\n ts.ScriptTarget.Latest,\n true,\n ts.ScriptKind.TS,\n )\n\n const importRanges: Array<{end: number; start: number}> = []\n\n function visit(node: ts.Node) {\n if (ts.isImportDeclaration(node)) {\n importRanges.push({\n end: node.getEnd(),\n start: node.getFullStart(),\n })\n }\n ts.forEachChild(node, visit)\n }\n\n visit(sourceFile)\n\n const imports = importRanges.map((range) => {\n let endPos = range.end\n if (code[endPos] === \"\\n\") {\n endPos++\n }\n return code.slice(range.start, endPos).trim()\n })\n\n importRanges.sort((a, b) => b.start - a.start)\n\n let strippedCode = code\n for (const range of importRanges) {\n let endPos = range.end\n if (strippedCode[endPos] === \"\\n\") {\n endPos++\n }\n strippedCode =\n strippedCode.slice(0, range.start) + strippedCode.slice(endPos)\n }\n\n strippedCode = strippedCode.trim()\n\n return {\n imports,\n strippedCode: strippedCode.replace(/^\\n+/, \"\"),\n }\n } catch (error) {\n logDev(\n `${chalk.blue.bold(LOG_PREFIX)} ${chalk.redBright(\"Failed to strip imports from\")} ${chalk.cyan(fileName)}:`,\n error,\n )\n return {\n imports: [],\n strippedCode: code,\n }\n }\n }\n\n async function parseAngularDemo(\n filePath: string,\n code: string,\n ): Promise<AngularDemoInfo | null> {\n try {\n const {formattedPreview, sourceWithoutPreviews} =\n extractAngularPreviewsAndCleanSource(code)\n\n const sourceFile = ts.createSourceFile(\n filePath,\n sourceWithoutPreviews,\n ts.ScriptTarget.Latest,\n true,\n ts.ScriptKind.TS,\n )\n\n let componentClass = \"\"\n let selector = \"\"\n let isStandalone = true\n let templateUrl: string | null = null\n const imports: string[] = []\n let hasDefaultExport = false\n\n function visit(node: ts.Node) {\n if (ts.isImportDeclaration(node)) {\n imports.push(node.getFullText(sourceFile).trim())\n }\n\n if (ts.isClassDeclaration(node)) {\n const decorators = node.modifiers?.filter(ts.isDecorator)\n const componentDecorator = decorators?.find((decorator) => {\n if (ts.isCallExpression(decorator.expression)) {\n const expression = decorator.expression.expression\n return (\n ts.isIdentifier(expression) && expression.text === \"Component\"\n )\n }\n return false\n })\n\n if (componentDecorator && node.name) {\n componentClass = node.name.text\n\n if (\n ts.isCallExpression(componentDecorator.expression) &&\n componentDecorator.expression.arguments[0] &&\n ts.isObjectLiteralExpression(\n componentDecorator.expression.arguments[0],\n )\n ) {\n const properties =\n componentDecorator.expression.arguments[0].properties\n\n const selectorProp = properties.find(\n (prop) =>\n ts.isPropertyAssignment(prop) &&\n ts.isIdentifier(prop.name) &&\n prop.name.text === \"selector\",\n ) as ts.PropertyAssignment | undefined\n\n if (\n selectorProp &&\n ts.isStringLiteral(selectorProp.initializer)\n ) {\n selector = selectorProp.initializer.text\n }\n\n const templateUrlProp = properties.find(\n (prop) =>\n ts.isPropertyAssignment(prop) &&\n ts.isIdentifier(prop.name) &&\n prop.name.text === \"templateUrl\",\n ) as ts.PropertyAssignment | undefined\n\n if (templateUrlProp) {\n if (ts.isStringLiteral(templateUrlProp.initializer)) {\n templateUrl = templateUrlProp.initializer.text\n } else if (\n ts.isNoSubstitutionTemplateLiteral(\n templateUrlProp.initializer,\n )\n ) {\n templateUrl = templateUrlProp.initializer.text\n }\n }\n\n const standaloneProp = properties.find(\n (prop) =>\n ts.isPropertyAssignment(prop) &&\n ts.isIdentifier(prop.name) &&\n prop.name.text === \"standalone\",\n ) as ts.PropertyAssignment | undefined\n\n if (standaloneProp) {\n if (\n standaloneProp.initializer.kind === ts.SyntaxKind.FalseKeyword\n ) {\n isStandalone = false\n }\n }\n }\n }\n }\n\n if (ts.isExportAssignment(node) && !node.isExportEquals) {\n hasDefaultExport = true\n }\n\n ts.forEachChild(node, visit)\n }\n\n visit(sourceFile)\n\n if (!componentClass || !selector) {\n return null\n }\n\n const demoId = componentClass\n const pageId = extractPageId(filePath, routesDir)\n const importPath = relative(process.cwd(), filePath).replace(/\\\\/g, \"/\")\n const fileName = basename(filePath)\n\n const {strippedCode: codeWithoutImports} = stripImports(code, filePath)\n\n const highlightedFull = await highlightCode(code, \"angular-ts\")\n const {highlightedPreview, highlightedWithoutPreview} =\n extractHighlightedVariants(highlightedFull)\n\n const sourceCode: SourceCodeData[] = [\n {\n fileName,\n filePath,\n highlighted: {\n full: highlightedWithoutPreview,\n preview: highlightedPreview,\n },\n raw: {\n full: sourceWithoutPreviews,\n preview: formattedPreview || \"\",\n withoutImports: codeWithoutImports,\n },\n },\n ]\n\n if (templateUrl) {\n const templatePath = resolveTemplateFile(templateUrl, filePath)\n\n if (existsSync(templatePath)) {\n try {\n const templateCode = await readFile(templatePath, \"utf-8\")\n\n const {\n formattedPreview: templatePreview,\n sourceWithoutPreviews: templateWithoutPreviews,\n } = extractAngularPreviewsAndCleanSource(templateCode)\n\n const highlightedTemplate = await highlightCode(\n templateCode,\n \"angular-html\",\n )\n\n const {\n highlightedPreview: highlightedTemplatePreview,\n highlightedWithoutPreview: highlightedTemplateWithoutPreview,\n } = extractHighlightedVariants(highlightedTemplate)\n\n sourceCode.push({\n fileName: basename(templatePath),\n highlighted: {\n full: highlightedTemplateWithoutPreview,\n preview: highlightedTemplatePreview,\n },\n raw: {\n full: templateWithoutPreviews,\n preview: templatePreview || \"\",\n withoutImports: templateCode,\n },\n })\n } catch (error) {\n console.log(\n `${chalk.blue.bold(LOG_PREFIX)} ${chalk.redBright(\"Failed to read template file:\")} ${chalk.cyan(templatePath)}`,\n error,\n )\n }\n }\n }\n\n const relativeImports = await collectAllImports(filePath)\n\n for (const resolvedPath of relativeImports) {\n try {\n const importedCode = await readFile(resolvedPath, \"utf-8\")\n const {strippedCode: importedCodeWithoutImports} = stripImports(\n importedCode,\n resolvedPath,\n )\n\n const {sourceWithoutPreviews: importedSourceWithoutSnippets} =\n extractAngularPreviewsAndCleanSource(importedCode)\n\n const importedFileName = basename(resolvedPath)\n const highlightedImportedSource = await highlightCode(\n importedSourceWithoutSnippets,\n \"angular-ts\",\n )\n\n sourceCode.push({\n fileName: importedFileName,\n highlighted: {\n full: highlightedImportedSource,\n preview: \"\",\n },\n raw: {\n full: importedSourceWithoutSnippets,\n preview: \"\",\n withoutImports: importedCodeWithoutImports,\n },\n })\n } catch (error) {\n logDev(\n `${chalk.blue.bold(LOG_PREFIX)} ${chalk.yellowBright(\"Failed to process relative import:\")} ${chalk.cyan(resolvedPath)}`,\n )\n }\n }\n\n return {\n componentClass,\n filePath: importPath.startsWith(\".\") ? importPath : `./${importPath}`,\n hasDefaultExport,\n id: demoId,\n imports,\n initialHtml: initialHtml?.[demoId] || undefined,\n isStandalone,\n lastModified: Date.now(),\n pageId,\n selector,\n sourceCode,\n }\n } catch (error) {\n console.error(\n `${chalk.blue.bold(LOG_PREFIX)} Failed to parse Angular demo ${filePath}:`,\n error,\n )\n return null\n }\n }\n\n function extractHighlightedVariants(highlightedHtml: string): {\n highlightedPreview: string\n highlightedWithoutPreview: string\n } {\n const preMatch = highlightedHtml.match(/^<pre[^>]*><code>/)?.[0] || \"\"\n const postMatch = highlightedHtml.match(/<\\/code><\\/pre>$/)?.[0] || \"\"\n const content = highlightedHtml.slice(preMatch.length, -postMatch.length)\n const lines = content.split(\"\\n\")\n const previewLines: string[] = []\n const withoutPreviewLines: string[] = []\n let inPreview = false\n let omitNextLine = false\n\n for (const line of lines) {\n const textContent = line\n .replace(/<[^>]*>/g, \"\")\n .replace(/</g, \"<\")\n .replace(/>/g, \">\")\n .trim()\n\n if (omitNextLine) {\n omitNextLine = false\n continue\n }\n\n if (textContent === \"// qui-docs::omit-next-line\") {\n omitNextLine = true\n continue\n }\n\n if (\n textContent === \"// preview\" ||\n textContent === \"/* preview */\" ||\n textContent === \"<!-- preview -->\"\n ) {\n inPreview = !inPreview\n continue\n }\n\n if (inPreview) {\n previewLines.push(line)\n }\n withoutPreviewLines.push(line)\n }\n\n const normalizedPreviewLines = normalizeIndentation(previewLines)\n const highlightedPreview =\n normalizedPreviewLines.length > 0\n ? `${preMatch}${normalizedPreviewLines.join(\"\\n\")}${postMatch}`\n : \"\"\n const highlightedWithoutPreview = `${preMatch}${withoutPreviewLines.join(\"\\n\")}${postMatch}`\n\n return {highlightedPreview, highlightedWithoutPreview}\n }\n\n function normalizeIndentation(lines: string[]): string[] {\n if (lines.length === 0) {\n return []\n }\n\n const nonEmptyLines = lines.filter(\n (line) => line.replace(/<[^>]*>/g, \"\").trim().length > 0,\n )\n\n if (nonEmptyLines.length === 0) {\n return lines\n }\n\n let minIndent = Infinity\n for (const line of nonEmptyLines) {\n const matches = line.match(/<span class=\"indent\">/g)\n if (matches) {\n minIndent = Math.min(minIndent, matches.length)\n } else {\n minIndent = 0\n break\n }\n }\n\n if (minIndent === 0 || minIndent === Infinity) {\n return lines\n }\n\n return lines.map((line) => {\n let result = line\n for (let i = 0; i < minIndent; i++) {\n result = result.replace(/<span class=\"indent\">(\\s*)<\\/span>/, \"\")\n }\n return result\n })\n }\n\n function generateRegistryModule(): string {\n const demos = Array.from(demoRegistry.values())\n return `// Auto-generated Angular demo registry\nexport const ANGULAR_DEMOS = {\n${demos\n .map(\n (demo) =>\n ` \"${demo.id}\": ${JSON.stringify(\n {\n componentClass: demo.componentClass,\n dimensions: demoDimensionsCache[demo.id],\n filePath: demo.filePath,\n hasDefaultExport: demo.hasDefaultExport,\n id: demo.id,\n imports: demo.imports,\n initialHtml: demo.initialHtml,\n isStandalone: demo.isStandalone,\n lastModified: demo.lastModified,\n pageId: demo.pageId,\n selector: demo.selector,\n sourceCode: demo.sourceCode,\n },\n null,\n 4,\n )}`,\n )\n .join(\",\\n\")}\n}\n\nexport function isAngularDemo(demoId) {\n return demoId in ANGULAR_DEMOS\n}\n\nexport function getAngularDemoInfo(demoId) {\n return ANGULAR_DEMOS[demoId] || null\n}\n\nexport function getAllAngularDemos() {\n return Object.values(ANGULAR_DEMOS)\n}\n\nexport const availableAngularDemos = Object.keys(ANGULAR_DEMOS)\n\nif (import.meta.hot) {\n import.meta.hot.accept(() => {\n console.log('[angular-demo-registry] Registry updated via HMR')\n })\n \n if (typeof window !== 'undefined') {\n import.meta.hot.on('angular-demo-update', (data) => {\n console.log('[angular-demo-registry] Demo updated:', data.demoId)\n })\n }\n}`\n }\n\n function generatePageRegistryModule(pageId: string): string {\n const pageDemos = Array.from(demoRegistry.values()).filter(\n (demo) => demo.pageId === pageId,\n )\n\n if (pageDemos.length === 0) {\n return `export function getAngularDemoInfo() { return null }\nexport const ANGULAR_DEMOS = {}`\n }\n\n return `// Auto-generated Angular demo registry for ${pageId}\nexport const ANGULAR_DEMOS = {\n${pageDemos\n .map(\n (demo) =>\n ` \"${demo.id}\": ${JSON.stringify(\n {\n componentClass: demo.componentClass,\n dimensions: demoDimensionsCache[demo.id],\n filePath: demo.filePath,\n hasDefaultExport: demo.hasDefaultExport,\n id: demo.id,\n imports: demo.imports,\n initialHtml: demo.initialHtml,\n isStandalone: demo.isStandalone,\n lastModified: demo.lastModified,\n pageId: demo.pageId,\n selector: demo.selector,\n sourceCode: demo.sourceCode,\n },\n null,\n 4,\n )}`,\n )\n .join(\",\\n\")}\n}\n\nexport function getAngularDemoInfo(demoId) {\n return ANGULAR_DEMOS[demoId] || null\n}\n\nif (import.meta.hot) {\n import.meta.hot.accept(() => {\n console.log('[angular-demo-registry/${pageId}] Registry updated')\n })\n}`\n }\n\n function extractPageId(filePath: string, routesDir: string): string {\n const relativePath = relative(routesDir, filePath)\n const pathParts = relativePath.split(\"/\")\n const demoIndex = pathParts.findIndex((part) => part.includes(\"demos\"))\n\n if (demoIndex === -1) {\n return pathParts.at(-2) || pathParts.join(\"/\")\n }\n\n return pathParts.slice(0, demoIndex).join(\"/\")\n }\n\n function isAngularDemoFile(filePath: string): boolean {\n return (\n filePath.includes(\"/demos/\") &&\n (filePath.endsWith(\".ts\") || filePath.endsWith(\"html\"))\n )\n }\n\n function isCssAsset(filePath: string) {\n return filePath.endsWith(\".css\")\n }\n\n function isRelativeImport(source: string): boolean {\n return source.startsWith(\"./\") || source.startsWith(\"../\")\n }\n\n function isNodeBuiltin(source: string): boolean {\n const NODE_BUILTINS = [\n \"assert\",\n \"buffer\",\n \"child_process\",\n \"cluster\",\n \"crypto\",\n \"dgram\",\n \"dns\",\n \"domain\",\n \"events\",\n \"fs\",\n \"http\",\n \"https\",\n \"net\",\n \"os\",\n \"path\",\n \"punycode\",\n \"querystring\",\n \"readline\",\n \"stream\",\n \"string_decoder\",\n \"timers\",\n \"tls\",\n \"tty\",\n \"url\",\n \"util\",\n \"v8\",\n \"vm\",\n \"zlib\",\n ]\n return source.startsWith(\"node:\") || NODE_BUILTINS.includes(source)\n }\n\n function resolveRelativeImport(source: string, fromFile: string): string {\n const fromDir = dirname(fromFile)\n const resolved = resolve(fromDir, source)\n const extensions = [\".ts\", \".tsx\", \".js\", \".jsx\"]\n\n for (const ext of extensions) {\n const withExt = resolved + ext\n if (existsSync(withExt)) {\n return withExt\n }\n }\n\n for (const ext of extensions) {\n const indexFile = join(resolved, `index${ext}`)\n if (existsSync(indexFile)) {\n return indexFile\n }\n }\n\n return resolved\n }\n\n function loadTsConfigPaths(fromFile: string): PathAlias[] {\n let currentDir = dirname(fromFile)\n const pathAliases: PathAlias[] = []\n\n while (currentDir !== dirname(currentDir)) {\n const tsconfigPath = join(currentDir, \"tsconfig.json\")\n\n if (existsSync(tsconfigPath)) {\n try {\n const configContent = ts.sys.readFile(tsconfigPath)\n if (!configContent) {\n currentDir = dirname(currentDir)\n continue\n }\n\n const parseResult = ts.parseConfigFileTextToJson(\n tsconfigPath,\n configContent,\n )\n\n if (parseResult.error) {\n currentDir = dirname(currentDir)\n continue\n }\n\n const paths = parseResult.config?.compilerOptions?.paths\n const baseUrl = parseResult.config?.compilerOptions?.baseUrl || \"./\"\n const resolvedBaseUrl = resolve(currentDir, baseUrl)\n\n if (paths) {\n for (const [alias, targets] of Object.entries(paths)) {\n if (Array.isArray(targets) && targets.length > 0) {\n const target = targets[0]\n const pattern = new RegExp(\n `^${alias\n .replace(\"*\", \"(.*)\")\n .replace(/[.*+?^${}()|[\\]\\\\]/g, \"\\\\$&\")\n .replace(\"\\\\(\\\\*\\\\)\", \"(.*)\")}$`,\n )\n const replacement = resolve(\n resolvedBaseUrl,\n target.replace(\"*\", \"$1\"),\n )\n pathAliases.push({pattern, replacement})\n }\n }\n }\n\n const extendsPath = parseResult.config?.extends\n if (extendsPath) {\n const resolvedExtends = resolve(currentDir, extendsPath)\n const extendedAliases = loadTsConfigPathsFromFile(resolvedExtends)\n pathAliases.push(...extendedAliases)\n }\n\n return pathAliases\n } catch (error) {\n currentDir = dirname(currentDir)\n continue\n }\n }\n\n currentDir = dirname(currentDir)\n }\n\n return pathAliases\n }\n\n async function setupAngularWatcher() {\n watcher = watch(routesDir, {\n ignoreInitial: true,\n persistent: true,\n })\n\n watcher.on(\"ready\", () => {\n logDev(\n `${chalk.blue.bold(LOG_PREFIX)} Registered ${chalk.green(demoRegistry.size)} demo files. Watching for file changes...`,\n )\n })\n\n watcher.on(\"add\", async (filePath: string) => {\n const fileStats = await stat(filePath)\n if (fileStats.size === 0) {\n return\n }\n\n if (isAngularDemoFile(filePath)) {\n logDev(\n `${chalk.blue.bold(LOG_PREFIX)} New Angular demo: ${chalk.green(filePath)}`,\n )\n await handleAngularDemoUpdate(filePath)\n triggerRegistryUpdate()\n }\n })\n\n watcher.on(\"unlink\", (filePath: string) => {\n if (isAngularDemoFile(filePath)) {\n const demoEntry = Array.from(demoRegistry.entries()).find(\n ([, info]) => info.filePath === filePath,\n )\n\n if (demoEntry) {\n const [demoId] = demoEntry\n demoRegistry.delete(demoId)\n logDev(\n `${chalk.blue.bold(LOG_PREFIX)} Removed demo: ${chalk.red(demoId)}`,\n )\n triggerRegistryUpdate()\n }\n }\n })\n }\n\n async function handleAngularDemoUpdate(filePath: string) {\n const code = await readFile(filePath, \"utf-8\")\n const demoInfo = await parseAngularDemo(filePath, code)\n if (demoInfo) {\n demoRegistry.set(demoInfo.id, demoInfo)\n }\n }\n\n function triggerRegistryUpdate() {\n if (devServer) {\n const mainModule = devServer.moduleGraph.getModuleById(VIRTUAL_MODULE_ID)\n if (mainModule) {\n devServer.moduleGraph.invalidateModule(mainModule)\n mainModule.lastHMRTimestamp = Date.now()\n devServer.reloadModule(mainModule)\n }\n\n const pageIds = new Set(\n Array.from(demoRegistry.values()).map((demo) => demo.pageId),\n )\n for (const pageId of pageIds) {\n const pageModuleId = `\\0${VIRTUAL_MODULE_PREFIX}${pageId}`\n const pageModule = devServer.moduleGraph.getModuleById(pageModuleId)\n if (pageModule) {\n devServer.moduleGraph.invalidateModule(pageModule)\n pageModule.lastHMRTimestamp = Date.now()\n devServer.reloadModule(pageModule)\n }\n }\n }\n }\n}\n\nfunction loadTsConfigPathsFromFile(tsconfigPath: string): PathAlias[] {\n const pathAliases: PathAlias[] = []\n const configDir = dirname(tsconfigPath)\n\n try {\n const configContent = ts.sys.readFile(tsconfigPath)\n if (!configContent) {\n return pathAliases\n }\n\n const parseResult = ts.parseConfigFileTextToJson(\n tsconfigPath,\n configContent,\n )\n\n if (parseResult.error) {\n return pathAliases\n }\n\n const paths = parseResult.config?.compilerOptions?.paths\n const baseUrl = parseResult.config?.compilerOptions?.baseUrl || \"./\"\n const resolvedBaseUrl = resolve(configDir, baseUrl)\n\n if (paths) {\n for (const [alias, targets] of Object.entries(paths)) {\n if (Array.isArray(targets) && targets.length > 0) {\n const target = targets[0]\n const pattern = new RegExp(\n `^${alias\n .replace(\"*\", \"(.*)\")\n .replace(/[.*+?^${}()|[\\]\\\\]/g, \"\\\\$&\")\n .replace(\"\\\\(\\\\*\\\\)\", \"(.*)\")}$`,\n )\n const replacement = resolve(\n resolvedBaseUrl,\n target.replace(\"*\", \"$1\"),\n )\n pathAliases.push({pattern, replacement})\n }\n }\n }\n\n const extendsPath = parseResult.config?.extends\n if (extendsPath) {\n let resolvedExtends = resolve(configDir, extendsPath)\n if (!resolvedExtends.endsWith(\".json\")) {\n resolvedExtends += \".json\"\n }\n if (existsSync(resolvedExtends)) {\n const extendedAliases = loadTsConfigPathsFromFile(resolvedExtends)\n pathAliases.push(...extendedAliases)\n }\n }\n } catch (error) {\n return pathAliases\n }\n\n return pathAliases\n}\n\nfunction isPathAliasImport(source: string, pathAliases: PathAlias[]): boolean {\n return pathAliases.some((alias) => alias.pattern.test(source))\n}\n\nfunction resolvePathAlias(\n source: string,\n pathAliases: PathAlias[],\n): string | null {\n for (const alias of pathAliases) {\n if (alias.pattern.test(source)) {\n const resolvedPath = source.replace(alias.pattern, alias.replacement)\n const extensions = [\".ts\", \".tsx\", \".js\", \".jsx\"]\n\n for (const ext of extensions) {\n const withExt = resolvedPath + ext\n if (existsSync(withExt)) {\n return withExt\n }\n }\n\n for (const ext of extensions) {\n const indexFile = join(resolvedPath, `index${ext}`)\n if (existsSync(indexFile)) {\n return indexFile\n }\n }\n\n return resolvedPath\n }\n }\n\n return null\n}\n\nfunction resolveTemplateFile(templateUrl: string, fromFile: string): string {\n const fromDir = dirname(fromFile)\n const resolved = resolve(fromDir, templateUrl)\n\n if (existsSync(resolved)) {\n return resolved\n }\n\n if (!resolved.endsWith(\".html\")) {\n const withHtml = `${resolved}.html`\n if (existsSync(withHtml)) {\n return withHtml\n }\n }\n\n return resolved\n}\n\nfunction isOmitNextLine(trimmedLine: string): boolean {\n return trimmedLine === \"// qui-docs::omit-next-line\"\n}\n", "// Copyright (c) Qualcomm Technologies, Inc. and/or its subsidiaries.\n// SPDX-License-Identifier: BSD-3-Clause-Clear\n\nimport chalk from \"chalk\"\nimport chokidar from \"chokidar\"\nimport {glob} from \"glob\"\nimport {readFileSync} from \"node:fs\"\nimport {resolve} from \"node:path\"\nimport prettyMilliseconds from \"pretty-ms\"\nimport type {PluginOption, ViteDevServer} from \"vite\"\n\nimport type {QuiPropTypes} from \"@qualcomm-ui/typedoc-common\"\n\nimport {\n ConfigLoader,\n fixPath,\n type ResolvedQuiDocsConfig,\n SearchIndexer,\n} from \"./internal\"\n\nconst isDev = process.env.NODE_ENV === \"development\"\n\nexport interface QuiDocsPluginOptions {\n /**\n * Path to the qui-docs config file. This is automatically detected if omitted.\n */\n configFile?: string\n\n /**\n * The current working directory.\n *\n * @default process.cwd()\n */\n cwd?: string\n}\n\n/**\n * TODO: adjust when https://github.com/vitejs/vite/discussions/16358 lands.\n */\nclass PluginState {\n buildCount: number = 0\n configFilePath: string = \"\"\n docPropsFilePath: string = \"\"\n indexer!: SearchIndexer\n configLoader: ConfigLoader | null = null\n routesDir!: string\n servers: ViteDevServer[] = []\n timeout: ReturnType<typeof setTimeout> | undefined = undefined\n watching = false\n\n readonly resolvedVirtualModuleId: string\n readonly virtualModuleId = \"@qualcomm-ui/mdx-vite-plugin\"\n private cwd!: string\n\n constructor() {\n this.resolvedVirtualModuleId = `\\0${this.virtualModuleId}`\n }\n\n init(cwd: string) {\n this.cwd = cwd\n }\n\n get docPropsDirectory() {\n if (!this.docPropsFilePath) {\n return \"\"\n }\n return this.docPropsFilePath.substring(\n 0,\n this.docPropsFilePath.lastIndexOf(\"/\"),\n )\n }\n\n private resolveDocProps(): Record<string, QuiPropTypes> {\n if (!this.docPropsFilePath) {\n return {}\n }\n try {\n return JSON.parse(readFileSync(this.docPropsFilePath, \"utf-8\"))?.props\n } catch (e) {\n console.debug(\n \"Invalid doc props file. Unable to parse JSON. Please check the file\",\n )\n return {}\n }\n }\n\n createIndexer(config: ResolvedQuiDocsConfig) {\n this.configFilePath = config.filePath\n this.docPropsFilePath = config.typeDocProps\n ? fixPath(resolve(this.cwd, config.typeDocProps))\n : \"\"\n this.routesDir = fixPath(resolve(config.appDirectory, config.pageDirectory))\n this.indexer = new SearchIndexer({\n ...config,\n srcDir: fixPath(resolve(this.cwd, config.appDirectory)),\n typeDocProps: this.resolveDocProps(),\n })\n }\n\n buildIndex(shouldLog: boolean) {\n const files = glob.sync(\n [`${this.routesDir}/**/*.mdx`, `${this.routesDir}/**/*.tsx`],\n {\n absolute: true,\n cwd: this.cwd,\n },\n )\n\n if (!files.length) {\n return\n }\n\n const startTime = Date.now()\n\n this.indexer.buildIndex(files, shouldLog)\n\n if (isDev && shouldLog) {\n console.debug(\n `${chalk.magenta.bold(`@qualcomm-ui/mdx-vite/docs-plugin:`)} Compiled search index in: ${chalk.blueBright.bold(prettyMilliseconds(Date.now() - startTime))}${state.indexer.cachedFileCount ? chalk.greenBright.bold(` (${state.indexer.cachedFileCount}/${state.indexer.mdxFileCount} files cached)`) : \"\"}`,\n )\n }\n }\n\n /**\n * When the user edits MDX content or modifies the plugin config, we re-index the\n * site. This function handles module invalidation so that virtual file imports\n * are refreshed as expected by the consumer's dev server.\n */\n sendUpdate() {\n for (const server of this.servers) {\n const virtualModule = server.moduleGraph.getModuleById(\n this.resolvedVirtualModuleId,\n )\n if (virtualModule) {\n server.moduleGraph.invalidateModule(virtualModule)\n server.reloadModule(virtualModule)\n }\n }\n }\n\n handleChange(callback?: () => void) {\n // the plugin is activating twice in dev mode. It's mostly harmless, but we\n // prevent logs from emitting twice by flipping a flag\n\n // debounce the change handler to prevent rapid updates from triggering rebuilds\n // in quick succession.\n clearTimeout(this.timeout)\n this.timeout = setTimeout(() => {\n this.buildIndex(true)\n this.sendUpdate()\n callback?.()\n }, 300)\n }\n\n initWatchers(configFile?: string) {\n if (this.watching) {\n return\n }\n this.initConfigWatcher(configFile)\n this.watching = true\n }\n\n private initConfigWatcher(configFile?: string) {\n const paths: string[] = [this.configFilePath]\n if (this.docPropsFilePath) {\n paths.push(this.docPropsFilePath)\n }\n chokidar\n .watch(paths, {\n cwd: this.cwd,\n })\n .on(\"change\", () => {\n console.debug(`qui-docs config changed, reloading plugin`)\n this.configLoader = new ConfigLoader({configFile})\n const resolvedConfig = this.configLoader.loadConfig()\n this.configFilePath = resolvedConfig.filePath\n this.createIndexer(resolvedConfig)\n this.handleChange()\n })\n }\n}\n\nconst state = new PluginState()\n\nexport function quiDocsPlugin(opts?: QuiDocsPluginOptions): PluginOption {\n state.init(fixPath(opts?.cwd ?? process.cwd()))\n\n // https://vitejs.dev/guide/api-plugin#virtual-modules-convention\n\n const configLoader = new ConfigLoader(opts || {})\n const config = configLoader.loadConfig()\n state.createIndexer(config)\n\n return {\n buildStart: async () => {\n state.buildIndex(state.buildCount > 0)\n state.buildCount++\n },\n configureServer: (server) => {\n if (!isDev) {\n return\n }\n state.initWatchers(opts?.configFile)\n server.watcher.on(\"add\", (path: string) => {\n if (path.endsWith(\".mdx\")) {\n state.handleChange(() => {\n server.ws.send({type: \"full-reload\"})\n })\n }\n })\n server.watcher.on(\"unlink\", (path: string) => {\n if (path.endsWith(\".mdx\")) {\n state.handleChange(() => {\n server.ws.send({type: \"full-reload\"})\n })\n }\n })\n state.servers.push(server)\n },\n handleHotUpdate: async ({file: updateFile}) => {\n const file = fixPath(updateFile)\n\n if (\n (!config.hotUpdateIgnore || !config.hotUpdateIgnore.test(file)) &&\n // ignore watched files. We watch for these separately.\n file !== state.configFilePath\n ) {\n if (\n state.docPropsDirectory &&\n file.startsWith(state.docPropsFilePath)\n ) {\n return []\n }\n state.handleChange()\n }\n return []\n },\n load: (id): string | undefined => {\n if (id === state.resolvedVirtualModuleId) {\n return `export const siteData = ${JSON.stringify({navItems: state.indexer.navItems, pageDocProps: state.indexer.pageDocProps, pageMap: state.indexer.pageMap, searchIndex: state.indexer.searchIndex})}`\n }\n return undefined\n },\n name: \"qui-mdx-vite-plugin\",\n resolveId: (id) => {\n if (id === state.virtualModuleId) {\n return state.resolvedVirtualModuleId\n }\n return undefined\n },\n }\n}\n", "// Copyright (c) Qualcomm Technologies, Inc. and/or its subsidiaries.\n// SPDX-License-Identifier: BSD-3-Clause-Clear\n\nimport {type Config, type CosmiconfigResult, cosmiconfigSync} from \"cosmiconfig\"\n\nimport type {QuiDocsConfig} from \"../types\"\n\nimport {configSchema} from \"./config-schema\"\nimport {removeTrailingSlash} from \"./utils\"\n\ninterface LoadedCosmicConfig {\n config: Config\n filepath: string\n isEmpty?: boolean\n}\n\nexport interface ResolvedQuiDocsConfig extends QuiDocsConfig {\n appDirectory: string\n /**\n * full path to the cosmiconfig file.\n */\n filePath: string\n pageDirectory: string\n}\n\nexport interface ConfigLoaderOptions {\n /**\n * Path to the qui-docs config file. This is automatically detected if omitted.\n */\n configFile?: string\n}\n\nexport class ConfigLoader {\n private readonly options: ConfigLoaderOptions\n\n constructor(options: ConfigLoaderOptions) {\n this.options = options\n return this\n }\n\n private getCosmiconfig(): LoadedCosmicConfig {\n const explorer = cosmiconfigSync(\"qui-docs\")\n\n const result: CosmiconfigResult | null = this.options.configFile\n ? explorer.load(this.options.configFile)\n : explorer.search()\n\n if (!result) {\n throw new Error(\n \"Config file not found. Please consult the docs at https://docs.qui.qualcomm.com/guide/page-setup#config\",\n )\n }\n\n return result\n }\n\n private resolveConfigFromCosmiconfig(\n config: CosmiconfigResult,\n ): ResolvedQuiDocsConfig {\n const parsed = configSchema.safeParse(config!.config)\n if (!parsed.success) {\n console.dir(parsed.error.issues, {depth: 10})\n throw new Error(\"Failed to parse config file.\")\n }\n const conf = parsed.data\n return {\n ...conf,\n appDirectory: conf.appDirectory || \"app\",\n filePath: config!.filepath,\n pageDirectory: conf.pageDirectory\n ? removeTrailingSlash(conf.pageDirectory)\n : \"routes\",\n }\n }\n\n loadConfig(): ResolvedQuiDocsConfig {\n const config = this.getCosmiconfig()\n return this.resolveConfigFromCosmiconfig(config)\n }\n}\n", "// Copyright (c) Qualcomm Technologies, Inc. and/or its subsidiaries.\n// SPDX-License-Identifier: BSD-3-Clause-Clear\n\nimport {z, type ZodObject, type ZodSchema} from \"zod\"\n\nimport type {\n NavMeta,\n QuiDocsConfig,\n QuiDocsTypeDocOptions,\n RouteMeta,\n} from \"../types\"\n\nimport {implement} from \"./zod\"\n\nexport const navMetaSchema: ZodObject<{}> = implement<NavMeta>().with({\n id: z.never().optional(),\n sectionTitle: z.string().optional(),\n separator: z.boolean().optional(),\n})\n\nexport const routeMetaSchema: ZodSchema<RouteMeta> =\n implement<RouteMeta>().with({\n children: z.array(z.lazy(() => routeMetaSchema)).optional(),\n expanded: z.boolean().optional(),\n group: z.string().optional(),\n groupOrder: z.string().array().optional(),\n hidden: z.boolean().optional(),\n hideBreadcrumbs: z.boolean().optional(),\n hideFromSearch: z.boolean().optional(),\n hidePageLinks: z.boolean().optional(),\n hideSideNav: z.boolean().optional(),\n hideToc: z.boolean().optional(),\n id: z.string(),\n ignoreRouteMetaOrder: z.boolean().optional(),\n restricted: z.boolean().optional(),\n sectionTitle: z.never().optional(),\n separator: z.never().optional(),\n sideNavTitle: z.string().optional(),\n title: z.string().optional(),\n })\n\nconst typeDocPropsSchema = implement<QuiDocsTypeDocOptions>().with({\n includeInSearchIndex: z.boolean().optional(),\n})\n\nexport const configSchema = implement<QuiDocsConfig>().with({\n appDirectory: z.string().optional(),\n disableCache: z.boolean().optional(),\n headings: z\n .array(\n z.union([\n z.literal(\"h1\"),\n z.literal(\"h2\"),\n z.literal(\"h3\"),\n z.literal(\"h4\"),\n z.literal(\"h5\"),\n z.literal(\"h6\"),\n ]),\n )\n .optional(),\n hotUpdateIgnore: z.instanceof(RegExp).optional(),\n navConfig: z.array(z.union([routeMetaSchema, navMetaSchema])).optional(),\n pageDirectory: z.string().optional(),\n routingStrategy: z\n .union([\n z.literal(\"vite-generouted\"),\n z.function(z.tuple([z.string()]), z.array(z.string())),\n ])\n .optional(),\n typeDocProps: z.string().optional(),\n typeDocPropsOptions: typeDocPropsSchema.optional(),\n})\n", "// Copyright (c) Qualcomm Technologies, Inc. and/or its subsidiaries.\n// SPDX-License-Identifier: BSD-3-Clause-Clear\n\nimport {z} from \"zod\"\n\ntype Implements<Model> = {\n [key in keyof Model]-?: undefined extends Model[key]\n ? null extends Model[key]\n ? z.ZodNullableType<z.ZodOptionalType<z.ZodType<Model[key]>>>\n : z.ZodOptionalType<z.ZodType<Model[key]>>\n : null extends Model[key]\n ? z.ZodNullableType<z.ZodType<Model[key]>>\n : z.ZodType<Model[key]> | z.ZodDefault<z.ZodType<Model[key]>>\n}\n\nexport function implement<Model = never>() {\n return {\n with: <\n Schema extends Implements<Model> & {\n [unknownKey in Exclude<keyof Schema, keyof Model>]: never\n },\n >(\n schema: Schema,\n ) => z.object(schema),\n }\n}\n", "// Copyright (c) Qualcomm Technologies, Inc. and/or its subsidiaries.\n// SPDX-License-Identifier: BSD-3-Clause-Clear\n\nimport {z, type ZodObject} from \"zod\"\n\nimport type {PageFrontmatter} from \"@qualcomm-ui/mdx-common\"\n\nimport {implement} from \"./zod\"\n\nexport const isDefined = (\n value: string | boolean | object | null | undefined | number,\n): boolean => typeof value !== \"undefined\" && value !== null\n\nexport function defined<T>(value: T | null | undefined): value is T {\n return typeof value !== \"undefined\" && value !== null\n}\n\n/**\n * Used to validate the MDX frontmatter and emit warnings for pages that violate the\n * schema.\n */\nexport const frontmatterSchema: ZodObject<{}> =\n implement<PageFrontmatter>().with({\n categories: z.string().array().optional(),\n group: z.string().optional(),\n hidden: z.boolean().optional(),\n hideBreadcrumbs: z.boolean().optional(),\n hideFromSearch: z.boolean().optional(),\n hidePageLinks: z.boolean().optional(),\n hideSideNav: z.boolean().optional(),\n hideToc: z.boolean().optional(),\n id: z.string().optional(),\n restricted: z.boolean().optional(),\n sideNavTitle: z.string().optional(),\n title: z.string(),\n })\n\n/**\n * Winblows fix\n */\nexport function fixPath(str: string): string {\n return str.replaceAll(\"\\\\\", \"/\")\n}\n\n/**\n * Removes the trailing slash from a string.\n */\nexport function removeTrailingSlash(str: string): string {\n return str.endsWith(\"/\") ? str.substring(0, str.length - 1) : str\n}\n", "// Copyright (c) Qualcomm Technologies, Inc. and/or its subsidiaries.\n// SPDX-License-Identifier: BSD-3-Clause-Clear\n\nimport chalk from \"chalk\"\n\nimport type {\n NavItem,\n PageFrontmatter,\n PageMap,\n PageSection,\n} from \"@qualcomm-ui/mdx-common\"\nimport type {QuiPropTypes} from \"@qualcomm-ui/typedoc-common\"\n\nimport type {\n RouteMetaInternal,\n RouteMetaNavInternal,\n SearchIndexerOptions,\n} from \"../types\"\n\nimport {\n DocPropsIndexer,\n filterFileGlob,\n getCategoriesFromPathSegments,\n getPathnameFromPathSegments,\n getPathSegmentsFromFileName,\n getRouteMeta,\n type IndexedPage,\n type IndexedSection,\n MarkdownFileReader,\n MarkdownIndexer,\n NavBuilder,\n} from \"./services\"\nimport {transformRouteMetaArray} from \"./transform-route-meta-array\"\nimport {defined, fixPath} from \"./utils\"\n\nexport class SearchIndexer {\n private readonly docPropsIndexer: DocPropsIndexer\n private readonly markdownIndexer: MarkdownIndexer\n private readonly navBuilder: NavBuilder\n private readonly fileCache: MarkdownFileReader\n private readonly allowedHeadings: Set<string>\n private readonly metaJson: RouteMetaInternal\n private readonly routeMetaNav: Record<string, RouteMetaNavInternal> = {}\n\n get cachedFileCount(): number {\n return this.fileCache.cachedFileCount\n }\n\n get pageDocProps(): Record<string, Record<string, QuiPropTypes>> {\n return this._pageDocProps\n }\n private _pageDocProps: Record<string, Record<string, QuiPropTypes>> = {}\n\n get mdxFileCount(): number {\n return this._mdxFileCount\n }\n private _mdxFileCount: number = 0\n\n get navItems(): NavItem[] {\n return this.navBuilder.navItems\n }\n\n get pageMap(): PageMap {\n return this._pageMap\n }\n private _pageMap: PageMap = {}\n\n get searchIndex(): PageSection[] {\n return this._searchIndex\n }\n private _searchIndex: PageSection[] = []\n\n reset(): void {\n this.fileCache.reset()\n this._pageMap = {}\n this._searchIndex = []\n }\n\n constructor(\n public config: SearchIndexerOptions,\n public logWarnings = true,\n // enable composition by making these classes replaceable\n addons: {\n docPropsIndexer?: DocPropsIndexer\n fileCache?: MarkdownFileReader\n markdownIndexer?: MarkdownIndexer\n navBuilder?: NavBuilder\n } = {},\n ) {\n this.allowedHeadings = new Set<string>(\n Array.from(config?.headings || [\"h2\", \"h3\", \"h4\"]),\n )\n this.metaJson = transformRouteMetaArray(\n this.config.navConfig ?? [],\n this.routeMetaNav,\n )\n\n this.markdownIndexer =\n addons.markdownIndexer || new MarkdownIndexer(this.allowedHeadings)\n this.navBuilder =\n addons.navBuilder || new NavBuilder(this.metaJson, this.routeMetaNav)\n this.docPropsIndexer =\n addons.docPropsIndexer ||\n new DocPropsIndexer(this.config.typeDocProps ?? {})\n this.fileCache =\n addons.fileCache ||\n new MarkdownFileReader(\n process.env.NODE_ENV === \"development\" && !this.config.disableCache,\n )\n }\n\n /**\n * Resolves a page's properties from the combined frontmatter and RouteMeta.\n * RouteMeta properties take precedence.\n */\n private getPageEntry(\n filepath: string,\n frontmatter: Partial<PageFrontmatter>,\n ): PageSection {\n const pagePath = filepath.replace(this.config.srcDir, \"\")\n\n const pathSegments = getPathSegmentsFromFileName(\n pagePath,\n this.config.pageDirectory,\n this.config.routingStrategy,\n )\n\n const pathname = getPathnameFromPathSegments(pathSegments)\n\n const routeMeta =\n getRouteMeta(\n pathSegments.length === 0\n ? frontmatter.id\n ? [frontmatter.id]\n : [\"_index\"]\n : pathSegments,\n this.metaJson,\n ) ?? {}\n\n return {\n categories:\n frontmatter.categories ??\n getCategoriesFromPathSegments(\n pathSegments,\n this.metaJson,\n routeMeta?.title || frontmatter.title || \"\",\n ),\n hidden: defined(routeMeta.hidden) ? routeMeta.hidden : frontmatter.hidden,\n hideBreadcrumbs: defined(routeMeta.hideBreadcrumbs)\n ? routeMeta.hideBreadcrumbs\n : frontmatter.hideBreadcrumbs,\n hideFromSearch: defined(routeMeta.hideFromSearch)\n ? routeMeta.hideFromSearch\n : frontmatter.hideFromSearch,\n hidePageLinks: defined(routeMeta.hidePageLinks)\n ? routeMeta.hidePageLinks\n : frontmatter.hidePageLinks,\n hideSideNav: defined(routeMeta.hideSideNav)\n ? routeMeta.hideSideNav\n : frontmatter.hideSideNav,\n hideToc: defined(routeMeta.hideToc)\n ? routeMeta.hideToc\n : frontmatter.hideToc,\n id: pagePath,\n pathname,\n pathSegments,\n restricted: defined(routeMeta.restricted)\n ? routeMeta.restricted\n : frontmatter.restricted,\n title: defined(routeMeta.title)\n ? routeMeta.title || \"\"\n : frontmatter.title || \"\",\n }\n }\n\n /**\n * Parses an MDX file to extract the site data for the nav items, doc props,\n * breadcrumbs, and search index.\n */\n private compileMdxFile(filepath: string): PageSection[] {\n const {cached, fileContents, frontmatter} =\n this.fileCache.readFile(filepath)\n\n this.docPropsIndexer.reset()\n this.markdownIndexer.reset()\n\n const defaultSection: PageSection = this.getPageEntry(filepath, frontmatter)\n if (!defaultSection.categories.length && defaultSection.title) {\n defaultSection.categories = [defaultSection.title]\n }\n\n if (!defaultSection.hidden) {\n this.navBuilder.add(defaultSection, frontmatter)\n }\n\n this._pageMap[defaultSection.pathname] = defaultSection\n\n let indexedPage: IndexedPage\n\n try {\n indexedPage = cached?.page\n ? cached.page\n : this.markdownIndexer.parseMarkdown(fileContents, frontmatter)\n } catch (error) {\n console.debug(\n `${chalk.yellowBright.bold(\n \"Failed to parse mdx page content.\",\n )} ${chalk.blueBright.bold(filepath)}`,\n )\n\n return [defaultSection]\n }\n\n const {sections, toc} = indexedPage\n\n if (toc.length) {\n this._pageMap[defaultSection.pathname].toc = toc\n }\n\n let docPropSections: IndexedSection[] = []\n let docProps: Record<string, QuiPropTypes> = {}\n\n if (this.config.typeDocProps) {\n docPropSections =\n cached?.pageDocPropSections ||\n (this.docPropsIndexer.build(fileContents, toc) ?? [])\n docProps = cached?.pageDocProps || this.docPropsIndexer.getDocProps()\n }\n\n if (docPropSections.length) {\n this._pageDocProps[defaultSection.pathname] = docProps\n }\n\n this.fileCache.updateCache(filepath, fileContents, {\n frontmatter,\n page: indexedPage,\n pageDocProps: docProps,\n pageDocPropSections: docPropSections,\n })\n\n // omit entries from pages that are explicitly omitted from the index.\n if (frontmatter.hideFromSearch) {\n return [defaultSection]\n }\n\n if (!sections.length && !docPropSections.length) {\n return [defaultSection]\n }\n\n const sectionReturn: PageSection[] = [\n ...this.formatSections(sections, defaultSection, false),\n ]\n\n if (this.config.typeDocPropsOptions?.includeInSearchIndex) {\n sectionReturn.push(\n ...this.formatSections(docPropSections, defaultSection, true),\n )\n }\n\n return sectionReturn\n }\n\n private formatSections(\n sections: IndexedSection[],\n {toc: _toc, ...defaultSection}: PageSection,\n isDocProp: boolean,\n ): PageSection[] {\n return sections.map((section, index): PageSection => {\n const content = section.content.map((c) => c.text.join(\" \")).join(\" \")\n return {\n ...defaultSection,\n content: content || undefined,\n heading: section.heading?.textContent ?? defaultSection.title,\n headingLevel: section.heading?.headingLevel,\n href:\n section.heading &&\n (this.allowedHeadings.has(section.heading.tagName) || isDocProp)\n ? `${defaultSection.pathname}#${section.heading.id}`\n : defaultSection.pathname,\n id: `${defaultSection.id}-${index}${isDocProp ? \"-prop\" : \"\"}`,\n isDocProp: isDocProp || undefined,\n richContent: section.richContent,\n }\n })\n }\n\n private compileTsxFile(filepath: string) {\n const entry = this.getPageEntry(filepath, {})\n\n const routeMeta = getRouteMeta(\n entry.pathSegments.length === 0 ? [\"_index\"] : entry.pathSegments,\n this.metaJson,\n )\n\n if (!routeMeta) {\n return null\n }\n\n if (!entry.hidden) {\n this.navBuilder.add(entry, {}, routeMeta)\n }\n\n this._pageMap[entry.pathname] = entry\n\n return entry\n }\n\n buildIndex(inputFileGlob: string[], logWarnings: boolean = true): void {\n this.logWarnings = logWarnings\n this.fileCache.logWarnings = logWarnings\n // Windows path fix\n const fileGlob = inputFileGlob.map(fixPath)\n this.navBuilder.reset()\n this.reset()\n\n const mdxFileGlob = filterFileGlob(\n fileGlob,\n \"mdx\",\n this.config.srcDir,\n this.config.routingStrategy,\n )\n\n this._mdxFileCount = mdxFileGlob.length\n const mdxIndex = mdxFileGlob.map((file) => this.compileMdxFile(file)).flat()\n\n filterFileGlob(\n fileGlob,\n \"tsx\",\n this.config.srcDir,\n this.config.routingStrategy,\n ).map((file) => this.compileTsxFile(file))\n\n this._searchIndex.push(...mdxIndex.filter((entry) => !entry.hideFromSearch))\n\n this.navBuilder.build()\n }\n}\n", "// Copyright (c) Qualcomm Technologies, Inc. and/or its subsidiaries.\n// SPDX-License-Identifier: BSD-3-Clause-Clear\n\nimport type {MdxJsxAttribute} from \"mdast-util-mdx-jsx\"\nimport remarkMdx from \"remark-mdx\"\nimport remarkParse from \"remark-parse\"\nimport remarkStringify from \"remark-stringify\"\nimport {type Plugin, unified} from \"unified\"\nimport {visit} from \"unist-util-visit\"\n\nimport {\n type PageDocProps,\n type PageHeading,\n type PagePropType,\n UniqueIdService,\n} from \"@qualcomm-ui/mdx-common\"\nimport type {\n QuiPropDeclaration,\n QuiPropTypes,\n} from \"@qualcomm-ui/typedoc-common\"\n\nimport type {IndexedSection} from \"../markdown\"\n\nfunction extractPickPropsRecord(\n node: MdxJsxAttribute,\n): Record<string, string[]> | null {\n if (\n node.name !== \"unionWithPick\" ||\n !node.value ||\n typeof node.value === \"string\"\n ) {\n return null\n }\n\n const estree = node.value.data?.estree\n if (!estree?.body?.[0] || estree.body[0].type !== \"ExpressionStatement\") {\n return null\n }\n\n const expression = estree.body[0].expression\n if (expression.type !== \"ObjectExpression\") {\n return null\n }\n\n const result: Record<string, string[]> = {}\n\n for (const property of expression.properties) {\n if (property.type !== \"Property\" || property.key.type !== \"Identifier\") {\n continue\n }\n\n if (property.value.type !== \"ArrayExpression\") {\n continue\n }\n\n const key = property.key.name\n const values: string[] = []\n\n for (const element of property.value.elements) {\n if (element?.type === \"Literal\" && typeof element.value === \"string\") {\n values.push(element.value)\n }\n }\n\n result[key] = values\n }\n\n return result\n}\n\nconst targetMdxElements: string[] = [\n \"TypeDocProps\",\n \"TypeDocAttributes\",\n \"TypeDocAngularAttributes\",\n]\n\ninterface DocPropEntry {\n name: string\n omitFrom?: string[]\n}\n\nexport class DocPropsIndexer {\n docPropsEntries: DocPropEntry[] = []\n idService: UniqueIdService = new UniqueIdService()\n private readonly props: Record<string, QuiPropTypes>\n private pageDocProps: PageDocProps = {}\n\n constructor(props: Record<string, QuiPropTypes>) {\n this.props = props\n }\n\n reset(): void {\n this.idService.reset()\n this.docPropsEntries = []\n }\n\n private extractNamesFromAttribute(attr: MdxJsxAttribute): string[] {\n if (!attr.value) {\n return []\n }\n\n if (typeof attr.value === \"string\") {\n return [attr.value]\n }\n\n if (attr.value.type === \"mdxJsxAttributeValueExpression\") {\n const estree = attr.value.data?.estree\n if (!estree?.body?.[0] || estree.body[0].type !== \"ExpressionStatement\") {\n return []\n }\n\n const expression = estree.body[0].expression\n\n if (expression.type === \"ArrayExpression\") {\n const names: string[] = []\n for (const element of expression.elements) {\n if (\n element?.type === \"Literal\" &&\n typeof element.value === \"string\"\n ) {\n names.push(element.value)\n }\n }\n return names\n }\n\n // Handle single string expression\n if (\n expression.type === \"Literal\" &&\n typeof expression.value === \"string\"\n ) {\n return [expression.value]\n }\n }\n\n return []\n }\n\n /**\n * Finds all JSX `<TypeDocProps />` nodes on the current page and adds their names\n * to an array. Once all nodes have been collected, we process them into\n * `PageSection` entries for the search index.\n */\n getTypeDocPropsNodes: Plugin = () => {\n return (tree, _file, done) => {\n visit(tree, \"mdxJsxFlowElement\", (node: any) => {\n if (node && \"name\" in node && targetMdxElements.includes(node.name)) {\n const nameAttr = node.attributes?.find(\n (attr: MdxJsxAttribute) => attr.name === \"name\",\n )\n const omitFromAttr = node.attributes?.find(\n (attr: MdxJsxAttribute) => attr.name === \"omitFrom\",\n )\n const omitFrom = omitFromAttr\n ? this.extractNamesFromAttribute(omitFromAttr)\n : undefined\n\n if (nameAttr) {\n const names = this.extractNamesFromAttribute(nameAttr)\n for (const name of names) {\n this.docPropsEntries.push({name, omitFrom})\n if (name.endsWith(\"Props\")) {\n // also index the corresponding component for lookup on this page.\n this.docPropsEntries.push({name: name.slice(0, -5), omitFrom})\n }\n }\n }\n\n const unionWithPickAttr: MdxJsxAttribute = node.attributes?.find(\n (attr: MdxJsxAttribute) => attr.name === \"unionWithPick\",\n )\n if (unionWithPickAttr) {\n try {\n const unionWithPick = extractPickPropsRecord(unionWithPickAttr)\n if (unionWithPick) {\n this.docPropsEntries.push(\n ...Object.keys(unionWithPick).map((entry) => ({\n name: entry,\n omitFrom,\n })),\n )\n }\n } catch (e) {}\n }\n }\n })\n done()\n }\n }\n\n build(fileContents: string, toc: PageHeading[]): IndexedSection[] | null {\n // parse the Markdown into an AST\n unified()\n .use(remarkMdx)\n // find the TypeDocProp nodes\n .use(this.getTypeDocPropsNodes)\n .use(remarkParse)\n .use(remarkStringify)\n .processSync(fileContents)\n\n if (!this.docPropsEntries.length) {\n return null\n }\n\n for (const item of toc) {\n this.idService.add(item.id)\n }\n\n return this.docPropsEntries\n .map((entry): IndexedSection[] => {\n const propTypes = this.props[entry.name]\n if (!propTypes) {\n return []\n }\n\n const omittedProps = new Set<string>(\n (entry.omitFrom ?? [])\n .map((entry) => {\n const propTypes = this.props[entry]\n if (!propTypes) {\n return []\n }\n return [\n propTypes.props,\n propTypes.input,\n propTypes.output,\n propTypes.publicMethods,\n ].reduce((acc: string[], current) => {\n if (current) {\n acc.push(...current.map((prop) => prop.name))\n }\n return acc\n }, [])\n })\n .flat(1)\n .filter(Boolean),\n )\n\n const sections: IndexedSection[] = []\n\n const assembleProps = (\n propsInput: QuiPropDeclaration[] | undefined,\n ): PagePropType[] | undefined => {\n if (!propsInput) {\n return undefined\n }\n const props: PagePropType[] = []\n for (const prop of propsInput) {\n if (omittedProps.has(prop.name)) {\n continue\n }\n const id = this.idService.add(prop.name)\n props.push({...prop, id})\n sections.push(this.assembleProp(prop, id))\n }\n return props\n }\n\n this.pageDocProps[entry.name] = {\n ...this.props[entry.name],\n input: assembleProps(propTypes.input),\n output: assembleProps(propTypes.output),\n props: assembleProps(propTypes.props),\n publicMethods: assembleProps(propTypes.publicMethods),\n }\n return sections\n })\n .flat()\n }\n\n getDocProps(): PageDocProps {\n return this.docPropsEntries.reduce((acc: PageDocProps, entry) => {\n const propTypes = this.pageDocProps[entry.name]\n // TODO: convert code comments to HTML using rehype. Remove markdown-to-jsx\n // in @qualcomm-ui/react-mdx library.\n if (propTypes) {\n acc[entry.name] = propTypes\n }\n return acc\n }, {})\n }\n\n private assembleProp(prop: QuiPropDeclaration, id: string): IndexedSection {\n const name = prop.name\n\n const heading: PageHeading = {\n headingLevel: 4,\n id,\n tagName: \"a\",\n textContent: name,\n }\n\n const comment = prop.comment\n if (!comment) {\n return {content: [], heading, richContent: []}\n }\n\n const content = {\n tagName: \"p\",\n text: [\n comment.summary\n .map((entry) => entry.text.replaceAll(\"\\n\", \" \"))\n .join(\"\"),\n ],\n }\n return {content: [content], heading, richContent: []}\n }\n}\n", "// Copyright (c) Qualcomm Technologies, Inc. and/or its subsidiaries.\n// SPDX-License-Identifier: BSD-3-Clause-Clear\n\nimport chalk from \"chalk\"\nimport {createHash} from \"node:crypto\"\nimport {readFileSync} from \"node:fs\"\nimport remarkFrontmatter from \"remark-frontmatter\"\nimport remarkParse from \"remark-parse\"\nimport remarkParseFrontmatter from \"remark-parse-frontmatter\"\nimport remarkStringify from \"remark-stringify\"\nimport {unified} from \"unified\"\n\nimport type {PageFrontmatter} from \"@qualcomm-ui/mdx-common\"\nimport type {QuiPropTypes} from \"@qualcomm-ui/typedoc-common\"\n\nimport {frontmatterSchema} from \"../../utils\"\n\nimport type {IndexedPage, IndexedSection} from \"./markdown.types\"\n\ninterface PageCache {\n frontmatter: PageFrontmatter\n md5: string\n page: IndexedPage\n pageDocProps: Record<string, QuiPropTypes>\n pageDocPropSections: IndexedSection[]\n}\n\nexport class MarkdownFileReader {\n cachedFileCount = 0\n logWarnings = true\n private mdxCache: Record<string, PageCache> = {}\n\n constructor(public enabled: boolean) {}\n\n private hash(input: string) {\n return createHash(\"md5\").update(input).digest(\"hex\")\n }\n\n reset(): void {\n this.cachedFileCount = 0\n }\n\n private checkCache(\n filepath: string,\n fileContents: string,\n ): Omit<PageCache, \"md5\"> | undefined {\n if (!this.enabled) {\n return\n }\n\n const fileMd5 = this.hash(fileContents)\n const cached = this.mdxCache[filepath]\n\n if (cached?.md5 !== fileMd5) {\n return\n }\n\n this.cachedFileCount++\n\n return {\n frontmatter: cached.frontmatter,\n page: cached.page,\n pageDocProps: cached.pageDocProps,\n pageDocPropSections: cached.pageDocPropSections,\n }\n }\n\n readFile(filepath: string): {\n cached: Omit<PageCache, \"md5\"> | undefined\n fileContents: string\n frontmatter: PageFrontmatter\n } {\n const fileContents = readFileSync(filepath, \"utf-8\")\n\n const cached = this.checkCache(filepath, fileContents)\n\n let file:\n | {data: {frontmatter: PageFrontmatter}}\n | ReturnType<typeof unified.processSync>\n if (cached?.frontmatter) {\n file = {data: {frontmatter: cached.frontmatter}}\n } else {\n // only parse the yaml section because we just need the frontmatter at this\n // stage.\n const yamlSection = fileContents.substring(\n 0,\n fileContents.indexOf(\"\\n---\") + 4,\n )\n file = unified()\n .use(remarkParse)\n .use(remarkFrontmatter, [\"yaml\"])\n .use(remarkParseFrontmatter)\n .use(remarkStringify)\n .processSync(yamlSection)\n }\n\n const frontmatter: PageFrontmatter = (file.data\n .frontmatter as PageFrontmatter) ?? {title: \"\"}\n\n if (!frontmatter.title) {\n const lines = fileContents.split(\"\\n\")\n const fallbackTitle = lines.find((line) => line.startsWith(\"# \"))\n if (fallbackTitle) {\n frontmatter.title = fallbackTitle.substring(2).trim()\n }\n }\n // TODO: permit omitting title from frontmatter if provided in the navConfig\n if (!frontmatter.title && this.logWarnings) {\n console.debug(chalk.red.bold(\"Missing title:\"), filepath)\n }\n\n const parsedFrontmatter = frontmatterSchema.safeParse(frontmatter)\n\n if (!parsedFrontmatter.success) {\n console.debug(\n `${chalk.redBright.bold(\"Invalid frontmatter detected for file\")}: ${filepath}\\n`,\n )\n console.debug(chalk.redBright.bold(\"Please check the following fields:\"))\n parsedFrontmatter.error.issues.map((issue: any) => {\n console.debug(`- ${issue.path.join(\".\")}`)\n })\n }\n\n return {cached, fileContents, frontmatter}\n }\n\n updateCache(\n filepath: string,\n fileContents: string,\n cacheData: Omit<PageCache, \"md5\">,\n ): void {\n if (this.enabled) {\n this.mdxCache[filepath] = {...cacheData, md5: this.hash(fileContents)}\n }\n }\n}\n", "// Copyright (c) Qualcomm Technologies, Inc. and/or its subsidiaries.\n// SPDX-License-Identifier: BSD-3-Clause-Clear\n\nimport type {Element} from \"hast\"\nimport {fromHtml} from \"hast-util-from-html\"\nimport {toText} from \"hast-util-to-text\"\nimport {clone, size} from \"lodash-es\"\nimport rehypeParse from \"rehype-parse\"\nimport rehypeStringify from \"rehype-stringify\"\nimport remarkGfm from \"remark-gfm\"\nimport remarkMdx from \"remark-mdx\"\nimport remarkParse from \"remark-parse\"\nimport remarkRehype from \"remark-rehype\"\nimport {unified} from \"unified\"\n\nimport type {\n PageFrontmatter,\n PageHeading,\n RichContentNode,\n} from \"@qualcomm-ui/mdx-common\"\n\nimport {rehypeSlug} from \"../../../rehype/rehype-slug\"\nimport {remarkAlerts} from \"../../../remark/remark-alerts\"\n\nimport type {IndexedPage, IndexedSection} from \"./markdown.types\"\nimport {remarkRemoveMermaidCodeBlocks} from \"./remark-remove-code-blocks\"\nimport {remarkRemoveJsx} from \"./remark-remove-jsx\"\n\n/**\n * Parses an html string into an AST and builds the search index from the tree.\n */\nexport class MarkdownIndexer {\n private sections: IndexedSection[] = []\n private currentSection!: IndexedSection\n private readonly headingLevels: Set<string>\n\n reset(): void {\n this.sections = []\n this._toc = []\n this.resetSection()\n }\n\n resetSection(): void {\n this.currentSection = {\n content: [],\n heading: null,\n richContent: [],\n }\n }\n\n get toc(): PageHeading[] {\n return this._toc\n }\n private _toc: PageHeading[] = []\n\n constructor(headingLevels: Set<string>) {\n this.resetSection()\n this.headingLevels = headingLevels\n }\n\n private appendTocItem(heading: PageHeading) {\n this._toc.push(heading)\n }\n\n private warn(...data: any[]) {\n if (process.env.DEBUG) {\n console.warn(...data)\n }\n // TODO: remove\n console.warn(...data)\n }\n\n private isHeading(element: Element): boolean {\n return this.headingLevels.has(element.tagName)\n }\n\n private isRootHeading(element: Element) {\n return element.tagName === \"h1\"\n }\n\n /**\n * Parses a heading Element node into the indexed heading data structure.\n */\n private parseHeading(headingElement: Element): PageHeading {\n const id = headingElement.properties.id\n const text = toText(headingElement)\n\n return {\n headingLevel: parseInt(headingElement.tagName.charAt(1)),\n id: id ? `${id}` : \"\",\n tagName: headingElement.tagName,\n textContent: text,\n }\n }\n\n private parseElementNode(element: Element) {\n const isRootHeading = this.isRootHeading(element)\n if (this.isHeading(element) || isRootHeading) {\n const currentSection = this.currentSection\n if (currentSection.heading) {\n // the old section is now done, so we add it and start a new one.\n this.sections.push(clone(this.currentSection))\n this.resetSection()\n }\n const heading = this.parseHeading(element)\n if (!isRootHeading) {\n this.appendTocItem(heading)\n }\n this.currentSection.heading = heading\n return\n }\n\n this.currentSection.richContent.push(element as RichContentNode)\n\n const text = toText(element, {whitespace: \"pre-wrap\"})\n .replaceAll(\"\\n\", \"\\t\")\n .split(\"\\t\")\n .filter(size)\n\n if (text.length) {\n this.currentSection.content.push({\n tagName: element.tagName,\n text,\n })\n }\n }\n\n parseMarkdown(\n fileContents: string | Buffer,\n frontmatter: PageFrontmatter,\n ): IndexedPage {\n const file = unified()\n .use(remarkMdx)\n .use(remarkRemoveJsx)\n .use(remarkRemoveMermaidCodeBlocks)\n .use(remarkParse)\n .use(remarkGfm)\n .use(remarkAlerts)\n .use(remarkRehype)\n .use(rehypeStringify)\n .processSync(fileContents)\n\n let contents = file.toString()\n\n contents = contents.substring(contents.indexOf(\"<h1>\"))\n\n for (const [key, value] of Object.entries(frontmatter)) {\n if (typeof value === \"string\" || typeof value === \"number\") {\n contents = contents.replaceAll(`frontmatter.${key}`, `${value}`)\n }\n }\n\n const htmlAst = unified()\n .data(\"settings\", {fragment: true})\n .use(rehypeParse)\n .use(rehypeStringify)\n .use(rehypeSlug)\n .processSync(contents)\n\n contents = htmlAst.toString()\n\n return this.build(contents)\n }\n\n build(html: string): IndexedPage {\n const tree = fromHtml(html, {fragment: true})\n\n for (const child of tree.children) {\n if (child.type === \"element\") {\n this.parseElementNode(child)\n }\n }\n\n // The parser processes sections in order and only appends the content once a\n // new section is encountered. We manually account for the final section here.\n if (this.currentSection.heading?.textContent) {\n this.sections.push(clone(this.currentSection))\n }\n\n return {\n sections: this.sections,\n toc: this.toc,\n }\n }\n}\n", "// Copyright (c) Qualcomm Technologies, Inc. and/or its subsidiaries.\n// SPDX-License-Identifier: BSD-3-Clause-Clear\n\nimport type {Root} from \"hast\"\nimport {headingRank} from \"hast-util-heading-rank\"\nimport {toString} from \"hast-util-to-string\"\nimport type {Plugin} from \"unified\"\nimport {visit} from \"unist-util-visit\"\n\nexport interface RehypeSlugOptions {\n /**\n * @default ['h2', 'h3', 'h4']\n */\n allowedHeadings?: string[]\n prefix?: string\n}\n\nconst emptyOptions: RehypeSlugOptions = {}\n\n/**\n * Converts heading text to URL-friendly slugs. Converts multi-word and PascalCase\n * text to kebab-case. Lowercases single sentence-case words. Appends counter for\n * duplicate slugs.\n */\nexport const rehypeSlug: Plugin<[RehypeSlugOptions?], Root> = (\n options: RehypeSlugOptions | null | undefined,\n) => {\n const settings = options || emptyOptions\n const prefix = settings.prefix || \"\"\n const allowedHeadings = new Set<string>(\n settings.allowedHeadings || [\"h2\", \"h3\", \"h4\"],\n )\n const seenIds = new Map<string, number>()\n\n function createSlug(text: string): string {\n const cleaned = text\n .replace(/[<>]/g, \"\")\n .replace(/[^\\w\\s-]/g, \"\")\n .trim()\n\n let slug: string\n if (cleaned.includes(\" \")) {\n slug = cleaned\n .toLowerCase()\n .replace(/\\s+/g, \"-\")\n .replace(/^-+|-+$/g, \"\")\n } else if ((cleaned.match(/[A-Z]/g) || []).length >= 2) {\n slug = cleaned\n .replace(/([a-z0-9])([A-Z])/g, \"$1-$2\")\n .replace(/([A-Z]+)([A-Z][a-z])/g, \"$1-$2\")\n .toLowerCase()\n } else {\n slug = cleaned.toLowerCase()\n }\n\n const count = seenIds.get(slug) || 0\n seenIds.set(slug, count + 1)\n return count > 0 ? `${slug}-${count}` : slug\n }\n\n return (tree) => {\n seenIds.clear()\n visit(tree, \"element\", function (node) {\n if (\n headingRank(node) &&\n !node.properties.id &&\n allowedHeadings.has(node.tagName)\n ) {\n node.properties.id = prefix + createSlug(toString(node))\n }\n })\n }\n}\n", "// Copyright (c) Qualcomm Technologies, Inc. and/or its subsidiaries.\n// SPDX-License-Identifier: BSD-3-Clause-Clear\n\nimport type {PhrasingContent, Root} from \"mdast\"\nimport type {Plugin} from \"unified\"\nimport {visit} from \"unist-util-visit\"\n\nconst alertLegacyRegex = /^\\[!(NOTE|TIP|SUCCESS|WARNING|CAUTION)(\\/.*)?\\]/i\n\n/**\n * Alerts are a Markdown extension based on the blockquote syntax that you can use\n * to emphasize critical information. On GitHub, they are displayed with distinctive\n * colors and icons to indicate the significance of the content.\n * https://docs.github.com/en/get-started/writing-on-github/getting-started-with-writing-and-formatting-on-github/basic-writing-and-formatting-syntax#alerts\n */\nexport const remarkAlerts: Plugin<[], Root> = () => {\n return (tree) => {\n visit(tree, \"blockquote\", (node) => {\n let alertType = \"\"\n let title = \"\"\n let isNext = true\n const child = node.children.map((item) => {\n if (isNext && item.type === \"paragraph\") {\n const firstNode = item.children[0]\n const text = firstNode.type === \"text\" ? firstNode.value : \"\"\n const reg = alertLegacyRegex\n const match = text.match(reg)\n if (match) {\n isNext = false\n alertType = match[1].toLocaleLowerCase()\n title = match[2] || alertType.toLocaleUpperCase()\n if (text.includes(\"\\n\")) {\n item.children[0] = {\n type: \"text\",\n value: text.replace(reg, \"\").replace(/^\\n+/, \"\"),\n }\n }\n\n if (!text.includes(\"\\n\")) {\n const itemChild: PhrasingContent[] = []\n item.children.forEach((item: any, idx: number) => {\n if (idx === 0) {\n return\n }\n if (idx === 1 && item.type === \"break\") {\n return\n }\n itemChild.push(item)\n })\n item.children = [...itemChild]\n }\n }\n }\n return item\n })\n\n title = title.replace(/^\\//, \"\")\n\n if (!!alertType) {\n node.data = {\n hName: \"div\",\n hProperties: {\n class: `qui-notification__root`,\n \"data-emphasis\":\n alertToEmphasis[alertType as IconType] || \"neutral\",\n \"data-orientation\": \"vertical\",\n dir: \"auto\",\n },\n }\n node.children = [\n {\n children: [getAlertIcon(alertType as IconType)],\n data: {\n hProperties: {\n class: \"qui-notification__icon\",\n \"data-part\": \"status-icon\",\n \"data-scope\": \"inline-notification\",\n },\n },\n type: \"paragraph\",\n },\n {\n children: [\n {\n type: \"text\",\n value: title,\n },\n ],\n data: {\n hProperties: {\n class: \"qui-notification__label\",\n dir: \"auto\",\n },\n },\n type: \"paragraph\",\n },\n {\n children: child,\n data: {\n hName: \"div\",\n hProperties: {\n class: `qui-notification__description`,\n dir: \"auto\",\n },\n },\n type: \"blockquote\",\n },\n ]\n }\n })\n }\n}\n\nexport function getAlertIcon(type: IconType): PhrasingContent {\n const svgChildren = svgData[type] ?? []\n return {\n children: svgChildren,\n data: {\n hName: \"svg\",\n hProperties: {\n ariaHidden: \"true\",\n class: \"lucide\",\n fill: \"transparent\",\n height: \"20\",\n stroke: \"currentColor\",\n strokeLinecap: \"round\",\n strokeLinejoin: \"round\",\n strokeWidth: \"2\",\n viewBox: \"0 0 24 24\",\n width: \"20\",\n },\n },\n type: \"emphasis\",\n }\n}\n\ntype IconType = \"note\" | \"tip\" | \"success\" | \"warning\" | \"caution\"\n\n/**\n * These SVG children correspond to the lucide icons matching our\n * {@link https://react.qui.qualcomm.com/components/inline-alert | Alert} component.\n */\nconst svgData: Record<IconType, PhrasingContent[]> = {\n caution: [\n {\n children: [],\n data: {\n hName: \"polygon\",\n hProperties: {\n points:\n \"7.86 2 16.14 2 22 7.86 22 16.14 16.14 22 7.86 22 2 16.14 2 7.86 7.86 2\",\n },\n },\n type: \"emphasis\",\n },\n {\n children: [],\n data: {\n hName: \"line\",\n hProperties: {\n x1: \"12\",\n x2: \"12\",\n y1: \"8\",\n y2: \"12\",\n },\n },\n type: \"emphasis\",\n },\n {\n children: [],\n data: {\n hName: \"line\",\n hProperties: {\n x1: \"12\",\n x2: \"12.01\",\n y1: \"16\",\n y2: \"16\",\n },\n },\n type: \"emphasis\",\n },\n ],\n note: [\n {\n children: [],\n data: {\n hName: \"circle\",\n hProperties: {\n cx: \"12\",\n cy: \"12\",\n r: \"10\",\n },\n },\n type: \"emphasis\",\n },\n {\n children: [],\n data: {\n hName: \"path\",\n hProperties: {\n d: \"M12 16v-4\",\n },\n },\n type: \"emphasis\",\n },\n {\n children: [],\n data: {\n hName: \"path\",\n hProperties: {\n d: \"M12 8h.01\",\n },\n },\n type: \"emphasis\",\n },\n ],\n success: [\n {\n children: [],\n data: {\n hName: \"path\",\n hProperties: {\n d: \"M20 6 9 17l-5-5\",\n },\n },\n type: \"emphasis\",\n },\n ],\n tip: [\n {\n children: [],\n data: {\n hName: \"path\",\n hProperties: {\n d: \"M15 14c.2-1 .7-1.7 1.5-2.5 1-.9 1.5-2.2 1.5-3.5A6 6 0 0 0 6 8c0 1 .2 2.2 1.5 3.5.7.7 1.3 1.5 1.5 2.5\",\n },\n },\n type: \"emphasis\",\n },\n {\n children: [],\n data: {\n hName: \"path\",\n hProperties: {\n d: \"M9 18h6\",\n },\n },\n type: \"emphasis\",\n },\n {\n children: [],\n data: {\n hName: \"path\",\n hProperties: {\n d: \"M10 22h4\",\n },\n },\n type: \"emphasis\",\n },\n ],\n warning: [\n {\n children: [],\n data: {\n hName: \"path\",\n hProperties: {\n d: \"m21.73 18-8-14a2 2 0 0 0-3.48 0l-8 14A2 2 0 0 0 4 21h16a2 2 0 0 0 1.73-3\",\n },\n },\n type: \"emphasis\",\n },\n {\n children: [],\n data: {\n hName: \"path\",\n hProperties: {\n d: \"M12 9v4\",\n },\n },\n type: \"emphasis\",\n },\n {\n children: [],\n data: {\n hName: \"path\",\n hProperties: {\n d: \"M12 17h.01\",\n },\n },\n type: \"emphasis\",\n },\n ],\n}\n\nconst alertToEmphasis: Record<IconType, string> = {\n caution: \"danger\",\n note: \"neutral\",\n success: \"success\",\n tip: \"info\",\n warning: \"warning\",\n}\n", "// Copyright (c) Qualcomm Technologies, Inc. and/or its subsidiaries.\n// SPDX-License-Identifier: BSD-3-Clause-Clear\n\nimport type {Plugin} from \"unified\"\nimport {remove} from \"unist-util-remove\"\n\nexport const remarkRemoveMermaidCodeBlocks: Plugin = () => {\n return (tree, _file, done) => {\n remove(tree, (node: any) => node.type === \"code\" && node.lang === \"mermaid\")\n done()\n }\n}\n", "// Copyright (c) Qualcomm Technologies, Inc. and/or its subsidiaries.\n// SPDX-License-Identifier: BSD-3-Clause-Clear\n\nimport type {Plugin} from \"unified\"\nimport {remove} from \"unist-util-remove\"\n\nexport const remarkRemoveJsx: Plugin = () => {\n return (tree, _file, done) => {\n remove(tree, \"mdxjsEsm\")\n remove(tree, \"mdxJsxFlowElement\")\n done()\n }\n}\n", "// Copyright (c) Qualcomm Technologies, Inc. and/or its subsidiaries.\n// SPDX-License-Identifier: BSD-3-Clause-Clear\n\nimport type {RouteMetaEntryInternal, RouteMetaInternal} from \"../../../types\"\n\n/**\n * Retrieves the route metadata for a given path based on its path segments.\n */\nexport function getRouteMeta(\n pathSegments: string[],\n metaJson: RouteMetaInternal,\n): RouteMetaEntryInternal | undefined | null {\n const routeMeta = metaJson[pathSegments[0]]\n if (!routeMeta) {\n // backup, fetch using id if provided\n return undefined\n }\n\n if (pathSegments.length === 1) {\n return routeMeta\n }\n\n return pathSegments\n .slice(1)\n .reduce((acc: RouteMetaEntryInternal | undefined | null, segment) => {\n return acc?.children?.[segment]\n }, routeMeta)\n}\n", "// Copyright (c) Qualcomm Technologies, Inc. and/or its subsidiaries.\n// SPDX-License-Identifier: BSD-3-Clause-Clear\n\nimport {capitalCase} from \"change-case\"\nimport {sortBy} from \"lodash-es\"\nimport {v4 as uuidv4} from \"uuid\"\n\nimport type {\n NavItem,\n PageFrontmatter,\n PageSection,\n} from \"@qualcomm-ui/mdx-common\"\n\nimport type {\n NavMeta,\n RouteMetaEntryInternal,\n RouteMetaInternal,\n} from \"../../../types\"\nimport {defined} from \"../../utils\"\n\nimport {getRouteMeta} from \"./get-route-meta\"\n\ninterface InitialRoute {\n pageFrontmatter: Partial<PageFrontmatter>\n pageSection: PageSection\n routeMeta?: RouteMetaEntryInternal\n}\n\n/**\n * Given a flat remix route structure, computes nested navigation items for the QUI\n * side nav.\n */\nexport class NavBuilder {\n private initialRoutes: InitialRoute[] = []\n private flatNavItems: NavItem[] = []\n\n get navItems(): NavItem[] {\n return this._navItems\n }\n private _navItems: NavItem[] = []\n\n private readonly metaJson: RouteMetaInternal\n private readonly navMeta: Record<number, NavMeta>\n\n constructor(metaJson: RouteMetaInternal, navMeta: Record<number, NavMeta>) {\n this.navMeta = navMeta\n this.metaJson = metaJson\n }\n\n add(\n pageSection: PageSection,\n pageFrontmatter: Partial<PageFrontmatter>,\n routeMeta?: RouteMetaEntryInternal,\n ): void {\n this.initialRoutes.push({pageFrontmatter, pageSection, routeMeta})\n }\n\n reset(): void {\n this.initialRoutes = []\n this.flatNavItems = []\n this._navItems = []\n }\n\n /**\n * Sorts nav items. Nav items with an order defined take precedence over nav items\n * without an order. Nav items with the same order are sorted alphabetically by\n * title.\n */\n private navItemSort(a: NavItem, b: NavItem, groupOrder?: string[]) {\n if (a.depth !== b.depth) {\n return a.depth - b.depth\n }\n\n if (a.order && !b.order) {\n return -1\n }\n if (!a.order && b.order) {\n return 1\n } else if (a.order && b.order && a.order !== b.order) {\n return a.order - b.order\n }\n\n if (groupOrder && a.group && b.group) {\n const aIndex = a.group ? groupOrder.indexOf(a.group) : -1\n const bIndex = b.group ? groupOrder.indexOf(b.group) : -1\n\n if (aIndex === bIndex) {\n // continue\n } else if (aIndex !== -1 && bIndex !== -1) {\n return aIndex - bIndex\n } else if (aIndex !== -1) {\n return -1\n } else if (bIndex !== -1) {\n return 1\n }\n }\n\n // group items with the same group\n if (a.group !== b.group) {\n if (!a.group && b.group) {\n return -1\n }\n if (a.group && !b.group) {\n return 1\n }\n if (a.group && b.group) {\n return a.group.localeCompare(b.group)\n }\n }\n\n return a.title.localeCompare(b.title)\n }\n\n resolveSideNavTitle(\n frontmatter: Partial<PageFrontmatter>,\n routeMeta: Partial<RouteMetaEntryInternal>,\n fallback: string,\n ): string {\n return (\n (defined(routeMeta.sideNavTitle)\n ? routeMeta.sideNavTitle || \"\"\n : frontmatter.sideNavTitle || \"\") || fallback\n )\n }\n\n /**\n * Builds a flat list of nav items from the MDX pages and _meta.json. If a page\n * does not exist, it is not added to the side nav (even if it has an entry in\n * _meta.json).\n */\n private buildNavItem({\n pageFrontmatter,\n pageSection: {pathname, pathSegments, title},\n routeMeta: routeMetaParam,\n }: InitialRoute) {\n const id = pageFrontmatter?.id || \"\"\n\n // handle home page (this route does not have path segments)\n if (!pathSegments.length && pathname === \"/\") {\n const routeMeta =\n routeMetaParam || getRouteMeta(id ? [id] : [], this.metaJson)\n if (!routeMeta) {\n return\n }\n\n this.flatNavItems.push({\n depth: 1,\n expanded: routeMeta?.expanded || false,\n id: `/`,\n order: routeMeta?.order,\n pathname,\n pathSegments: [],\n title: this.resolveSideNavTitle(\n pageFrontmatter,\n routeMeta,\n routeMeta?.title || title,\n ),\n })\n }\n\n pathSegments.forEach((segment, index) => {\n const depth = index + 1\n\n // we only add an item if it doesn't already exist, which we determine by\n // comparing the path segments iteratively.\n const navItem = this.flatNavItems.find((item) =>\n pathSegments\n .slice(0, depth)\n .every((value, i) => value === item.pathSegments[i]),\n )\n\n if (!navItem) {\n const isPage = index === pathSegments.length - 1\n const adjustedSegments = pathSegments.slice(0, depth)\n\n const routeMeta =\n getRouteMeta(\n isPage ? pathSegments : adjustedSegments,\n this.metaJson,\n ) ?? {}\n\n this.flatNavItems.push({\n depth,\n expanded: routeMeta?.expanded || false,\n group: isPage\n ? routeMeta.group || pageFrontmatter.group\n : routeMeta.group,\n id: `/${adjustedSegments.join(\"/\")}`,\n items: [],\n order: routeMeta?.order,\n pathname: isPage ? pathname : undefined,\n pathSegments: adjustedSegments,\n title: this.resolveSideNavTitle(\n pageFrontmatter,\n routeMeta,\n routeMeta?.title\n ? routeMeta.title\n : isPage\n ? title\n : capitalCase(segment),\n ),\n })\n }\n })\n }\n\n /**\n * Iterates through a nav item's path segments and ensures that all of its parent\n * elements exist in the recursive structure.\n */\n private ensureParent(navItem: NavItem) {\n const segments = navItem.pathSegments\n let items: NavItem[] = this.navItems\n let item: NavItem | undefined\n let prevItem: NavItem | undefined = undefined\n\n for (let i = 0; i < segments.length - 1; i++) {\n const segment = segments[i]\n item = items?.find((entry) => entry.pathSegments[i] === segment)\n if (item) {\n // point to the found item's children and keep iterating\n items = item.items ?? []\n prevItem = item\n continue\n }\n if (prevItem) {\n const pathSegments = segments.slice(0, i + 1)\n const routeMeta = getRouteMeta(pathSegments, this.metaJson)\n\n items = []\n const base = {\n depth: pathSegments.length,\n id: `/routes/${pathSegments.join(\"/\")}`,\n items,\n pathSegments,\n title: segment,\n }\n const newItem = routeMeta\n ? {\n ...base,\n expanded: routeMeta.expanded,\n order: routeMeta.order,\n restricted: routeMeta.restricted,\n title: routeMeta.title ?? segment,\n }\n : base\n prevItem.items = prevItem.items\n ? [...prevItem.items, newItem]\n : [newItem]\n }\n prevItem = item\n }\n }\n\n /**\n * Deeply inserts a nav item into the array, iterating through parent routes\n * (based on the pathSegments) and adding them if they don't exist.\n *\n * For example, given a leaf node 4 path segments deep, this function will create\n * all parent nav items as nested children of the top-most nav item.\n */\n private nestedInsert(\n item: NavItem,\n pathSegments: string[],\n items: NavItem[],\n ) {\n const segment = pathSegments[0]\n const parentItem = items.find(\n (parent) =>\n parent.pathSegments[parent.pathSegments.length - 1] === segment,\n )\n if (parentItem) {\n this.nestedInsert(item, pathSegments.slice(1), parentItem.items ?? [])\n } else if (pathSegments.length === 1) {\n items.push(item)\n }\n }\n\n private buildNestedNavItems() {\n for (let i = 0; i < this.flatNavItems.length; i++) {\n const navItem = this.flatNavItems[i]\n if (navItem.depth === 1) {\n this.navItems.push(navItem)\n continue\n }\n\n this.ensureParent(navItem)\n this.nestedInsert(navItem, navItem.pathSegments, this.navItems)\n }\n }\n\n private sortNestedNavItems(items: NavItem[], groupOrder?: string[]) {\n items.sort((a, b) => this.navItemSort(a, b, groupOrder))\n items.forEach((item) => {\n if (item.items?.length) {\n const meta = getRouteMeta(item.pathSegments, this.metaJson)\n this.sortNestedNavItems(item.items, meta?.groupOrder)\n }\n })\n }\n\n /**\n * To be called after every mdx page route has been added through the {@link add}\n * function.\n */\n build(): NavItem[] {\n // We need to process parent items first, so we sort by path segment. Routes\n // with shorter path segments will be processed first.\n sortBy(\n this.initialRoutes,\n (item) => item.pageSection.pathSegments.length,\n ).map((r) => this.buildNavItem(r))\n\n this.buildNestedNavItems()\n\n const rootMeta = getRouteMeta([], this.metaJson)\n this.sortNestedNavItems(this.navItems, rootMeta?.groupOrder)\n\n if (this.navMeta) {\n Object.entries(this.navMeta).forEach(([index, value]) => {\n this._navItems.splice(parseInt(index), 0, {\n depth: 1,\n id: uuidv4(),\n pathSegments: [],\n sectionTitle: value.sectionTitle,\n separator: value.separator,\n title: \"\",\n })\n })\n }\n\n this._navItems = this.groupNavItems(this.navItems)\n this._navItems = this.buildSearchMeta(this.navItems, [])\n return this.navItems\n }\n\n private groupNavItems(items: NavItem[]): NavItem[] {\n const result: NavItem[] = []\n const seenGroups = new Set<string>()\n\n for (const item of items) {\n if (item.group && !seenGroups.has(item.group)) {\n seenGroups.add(item.group)\n result.push({\n depth: item.depth,\n group: item.group,\n id: uuidv4(),\n pathSegments: [],\n sectionTitle: item.group,\n title: \"\",\n })\n }\n\n result.push({\n ...item,\n items: item.items ? this.groupNavItems(item.items) : undefined,\n })\n }\n\n return result\n }\n\n /**\n * Walks over the tree and builds search metadata using the nearest sectionTitle.\n */\n private buildSearchMeta(items: NavItem[], meta: string[]): NavItem[] {\n let sectionTitle = \"\"\n const results: NavItem[] = []\n\n for (const ogItem of items) {\n const item = {...ogItem}\n\n if (item.sectionTitle) {\n sectionTitle = item.sectionTitle\n } else if (item.separator) {\n sectionTitle = \"\"\n }\n\n if (!item.separator) {\n const currentMeta = sectionTitle ? [...meta, sectionTitle] : [...meta]\n const nextMeta = [...(item.searchMeta || []), ...currentMeta]\n if (nextMeta.length) {\n item.searchMeta = [...nextMeta]\n }\n\n if (item.items) {\n item.items = this.buildSearchMeta(item.items, currentMeta)\n }\n }\n\n results.push(item)\n }\n\n return results\n }\n}\n", "// Copyright (c) Qualcomm Technologies, Inc. and/or its subsidiaries.\n// SPDX-License-Identifier: BSD-3-Clause-Clear\n\nimport {capitalCase} from \"change-case\"\nimport {join} from \"node:path\"\n\nimport type {RouteMetaInternal, RoutingStrategy} from \"../../../types\"\n\nimport {getRouteMeta} from \"./get-route-meta\"\n\nexport function getPathnameFromPathSegments(segments: string[]) {\n return `/${segments.join(\"/\")}`\n}\n\nexport function getCategoriesFromPathSegments(\n segments: string[],\n metaJson: RouteMetaInternal,\n // the frontmatter title only applies to the last segment.\n frontmatterTitle: string,\n): string[] {\n return segments.reduce((acc: string[], segment, index) => {\n const pathSegments = segments.slice(0, index + 1)\n if (index === segments.length - 1) {\n acc.push(frontmatterTitle)\n return acc\n }\n const meta = getRouteMeta(pathSegments, metaJson)\n if (meta?.title) {\n acc.push(meta.title)\n } else {\n acc.push(pathSegmentToCategory(segment))\n }\n return acc\n }, [])\n}\n\n// fallback for unmatched path segments\nexport function pathSegmentToCategory(segment: string): string {\n // we don't transform words like `a`, `or`, and `and`\n return segment\n .split(\"-\")\n .map((segment) =>\n /\\b(a|an|and|but|or|in|on|at)\\b/.test(segment)\n ? segment\n : capitalCase(segment),\n )\n .join(\" \")\n}\n\nfunction getGeneroutedPathSegments(filePath: string): string[] {\n const extension = filePath.endsWith(\"mdx\") ? \"mdx\" : \"tsx\"\n\n const segments = filePath\n .substring(0, filePath.lastIndexOf(`.${extension}`))\n .split(\"/\")\n\n if (segments[segments.length - 1] === \"index\") {\n return segments.slice(0, segments.length - 1)\n }\n return segments\n}\n\nconst pathSeparatorRegex = /[\\/\\\\.]/\nfunction isPathSeparator(char: string) {\n return pathSeparatorRegex.test(char)\n}\n\nconst indexRouteRegex =\n /((^|[.]|[+]\\/)(index|_index))(\\/[^\\/]+)?$|(\\/_?index\\/)/\n\nfunction getRemixFlatRoutesSegments(\n name: string,\n index: boolean,\n paramPrefixChar: string = \"$\",\n) {\n let routeSegments: string[] = []\n let i = 0\n let routeSegment = \"\"\n let state = \"START\"\n let subState = \"NORMAL\"\n let hasPlus = false\n\n // ignore layout routes\n if (name.endsWith(\"_layout\")) {\n return []\n }\n\n /*\n * name has already been normalized to use / as path separator.\n * replace `+/_.` with `_+/`\n * this supports the ability to specify parent folder will not be a layout.\n * _public+/_.about.tsx => _public_.about.tsx\n */\n if (/\\+\\/_\\./.test(name)) {\n name = name.replace(/\\+\\/_\\./g, \"_+/\")\n }\n\n /*\n * replace `+/` with `.`\n * this supports folders for organizing flat-files convention.\n * _public+/about.tsx => _public.about.tsx\n */\n if (/\\+\\//.test(name)) {\n name = name.replace(/\\+\\//g, \".\")\n hasPlus = true\n }\n const hasFolder = /\\//.test(name)\n // if name has plus folder, but we still have regular folders\n // then treat ending route as flat-folders\n if (\n ((hasPlus && hasFolder) || !hasPlus) &&\n !(name.endsWith(\".route\") || name.endsWith(\".index\"))\n ) {\n // Do not remove segments ending in .route\n // since these would be part of the route directory name\n // docs/readme.route.tsx => docs/readme\n // Remove last segment since this should just be the route filename, and we only\n // want the directory name docs/_layout.tsx => docs\n const last = name.lastIndexOf(\"/\")\n if (last >= 0) {\n name = name.substring(0, last)\n }\n }\n\n const pushRouteSegment = (routeSegment: string) => {\n if (routeSegment) {\n routeSegments.push(routeSegment)\n }\n }\n\n while (i < name.length) {\n const char = name[i]\n switch (state) {\n case \"START\":\n // process existing segment\n if (\n routeSegment.includes(paramPrefixChar) &&\n !(\n routeSegment.startsWith(paramPrefixChar) ||\n routeSegment.startsWith(`(${paramPrefixChar}`)\n )\n ) {\n throw new Error(\n `Route params must start with prefix char ${paramPrefixChar}: ${routeSegment}`,\n )\n }\n if (\n routeSegment.includes(\"(\") &&\n !routeSegment.startsWith(\"(\") &&\n !routeSegment.endsWith(\")\")\n ) {\n throw new Error(\n `Optional routes must start and end with parentheses: ${routeSegment}`,\n )\n }\n pushRouteSegment(routeSegment)\n routeSegment = \"\"\n state = \"PATH\"\n continue // restart without advancing index\n case \"PATH\":\n if (isPathSeparator(char) && subState === \"NORMAL\") {\n state = \"START\"\n break\n } else if (char === \"[\") {\n subState = \"ESCAPE\"\n break\n } else if (char === \"]\") {\n subState = \"NORMAL\"\n break\n }\n routeSegment += char\n break\n }\n i++ // advance to next character\n }\n // process remaining segment\n pushRouteSegment(routeSegment)\n // strip trailing .route segment\n if (\n routeSegments.at(-1) === \"route\" ||\n routeSegments.at(-1) === \"index\" ||\n routeSegments.at(-1) === \"_index\" ||\n routeSegments.at(-1) === \"_route\"\n ) {\n routeSegments = routeSegments.slice(0, -1)\n }\n // if hasPlus, we need to strip the trailing segment if it starts with _\n // and route is not an index route\n // this is to handle layouts in flat-files\n // _public+/_layout.tsx => _public.tsx\n // _public+/index.tsx => _public.index.tsx\n if (!index && hasPlus && routeSegments.at(-1)?.startsWith(\"_\")) {\n routeSegments = routeSegments.slice(0, -1)\n }\n return routeSegments\n}\n\nfunction getRemixHybridRoutesPathSegments(filePath: string): string[] {\n const routeWithoutExtension = filePath.substring(0, filePath.lastIndexOf(\".\"))\n\n return getRemixFlatRoutesSegments(\n routeWithoutExtension,\n indexRouteRegex.test(routeWithoutExtension),\n )\n}\n\nexport function getPathSegmentsFromFileName(\n filePath: string,\n pageDirectory: string,\n strategy?: RoutingStrategy,\n): string[] {\n const filePathWithoutPageDirectory = filePath.substring(\n filePath.indexOf(pageDirectory) + pageDirectory.length + 1,\n )\n if (typeof strategy === \"function\") {\n return strategy(filePathWithoutPageDirectory)\n }\n switch (strategy) {\n case \"vite-generouted\":\n return getGeneroutedPathSegments(filePathWithoutPageDirectory)\n default:\n return getRemixHybridRoutesPathSegments(filePathWithoutPageDirectory)\n }\n}\n\nexport function filterFileGlob(\n fileGlob: string[],\n ext: string,\n srcDir: string,\n router?: RoutingStrategy,\n): string[] {\n if (typeof router === \"string\" && router === \"vite-generouted\") {\n // vite-generouted: filter routes\n const restrictedPattern = /(\\(.*\\))|(\\[.*\\])/\n // pull out the full path before filtering to avoid potential issues with\n // parent directories.\n const relativeGlobs = fileGlob.map((file) => file.replace(srcDir, \"\"))\n return (\n relativeGlobs\n .filter(\n (file) =>\n file.endsWith(`.${ext}`) &&\n !file.includes(\"/_\") &&\n !file.includes(\"/+\"),\n )\n // filter pathless segments\n .map((file) =>\n file\n .split(\"/\")\n .filter((segment) => !restrictedPattern.test(segment))\n .join(\"/\"),\n )\n // restore full path\n .map((file) => join(srcDir, file))\n )\n }\n return fileGlob.filter((file) => file.endsWith(ext) && !file.includes(\"$\"))\n}\n", "// Copyright (c) Qualcomm Technologies, Inc. and/or its subsidiaries.\n// SPDX-License-Identifier: BSD-3-Clause-Clear\n\nimport type {NavConfig, NavMeta, RouteMeta, RouteMetaInternal} from \"../types\"\n\nexport function transformRouteMetaArray(\n meta: NavConfig[],\n routeMetaNav: Record<string, NavMeta>,\n): RouteMetaInternal {\n let ignoringOrder = 0\n return meta.reduce((acc: RouteMetaInternal, item, index) => {\n // strip the nav meta and populate a separate record. This will be used for\n // lookup while building the nav items.\n if (!(\"id\" in item)) {\n if (\"separator\" in item || \"sectionTitle\" in item) {\n // offset the navMeta index by the number of items that will be sorted to\n // the back of the nav order.\n routeMetaNav[index - ignoringOrder] = item\n }\n return acc\n }\n const current = item as RouteMeta\n if (current.ignoreRouteMetaOrder || current.hidden) {\n // items with ignored order are always sorted to the back of the nav order. We\n // need to account for this when splicing in the navMeta entries.\n ignoringOrder++\n }\n acc[current.id] = {\n children: current.children\n ? transformRouteMetaArray(current.children, routeMetaNav)\n : undefined,\n expanded: current.expanded,\n group: current.group,\n groupOrder: current.groupOrder,\n hidden: current.hidden,\n hideBreadcrumbs: current.hideBreadcrumbs,\n hideFromSearch: current.hideFromSearch,\n hidePageLinks: current.hidePageLinks,\n hideSideNav: current.hideSideNav,\n hideToc: current.hideToc,\n order: current.ignoreRouteMetaOrder ? undefined : index + 1,\n restricted: current.restricted,\n title: current.title,\n }\n return acc\n }, {})\n}\n", "// Copyright (c) Qualcomm Technologies, Inc. and/or its subsidiaries.\n// SPDX-License-Identifier: BSD-3-Clause-Clear\n\nimport rehypeShiki, {type RehypeShikiOptions} from \"@shikijs/rehype\"\nimport type {PluggableList} from \"unified\"\n\nimport {quiCustomDarkTheme} from \"@qualcomm-ui/mdx-common\"\n\nimport {\n rehypeMdxCodeProps,\n remarkFrontmatter,\n remarkGfm,\n remarkMdxFrontmatter,\n} from \"../exports\"\n\nimport {ConfigLoader, type ConfigLoaderOptions} from \"./internal\"\nimport {rehypeSectionize, rehypeSlug, type RehypeSlugOptions} from \"./rehype\"\nimport {remarkAlerts, remarkCodeTabs, remarkSpoilers} from \"./remark\"\n\n/**\n * @deprecated migrate to the {@link getRehypePlugins} function\n */\nexport const quiRehypePlugins: PluggableList = [rehypeSectionize, rehypeSlug]\n\nexport interface QuiRehypePluginOptions extends ConfigLoaderOptions {\n rehypeShikiOptions?: Partial<RehypeShikiOptions>\n}\n\n/**\n * Used to retrieve all the rehype plugins required for QUI Docs MDX.\n * These should be passed to the `mdx` vite plugin from\n */\nexport function getRehypePlugins(\n options: QuiRehypePluginOptions = {},\n): PluggableList {\n const config = new ConfigLoader(options).loadConfig()\n return [\n rehypeMdxCodeProps,\n [\n rehypeSlug,\n {allowedHeadings: config.headings} satisfies RehypeSlugOptions,\n ],\n rehypeSectionize,\n [\n rehypeShiki,\n {\n defaultColor: \"light-dark()\",\n themes: {\n dark: quiCustomDarkTheme,\n light: \"github-light-high-contrast\",\n },\n ...options.rehypeShikiOptions,\n } satisfies RehypeShikiOptions,\n ],\n ]\n}\n\n/**\n * @deprecated migrate to the {@link getRemarkPlugins} function\n */\nexport const quiRemarkPlugins: PluggableList = [remarkAlerts, remarkCodeTabs]\n\n/**\n * @returns every remark plugin needed for QUI Docs MDX.\n *\n * @example\n * ```ts\n * // in your vite config\n * plugins: [\n * mdx({\n * providerImportSource: \"@mdx-js/react\",\n * rehypePlugins: [...getRehypePlugins()],\n * remarkPlugins: [...getRemarkPlugins()],\n * }),\n * quiDocsPlugin(),\n * // ... the rest of your plugins\n * ]\n * ```\n */\nexport function getRemarkPlugins(): PluggableList {\n return [\n remarkFrontmatter,\n remarkMdxFrontmatter,\n remarkGfm,\n remarkAlerts,\n remarkCodeTabs,\n remarkSpoilers,\n ]\n}\n", "// Copyright (c) Qualcomm Technologies, Inc. and/or its subsidiaries.\n// SPDX-License-Identifier: BSD-3-Clause-Clear\n\nimport rehypeMdxCodeProps from \"rehype-mdx-code-props\"\nimport remarkFrontmatter from \"remark-frontmatter\"\nimport remarkGfm from \"remark-gfm\"\nimport remarkMdxFrontmatter from \"remark-mdx-frontmatter\"\n\nimport {rehypeSlug} from \"./docs-plugin/rehype/rehype-slug\"\n\n// Re-export these peerDependencies for more convenient imports.\n// Some of these are not included in the bundled JS, so the user must install them\n// separately.\nexport {\n remarkFrontmatter,\n remarkGfm,\n remarkMdxFrontmatter,\n rehypeMdxCodeProps,\n rehypeSlug,\n}\n", "// Copyright (c) Qualcomm Technologies, Inc. and/or its subsidiaries.\n// SPDX-License-Identifier: BSD-3-Clause-Clear\n\nimport type {Element, Root, RootContent} from \"hast\"\nimport {heading} from \"hast-util-heading\"\nimport {headingRank} from \"hast-util-heading-rank\"\nimport type {Properties} from \"hastscript\"\nimport type {Plugin} from \"unified\"\n\nexport type RehypeSectionizeOptions = {\n enableRootSection?: boolean | undefined\n idPropertyName?: string | undefined\n properties?: Properties | undefined\n rankPropertyName?: string | undefined\n}\n\nconst defaultOptions: Required<RehypeSectionizeOptions> = {\n enableRootSection: false,\n idPropertyName: \"ariaLabelledby\",\n properties: {},\n rankPropertyName: \"dataHeadingRank\",\n}\n\nconst wrappingRank = (\n rootContent: RootContent | undefined,\n rankPropertyName: RehypeSectionizeOptions[\"rankPropertyName\"],\n) => {\n if (\n rootContent == null ||\n rankPropertyName == null ||\n !(\"properties\" in rootContent)\n ) {\n throw new Error(\"rootContent and rankPropertyName must have value\")\n }\n\n const rank = rootContent.properties?.[rankPropertyName]\n if (typeof rank !== \"number\") {\n throw new Error(`rankPropertyName(${rankPropertyName}) must be number`)\n }\n\n return rank\n}\n\nconst createElement = (\n rank: number,\n options: Pick<\n RehypeSectionizeOptions,\n \"properties\" | \"rankPropertyName\" | \"idPropertyName\"\n >,\n children: Element[] = [],\n) => {\n const {idPropertyName, properties, rankPropertyName} = options\n\n if (\n properties != null &&\n rankPropertyName != null &&\n rankPropertyName in properties\n ) {\n throw new Error(\n `rankPropertyName(${rankPropertyName}) dataHeadingRank must exist`,\n )\n }\n\n const id = children.at(0)?.properties?.id\n const element: Element = {\n children,\n properties: {\n className: [\"heading\"],\n ...(rankPropertyName ? {[rankPropertyName]: rank} : {}),\n ...(idPropertyName && typeof id === \"string\"\n ? {[idPropertyName]: id}\n : {}),\n ...(properties ? properties : {}),\n },\n tagName: \"section\",\n type: \"element\",\n }\n\n return element\n}\n\nexport const rehypeSectionize: Plugin<[RehypeSectionizeOptions?], Root> = (\n options = defaultOptions,\n) => {\n const {enableRootSection, ...rest} = {\n enableRootSection:\n options.enableRootSection ?? defaultOptions.enableRootSection,\n idPropertyName: options.idPropertyName ?? defaultOptions.idPropertyName,\n properties: options.properties ?? defaultOptions.properties,\n rankPropertyName:\n options.rankPropertyName ?? defaultOptions.rankPropertyName,\n }\n\n return (root) => {\n const rootWrapper = createElement(0, rest)\n\n const wrapperStack: RootContent[] = []\n wrapperStack.push(rootWrapper)\n\n const lastStackItem = () => {\n const last = wrapperStack.at(-1)\n if (last == null || last.type !== \"element\") {\n throw new Error(\"lastStackItem must be Element\")\n }\n return wrapperStack.at(-1) as Element\n }\n\n for (const rootContent of root.children) {\n if (heading(rootContent)) {\n const rank = headingRank(rootContent)\n if (rank == null) {\n throw new Error(\"heading or headingRank is not working\")\n }\n\n if (rank > wrappingRank(lastStackItem(), rest.rankPropertyName)) {\n const childWrapper = createElement(rank, rest, [rootContent])\n lastStackItem().children.push(childWrapper)\n wrapperStack.push(childWrapper)\n } else if (\n rank <= wrappingRank(lastStackItem(), rest.rankPropertyName)\n ) {\n while (rank <= wrappingRank(lastStackItem(), rest.rankPropertyName)) {\n wrapperStack.pop()\n }\n const siblingWrapper = createElement(rank, rest, [rootContent])\n\n lastStackItem().children.push(siblingWrapper)\n wrapperStack.push(siblingWrapper)\n }\n } else {\n if (rootContent.type === \"doctype\") {\n throw new Error(\"must be used in a fragment\")\n }\n lastStackItem().children.push(rootContent as any)\n }\n }\n\n return {\n ...root,\n children: enableRootSection ? [rootWrapper] : rootWrapper.children,\n }\n }\n}\n", "// Copyright (c) Qualcomm Technologies, Inc. and/or its subsidiaries.\n// SPDX-License-Identifier: BSD-3-Clause-Clear\n\nimport type {Code, Parent, Root} from \"mdast\"\nimport type {Plugin} from \"unified\"\nimport {visit} from \"unist-util-visit\"\n\ninterface Tab {\n index: number\n label: string\n meta: string | undefined\n tabsGroup: string\n}\n\nfunction parseTabAttributes(meta: string): {\n label: string | null\n remainingMeta: string\n tabsGroup: string | null\n} {\n if (!meta) {\n return {label: null, remainingMeta: \"\", tabsGroup: null}\n }\n\n const tabsMatch = meta.match(/tabs=[\"']([^\"']+)[\"']|tabs=(\\S+)/)\n const labelMatch = meta.match(/label=[\"']([^\"']+)[\"']|label=(\\S+)/)\n\n const tabsGroup = tabsMatch ? tabsMatch[1] || tabsMatch[2] : null\n const label = labelMatch ? labelMatch[1] || labelMatch[2] : null\n\n // Remove both tabs and label attributes from meta\n const remainingMeta = meta\n .replace(/\\s*tabs=[\"']([^\"']+)[\"']/g, \"\")\n .replace(/\\s*tabs=(\\S+)/g, \"\")\n .replace(/\\s*label=[\"']([^\"']+)[\"']/g, \"\")\n .replace(/\\s*label=(\\S+)/g, \"\")\n .trim()\n\n return {label, remainingMeta, tabsGroup}\n}\n\nfunction findConsecutiveTabs(\n startIndex: number,\n parent: Parent,\n targetTabsGroup: string,\n): Tab[] {\n const tabs: Tab[] = []\n let currentIndex = startIndex\n\n while (currentIndex < parent.children.length) {\n const currentNode = parent.children[currentIndex]\n\n if (!currentNode || currentNode.type !== \"code\") {\n break\n }\n\n const codeNode = currentNode\n\n if (!codeNode.meta) {\n break\n }\n\n const {label, remainingMeta, tabsGroup} = parseTabAttributes(codeNode.meta)\n\n // Only include if it matches the target tabs group and has a label\n if (!tabsGroup || !label || tabsGroup !== targetTabsGroup) {\n break\n }\n\n // Clean the original node's meta NOW\n codeNode.meta = remainingMeta || undefined\n\n tabs.push({\n index: currentIndex,\n label,\n meta: remainingMeta || undefined,\n tabsGroup,\n })\n\n if (remainingMeta && remainingMeta.includes(\"end\")) {\n break\n }\n\n currentIndex++\n }\n\n return tabs\n}\n\nfunction renderTabs(tabs: Tab[], parent: Parent): any[] {\n const tabsContainer = {\n attributes: [],\n children: [] as any[],\n name: \"CodeTabs\",\n type: \"mdxJsxFlowElement\",\n }\n\n tabs.forEach((tab) => {\n const codeNode = parent.children[tab.index] as Code\n\n const tabAttributes = [\n {\n name: \"label\",\n type: \"mdxJsxAttribute\",\n value: tab.label,\n },\n ]\n\n // Add meta to JSX element if it exists\n if (tab.meta) {\n tabAttributes.push({\n name: \"meta\",\n type: \"mdxJsxAttribute\",\n value: tab.meta,\n })\n }\n\n const tabElement = {\n attributes: tabAttributes,\n children: [\n {\n lang: codeNode.lang,\n meta: codeNode.meta, // This is now clean\n type: \"code\",\n value: codeNode.value,\n },\n ],\n name: \"CodeTab\",\n type: \"mdxJsxFlowElement\",\n }\n\n tabsContainer.children.push(tabElement)\n })\n\n return [tabsContainer]\n}\n\n/**\n * Very cool. TODO: document this https://docs.qui.qualcomm.com/guide/markdown\n */\nexport const remarkCodeTabs: Plugin<[], Root> = () => {\n return (tree) => {\n const transformations: Array<{\n endIndex: number\n parent: Parent\n replacement: any[]\n startIndex: number\n }> = []\n\n visit(\n tree,\n \"code\",\n (node: Code, index: number | undefined, parent: Parent | undefined) => {\n if (!node.meta || !parent || index === undefined) {\n return\n }\n\n const {label, tabsGroup} = parseTabAttributes(node.meta)\n if (!tabsGroup || !label) {\n return\n }\n\n const alreadyProcessed = transformations.some(\n (t) =>\n t.parent === parent && index >= t.startIndex && index < t.endIndex,\n )\n\n if (alreadyProcessed) {\n return\n }\n\n const tabs = findConsecutiveTabs(index, parent, tabsGroup)\n\n if (tabs.length > 1) {\n const startIndex = tabs[0].index\n const endIndex = tabs[tabs.length - 1].index + 1\n const newChildren = renderTabs(tabs, parent)\n\n transformations.push({\n endIndex,\n parent,\n replacement: newChildren,\n startIndex,\n })\n }\n },\n )\n\n transformations\n .sort((a, b) => b.startIndex - a.startIndex)\n .forEach((transformation) => {\n transformation.parent.children.splice(\n transformation.startIndex,\n transformation.endIndex - transformation.startIndex,\n ...transformation.replacement,\n )\n })\n }\n}\n", "// Copyright (c) Qualcomm Technologies, Inc. and/or its subsidiaries.\n// SPDX-License-Identifier: BSD-3-Clause-Clear\n\nimport type {Heading, Link, Root} from \"mdast\"\nimport {toString} from \"mdast-util-to-string\"\nimport type {Plugin} from \"unified\"\nimport {visit} from \"unist-util-visit\"\n\nexport interface RemarkSelfLinkOptions {\n /**\n * @default [2, 3, 4]\n */\n allowedLevels?: number[]\n prefix?: string\n}\n\nconst emptyOptions: RemarkSelfLinkOptions = {}\n\nexport function remarkSelfLinkHeadings(\n baseUrl: string = \"\",\n options?: RemarkSelfLinkOptions | null,\n): Plugin<[], Root> {\n if (!baseUrl) {\n return () => {}\n }\n return () => {\n const settings = options || emptyOptions\n const prefix = settings.prefix || \"\"\n const allowedLevels = new Set<number>(settings.allowedLevels || [2, 3, 4])\n const seenIds = new Map<string, number>()\n\n function createSlug(text: string): string {\n const cleaned = text\n .replace(/[<>]/g, \"\")\n .replace(/[^\\w\\s-]/g, \"\")\n .trim()\n\n let slug: string\n if (cleaned.includes(\" \")) {\n slug = cleaned\n .toLowerCase()\n .replace(/\\s+/g, \"-\")\n .replace(/^-+|-+$/g, \"\")\n } else if ((cleaned.match(/[A-Z]/g) || []).length >= 2) {\n slug = cleaned\n .replace(/([a-z0-9])([A-Z])/g, \"$1-$2\")\n .replace(/([A-Z]+)([A-Z][a-z])/g, \"$1-$2\")\n .toLowerCase()\n } else {\n slug = cleaned.toLowerCase()\n }\n\n const count = seenIds.get(slug) || 0\n seenIds.set(slug, count + 1)\n return count > 0 ? `${slug}-${count}` : slug\n }\n\n return (tree) => {\n seenIds.clear()\n visit(tree, \"heading\", (node: Heading) => {\n if (allowedLevels.has(node.depth)) {\n const text = toString(node)\n const slug = prefix + createSlug(text)\n\n const linkNode: Link = {\n children: node.children,\n type: \"link\",\n url: `${baseUrl}#${slug}`,\n }\n\n node.children = [linkNode]\n }\n })\n }\n }\n}\n", "// Copyright (c) Qualcomm Technologies, Inc. and/or its subsidiaries.\n// SPDX-License-Identifier: BSD-3-Clause-Clear\n\nimport type {BlockContent, Root} from \"mdast\"\nimport type {Plugin} from \"unified\"\nimport {visit} from \"unist-util-visit\"\n\ninterface SpoilerOptions {\n defaultSummary?: string\n detailsClassName?: string[]\n summaryClassName?: string[]\n}\n\n/**\n * Transforms spoiler blocks into MDX components.\n *\n * @example\n * ```\n * ::: spoiler Title\n *\n * Content\n *\n * :::\n * ```\n *\n * result:\n *\n * ```jsx\n * <SpoilerRoot>\n * <SpoilerTrigger><p>Title</p></SpoilerTrigger>\n * <SpoilerContent>Content</SpoilerContent>\n * </SpoilerRoot>\n * ```\n */\nexport const remarkSpoilers: Plugin<[SpoilerOptions?], Root> = (\n options = {},\n) => {\n const {\n defaultSummary = \"Open spoiler\",\n detailsClassName = [],\n summaryClassName = [],\n } = options\n\n return (tree) => {\n visit(tree, \"paragraph\", (node, index, parent) => {\n if (!parent || index === undefined) {\n return\n }\n\n const firstChild = node.children[0]\n if (firstChild?.type !== \"text\") {\n return\n }\n\n const match = firstChild.value.match(/^:::\\s*spoiler\\s*(.*)$/)\n if (!match) {\n return\n }\n\n const summary = match[1].trim() || defaultSummary\n let endIndex = index + 1\n const contentNodes: BlockContent[] = []\n\n while (endIndex < parent.children.length) {\n const child = parent.children[endIndex]\n\n if (child.type === \"paragraph\") {\n const firstText = child.children[0]\n if (firstText?.type === \"text\" && firstText.value.trim() === \":::\") {\n break\n }\n }\n\n contentNodes.push(child as BlockContent)\n endIndex++\n }\n\n if (endIndex >= parent.children.length) {\n return\n }\n\n const summaryNode: BlockContent = {\n attributes: summaryClassName.length\n ? [\n {\n name: \"className\",\n type: \"mdxJsxAttribute\",\n value: summaryClassName.join(\" \"),\n },\n ]\n : [],\n children: [\n {\n children: [{type: \"text\", value: summary}],\n type: \"paragraph\",\n },\n ],\n name: \"SpoilerSummary\",\n type: \"mdxJsxFlowElement\",\n }\n\n const contentNode: BlockContent = {\n attributes: [],\n children: contentNodes,\n name: \"SpoilerContent\",\n type: \"mdxJsxFlowElement\",\n }\n\n const detailsNode: BlockContent = {\n attributes: detailsClassName.length\n ? [\n {\n name: \"className\",\n type: \"mdxJsxAttribute\",\n value: detailsClassName.join(\" \"),\n },\n ]\n : [],\n children: [summaryNode, contentNode],\n name: \"SpoilerRoot\",\n type: \"mdxJsxFlowElement\",\n }\n\n parent.children.splice(index, endIndex - index + 1, detailsNode)\n })\n }\n}\n", "// Copyright (c) Qualcomm Technologies, Inc. and/or its subsidiaries.\n// SPDX-License-Identifier: BSD-3-Clause-Clear\n\nexport const VIRTUAL_MODULE_IDS = {\n AUTO: \"\\0virtual:qui-demo-scope/auto\",\n CONFIG: \"\\0virtual:qui-demo-scope/config\",\n PAGE_PREFIX: \"\\0virtual:qui-demo-scope/page:\",\n} as const\n\nexport const LOG_PREFIX = \"@qualcomm-ui/mdx-vite/react-demo-plugin:\"\n\nexport const REACT_IMPORTS: string[] = [\n \"useState\",\n \"useEffect\",\n \"useMemo\",\n \"useCallback\",\n \"useRef\",\n \"useContext\",\n \"createContext\",\n \"forwardRef\",\n \"memo\",\n \"lazy\",\n \"Suspense\",\n \"Fragment\",\n] as const\n\nexport const NODE_BUILTINS: string[] = [\n \"fs\",\n \"path\",\n \"url\",\n \"util\",\n \"os\",\n \"crypto\",\n \"events\",\n \"stream\",\n \"buffer\",\n] as const\n", "// Copyright (c) Qualcomm Technologies, Inc. and/or its subsidiaries.\n// SPDX-License-Identifier: BSD-3-Clause-Clear\n\nimport chalk from \"chalk\"\nimport {createHash} from \"node:crypto\"\nimport {existsSync, readFileSync} from \"node:fs\"\nimport {readFile} from \"node:fs/promises\"\nimport {dirname, join, relative, resolve, sep} from \"node:path\"\nimport * as ts from \"typescript\"\n\nimport {pascalCase} from \"@qualcomm-ui/utils/change-case\"\n\nimport {LOG_PREFIX, NODE_BUILTINS, REACT_IMPORTS} from \"./demo-plugin-constants\"\n\ninterface PathAlias {\n pattern: RegExp\n replacement: string\n}\n\nexport interface ImportSpecifier {\n source: string\n specifiers: Array<{\n imported: string\n local: string\n }>\n type: \"thirdParty\"\n}\n\nexport interface RelativeImport {\n resolvedPath: string\n source: string\n specifiers: Array<{\n imported: string\n local: string\n }>\n type: \"relative\"\n}\n\n/**\n * Demo names are created using the PascalCase format of the file name without the\n * extension.\n */\nexport function createDemoName(filePath: string): string {\n const separatorChar = filePath.includes(\"/\") ? \"/\" : \"\\\\\"\n const fileName = filePath.substring(\n filePath.lastIndexOf(separatorChar),\n filePath.lastIndexOf(\".\"),\n )\n if (!fileName) {\n throw new Error(`Failed to create demo name for ${filePath}`)\n }\n return pascalCase(fileName)\n}\n\nexport async function extractFileImports(filePath: string): Promise<{\n relativeImports: RelativeImport[]\n thirdPartyImports: ImportSpecifier[]\n} | null> {\n try {\n const content = await readFile(filePath, \"utf-8\")\n return extractImports(content, filePath)\n } catch (error) {\n console.log(\n `${chalk.magenta.bold(LOG_PREFIX)} ${chalk.yellowBright(\"Failed to parse\")} ${chalk.blueBright.bold(filePath)}:`,\n error,\n )\n return null\n }\n}\n\nfunction mergeImports(\n importMap: Map<string, Set<{imported: string; local: string}>>,\n imports: ImportSpecifier[],\n) {\n for (const {source, specifiers} of imports) {\n if (isNodeBuiltin(source)) {\n continue\n }\n let sourceSpecifiers = importMap.get(source)\n if (!sourceSpecifiers) {\n sourceSpecifiers = new Set()\n importMap.set(source, sourceSpecifiers)\n }\n for (const spec of specifiers) {\n sourceSpecifiers.add(spec)\n }\n }\n}\n\nfunction extractImports(\n code: string,\n fileName: string,\n): {\n relativeImports: RelativeImport[]\n thirdPartyImports: ImportSpecifier[]\n} {\n const sourceFile = ts.createSourceFile(\n fileName,\n code,\n ts.ScriptTarget.Latest,\n true,\n getScriptKind(fileName),\n )\n const thirdPartyImports: ImportSpecifier[] = []\n const relativeImports: RelativeImport[] = []\n\n function visit(node: ts.Node) {\n if (ts.isImportDeclaration(node)) {\n const importSpec = parseImportDeclaration(node, fileName)\n if (importSpec) {\n if (importSpec.type === \"relative\") {\n relativeImports.push(importSpec)\n } else {\n thirdPartyImports.push(importSpec)\n }\n }\n }\n ts.forEachChild(node, visit)\n }\n\n visit(sourceFile)\n return {relativeImports, thirdPartyImports}\n}\n\nexport function getScriptKind(fileName: string): ts.ScriptKind {\n return fileName.endsWith(\".tsx\") || fileName.endsWith(\".jsx\")\n ? ts.ScriptKind.TSX\n : ts.ScriptKind.TS\n}\n\nfunction parseImportDeclaration(\n node: ts.ImportDeclaration,\n fileName: string,\n): ImportSpecifier | RelativeImport | null {\n const moduleSpecifier = node.moduleSpecifier\n if (!ts.isStringLiteral(moduleSpecifier)) {\n return null\n }\n\n const source = moduleSpecifier.text\n if (node.importClause?.isTypeOnly) {\n return null\n }\n\n const specifiers = extractSpecifiers(node.importClause)\n if (specifiers.length === 0) {\n return null\n }\n\n if (isRelativeImport(source)) {\n const resolvedPath = resolveRelativeImport(source, fileName)\n return {\n resolvedPath,\n source,\n specifiers,\n type: \"relative\",\n }\n }\n\n if (isNodeBuiltin(source)) {\n return null\n }\n\n const pathAliases = loadTsConfigPaths(fileName)\n if (isPathAliasImport(source, pathAliases)) {\n const resolvedPath = resolvePathAlias(source, pathAliases)\n if (resolvedPath) {\n return {\n resolvedPath,\n source,\n specifiers,\n type: \"relative\",\n }\n }\n }\n\n return {\n source,\n specifiers,\n type: \"thirdParty\",\n }\n}\n\nfunction extractSpecifiers(\n importClause: ts.ImportClause | undefined,\n): Array<{imported: string; local: string}> {\n if (!importClause) {\n return []\n }\n\n const specifiers: Array<{imported: string; local: string}> = []\n\n if (importClause.name) {\n specifiers.push({imported: \"default\", local: \"default\"})\n }\n\n if (importClause.namedBindings) {\n if (ts.isNamespaceImport(importClause.namedBindings)) {\n specifiers.push({imported: \"*\", local: \"*\"})\n } else if (ts.isNamedImports(importClause.namedBindings)) {\n importClause.namedBindings.elements.forEach((element) => {\n if (!element.isTypeOnly) {\n const imported = element.propertyName\n ? element.propertyName.text\n : element.name.text\n const local = element.name.text\n specifiers.push({imported, local})\n }\n })\n }\n }\n\n return specifiers\n}\n\nfunction resolveRelativeImport(source: string, fromFile: string): string {\n const fromDir = dirname(fromFile)\n const resolved = resolve(fromDir, source)\n\n const extensions = [\".ts\", \".tsx\", \".js\", \".jsx\"]\n for (const ext of extensions) {\n const withExt = resolved + ext\n if (existsSync(withExt)) {\n return withExt\n }\n }\n\n for (const ext of extensions) {\n const indexFile = join(resolved, `index${ext}`)\n if (existsSync(indexFile)) {\n return indexFile\n }\n }\n\n return resolved\n}\n\nexport async function extractAllImports(files: string[]): Promise<{\n importMap: Map<string, Set<{imported: string; local: string}>>\n relativeImports: RelativeImport[]\n}> {\n const importMap = new Map<string, Set<{imported: string; local: string}>>()\n const relativeImports: RelativeImport[] = []\n\n for (const filePath of files) {\n const result = await extractFileImports(filePath)\n if (result) {\n mergeImports(importMap, result.thirdPartyImports)\n relativeImports.push(...result.relativeImports)\n }\n }\n\n return {importMap, relativeImports}\n}\n\nfunction isRelativeImport(source: string): boolean {\n return source.startsWith(\"./\") || source.startsWith(\"../\")\n}\n\nfunction isNodeBuiltin(source: string): boolean {\n return source.startsWith(\"node:\") || NODE_BUILTINS.includes(source)\n}\n\nfunction loadTsConfigPaths(fromFile: string): PathAlias[] {\n let currentDir = dirname(fromFile)\n const pathAliases: PathAlias[] = []\n\n while (currentDir !== dirname(currentDir)) {\n const tsconfigPath = join(currentDir, \"tsconfig.json\")\n if (existsSync(tsconfigPath)) {\n try {\n const configContent = ts.sys.readFile(tsconfigPath)\n if (!configContent) {\n currentDir = dirname(currentDir)\n continue\n }\n\n const parseResult = ts.parseConfigFileTextToJson(\n tsconfigPath,\n configContent,\n )\n if (parseResult.error) {\n currentDir = dirname(currentDir)\n continue\n }\n\n const paths = parseResult.config?.compilerOptions?.paths\n const baseUrl = parseResult.config?.compilerOptions?.baseUrl || \"./\"\n const resolvedBaseUrl = resolve(currentDir, baseUrl)\n\n if (paths) {\n for (const [alias, targets] of Object.entries(paths)) {\n if (Array.isArray(targets) && targets.length > 0) {\n const target = targets[0]\n const pattern = new RegExp(\n `^${alias\n .replace(\"*\", \"(.*)\")\n .replace(/[.*+?^${}()|[\\]\\\\]/g, \"\\\\$&\")\n .replace(\"\\\\(\\\\*\\\\)\", \"(.*)\")}$`,\n )\n const replacement = resolve(\n resolvedBaseUrl,\n target.replace(\"*\", \"$1\"),\n )\n pathAliases.push({pattern, replacement})\n }\n }\n }\n\n const extendsPath = parseResult.config?.extends\n if (extendsPath) {\n const resolvedExtends = resolve(currentDir, extendsPath)\n const extendedAliases = loadTsConfigPathsFromFile(resolvedExtends)\n pathAliases.push(...extendedAliases)\n }\n\n return pathAliases\n } catch (error) {\n currentDir = dirname(currentDir)\n continue\n }\n }\n currentDir = dirname(currentDir)\n }\n\n return pathAliases\n}\n\nfunction loadTsConfigPathsFromFile(tsconfigPath: string): PathAlias[] {\n const pathAliases: PathAlias[] = []\n const configDir = dirname(tsconfigPath)\n\n try {\n const configContent = ts.sys.readFile(tsconfigPath)\n if (!configContent) {\n return pathAliases\n }\n\n const parseResult = ts.parseConfigFileTextToJson(\n tsconfigPath,\n configContent,\n )\n if (parseResult.error) {\n return pathAliases\n }\n\n const paths = parseResult.config?.compilerOptions?.paths\n const baseUrl = parseResult.config?.compilerOptions?.baseUrl || \"./\"\n const resolvedBaseUrl = resolve(configDir, baseUrl)\n\n if (paths) {\n for (const [alias, targets] of Object.entries(paths)) {\n if (Array.isArray(targets) && targets.length > 0) {\n const target = targets[0]\n const pattern = new RegExp(\n `^${alias\n .replace(\"*\", \"(.*)\")\n .replace(/[.*+?^${}()|[\\]\\\\]/g, \"\\\\$&\")\n .replace(\"\\\\(\\\\*\\\\)\", \"(.*)\")}$`,\n )\n const replacement = resolve(\n resolvedBaseUrl,\n target.replace(\"*\", \"$1\"),\n )\n pathAliases.push({pattern, replacement})\n }\n }\n }\n\n const extendsPath = parseResult.config?.extends\n if (extendsPath) {\n let resolvedExtends = resolve(configDir, extendsPath)\n if (!resolvedExtends.endsWith(\".json\")) {\n resolvedExtends += \".json\"\n }\n if (existsSync(resolvedExtends)) {\n const extendedAliases = loadTsConfigPathsFromFile(resolvedExtends)\n pathAliases.push(...extendedAliases)\n }\n }\n } catch (error) {\n return pathAliases\n }\n\n return pathAliases\n}\n\nfunction isPathAliasImport(source: string, pathAliases: PathAlias[]): boolean {\n return pathAliases.some((alias) => alias.pattern.test(source))\n}\n\nfunction resolvePathAlias(\n source: string,\n pathAliases: PathAlias[],\n): string | null {\n for (const alias of pathAliases) {\n if (alias.pattern.test(source)) {\n const resolvedPath = source.replace(alias.pattern, alias.replacement)\n const extensions = [\".ts\", \".tsx\", \".js\", \".jsx\"]\n\n for (const ext of extensions) {\n const withExt = resolvedPath + ext\n if (existsSync(withExt)) {\n return withExt\n }\n }\n\n for (const ext of extensions) {\n const indexFile = join(resolvedPath, `index${ext}`)\n if (existsSync(indexFile)) {\n return indexFile\n }\n }\n\n return resolvedPath\n }\n }\n return null\n}\n\nexport function sanitizeSourceName(source: string): string {\n return source\n .replace(/@/g, \"at_\")\n .replace(/\\//g, \"_\")\n .replace(/[^a-zA-Z0-9_]/g, \"_\")\n .replace(/_+/g, \"_\")\n .replace(/^_|_$/g, \"\")\n}\n\nexport function sanitizeIdentifier(str: string): string {\n return str.replace(/[^a-zA-Z0-9]/g, \"_\")\n}\n\nexport function createUniqueModuleName(source: string): string {\n const hash = createHash(\"sha256\").update(source).digest(\"hex\").substring(0, 8)\n const baseName =\n source\n .split(\"/\")\n .pop()\n ?.replace(/[^a-zA-Z0-9]/g, \"_\")\n ?.replace(/^_+|_+$/g, \"\")\n ?.replace(/^(\\d)/, \"_$1\") || \"module\"\n\n return `mod_${baseName}_${hash}`\n}\n\nexport function addReactImports(imports: string[], scopeEntries: string[]) {\n imports.push(`import React from \"react\"`)\n imports.push(`import {\n ${REACT_IMPORTS.join(\", \")}\n } from \"react\"`)\n scopeEntries.push(\"React\", ...REACT_IMPORTS)\n}\n\nexport function addThirdPartyImports(\n importMap: Map<string, Set<{imported: string; local: string}>>,\n imports: string[],\n scopeEntries: string[],\n) {\n const sortedImports = Array.from(importMap.entries()).sort(([a], [b]) =>\n a.localeCompare(b),\n )\n const usedNames = new Set([\"React\", ...REACT_IMPORTS])\n\n for (const [source, specifiers] of sortedImports) {\n const moduleName = createUniqueModuleName(source)\n imports.push(`import * as ${moduleName} from \"${source}\"`)\n addModuleToScope(source, specifiers, moduleName, scopeEntries, usedNames)\n }\n}\n\nexport function addThirdPartyImportsNamespaced(\n importMap: Map<string, Set<{imported: string; local: string}>>,\n imports: string[],\n scopeEntries: string[],\n demoName: string,\n) {\n const sortedImports = Array.from(importMap.entries()).sort(([a], [b]) =>\n a.localeCompare(b),\n )\n const usedNames = new Set([\"React\", ...REACT_IMPORTS])\n\n for (const [source, specifiers] of sortedImports) {\n const moduleName = `${sanitizeIdentifier(demoName)}_${createUniqueModuleName(source)}`\n imports.push(`import * as ${moduleName} from \"${source}\"`)\n addModuleToScope(source, specifiers, moduleName, scopeEntries, usedNames)\n }\n}\n\nexport function addRelativeImportsNamespaced(\n relativeImports: RelativeImport[],\n imports: string[],\n scopeEntries: string[],\n demoName: string,\n) {\n const processedPaths = new Set<string>()\n\n for (const {resolvedPath, specifiers} of relativeImports) {\n if (processedPaths.has(resolvedPath)) {\n continue\n }\n processedPaths.add(resolvedPath)\n\n const moduleName = `${sanitizeIdentifier(demoName)}_${createUniqueModuleName(resolvedPath)}`\n imports.push(`import * as ${moduleName} from \"${resolvedPath}\"`)\n\n for (const {imported, local} of specifiers) {\n if (imported === \"default\") {\n scopeEntries.push(`${local}: ${moduleName}.default`)\n } else if (imported === \"*\") {\n scopeEntries.push(`...${moduleName}`)\n } else {\n scopeEntries.push(`${local}: ${moduleName}.${imported}`)\n }\n }\n }\n}\n\nfunction addModuleToScope(\n source: string,\n specifiers: Set<{imported: string; local: string}>,\n moduleName: string,\n scopeEntries: string[],\n usedNames: Set<string>,\n) {\n const specArray = Array.from(specifiers)\n const hasDefault = specArray.some((spec) => spec.imported === \"default\")\n const hasNamespace = specArray.some((spec) => spec.imported === \"*\")\n const namedImports = specArray.filter(\n (spec) => spec.imported !== \"default\" && spec.imported !== \"*\",\n )\n\n if (hasNamespace) {\n scopeEntries.push(`...${moduleName}`)\n return\n }\n\n const sanitizedSource = sanitizeSourceName(source)\n if (hasDefault) {\n scopeEntries.push(`\"${sanitizedSource}__default\": ${moduleName}.default`)\n }\n\n for (const {imported, local} of namedImports) {\n const sanitizedKey = `${sanitizedSource}__${imported}`\n scopeEntries.push(`\"${sanitizedKey}\": ${moduleName}.${imported}`)\n if (!usedNames.has(local)) {\n scopeEntries.push(`${local}: ${moduleName}.${imported}`)\n usedNames.add(local)\n }\n }\n}\n\nexport function extractPageId(filePath: string, routesDir: string): string {\n const relativePath = relative(routesDir, filePath)\n const pathParts = relativePath.split(sep)\n if (pathParts.includes(\"demos\")) {\n const demosIndex = pathParts.indexOf(\"demos\")\n return pathParts.slice(0, demosIndex).join(sep)\n }\n return dirname(relativePath)\n}\n\nexport function isCssAsset(filePath: string) {\n return filePath.endsWith(\".css\")\n}\n\nexport function isDemoFile(filePath: string): boolean {\n try {\n return (\n filePath.includes(\"/demos/\") &&\n filePath.endsWith(\".tsx\") &&\n // could also be in a comment, probably need to use TS parser\n readFileSync(filePath, \"utf-8\").includes(\"export default\")\n )\n } catch (error) {\n return false\n }\n}\n\nexport function createEmptyScopeModule(): string {\n return \"export const createDemoScope = () => ({})\"\n}\n", "// Copyright (c) Qualcomm Technologies, Inc. and/or its subsidiaries.\n// SPDX-License-Identifier: BSD-3-Clause-Clear\n\nimport {transformerRenderIndentGuides} from \"@shikijs/transformers\"\nimport chalk from \"chalk\"\nimport {type FSWatcher, watch} from \"chokidar\"\nimport {glob} from \"glob\"\nimport {readFile} from \"node:fs/promises\"\nimport {basename, resolve} from \"node:path\"\nimport {createHighlighter, type Highlighter} from \"shiki\"\nimport * as ts from \"typescript\"\nimport type {Plugin} from \"vite\"\n\nimport {quiCustomDarkTheme, type ReactDemoData} from \"@qualcomm-ui/mdx-common\"\nimport {dedent} from \"@qualcomm-ui/utils/dedent\"\nimport {debounce} from \"@qualcomm-ui/utils/functions\"\n\nimport {LOG_PREFIX, VIRTUAL_MODULE_IDS} from \"./demo-plugin-constants\"\nimport type {QuiDemoPluginOptions} from \"./demo-plugin-types\"\nimport {\n addReactImports,\n createDemoName,\n createEmptyScopeModule,\n createUniqueModuleName,\n extractAllImports,\n extractFileImports,\n extractPageId,\n getScriptKind,\n isCssAsset,\n isDemoFile,\n type RelativeImport,\n sanitizeIdentifier,\n} from \"./demo-plugin-utils\"\n\nconst isDev = process.env.NODE_ENV === \"development\"\n\nlet highlighter: Highlighter | null = null\nlet initCount = 0\n\ninterface HmrState {\n windowScrollY: number\n}\n\nconst hmrState: HmrState = {\n windowScrollY: 0,\n}\nconst demoRegistry = new Map<string, ReactDemoData>()\nconst pageScopes = new Map<string, string>()\nconst pageFiles = new Map<string, string[]>()\nconst relativeImportDependents = new Map<string, Set<string>>()\n\nlet hasWatcherInitialized = false\n\n/**\n * Logs in dev mode only after the watcher has been initialized. Vite runs setup\n * hooks multiple times (once for each environment), so we use this approach to\n * ensure that certain messages are only logged once.\n */\nfunction logDev(...args: any[]) {\n if (!hasWatcherInitialized) {\n return\n }\n console.log(...args)\n}\n\nexport function reactDemoPlugin({\n demoPattern = \"src/routes/**/demos/*.tsx\",\n lazyLoadDevModules = true,\n routesDir = \"src/routes\",\n theme = {\n dark: quiCustomDarkTheme,\n light: \"github-light-high-contrast\",\n },\n transformers = [],\n transformLine,\n}: QuiDemoPluginOptions = {}): Plugin {\n let watcher: FSWatcher | null = null\n\n return {\n async buildEnd() {\n if (watcher) {\n await watcher.close()\n watcher = null\n hasWatcherInitialized = false\n }\n },\n\n async buildStart() {\n if (initCount === 0) {\n initCount++\n return\n }\n\n if (!highlighter) {\n try {\n highlighter = await createHighlighter({\n langs: [\"tsx\", \"typescript\"],\n themes: [theme.dark, theme.light],\n })\n console.log(\n `${chalk.magenta.bold(LOG_PREFIX)} Shiki highlighter initialized`,\n )\n } catch (error) {\n console.warn(\n `${chalk.magenta.bold(LOG_PREFIX)} Failed to initialize highlighter:`,\n error,\n )\n }\n }\n\n try {\n await collectReactDemos()\n if (isDev && !hasWatcherInitialized) {\n hasWatcherInitialized = true\n await setupFileWatcher()\n } else if (isDev) {\n logDev(\n `${chalk.magenta.bold(LOG_PREFIX)} skipping watch: watcher already initialized by another instance`,\n )\n }\n } catch (error) {\n if (watcher) {\n await watcher.close()\n watcher = null\n hasWatcherInitialized = false\n }\n throw error\n }\n },\n\n configureServer(server) {\n const debouncedRestore = debounce((data: {scrollY: number}) => {\n hmrState.windowScrollY = data.scrollY\n }, 100)\n server.ws.on(\"custom:store-scroll-position\", debouncedRestore)\n\n server.ws.on(\"custom:request-scroll-position\", () => {\n server.ws.send({\n data: hmrState.windowScrollY,\n event: \"custom:restore-scroll-position\",\n type: \"custom\",\n })\n })\n },\n\n async handleHotUpdate({file, server}) {\n if (isCssAsset(file)) {\n return server.moduleGraph.getModulesByFile(file)?.values()?.toArray()\n }\n\n if (!lazyLoadDevModules) {\n let shouldUpdate = false\n if (isDemoFile(file)) {\n await handleFileAdditionOrUpdate(file, false)\n shouldUpdate = true\n }\n const normalizedFile = resolve(file)\n const dependents = relativeImportDependents.get(normalizedFile)\n if (dependents) {\n shouldUpdate = true\n }\n\n if (shouldUpdate) {\n const autoModule = server.moduleGraph.getModuleById(\n VIRTUAL_MODULE_IDS.AUTO,\n )\n if (autoModule) {\n server.moduleGraph.invalidateModule(autoModule)\n await server.reloadModule(autoModule)\n }\n return []\n }\n }\n\n if (isDemoFile(file)) {\n logDev(\n `${chalk.magenta.bold(LOG_PREFIX)} Processing change: ${chalk.blueBright.bold(file)}`,\n )\n\n const pageId = extractPageId(file, routesDir)\n const demoName = createDemoName(file)\n const wasNew = !demoRegistry.has(demoName)\n await handleFileAdditionOrUpdate(file, false)\n\n const pageModule = server.moduleGraph.getModuleById(\n `${VIRTUAL_MODULE_IDS.PAGE_PREFIX}${pageId}`,\n )\n if (pageModule) {\n console.debug(\n \"invalidating:\",\n `virtual:qui-demo-scope/page:${pageId}`,\n )\n server.moduleGraph.invalidateModule(pageModule)\n await server.reloadModule(pageModule)\n // server.ws.send({type: \"full-reload\"})\n }\n if (wasNew) {\n const autoModule = server.moduleGraph.getModuleById(\n VIRTUAL_MODULE_IDS.AUTO,\n )\n if (autoModule) {\n server.moduleGraph.invalidateModule(autoModule)\n await server.reloadModule(autoModule)\n }\n }\n\n server.ws.send({\n data: demoRegistry.get(createDemoName(file)),\n event: \"qui-demo-update\",\n type: \"custom\",\n })\n } else {\n const normalizedFile = resolve(file)\n const dependents = relativeImportDependents.get(normalizedFile)\n if (dependents) {\n for (const demoName of dependents) {\n server.ws.send({\n data: {demoName},\n event: \"react-demo-updating\",\n type: \"custom\",\n })\n }\n }\n }\n\n return []\n },\n\n async load(id) {\n if (id === VIRTUAL_MODULE_IDS.AUTO) {\n return generateAutoScopeModule()\n }\n if (id.startsWith(VIRTUAL_MODULE_IDS.PAGE_PREFIX)) {\n const pageId = id.replace(VIRTUAL_MODULE_IDS.PAGE_PREFIX, \"\")\n return pageScopes.get(pageId) || createEmptyScopeModule()\n }\n if (id === VIRTUAL_MODULE_IDS.CONFIG) {\n return generateConfigModule()\n }\n },\n\n name: \"auto-demo-scope\",\n\n resolveId(id) {\n if (id === \"virtual:qui-demo-scope/auto\") {\n return VIRTUAL_MODULE_IDS.AUTO\n }\n if (id.startsWith(\"virtual:qui-demo-scope/page:\")) {\n return `\\0${id}`\n }\n if (id === \"virtual:qui-demo-scope/config\") {\n return VIRTUAL_MODULE_IDS.CONFIG\n }\n },\n\n writeBundle() {\n console.log(\n `${chalk.blue.bold(LOG_PREFIX)} Successfully integrated ${chalk.green(demoRegistry.size)} component demos`,\n )\n },\n }\n\n async function setupFileWatcher() {\n watcher = watch(routesDir, {\n ignoreInitial: true,\n persistent: true,\n })\n\n watcher.on(\"ready\", () => {\n logDev(\n `${chalk.blue.bold(LOG_PREFIX)} Registered ${chalk.green(demoRegistry.size)} demo files. Watching for file changes...`,\n )\n })\n\n watcher.on(\"addDir\", (dirPath: string) => {\n if (dirPath.endsWith(\"/demos\")) {\n logDev(\n `${chalk.magenta.bold(LOG_PREFIX)} ${chalk.greenBright(\"New demo directory detected:\")} ${chalk.blueBright.bold(dirPath)}`,\n )\n }\n })\n\n watcher.on(\"unlink\", async (filePath: string) => {\n if (isDemoFile(filePath)) {\n logDev(\n `${chalk.magenta.bold(LOG_PREFIX)} ${chalk.redBright(\"Demo file deleted:\")} ${chalk.blueBright.bold(filePath)}`,\n )\n await handleFileDeletion(filePath)\n }\n })\n\n watcher.on(\"add\", async (filePath: string) => {\n if (isDemoFile(filePath)) {\n logDev(\n `${chalk.magenta.bold(LOG_PREFIX)} ${chalk.greenBright(\"Demo file added:\")} ${chalk.blueBright.bold(filePath)}`,\n )\n await handleFileAdditionOrUpdate(filePath, true).catch(() => {\n console.debug(\"failed to add file\", filePath)\n })\n }\n })\n }\n\n /**\n * True if the scope changed\n */\n async function handleFileAdditionOrUpdate(\n filePath: string,\n isAdd?: boolean,\n ): Promise<boolean> {\n const pageId = extractPageId(filePath, routesDir)\n const demoName = createDemoName(filePath)\n\n const existingFiles = pageFiles.get(pageId) ?? []\n if (!existingFiles.includes(filePath)) {\n existingFiles.push(filePath)\n pageFiles.set(pageId, existingFiles)\n }\n\n const fileData = await extractFileData(filePath)\n if (fileData) {\n demoRegistry.set(demoName, {\n ...fileData,\n demoName,\n pageId,\n })\n\n const fileImports = await extractFileImports(filePath)\n if (fileImports) {\n for (const relativeImport of fileImports.relativeImports) {\n const dependents =\n relativeImportDependents.get(relativeImport.resolvedPath) ??\n new Set()\n dependents.add(demoName)\n relativeImportDependents.set(relativeImport.resolvedPath, dependents)\n }\n }\n }\n\n const previousScope = pageScopes.get(pageId)\n const allPageFiles = pageFiles.get(pageId)!\n const scope = await generateScopeForPage(pageId, allPageFiles)\n pageScopes.set(pageId, scope)\n\n logDev(\n `${chalk.magenta.bold(LOG_PREFIX)} ${chalk.greenBright(isAdd ? \"Added demo:\" : \"Updated demo:\")} ${chalk.greenBright.bold(demoName)}`,\n )\n\n return previousScope !== scope\n }\n\n async function handleFileDeletion(deletedFile: string) {\n const demoName = createDemoName(deletedFile)\n const pageId = extractPageId(deletedFile, routesDir)\n\n demoRegistry.delete(demoName)\n\n for (const [importPath, dependents] of relativeImportDependents.entries()) {\n dependents.delete(demoName)\n if (dependents.size === 0) {\n relativeImportDependents.delete(importPath)\n }\n }\n\n const files = pageFiles.get(pageId)\n if (files) {\n const updatedFiles = files.filter((f) => f !== deletedFile)\n if (updatedFiles.length === 0) {\n pageFiles.delete(pageId)\n pageScopes.delete(pageId)\n logDev(\n `${chalk.magenta.bold(LOG_PREFIX)} ${chalk.redBright(\"Removed empty page:\")} ${chalk.blueBright.bold(pageId)}`,\n )\n } else {\n pageFiles.set(pageId, updatedFiles)\n const scope = await generateScopeForPage(pageId, updatedFiles)\n pageScopes.set(pageId, scope)\n }\n }\n\n logDev(\n `${chalk.magenta.bold(LOG_PREFIX)} ${chalk.redBright(\"Cleaned up deleted file:\")} ${chalk.blueBright.bold(deletedFile)}`,\n )\n }\n\n function isPreviewLine(trimmedLine: string): boolean {\n return (\n trimmedLine === \"// preview\" ||\n /^\\{\\s*\\/\\*\\s*preview\\s*\\*\\/\\s*\\}$/.test(trimmedLine)\n )\n }\n\n function extractPreviewsAndCleanSource(code: string): {\n formattedPreview: string\n sourceWithoutSnippetComments: string\n } {\n const lines = code.split(\"\\n\")\n const previewBlocks: string[] = []\n const cleanedLines: string[] = []\n let inPreview = false\n let currentBlock: string[] = []\n\n for (const line of lines) {\n const trimmedLine = line.trim()\n\n if (isPreviewLine(trimmedLine)) {\n if (inPreview) {\n previewBlocks.push(currentBlock.join(\"\\n\"))\n currentBlock = []\n inPreview = false\n } else {\n inPreview = true\n }\n continue\n }\n\n cleanedLines.push(line)\n if (inPreview) {\n currentBlock.push(line)\n }\n }\n\n const joined = previewBlocks.join(\"\\n\")\n const split = joined.split(\"\\n\")\n if (!split.at(-1)?.trim()) {\n split.pop()\n }\n\n return {\n formattedPreview: dedent(split.join(\"\\n\")).trim(),\n sourceWithoutSnippetComments: cleanedLines.join(\"\\n\"),\n }\n }\n\n async function highlightCode(code: string): Promise<string> {\n if (!highlighter) {\n return code\n }\n try {\n return highlighter.codeToHtml(code, {\n defaultColor: \"light-dark()\",\n lang: \"tsx\",\n themes: {\n dark: theme.dark,\n light: theme.light,\n },\n transformers: [transformerRenderIndentGuides(), ...transformers],\n })\n } catch (error) {\n console.warn(\n `${chalk.magenta.bold(LOG_PREFIX)} Failed to highlight code:`,\n error,\n )\n return code\n }\n }\n\n async function collectReactDemos() {\n if (demoRegistry.size && pageScopes.size && pageFiles.size) {\n logDev(\n `${chalk.magenta.bold(LOG_PREFIX)} Using cached ${chalk.cyanBright.bold(demoRegistry.size)} demos`,\n )\n return\n }\n\n const demoFiles = (await glob(demoPattern)).filter(isDemoFile)\n\n for (const filePath of demoFiles) {\n const pageId = extractPageId(filePath, routesDir)\n const existingFiles = pageFiles.get(pageId) ?? []\n existingFiles.push(filePath)\n pageFiles.set(pageId, existingFiles)\n\n const fileData = await extractFileData(filePath)\n if (fileData) {\n const demoName = createDemoName(filePath)\n demoRegistry.set(demoName, {\n ...fileData,\n pageId,\n })\n }\n\n const fileImports = await extractFileImports(filePath)\n if (fileImports) {\n for (const relativeImport of fileImports.relativeImports) {\n const demoName = createDemoName(filePath)\n const dependents =\n relativeImportDependents.get(relativeImport.resolvedPath) ??\n new Set()\n dependents.add(demoName)\n relativeImportDependents.set(relativeImport.resolvedPath, dependents)\n }\n }\n }\n\n // Generate one scope module per page\n for (const [pageId, files] of pageFiles.entries()) {\n const scope = await generateScopeForPage(pageId, files)\n pageScopes.set(pageId, scope)\n }\n }\n\n async function generateScopeForPage(\n pageId: string,\n files: string[],\n ): Promise<string> {\n const demosData = []\n\n // Collect all imports from all demos\n const allThirdPartyImports = new Map<\n string,\n Set<{imported: string; local: string}>\n >()\n const allRelativeImports: RelativeImport[] = []\n const demoImportData = new Map<\n string,\n {\n relative: Array<{\n resolvedPath: string\n specifiers: Array<{imported: string; local: string}>\n }>\n thirdParty: Array<{\n source: string\n specifiers: Array<{imported: string; local: string}>\n }>\n }\n >()\n\n for (const file of files) {\n const demoName = createDemoName(file)\n const demo = demoRegistry.get(demoName)\n if (!demo) {\n continue\n }\n\n demosData.push({\n demoName,\n fileName: demo.fileName,\n imports: demo.imports,\n pageId: demo.pageId,\n sourceCode: demo.sourceCode,\n })\n\n const {importMap, relativeImports} = await extractAllImports([file])\n\n demoImportData.set(demoName, {\n relative: relativeImports.map((r) => ({\n resolvedPath: r.resolvedPath,\n specifiers: r.specifiers,\n })),\n thirdParty: Array.from(importMap.entries()).map(([source, specs]) => ({\n source,\n specifiers: Array.from(specs),\n })),\n })\n\n for (const [source, specifiers] of importMap) {\n if (!allThirdPartyImports.has(source)) {\n allThirdPartyImports.set(source, new Set())\n }\n for (const spec of specifiers) {\n allThirdPartyImports.get(source)!.add(spec)\n }\n }\n for (const relImport of relativeImports) {\n if (\n !allRelativeImports.some(\n (r) => r.resolvedPath === relImport.resolvedPath,\n )\n ) {\n allRelativeImports.push(relImport)\n }\n }\n }\n\n const pageImports: string[] = []\n const reactScopeEntries: string[] = []\n addReactImports(pageImports, reactScopeEntries)\n\n const moduleNames = new Map<string, string>()\n const moduleRegistryEntries: string[] = []\n\n for (const [source] of Array.from(allThirdPartyImports.entries()).sort(\n ([a], [b]) => a.localeCompare(b),\n )) {\n const moduleName = createUniqueModuleName(source)\n moduleNames.set(source, moduleName)\n pageImports.push(`import * as ${moduleName} from \"${source}\"`)\n moduleRegistryEntries.push(` \"${source}\": ${moduleName}`)\n }\n\n for (const {resolvedPath} of allRelativeImports) {\n const moduleName = createUniqueModuleName(resolvedPath)\n moduleNames.set(resolvedPath, moduleName)\n pageImports.push(`import * as ${moduleName} from \"${resolvedPath}\"`)\n moduleRegistryEntries.push(` \"${resolvedPath}\": ${moduleName}`)\n }\n\n const demosJson = JSON.stringify(demosData)\n const demoImportDataJson = JSON.stringify(\n Array.from(demoImportData.entries()),\n )\n const reactScopeEntriesCode = reactScopeEntries\n .map((e) => ` ${e}`)\n .join(\",\\n\")\n\n return `// Auto-generated page scope for ${pageId}\n${pageImports.join(\"\\n\")}\n\nconst modules = {\n${moduleRegistryEntries.join(\",\\n\")}\n}\n\nconst demosData = ${demosJson}\nconst demoImportData = new Map(${demoImportDataJson})\n\nconst reactScope = {\n${reactScopeEntriesCode}\n}\n\nconst scopeCache = new Map()\n\nfunction createScope(demoName) {\n if (scopeCache.has(demoName)) {\n return scopeCache.get(demoName)\n }\n \n const imports = demoImportData.get(demoName)\n if (!imports) return {}\n \n const scope = {...reactScope}\n \n for (const {source, specifiers} of imports.thirdParty) {\n const mod = modules[source]\n if (!mod) continue\n \n for (const {imported, local} of specifiers) {\n if (imported === 'default') {\n scope[local] = mod.default\n } else if (imported === '*') {\n Object.assign(scope, mod)\n } else {\n scope[local] = mod[imported]\n }\n }\n }\n \n for (const {resolvedPath, specifiers} of imports.relative) {\n const mod = modules[resolvedPath]\n if (!mod) continue\n \n for (const {imported, local} of specifiers) {\n if (imported === 'default') {\n scope[local] = mod.default\n } else if (imported === '*') {\n Object.assign(scope, mod)\n } else {\n scope[local] = mod[imported]\n }\n }\n }\n \n scopeCache.set(demoName, scope)\n return scope\n}\n\nexport function getDemo(demoName) {\n const demo = demosData.find(d => d.demoName === demoName)\n if (!demo) return null\n return {\n ...demo,\n scope: createScope(demoName)\n }\n}\n\nexport function getDemos() {\n return demosData.map(demo => ({\n ...demo,\n scope: createScope(demo.demoName)\n }))\n}\n`\n }\n\n async function generateAutoScopeModule(): Promise<string> {\n if (isDev && lazyLoadDevModules) {\n return [\n \"// Auto-generated demo scope resolver (DEV MODE - Lazy by Page)\",\n generateLazyPageLoaders(),\n generateDemoToPageMap(),\n generateDevGetDemo(),\n ].join(\"\\n\\n\")\n }\n\n const registryCode = generateDemoRegistry(demoRegistry)\n return [\n \"// Auto-generated demo scope resolver (PROD MODE)\",\n generatePageImports(),\n generateScopeMap(),\n registryCode,\n generateExportedFunctions(),\n ].join(\"\\n\\n\")\n }\n\n function generateConfigModule(): string {\n return dedent`\n export function getReactDemoConfig() {\n return {lazyLoadDevModules: ${lazyLoadDevModules}}\n }\n `\n }\n\n function generateLazyPageLoaders(): string {\n const pageIds = Array.from(pageFiles.keys()).sort()\n\n if (pageIds.length === 0) {\n return \"export const lazyDemoLoader = {}\"\n }\n const entries = pageIds\n .map((pageId) => {\n return ` \"${pageId}\": () => import(\"virtual:qui-demo-scope/page:${pageId}\")`\n })\n .join(\",\\n\")\n return `export const lazyDemoLoader = {\\n${entries}\\n}`\n }\n\n function generateDemoToPageMap(): string {\n const entries = Array.from(demoRegistry.entries())\n .map(([demoName, {pageId}]) => {\n return ` \"${demoName}\": \"${pageId}\"`\n })\n .join(\",\\n\")\n\n return `const demoToPageMap = {\\n${entries}\\n}`\n }\n\n function generateDevGetDemo(): string {\n return dedent`\n export async function getDemo(demoName) {\n const pageId = demoToPageMap[demoName]\n if (!pageId) {\n return {\n fileName: \"\",\n imports: [],\n errorMessage: \\`Demo \"\\${demoName}\" not found.\\`,\n scope: {},\n pageId: \"\",\n sourceCode: [],\n }\n }\n \n const loader = lazyDemoLoader[pageId]\n if (!loader) {\n return {\n fileName: \"\",\n imports: [],\n errorMessage: \\`Page \"\\${pageId}\" not found.\\`,\n scope: {},\n pageId: \"\",\n sourceCode: [],\n }\n }\n \n const pageModule = await loader()\n const demo = pageModule.getDemo(demoName)\n \n return demo || {\n fileName: \"\",\n imports: [],\n errorMessage: \\`Demo \"\\${demoName}\" not found in page.\\`,\n scope: {},\n pageId: \"\",\n sourceCode: [],\n }\n }\n `\n }\n\n function extractHighlightedVariants(highlightedHtml: string): {\n highlightedPreview: string\n highlightedWithoutPreview: string\n } {\n const preMatch = highlightedHtml.match(/^<pre[^>]*><code>/)?.[0] || \"\"\n const postMatch = highlightedHtml.match(/<\\/code><\\/pre>$/)?.[0] || \"\"\n const content = highlightedHtml.slice(preMatch.length, -postMatch.length)\n const lines = content.split(\"\\n\")\n const previewLines: string[] = []\n const withoutPreviewLines: string[] = []\n let inPreview = false\n\n for (const line of lines) {\n const textContent = line\n .replace(/<[^>]*>/g, \"\")\n .replace(/</g, \"<\")\n .replace(/>/g, \">\")\n .trim()\n if (textContent === \"// preview\" || textContent === \"{/* preview */}\") {\n inPreview = !inPreview\n continue\n }\n if (inPreview) {\n previewLines.push(line)\n }\n withoutPreviewLines.push(line)\n }\n\n const normalizedPreviewLines = normalizeIndentation(previewLines)\n const highlightedPreview =\n normalizedPreviewLines.length > 0\n ? `${preMatch}${normalizedPreviewLines.join(\"\\n\")}${postMatch}`\n : \"\"\n const highlightedWithoutPreview = `${preMatch}${withoutPreviewLines.join(\"\\n\")}${postMatch}`\n return {highlightedPreview, highlightedWithoutPreview}\n }\n\n function normalizeIndentation(lines: string[]): string[] {\n if (lines.length === 0) {\n return []\n }\n const nonEmptyLines = lines.filter(\n (line) => line.replace(/<[^>]*>/g, \"\").trim().length > 0,\n )\n if (nonEmptyLines.length === 0) {\n return lines\n }\n let minIndent = Infinity\n for (const line of nonEmptyLines) {\n const matches = line.match(/<span class=\"indent\">/g)\n if (matches) {\n minIndent = Math.min(minIndent, matches.length)\n } else {\n minIndent = 0\n break\n }\n }\n if (minIndent === 0 || minIndent === Infinity) {\n return lines\n }\n return lines.map((line) => {\n let result = line\n for (let i = 0; i < minIndent; i++) {\n result = result.replace(/<span class=\"indent\">(\\s*)<\\/span>/, \"\")\n }\n return result\n })\n }\n\n function transformLines(code: string): string {\n if (!transformLine) {\n return code\n }\n const result: string[] = []\n for (const line of code.split(\"\\n\")) {\n if (line.trim()) {\n const transformed = transformLine(line)\n if (transformed) {\n result.push(transformed)\n }\n } else {\n // include all empty lines\n result.push(line)\n }\n }\n return result.join(\"\\n\")\n }\n\n async function extractFileData(\n filePath: string,\n ): Promise<Omit<ReactDemoData, \"pageId\"> | null> {\n try {\n const code = await readFile(filePath, \"utf-8\").then(transformLines)\n\n const {imports, strippedCode: codeWithoutImports} = stripImports(\n code,\n filePath,\n )\n const fileName = basename(filePath)\n const {formattedPreview, sourceWithoutSnippetComments} =\n extractPreviewsAndCleanSource(code)\n\n const highlightedFull = await highlightCode(code)\n\n const {highlightedPreview, highlightedWithoutPreview} =\n extractHighlightedVariants(highlightedFull)\n\n const sourceCode = [\n {\n fileName,\n highlighted: {\n full: highlightedWithoutPreview,\n preview: highlightedPreview,\n },\n raw: {\n full: sourceWithoutSnippetComments,\n preview: formattedPreview,\n withoutImports: codeWithoutImports,\n },\n },\n ]\n\n const fileImports = await extractFileImports(filePath)\n if (fileImports) {\n for (const relativeImport of fileImports.relativeImports) {\n try {\n const importedCode = await readFile(\n relativeImport.resolvedPath,\n \"utf-8\",\n ).then(transformLines)\n\n const {strippedCode: importedCodeWithoutImports} = stripImports(\n importedCode,\n relativeImport.resolvedPath,\n )\n const {\n sourceWithoutSnippetComments: importedSourceWithoutSnippets,\n } = extractPreviewsAndCleanSource(importedCode)\n const importedFileName = basename(relativeImport.resolvedPath)\n const highlightedImportedSource = await highlightCode(\n importedSourceWithoutSnippets,\n )\n sourceCode.push({\n fileName: importedFileName,\n highlighted: {\n full: highlightedImportedSource,\n preview: \"\",\n },\n raw: {\n full: importedSourceWithoutSnippets,\n preview: \"\",\n withoutImports: importedCodeWithoutImports,\n },\n })\n } catch (error) {\n logDev(\n `${chalk.magenta.bold(LOG_PREFIX)} ${chalk.yellowBright(\"Failed to process relative import:\")} ${chalk.blueBright.bold(relativeImport.resolvedPath)}`,\n )\n }\n }\n }\n\n return {\n demoName: createDemoName(filePath),\n fileName,\n imports,\n sourceCode,\n }\n } catch (e) {\n logDev(\n `${chalk.magenta.bold(LOG_PREFIX)} ${chalk.yellowBright(\"Failed to parse\")} ${chalk.blueBright.bold(filePath)}. ${chalk.yellowBright(\"Removing from registry\")}`,\n )\n return null\n }\n }\n\n function stripImports(\n code: string,\n fileName: string,\n ): {\n imports: string[]\n strippedCode: string\n } {\n try {\n const sourceFile = ts.createSourceFile(\n fileName,\n code,\n ts.ScriptTarget.Latest,\n true,\n getScriptKind(fileName),\n )\n\n const importRanges: Array<{end: number; start: number}> = []\n\n function visit(node: ts.Node) {\n if (ts.isImportDeclaration(node)) {\n importRanges.push({\n end: node.getEnd(),\n start: node.getFullStart(),\n })\n }\n ts.forEachChild(node, visit)\n }\n\n visit(sourceFile)\n\n const imports = importRanges.map((range) => {\n let endPos = range.end\n if (code[endPos] === \"\\n\") {\n endPos++\n }\n return code.slice(range.start, endPos).trim()\n })\n\n importRanges.sort((a, b) => b.start - a.start)\n\n let strippedCode = code\n for (const range of importRanges) {\n let endPos = range.end\n if (strippedCode[endPos] === \"\\n\") {\n endPos++\n }\n strippedCode =\n strippedCode.slice(0, range.start) + strippedCode.slice(endPos)\n }\n\n strippedCode = strippedCode.trim()\n\n return {\n imports,\n strippedCode: strippedCode.replace(/^\\n+/, \"\"),\n }\n } catch (error) {\n logDev(\n `${chalk.magenta.bold(LOG_PREFIX)} ${chalk.redBright(\"Failed to strip imports from\")} ${chalk.blueBright.bold(fileName)}:`,\n error,\n )\n return {\n imports: [],\n strippedCode: code,\n }\n }\n }\n\n function generatePageImports(): string {\n const pageIds = Array.from(pageScopes.keys())\n return pageIds\n .map((pageId) => {\n const safeName = sanitizeIdentifier(pageId)\n return `import * as page_${safeName} from \"virtual:qui-demo-scope/page:${pageId}\"`\n })\n .join(\"\\n\")\n }\n\n function generateScopeMap(): string {\n const pageIds = Array.from(pageScopes.keys())\n if (pageIds.length === 0) {\n return \"const pageModules = {}\"\n }\n\n const entries = pageIds\n .map((pageId) => {\n const safeName = sanitizeIdentifier(pageId)\n return ` \"${pageId}\": page_${safeName}`\n })\n .join(\",\\n\")\n\n return `const pageModules = {\\n${entries}\\n}`\n }\n\n function generateDemoRegistry(registry: Map<string, ReactDemoData>): string {\n const entries = Array.from(registry.entries())\n .map(([demoName, {fileName, imports, pageId, sourceCode}]) => {\n return ` [\"${demoName}\", { fileName: \"${fileName}\", imports: ${JSON.stringify(imports)}, pageId: \"${pageId}\", sourceCode: ${JSON.stringify(sourceCode)}, demoName: \"${demoName}\" }]`\n })\n .join(\",\\n\")\n return `const demoRegistry = new Map([\\n${entries}\\n])`\n }\n\n function generateExportedFunctions(): string {\n return dedent`\n export function getDemo(demoName) {\n const demo = demoRegistry.get(demoName)\n if (!demo) {\n return {\n fileName: \"\",\n imports: [],\n errorMessage: \\`Demo \"\\${demoName}\" not found.\\`,\n scope: {},\n pageId: \"\",\n sourceCode: [],\n }\n }\n \n const pageModule = pageModules[demo.pageId]\n if (!pageModule) {\n return {\n fileName: \"\",\n imports: [],\n errorMessage: \\`Page module not found.\\`,\n scope: {},\n pageId: demo.pageId,\n sourceCode: [],\n }\n }\n \n return pageModule.getDemo(demoName) || {\n fileName: demo.fileName,\n imports: demo.imports,\n scope: {},\n pageId: demo.pageId,\n sourceCode: demo.sourceCode,\n }\n }\n `\n }\n}\n"],
|
|
5
|
-
"mappings": "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",
|
|
6
|
-
"names": ["isCssAsset", "mainModule", "pageModuleId", "pageModule", "normalizeIndentation", "lines", "visit", "isRelativeImport", "resolveRelativeImport", "isNodeBuiltin", "loadTsConfigPaths", "extractPageId", "routesDir", "NODE_BUILTINS", "chalk", "glob", "readFileSync", "resolve", "z", "z", "z", "z", "chalk", "entry", "propTypes", "heading", "chalk", "remarkParse", "remarkStringify", "unified", "unified", "remarkParse", "remarkStringify", "chalk", "remarkMdx", "remarkParse", "unified", "visit", "visit", "item", "remove", "heading", "unified", "remarkMdx", "remarkParse", "
|
|
3
|
+
"sources": ["../src/angular-demo-plugin/angular-demo-plugin.ts", "../src/docs-plugin/docs-plugin.ts", "../src/docs-plugin/internal/config-loader.ts", "../src/docs-plugin/internal/config-schema.ts", "../src/docs-plugin/internal/zod.ts", "../src/docs-plugin/internal/utils.ts", "../src/docs-plugin/internal/search-indexer.ts", "../src/docs-plugin/internal/services/doc-props/doc-props-indexer.ts", "../src/docs-plugin/internal/services/markdown/markdown-file-reader.ts", "../src/docs-plugin/internal/services/markdown/markdown-indexer.ts", "../src/docs-plugin/rehype/rehype-slug.ts", "../src/docs-plugin/remark/remark-alerts.ts", "../src/docs-plugin/internal/services/markdown/remark-remove-code-blocks.ts", "../src/docs-plugin/internal/services/markdown/remark-remove-jsx.ts", "../src/docs-plugin/internal/services/nav-builder/get-route-meta.ts", "../src/docs-plugin/internal/services/nav-builder/nav-builder.ts", "../src/docs-plugin/internal/services/nav-builder/page-map.ts", "../src/docs-plugin/internal/transform-route-meta-array.ts", "../src/docs-plugin/mdx-plugins.ts", "../src/exports.ts", "../src/docs-plugin/rehype/rehype-sectionize.ts", "../src/docs-plugin/remark/remark-code-tabs.ts", "../src/docs-plugin/remark/remark-self-link-headings.ts", "../src/docs-plugin/remark/remark-spoilers.ts", "../src/docs-plugin/shiki/utils.ts", "../src/docs-plugin/shiki/shiki-transformer-code-attribute.ts", "../src/react-demo-plugin/demo-plugin-constants.ts", "../src/react-demo-plugin/demo-plugin-utils.ts", "../src/react-demo-plugin/react-demo-plugin.ts"],
|
|
4
|
+
"sourcesContent": ["// Copyright (c) Qualcomm Technologies, Inc. and/or its subsidiaries.\n// SPDX-License-Identifier: BSD-3-Clause-Clear\n\nimport {transformerRenderIndentGuides} from \"@shikijs/transformers\"\nimport chalk from \"chalk\"\nimport {type FSWatcher, watch} from \"chokidar\"\nimport {glob} from \"glob\"\nimport {existsSync} from \"node:fs\"\nimport {readFile, stat} from \"node:fs/promises\"\nimport {basename, dirname, join, relative, resolve} from \"node:path\"\nimport {\n createHighlighter,\n type Highlighter,\n type ThemeRegistration,\n type ThemeRegistrationRaw,\n type ThemeRegistrationResolved,\n} from \"shiki\"\nimport * as ts from \"typescript\"\nimport type {Plugin, ViteDevServer} from \"vite\"\n\nimport {\n type AngularDemoInfo,\n type ExtractedPreview,\n type PreviewContext,\n quiCustomDarkTheme,\n type SourceCodeData,\n} from \"@qualcomm-ui/mdx-common\"\n\nexport interface AngularDemoPluginOptions {\n demoPattern?: string | string[]\n /**\n * A mapping of <demoId, initialHtml>, which will be used for the initial\n * serverside render of each demo to prevent FOUC.\n */\n initialHtml?: Record<string, string>\n routesDir?: string\n theme?: {\n dark:\n | ThemeRegistrationRaw\n | ThemeRegistration\n | ThemeRegistrationResolved\n | string\n light:\n | ThemeRegistrationRaw\n | ThemeRegistration\n | ThemeRegistrationResolved\n | string\n }\n}\n\ninterface RelativeImport {\n resolvedPath: string\n source: string\n}\n\ninterface PathAlias {\n pattern: RegExp\n replacement: string\n}\n\nconst VIRTUAL_MODULE_ID = \"\\0virtual:angular-demo-registry\"\nconst VIRTUAL_MODULE_PREFIX = \"virtual:angular-demo-registry/\"\nconst LOG_PREFIX = \"[angular-demo]\"\n\nlet hasWatcherInitialized = false\n\n/**\n * Logs in dev mode only after the watcher has been initialized. Vite runs setup\n * hooks multiple times (once for each environment), so we use this approach to\n * ensure that certain messages are only logged once.\n */\nfunction logDev(...args: any[]) {\n if (!hasWatcherInitialized) {\n return\n }\n console.log(...args)\n}\n\nlet demoDimensionsCache: Record<string, DOMRect> = {}\nlet highlighter: Highlighter | null = null\nlet initCount = 0\nconst demoRegistry = new Map<string, AngularDemoInfo>()\n\nlet hotUpdateDemoIds: string[] = []\n\nexport function angularDemoPlugin({\n demoPattern = \"src/routes/**/demos/*.ts\",\n initialHtml,\n routesDir = \"src/routes\",\n theme = {\n dark: quiCustomDarkTheme,\n light: \"github-light-high-contrast\",\n },\n}: AngularDemoPluginOptions = {}): Plugin {\n let watcher: FSWatcher | null = null\n let devServer: ViteDevServer | null = null\n\n return {\n async buildEnd() {\n if (watcher) {\n await watcher.close()\n watcher = null\n hasWatcherInitialized = false\n }\n },\n\n async buildStart() {\n if (initCount === 0) {\n initCount++\n return\n }\n\n if (!highlighter) {\n try {\n highlighter = await createHighlighter({\n langs: [\"angular-ts\", \"angular-html\"],\n themes: [theme.dark, theme.light],\n })\n logDev(`${chalk.blue.bold(LOG_PREFIX)} Shiki highlighter initialized`)\n } catch (error) {\n console.warn(\n `${chalk.blue.bold(LOG_PREFIX)} Failed to initialize highlighter:`,\n error,\n )\n }\n }\n\n logDev(`${chalk.blue.bold(LOG_PREFIX)} Initializing Angular demo scanner`)\n await collectAngularDemos()\n\n if (process.env.NODE_ENV === \"development\") {\n if (!hasWatcherInitialized) {\n hasWatcherInitialized = true\n await setupAngularWatcher()\n } else {\n logDev(\n `${chalk.blue.bold(LOG_PREFIX)} Watcher already initialized by another instance`,\n )\n }\n }\n },\n\n configureServer(server) {\n devServer = server\n let dimensionUpdateTimeout: NodeJS.Timeout | null = null\n\n server.ws.on(\n \"custom:store-demo-dimensions\",\n (data: {demoId: string; dimensions: DOMRect}) => {\n const demoId = data.demoId\n demoDimensionsCache[demoId] = data.dimensions\n\n if (dimensionUpdateTimeout) {\n clearTimeout(dimensionUpdateTimeout)\n }\n\n dimensionUpdateTimeout = setTimeout(() => {\n const module = server.moduleGraph.getModuleById(VIRTUAL_MODULE_ID)\n if (module) {\n server.moduleGraph.invalidateModule(module)\n }\n }, 50)\n },\n )\n\n server.ws.on(\"custom:reset-demo-dimensions\", () => {\n demoDimensionsCache = {}\n const module = server.moduleGraph.getModuleById(VIRTUAL_MODULE_ID)\n if (module) {\n server.moduleGraph.invalidateModule(module)\n server.reloadModule(module)\n }\n })\n },\n\n async handleHotUpdate({file, server}) {\n if (!isAngularDemoFile(file)) {\n if (isCssAsset(file)) {\n return server.moduleGraph.getModulesByFile(file)?.values()?.toArray()\n } else if (file.endsWith(\"main.js\")) {\n const ids = [...hotUpdateDemoIds]\n server.ws.send({\n data: {\n demoInfo: ids.reduce(\n (acc: Record<string, AngularDemoInfo | undefined>, current) => {\n acc[current] = demoRegistry.get(current)\n return acc\n },\n {},\n ),\n },\n event: \"demo-bundle-updated\",\n type: \"custom\",\n })\n }\n return []\n }\n\n logDev(\n `${chalk.blue.bold(LOG_PREFIX)} Processing Angular demo change: ${chalk.cyan(file)}`,\n )\n\n const code = await readFile(file, \"utf-8\")\n const demoInfo = await parseAngularDemo(file, code)\n\n if (!demoInfo) {\n // might be an imported file\n const affectedDemos: AngularDemoInfo[] =\n await scanDemosForFileImport(file)\n\n if (affectedDemos.length > 0) {\n hotUpdateDemoIds = []\n const mainModule = server.moduleGraph.getModuleById(VIRTUAL_MODULE_ID)\n if (mainModule) {\n server.moduleGraph.invalidateModule(mainModule)\n await server.reloadModule(mainModule)\n }\n for (const demo of affectedDemos) {\n hotUpdateDemoIds.push(demo.id)\n }\n const pageIds = new Set(affectedDemos.map((demo) => demo.pageId))\n for (const pageId of pageIds) {\n const pageModuleId = `\\0${VIRTUAL_MODULE_PREFIX}${pageId}`\n const pageModule = server.moduleGraph.getModuleById(pageModuleId)\n if (pageModule) {\n server.moduleGraph.invalidateModule(pageModule)\n await server.reloadModule(pageModule)\n }\n }\n }\n\n server.ws.send({\n data: {\n ids: [...hotUpdateDemoIds],\n },\n event: \"demo-bundle-updating\",\n type: \"custom\",\n })\n\n return\n }\n\n delete demoDimensionsCache[demoInfo.id]\n demoRegistry.set(demoInfo.id, demoInfo)\n hotUpdateDemoIds = [demoInfo.id]\n\n server.ws.send({\n data: {\n ids: [...hotUpdateDemoIds],\n },\n event: \"demo-bundle-updating\",\n type: \"custom\",\n })\n\n const mainModule = server.moduleGraph.getModuleById(VIRTUAL_MODULE_ID)\n if (mainModule) {\n server.moduleGraph.invalidateModule(mainModule)\n await server.reloadModule(mainModule)\n }\n\n const pageModuleId = `\\0${VIRTUAL_MODULE_PREFIX}${demoInfo.pageId}`\n const pageModule = server.moduleGraph.getModuleById(pageModuleId)\n if (pageModule) {\n server.moduleGraph.invalidateModule(pageModule)\n await server.reloadModule(pageModule)\n }\n\n const demoModule = server.moduleGraph.getModuleById(file)\n if (demoModule) {\n server.moduleGraph.invalidateModule(demoModule)\n }\n\n return []\n },\n\n async load(id) {\n if (id === VIRTUAL_MODULE_ID) {\n return generateRegistryModule()\n }\n if (id.startsWith(`\\0${VIRTUAL_MODULE_PREFIX}`)) {\n const pageId = id.slice(`\\0${VIRTUAL_MODULE_PREFIX}`.length)\n return generatePageRegistryModule(pageId)\n }\n },\n\n name: \"angular-demo-plugin\",\n\n resolveId(id) {\n if (id === \"virtual:angular-demo-registry\") {\n return VIRTUAL_MODULE_ID\n }\n if (id.startsWith(VIRTUAL_MODULE_PREFIX)) {\n const pageId = id.slice(VIRTUAL_MODULE_PREFIX.length)\n return `\\0${VIRTUAL_MODULE_PREFIX}${pageId}`\n }\n },\n\n writeBundle() {\n console.log(\n `${chalk.blue.bold(LOG_PREFIX)} Successfully integrated ${chalk.green(demoRegistry.size)} component demos`,\n )\n },\n }\n\n async function collectAngularDemos() {\n if (demoRegistry.size) {\n logDev(\n `${chalk.magenta.bold(LOG_PREFIX)} Using cached ${chalk.cyanBright.bold(demoRegistry.size)} demos`,\n )\n return\n }\n\n const demoFiles = await glob(demoPattern)\n demoRegistry.clear()\n\n for (const filePath of demoFiles) {\n const code = await readFile(filePath, \"utf-8\")\n const demoInfo = await parseAngularDemo(filePath, code)\n if (demoInfo) {\n demoRegistry.set(demoInfo.id, demoInfo)\n }\n }\n }\n\n async function scanDemosForFileImport(\n file: string,\n ): Promise<AngularDemoInfo[]> {\n const affectedDemos: AngularDemoInfo[] = []\n for (const [demoId, demo] of demoRegistry.entries()) {\n if (demo.sourceCode.find((entry) => entry.filePath === file)) {\n logDev(\n `${chalk.blue.bold(LOG_PREFIX)} Re-parsing demo ${chalk.cyan(demoId)} due to imported file change: ${chalk.yellow(file)}`,\n )\n const code = await readFile(demo.filePath, \"utf-8\")\n const updatedDemo = await parseAngularDemo(demo.filePath, code)\n if (updatedDemo) {\n delete demoDimensionsCache[updatedDemo.id]\n demoRegistry.set(updatedDemo.id, updatedDemo)\n affectedDemos.push(updatedDemo)\n hotUpdateDemoIds.push(updatedDemo.id)\n }\n }\n }\n return affectedDemos\n }\n\n async function highlightCode(\n code: string,\n language: \"angular-ts\" | \"angular-html\" = \"angular-ts\",\n ): Promise<string> {\n if (!highlighter) {\n return code\n }\n\n try {\n return highlighter.codeToHtml(code, {\n defaultColor: \"light-dark()\",\n lang: language,\n themes: {\n dark: theme.dark,\n light: theme.light,\n },\n transformers: [transformerRenderIndentGuides()],\n })\n } catch (error) {\n console.warn(\n `${chalk.blue.bold(LOG_PREFIX)} Failed to highlight code with ${language} language:`,\n error,\n )\n return code\n }\n }\n\n function extractAngularPreviewsAndCleanSource(\n code: string,\n ): ExtractedPreview {\n const lines = code.split(\"\\n\")\n const previewBlocks: PreviewContext[] = []\n const cleanedLines: string[] = []\n let inPreview = false\n let currentBlock: string[] = []\n let startLine = -1\n let currentContext: \"template\" | \"typescript\" = \"typescript\"\n let inTemplate = false\n let templateDepth = 0\n let omitNextLine = false\n\n for (let i = 0; i < lines.length; i++) {\n const line = lines[i]\n const trimmedLine = line.trim()\n\n if (/template\\s*:\\s*[`\"']/.test(line)) {\n inTemplate = true\n templateDepth = 0\n }\n\n if (inTemplate && line.includes(\"`\")) {\n const backticks = (line.match(/`/g) || []).length\n templateDepth += backticks\n if (templateDepth % 2 === 0 && backticks > 0) {\n inTemplate = false\n }\n }\n\n if (inTemplate && /['\"]\\s*[,}]/.test(line)) {\n inTemplate = false\n }\n\n if (omitNextLine) {\n omitNextLine = false\n continue\n }\n\n if (isOmitNextLine(trimmedLine)) {\n omitNextLine = true\n continue\n }\n\n if (isPreviewLine(trimmedLine)) {\n if (inPreview) {\n const normalizedContent = normalizeIndentation(currentBlock)\n previewBlocks.push({\n content: normalizedContent,\n context: currentContext,\n endLine: i - 1,\n startLine,\n })\n currentBlock = []\n inPreview = false\n } else {\n inPreview = true\n startLine = i + 1\n currentContext = inTemplate ? \"template\" : \"typescript\"\n }\n } else {\n cleanedLines.push(line)\n if (inPreview) {\n currentBlock.push(line)\n }\n }\n }\n\n function normalizeIndentation(lines: string[]): string {\n if (lines.length === 0) {\n return \"\"\n }\n const nonEmptyLines = lines.filter((line) => line.trim().length > 0)\n if (nonEmptyLines.length === 0) {\n return lines.join(\"\\n\")\n }\n let minIndent = Infinity\n for (const line of nonEmptyLines) {\n const match = line.match(/^(\\s*)/)\n const indent = match ? match[1].length : 0\n minIndent = Math.min(minIndent, indent)\n }\n const normalizedLines = lines.map((line) => {\n if (line.trim().length === 0) {\n return line\n }\n return line.slice(minIndent)\n })\n return normalizedLines.join(\"\\n\")\n }\n\n const formattedPreview = previewBlocks.length\n ? previewBlocks.map((block) => block.content).join(\"\\n\")\n : \"\"\n\n return {\n formattedPreview,\n previewBlocks,\n sourceWithoutPreviews: cleanedLines.join(\"\\n\"),\n }\n }\n\n function isPreviewLine(trimmedLine: string): boolean {\n return (\n trimmedLine === \"// preview\" ||\n /^\\/\\*\\s*preview\\s*\\*\\/$/.test(trimmedLine) ||\n /^<!--\\s*preview\\s*-->$/.test(trimmedLine)\n )\n }\n\n async function extractRelativeImports(\n filePath: string,\n ): Promise<RelativeImport[]> {\n try {\n const content = await readFile(filePath, \"utf-8\")\n const sourceFile = ts.createSourceFile(\n filePath,\n content,\n ts.ScriptTarget.Latest,\n true,\n ts.ScriptKind.TS,\n )\n\n const relativeImports: RelativeImport[] = []\n\n function visit(node: ts.Node) {\n if (ts.isImportDeclaration(node)) {\n const moduleSpecifier = node.moduleSpecifier\n if (ts.isStringLiteral(moduleSpecifier)) {\n const source = moduleSpecifier.text\n if (isRelativeImport(source)) {\n const resolvedPath = resolveRelativeImport(source, filePath)\n relativeImports.push({resolvedPath, source})\n } else if (!isNodeBuiltin(source)) {\n const pathAliases = loadTsConfigPaths(filePath)\n if (isPathAliasImport(source, pathAliases)) {\n const resolvedPath = resolvePathAlias(source, pathAliases)\n if (resolvedPath) {\n relativeImports.push({resolvedPath, source})\n }\n }\n }\n }\n }\n ts.forEachChild(node, visit)\n }\n\n visit(sourceFile)\n return relativeImports\n } catch (error) {\n logDev(\n `${chalk.blue.bold(LOG_PREFIX)} ${chalk.yellowBright(\"Failed to extract imports from\")} ${chalk.cyan(filePath)}:`,\n error,\n )\n return []\n }\n }\n\n async function collectAllImports(\n filePath: string,\n visited = new Set<string>(),\n ): Promise<string[]> {\n if (visited.has(filePath)) {\n return []\n }\n visited.add(filePath)\n\n const directImports = await extractRelativeImports(filePath)\n\n for (const {resolvedPath} of directImports) {\n await collectAllImports(resolvedPath, visited)\n }\n\n return Array.from(visited).slice(1)\n }\n\n function stripImports(\n code: string,\n fileName: string,\n ): {\n imports: string[]\n strippedCode: string\n } {\n try {\n const sourceFile = ts.createSourceFile(\n fileName,\n code,\n ts.ScriptTarget.Latest,\n true,\n ts.ScriptKind.TS,\n )\n\n const importRanges: Array<{end: number; start: number}> = []\n\n function visit(node: ts.Node) {\n if (ts.isImportDeclaration(node)) {\n importRanges.push({\n end: node.getEnd(),\n start: node.getFullStart(),\n })\n }\n ts.forEachChild(node, visit)\n }\n\n visit(sourceFile)\n\n const imports = importRanges.map((range) => {\n let endPos = range.end\n if (code[endPos] === \"\\n\") {\n endPos++\n }\n return code.slice(range.start, endPos).trim()\n })\n\n importRanges.sort((a, b) => b.start - a.start)\n\n let strippedCode = code\n for (const range of importRanges) {\n let endPos = range.end\n if (strippedCode[endPos] === \"\\n\") {\n endPos++\n }\n strippedCode =\n strippedCode.slice(0, range.start) + strippedCode.slice(endPos)\n }\n\n strippedCode = strippedCode.trim()\n\n return {\n imports,\n strippedCode: strippedCode.replace(/^\\n+/, \"\"),\n }\n } catch (error) {\n logDev(\n `${chalk.blue.bold(LOG_PREFIX)} ${chalk.redBright(\"Failed to strip imports from\")} ${chalk.cyan(fileName)}:`,\n error,\n )\n return {\n imports: [],\n strippedCode: code,\n }\n }\n }\n\n async function parseAngularDemo(\n filePath: string,\n code: string,\n ): Promise<AngularDemoInfo | null> {\n try {\n const {formattedPreview, sourceWithoutPreviews} =\n extractAngularPreviewsAndCleanSource(code)\n\n const sourceFile = ts.createSourceFile(\n filePath,\n sourceWithoutPreviews,\n ts.ScriptTarget.Latest,\n true,\n ts.ScriptKind.TS,\n )\n\n let componentClass = \"\"\n let selector = \"\"\n let isStandalone = true\n let templateUrl: string | null = null\n const imports: string[] = []\n let hasDefaultExport = false\n\n function visit(node: ts.Node) {\n if (ts.isImportDeclaration(node)) {\n imports.push(node.getFullText(sourceFile).trim())\n }\n\n if (ts.isClassDeclaration(node)) {\n const decorators = node.modifiers?.filter(ts.isDecorator)\n const componentDecorator = decorators?.find((decorator) => {\n if (ts.isCallExpression(decorator.expression)) {\n const expression = decorator.expression.expression\n return (\n ts.isIdentifier(expression) && expression.text === \"Component\"\n )\n }\n return false\n })\n\n if (componentDecorator && node.name) {\n componentClass = node.name.text\n\n if (\n ts.isCallExpression(componentDecorator.expression) &&\n componentDecorator.expression.arguments[0] &&\n ts.isObjectLiteralExpression(\n componentDecorator.expression.arguments[0],\n )\n ) {\n const properties =\n componentDecorator.expression.arguments[0].properties\n\n const selectorProp = properties.find(\n (prop) =>\n ts.isPropertyAssignment(prop) &&\n ts.isIdentifier(prop.name) &&\n prop.name.text === \"selector\",\n ) as ts.PropertyAssignment | undefined\n\n if (\n selectorProp &&\n ts.isStringLiteral(selectorProp.initializer)\n ) {\n selector = selectorProp.initializer.text\n }\n\n const templateUrlProp = properties.find(\n (prop) =>\n ts.isPropertyAssignment(prop) &&\n ts.isIdentifier(prop.name) &&\n prop.name.text === \"templateUrl\",\n ) as ts.PropertyAssignment | undefined\n\n if (templateUrlProp) {\n if (ts.isStringLiteral(templateUrlProp.initializer)) {\n templateUrl = templateUrlProp.initializer.text\n } else if (\n ts.isNoSubstitutionTemplateLiteral(\n templateUrlProp.initializer,\n )\n ) {\n templateUrl = templateUrlProp.initializer.text\n }\n }\n\n const standaloneProp = properties.find(\n (prop) =>\n ts.isPropertyAssignment(prop) &&\n ts.isIdentifier(prop.name) &&\n prop.name.text === \"standalone\",\n ) as ts.PropertyAssignment | undefined\n\n if (standaloneProp) {\n if (\n standaloneProp.initializer.kind === ts.SyntaxKind.FalseKeyword\n ) {\n isStandalone = false\n }\n }\n }\n }\n }\n\n if (ts.isExportAssignment(node) && !node.isExportEquals) {\n hasDefaultExport = true\n }\n\n ts.forEachChild(node, visit)\n }\n\n visit(sourceFile)\n\n if (!componentClass || !selector) {\n return null\n }\n\n const demoId = componentClass\n const pageId = extractPageId(filePath, routesDir)\n const importPath = relative(process.cwd(), filePath).replace(/\\\\/g, \"/\")\n const fileName = basename(filePath)\n\n const {strippedCode: codeWithoutImports} = stripImports(code, filePath)\n\n const highlightedFull = await highlightCode(code, \"angular-ts\")\n const {highlightedPreview, highlightedWithoutPreview} =\n extractHighlightedVariants(highlightedFull)\n\n const sourceCode: SourceCodeData[] = [\n {\n fileName,\n filePath,\n highlighted: {\n full: highlightedWithoutPreview,\n preview: highlightedPreview,\n },\n raw: {\n full: sourceWithoutPreviews,\n preview: formattedPreview || \"\",\n withoutImports: codeWithoutImports,\n },\n },\n ]\n\n if (templateUrl) {\n const templatePath = resolveTemplateFile(templateUrl, filePath)\n\n if (existsSync(templatePath)) {\n try {\n const templateCode = await readFile(templatePath, \"utf-8\")\n\n const {\n formattedPreview: templatePreview,\n sourceWithoutPreviews: templateWithoutPreviews,\n } = extractAngularPreviewsAndCleanSource(templateCode)\n\n const highlightedTemplate = await highlightCode(\n templateCode,\n \"angular-html\",\n )\n\n const {\n highlightedPreview: highlightedTemplatePreview,\n highlightedWithoutPreview: highlightedTemplateWithoutPreview,\n } = extractHighlightedVariants(highlightedTemplate)\n\n sourceCode.push({\n fileName: basename(templatePath),\n highlighted: {\n full: highlightedTemplateWithoutPreview,\n preview: highlightedTemplatePreview,\n },\n raw: {\n full: templateWithoutPreviews,\n preview: templatePreview || \"\",\n withoutImports: templateCode,\n },\n })\n } catch (error) {\n console.log(\n `${chalk.blue.bold(LOG_PREFIX)} ${chalk.redBright(\"Failed to read template file:\")} ${chalk.cyan(templatePath)}`,\n error,\n )\n }\n }\n }\n\n const relativeImports = await collectAllImports(filePath)\n\n for (const resolvedPath of relativeImports) {\n try {\n const importedCode = await readFile(resolvedPath, \"utf-8\")\n const {strippedCode: importedCodeWithoutImports} = stripImports(\n importedCode,\n resolvedPath,\n )\n\n const {sourceWithoutPreviews: importedSourceWithoutSnippets} =\n extractAngularPreviewsAndCleanSource(importedCode)\n\n const importedFileName = basename(resolvedPath)\n const highlightedImportedSource = await highlightCode(\n importedSourceWithoutSnippets,\n \"angular-ts\",\n )\n\n sourceCode.push({\n fileName: importedFileName,\n highlighted: {\n full: highlightedImportedSource,\n preview: \"\",\n },\n raw: {\n full: importedSourceWithoutSnippets,\n preview: \"\",\n withoutImports: importedCodeWithoutImports,\n },\n })\n } catch (error) {\n logDev(\n `${chalk.blue.bold(LOG_PREFIX)} ${chalk.yellowBright(\"Failed to process relative import:\")} ${chalk.cyan(resolvedPath)}`,\n )\n }\n }\n\n return {\n componentClass,\n filePath: importPath.startsWith(\".\") ? importPath : `./${importPath}`,\n hasDefaultExport,\n id: demoId,\n imports,\n initialHtml: initialHtml?.[demoId] || undefined,\n isStandalone,\n lastModified: Date.now(),\n pageId,\n selector,\n sourceCode,\n }\n } catch (error) {\n console.error(\n `${chalk.blue.bold(LOG_PREFIX)} Failed to parse Angular demo ${filePath}:`,\n error,\n )\n return null\n }\n }\n\n function extractHighlightedVariants(highlightedHtml: string): {\n highlightedPreview: string\n highlightedWithoutPreview: string\n } {\n const preMatch = highlightedHtml.match(/^<pre[^>]*><code>/)?.[0] || \"\"\n const postMatch = highlightedHtml.match(/<\\/code><\\/pre>$/)?.[0] || \"\"\n const content = highlightedHtml.slice(preMatch.length, -postMatch.length)\n const lines = content.split(\"\\n\")\n const previewLines: string[] = []\n const withoutPreviewLines: string[] = []\n let inPreview = false\n let omitNextLine = false\n\n for (const line of lines) {\n const textContent = line\n .replace(/<[^>]*>/g, \"\")\n .replace(/</g, \"<\")\n .replace(/>/g, \">\")\n .trim()\n\n if (omitNextLine) {\n omitNextLine = false\n continue\n }\n\n if (textContent === \"// qui-docs::omit-next-line\") {\n omitNextLine = true\n continue\n }\n\n if (\n textContent === \"// preview\" ||\n textContent === \"/* preview */\" ||\n textContent === \"<!-- preview -->\"\n ) {\n inPreview = !inPreview\n continue\n }\n\n if (inPreview) {\n previewLines.push(line)\n }\n withoutPreviewLines.push(line)\n }\n\n const normalizedPreviewLines = normalizeIndentation(previewLines)\n const highlightedPreview =\n normalizedPreviewLines.length > 0\n ? `${preMatch}${normalizedPreviewLines.join(\"\\n\")}${postMatch}`\n : \"\"\n const highlightedWithoutPreview = `${preMatch}${withoutPreviewLines.join(\"\\n\")}${postMatch}`\n\n return {highlightedPreview, highlightedWithoutPreview}\n }\n\n function normalizeIndentation(lines: string[]): string[] {\n if (lines.length === 0) {\n return []\n }\n\n const nonEmptyLines = lines.filter(\n (line) => line.replace(/<[^>]*>/g, \"\").trim().length > 0,\n )\n\n if (nonEmptyLines.length === 0) {\n return lines\n }\n\n let minIndent = Infinity\n for (const line of nonEmptyLines) {\n const matches = line.match(/<span class=\"indent\">/g)\n if (matches) {\n minIndent = Math.min(minIndent, matches.length)\n } else {\n minIndent = 0\n break\n }\n }\n\n if (minIndent === 0 || minIndent === Infinity) {\n return lines\n }\n\n return lines.map((line) => {\n let result = line\n for (let i = 0; i < minIndent; i++) {\n result = result.replace(/<span class=\"indent\">(\\s*)<\\/span>/, \"\")\n }\n return result\n })\n }\n\n function generateRegistryModule(): string {\n const demos = Array.from(demoRegistry.values())\n return `// Auto-generated Angular demo registry\nexport const ANGULAR_DEMOS = {\n${demos\n .map(\n (demo) =>\n ` \"${demo.id}\": ${JSON.stringify(\n {\n componentClass: demo.componentClass,\n dimensions: demoDimensionsCache[demo.id],\n filePath: demo.filePath,\n hasDefaultExport: demo.hasDefaultExport,\n id: demo.id,\n imports: demo.imports,\n initialHtml: demo.initialHtml,\n isStandalone: demo.isStandalone,\n lastModified: demo.lastModified,\n pageId: demo.pageId,\n selector: demo.selector,\n sourceCode: demo.sourceCode,\n },\n null,\n 4,\n )}`,\n )\n .join(\",\\n\")}\n}\n\nexport function isAngularDemo(demoId) {\n return demoId in ANGULAR_DEMOS\n}\n\nexport function getAngularDemoInfo(demoId) {\n return ANGULAR_DEMOS[demoId] || null\n}\n\nexport function getAllAngularDemos() {\n return Object.values(ANGULAR_DEMOS)\n}\n\nexport const availableAngularDemos = Object.keys(ANGULAR_DEMOS)\n\nif (import.meta.hot) {\n import.meta.hot.accept(() => {\n console.log('[angular-demo-registry] Registry updated via HMR')\n })\n \n if (typeof window !== 'undefined') {\n import.meta.hot.on('angular-demo-update', (data) => {\n console.log('[angular-demo-registry] Demo updated:', data.demoId)\n })\n }\n}`\n }\n\n function generatePageRegistryModule(pageId: string): string {\n const pageDemos = Array.from(demoRegistry.values()).filter(\n (demo) => demo.pageId === pageId,\n )\n\n if (pageDemos.length === 0) {\n return `export function getAngularDemoInfo() { return null }\nexport const ANGULAR_DEMOS = {}`\n }\n\n return `// Auto-generated Angular demo registry for ${pageId}\nexport const ANGULAR_DEMOS = {\n${pageDemos\n .map(\n (demo) =>\n ` \"${demo.id}\": ${JSON.stringify(\n {\n componentClass: demo.componentClass,\n dimensions: demoDimensionsCache[demo.id],\n filePath: demo.filePath,\n hasDefaultExport: demo.hasDefaultExport,\n id: demo.id,\n imports: demo.imports,\n initialHtml: demo.initialHtml,\n isStandalone: demo.isStandalone,\n lastModified: demo.lastModified,\n pageId: demo.pageId,\n selector: demo.selector,\n sourceCode: demo.sourceCode,\n },\n null,\n 4,\n )}`,\n )\n .join(\",\\n\")}\n}\n\nexport function getAngularDemoInfo(demoId) {\n return ANGULAR_DEMOS[demoId] || null\n}\n\nif (import.meta.hot) {\n import.meta.hot.accept(() => {\n console.log('[angular-demo-registry/${pageId}] Registry updated')\n })\n}`\n }\n\n function extractPageId(filePath: string, routesDir: string): string {\n const relativePath = relative(routesDir, filePath)\n const pathParts = relativePath.split(\"/\")\n const demoIndex = pathParts.findIndex((part) => part.includes(\"demos\"))\n\n if (demoIndex === -1) {\n return pathParts.at(-2) || pathParts.join(\"/\")\n }\n\n return pathParts.slice(0, demoIndex).join(\"/\")\n }\n\n function isAngularDemoFile(filePath: string): boolean {\n return (\n filePath.includes(\"/demos/\") &&\n (filePath.endsWith(\".ts\") || filePath.endsWith(\"html\"))\n )\n }\n\n function isCssAsset(filePath: string) {\n return filePath.endsWith(\".css\")\n }\n\n function isRelativeImport(source: string): boolean {\n return source.startsWith(\"./\") || source.startsWith(\"../\")\n }\n\n function isNodeBuiltin(source: string): boolean {\n const NODE_BUILTINS = [\n \"assert\",\n \"buffer\",\n \"child_process\",\n \"cluster\",\n \"crypto\",\n \"dgram\",\n \"dns\",\n \"domain\",\n \"events\",\n \"fs\",\n \"http\",\n \"https\",\n \"net\",\n \"os\",\n \"path\",\n \"punycode\",\n \"querystring\",\n \"readline\",\n \"stream\",\n \"string_decoder\",\n \"timers\",\n \"tls\",\n \"tty\",\n \"url\",\n \"util\",\n \"v8\",\n \"vm\",\n \"zlib\",\n ]\n return source.startsWith(\"node:\") || NODE_BUILTINS.includes(source)\n }\n\n function resolveRelativeImport(source: string, fromFile: string): string {\n const fromDir = dirname(fromFile)\n const resolved = resolve(fromDir, source)\n const extensions = [\".ts\", \".tsx\", \".js\", \".jsx\"]\n\n for (const ext of extensions) {\n const withExt = resolved + ext\n if (existsSync(withExt)) {\n return withExt\n }\n }\n\n for (const ext of extensions) {\n const indexFile = join(resolved, `index${ext}`)\n if (existsSync(indexFile)) {\n return indexFile\n }\n }\n\n return resolved\n }\n\n function loadTsConfigPaths(fromFile: string): PathAlias[] {\n let currentDir = dirname(fromFile)\n const pathAliases: PathAlias[] = []\n\n while (currentDir !== dirname(currentDir)) {\n const tsconfigPath = join(currentDir, \"tsconfig.json\")\n\n if (existsSync(tsconfigPath)) {\n try {\n const configContent = ts.sys.readFile(tsconfigPath)\n if (!configContent) {\n currentDir = dirname(currentDir)\n continue\n }\n\n const parseResult = ts.parseConfigFileTextToJson(\n tsconfigPath,\n configContent,\n )\n\n if (parseResult.error) {\n currentDir = dirname(currentDir)\n continue\n }\n\n const paths = parseResult.config?.compilerOptions?.paths\n const baseUrl = parseResult.config?.compilerOptions?.baseUrl || \"./\"\n const resolvedBaseUrl = resolve(currentDir, baseUrl)\n\n if (paths) {\n for (const [alias, targets] of Object.entries(paths)) {\n if (Array.isArray(targets) && targets.length > 0) {\n const target = targets[0]\n const pattern = new RegExp(\n `^${alias\n .replace(\"*\", \"(.*)\")\n .replace(/[.*+?^${}()|[\\]\\\\]/g, \"\\\\$&\")\n .replace(\"\\\\(\\\\*\\\\)\", \"(.*)\")}$`,\n )\n const replacement = resolve(\n resolvedBaseUrl,\n target.replace(\"*\", \"$1\"),\n )\n pathAliases.push({pattern, replacement})\n }\n }\n }\n\n const extendsPath = parseResult.config?.extends\n if (extendsPath) {\n const resolvedExtends = resolve(currentDir, extendsPath)\n const extendedAliases = loadTsConfigPathsFromFile(resolvedExtends)\n pathAliases.push(...extendedAliases)\n }\n\n return pathAliases\n } catch (error) {\n currentDir = dirname(currentDir)\n continue\n }\n }\n\n currentDir = dirname(currentDir)\n }\n\n return pathAliases\n }\n\n async function setupAngularWatcher() {\n watcher = watch(routesDir, {\n ignoreInitial: true,\n persistent: true,\n })\n\n watcher.on(\"ready\", () => {\n logDev(\n `${chalk.blue.bold(LOG_PREFIX)} Registered ${chalk.green(demoRegistry.size)} demo files. Watching for file changes...`,\n )\n })\n\n watcher.on(\"add\", async (filePath: string) => {\n const fileStats = await stat(filePath)\n if (fileStats.size === 0) {\n return\n }\n\n if (isAngularDemoFile(filePath)) {\n logDev(\n `${chalk.blue.bold(LOG_PREFIX)} New Angular demo: ${chalk.green(filePath)}`,\n )\n await handleAngularDemoUpdate(filePath)\n triggerRegistryUpdate()\n }\n })\n\n watcher.on(\"unlink\", (filePath: string) => {\n if (isAngularDemoFile(filePath)) {\n const demoEntry = Array.from(demoRegistry.entries()).find(\n ([, info]) => info.filePath === filePath,\n )\n\n if (demoEntry) {\n const [demoId] = demoEntry\n demoRegistry.delete(demoId)\n logDev(\n `${chalk.blue.bold(LOG_PREFIX)} Removed demo: ${chalk.red(demoId)}`,\n )\n triggerRegistryUpdate()\n }\n }\n })\n }\n\n async function handleAngularDemoUpdate(filePath: string) {\n const code = await readFile(filePath, \"utf-8\")\n const demoInfo = await parseAngularDemo(filePath, code)\n if (demoInfo) {\n demoRegistry.set(demoInfo.id, demoInfo)\n }\n }\n\n function triggerRegistryUpdate() {\n if (devServer) {\n const mainModule = devServer.moduleGraph.getModuleById(VIRTUAL_MODULE_ID)\n if (mainModule) {\n devServer.moduleGraph.invalidateModule(mainModule)\n mainModule.lastHMRTimestamp = Date.now()\n devServer.reloadModule(mainModule)\n }\n\n const pageIds = new Set(\n Array.from(demoRegistry.values()).map((demo) => demo.pageId),\n )\n for (const pageId of pageIds) {\n const pageModuleId = `\\0${VIRTUAL_MODULE_PREFIX}${pageId}`\n const pageModule = devServer.moduleGraph.getModuleById(pageModuleId)\n if (pageModule) {\n devServer.moduleGraph.invalidateModule(pageModule)\n pageModule.lastHMRTimestamp = Date.now()\n devServer.reloadModule(pageModule)\n }\n }\n }\n }\n}\n\nfunction loadTsConfigPathsFromFile(tsconfigPath: string): PathAlias[] {\n const pathAliases: PathAlias[] = []\n const configDir = dirname(tsconfigPath)\n\n try {\n const configContent = ts.sys.readFile(tsconfigPath)\n if (!configContent) {\n return pathAliases\n }\n\n const parseResult = ts.parseConfigFileTextToJson(\n tsconfigPath,\n configContent,\n )\n\n if (parseResult.error) {\n return pathAliases\n }\n\n const paths = parseResult.config?.compilerOptions?.paths\n const baseUrl = parseResult.config?.compilerOptions?.baseUrl || \"./\"\n const resolvedBaseUrl = resolve(configDir, baseUrl)\n\n if (paths) {\n for (const [alias, targets] of Object.entries(paths)) {\n if (Array.isArray(targets) && targets.length > 0) {\n const target = targets[0]\n const pattern = new RegExp(\n `^${alias\n .replace(\"*\", \"(.*)\")\n .replace(/[.*+?^${}()|[\\]\\\\]/g, \"\\\\$&\")\n .replace(\"\\\\(\\\\*\\\\)\", \"(.*)\")}$`,\n )\n const replacement = resolve(\n resolvedBaseUrl,\n target.replace(\"*\", \"$1\"),\n )\n pathAliases.push({pattern, replacement})\n }\n }\n }\n\n const extendsPath = parseResult.config?.extends\n if (extendsPath) {\n let resolvedExtends = resolve(configDir, extendsPath)\n if (!resolvedExtends.endsWith(\".json\")) {\n resolvedExtends += \".json\"\n }\n if (existsSync(resolvedExtends)) {\n const extendedAliases = loadTsConfigPathsFromFile(resolvedExtends)\n pathAliases.push(...extendedAliases)\n }\n }\n } catch (error) {\n return pathAliases\n }\n\n return pathAliases\n}\n\nfunction isPathAliasImport(source: string, pathAliases: PathAlias[]): boolean {\n return pathAliases.some((alias) => alias.pattern.test(source))\n}\n\nfunction resolvePathAlias(\n source: string,\n pathAliases: PathAlias[],\n): string | null {\n for (const alias of pathAliases) {\n if (alias.pattern.test(source)) {\n const resolvedPath = source.replace(alias.pattern, alias.replacement)\n const extensions = [\".ts\", \".tsx\", \".js\", \".jsx\"]\n\n for (const ext of extensions) {\n const withExt = resolvedPath + ext\n if (existsSync(withExt)) {\n return withExt\n }\n }\n\n for (const ext of extensions) {\n const indexFile = join(resolvedPath, `index${ext}`)\n if (existsSync(indexFile)) {\n return indexFile\n }\n }\n\n return resolvedPath\n }\n }\n\n return null\n}\n\nfunction resolveTemplateFile(templateUrl: string, fromFile: string): string {\n const fromDir = dirname(fromFile)\n const resolved = resolve(fromDir, templateUrl)\n\n if (existsSync(resolved)) {\n return resolved\n }\n\n if (!resolved.endsWith(\".html\")) {\n const withHtml = `${resolved}.html`\n if (existsSync(withHtml)) {\n return withHtml\n }\n }\n\n return resolved\n}\n\nfunction isOmitNextLine(trimmedLine: string): boolean {\n return trimmedLine === \"// qui-docs::omit-next-line\"\n}\n", "// Copyright (c) Qualcomm Technologies, Inc. and/or its subsidiaries.\n// SPDX-License-Identifier: BSD-3-Clause-Clear\n\nimport chalk from \"chalk\"\nimport chokidar from \"chokidar\"\nimport {glob} from \"glob\"\nimport {readFileSync} from \"node:fs\"\nimport {resolve} from \"node:path\"\nimport prettyMilliseconds from \"pretty-ms\"\nimport type {ModuleNode, PluginOption, ViteDevServer} from \"vite\"\n\nimport type {PageDocProps, SiteData} from \"@qualcomm-ui/mdx-common\"\nimport type {QuiPropTypes} from \"@qualcomm-ui/typedoc-common\"\n\nimport {\n type CompiledMdxFile,\n ConfigLoader,\n fixPath,\n type ResolvedQuiDocsConfig,\n SearchIndexer,\n} from \"./internal\"\n\nconst isDev = process.env.NODE_ENV === \"development\"\n\ninterface ChangeOptions {\n onComplete?: () => void\n}\n\nexport interface QuiDocsPluginOptions {\n /**\n * Path to the qui-docs config file. This is automatically detected if omitted.\n */\n configFile?: string\n\n /**\n * The current working directory.\n *\n * @default process.cwd()\n */\n cwd?: string\n}\n\nconst VIRTUAL_MODULE_ID = \"\\0@qualcomm-ui/mdx-vite-plugin\"\n\n/**\n * TODO: adjust when https://github.com/vitejs/vite/discussions/16358 lands.\n */\nclass PluginState {\n buildCount: number = 0\n configFilePath: string = \"\"\n docPropsFilePath: string = \"\"\n indexer!: SearchIndexer\n configLoader: ConfigLoader | null = null\n routesDir!: string\n servers: ViteDevServer[] = []\n timeout: ReturnType<typeof setTimeout> | undefined = undefined\n watching = false\n\n private cwd!: string\n\n init(cwd: string) {\n this.cwd = cwd\n }\n\n get docPropsDirectory() {\n if (!this.docPropsFilePath) {\n return \"\"\n }\n return this.docPropsFilePath.substring(\n 0,\n this.docPropsFilePath.lastIndexOf(\"/\"),\n )\n }\n\n get siteData(): SiteData {\n return {\n navItems: state.indexer.navItems,\n pageDocProps: state.indexer.pageDocProps as unknown as PageDocProps,\n pageMap: state.indexer.pageMap,\n searchIndex: state.indexer.searchIndex,\n }\n }\n\n private resolveDocProps(): Record<string, QuiPropTypes> {\n if (!this.docPropsFilePath) {\n return {}\n }\n try {\n return JSON.parse(readFileSync(this.docPropsFilePath, \"utf-8\"))?.props\n } catch (e) {\n console.debug(\n \"Invalid doc props file. Unable to parse JSON. Please check the file\",\n )\n return {}\n }\n }\n\n createIndexer(config: ResolvedQuiDocsConfig) {\n this.configFilePath = config.filePath\n this.docPropsFilePath = config.typeDocProps\n ? fixPath(resolve(this.cwd, config.typeDocProps))\n : \"\"\n this.routesDir = fixPath(resolve(config.appDirectory, config.pageDirectory))\n this.indexer = new SearchIndexer({\n ...config,\n srcDir: fixPath(resolve(this.cwd, config.appDirectory)),\n typeDocProps: this.resolveDocProps(),\n })\n }\n\n buildIndex(shouldLog: boolean): CompiledMdxFile[] {\n const files = glob.sync(\n [`${this.routesDir}/**/*.mdx`, `${this.routesDir}/**/*.tsx`],\n {\n absolute: true,\n cwd: this.cwd,\n },\n )\n\n if (!files.length) {\n return []\n }\n\n const startTime = Date.now()\n\n const compiledMdxFiles = this.indexer.buildIndex(files, shouldLog)\n\n if (isDev && shouldLog) {\n console.debug(\n `${chalk.magenta.bold(`@qualcomm-ui/mdx-vite/docs-plugin:`)} Compiled search index in: ${chalk.blueBright.bold(prettyMilliseconds(Date.now() - startTime))}${state.indexer.cachedFileCount ? chalk.greenBright.bold(` (${state.indexer.cachedFileCount}/${state.indexer.mdxFileCount} files cached)`) : \"\"}`,\n )\n }\n\n return compiledMdxFiles\n }\n\n /**\n * When the user adds or removes mdx files, we re-index the site. This function\n * handles module invalidation so that virtual file imports are refreshed as\n * expected by the consumer's dev server.\n */\n sendUpdate() {\n for (const server of this.servers) {\n const virtualModule = server.moduleGraph.getModuleById(VIRTUAL_MODULE_ID)\n if (virtualModule) {\n server.moduleGraph.invalidateModule(virtualModule)\n server.reloadModule(virtualModule)\n }\n }\n }\n\n handleChange(opts: ChangeOptions = {}) {\n // the plugin is activating twice in dev mode. It's mostly harmless, but we\n // prevent logs from emitting twice by flipping a flag\n\n // debounce the change handler to prevent rapid updates from triggering rebuilds\n // in quick succession.\n clearTimeout(this.timeout)\n this.timeout = setTimeout(() => {\n this.buildIndex(true)\n this.sendUpdate()\n opts?.onComplete?.()\n }, 300)\n }\n\n initWatchers(configFile?: string) {\n if (this.watching) {\n return\n }\n this.initConfigWatcher(configFile)\n this.watching = true\n }\n\n private initConfigWatcher(configFile?: string) {\n const paths: string[] = [this.configFilePath]\n if (this.docPropsFilePath) {\n paths.push(this.docPropsFilePath)\n }\n chokidar\n .watch(paths, {\n cwd: this.cwd,\n })\n .on(\"change\", () => {\n console.debug(`qui-docs config changed, reloading plugin`)\n this.configLoader = new ConfigLoader({configFile})\n const resolvedConfig = this.configLoader.loadConfig()\n this.configFilePath = resolvedConfig.filePath\n this.createIndexer(resolvedConfig)\n this.handleChange({\n onComplete: () => {\n this.servers.forEach((server) =>\n server.ws.send({type: \"full-reload\"}),\n )\n },\n })\n })\n }\n}\n\nconst state = new PluginState()\n\nexport function quiDocsPlugin(opts?: QuiDocsPluginOptions): PluginOption {\n state.init(fixPath(opts?.cwd ?? process.cwd()))\n\n // https://vitejs.dev/guide/api-plugin#virtual-modules-convention\n\n const configLoader = new ConfigLoader(opts || {})\n const config = configLoader.loadConfig()\n state.createIndexer(config)\n\n return {\n apply(config, env) {\n return (\n (env.mode === \"development\" && env.command === \"serve\") ||\n (env.mode === \"production\" && env.command === \"build\")\n )\n },\n buildStart: async () => {\n state.buildIndex(state.buildCount > 0)\n state.buildCount++\n },\n configureServer: (server) => {\n if (!isDev) {\n return\n }\n state.initWatchers(opts?.configFile)\n server.watcher.on(\"add\", (path: string) => {\n if (path.endsWith(\".mdx\")) {\n state.handleChange({\n onComplete: () => {\n server.ws.send({type: \"full-reload\"})\n },\n })\n }\n })\n server.watcher.on(\"unlink\", (path: string) => {\n if (path.endsWith(\".mdx\")) {\n state.handleChange({\n onComplete: () => {\n server.ws.send({type: \"full-reload\"})\n },\n })\n }\n })\n state.servers.push(server)\n },\n handleHotUpdate: async ({file: updateFile, server}) => {\n const file = fixPath(updateFile)\n if (\n (!config.hotUpdateIgnore || !config.hotUpdateIgnore.test(file)) &&\n // ignore watched files. We watch for these separately.\n file !== state.configFilePath\n ) {\n if (\n state.docPropsDirectory &&\n file.startsWith(state.docPropsFilePath)\n ) {\n return []\n }\n\n if (updateFile.endsWith(\".mdx\")) {\n const mods: ModuleNode[] = []\n const files = state.buildIndex(true)\n\n const moduleByFile = server.moduleGraph.getModulesByFile(updateFile)\n if (!moduleByFile?.size) {\n console.debug(\"no module found for file, returning\", updateFile)\n return []\n }\n\n const virtualModule =\n server.moduleGraph.getModuleById(VIRTUAL_MODULE_ID)\n if (virtualModule) {\n // invalidate the plugin module so that the virtual file is refreshed\n server.moduleGraph.invalidateModule(virtualModule)\n // can't refresh the module here, otherwise we get react router hmr\n // conflicts. But we can send the updated site data to the site.\n server.ws.send({\n data: state.siteData,\n event: \"qui-docs-plugin:refresh-site-data\",\n type: \"custom\",\n })\n }\n if (files.some((file) => file.metadata.changed.frontmatter)) {\n console.debug(\n \"Frontmatter changed, reloading plugin to reflect changes in the page configuration\",\n )\n server.ws.send({type: \"full-reload\"})\n return []\n }\n return mods\n }\n }\n return []\n },\n load: (id): string | undefined => {\n if (id === VIRTUAL_MODULE_ID) {\n return `export const siteData = ${JSON.stringify(state.siteData)}`\n }\n return undefined\n },\n name: \"qui-mdx-vite-plugin\",\n resolveId: (id) => {\n if (id === \"@qualcomm-ui/mdx-vite-plugin\") {\n return VIRTUAL_MODULE_ID\n }\n return undefined\n },\n }\n}\n", "// Copyright (c) Qualcomm Technologies, Inc. and/or its subsidiaries.\n// SPDX-License-Identifier: BSD-3-Clause-Clear\n\nimport {type Config, type CosmiconfigResult, cosmiconfigSync} from \"cosmiconfig\"\n\nimport type {QuiDocsConfig} from \"../types\"\n\nimport {configSchema} from \"./config-schema\"\nimport {removeTrailingSlash} from \"./utils\"\n\ninterface LoadedCosmicConfig {\n config: Config\n filepath: string\n isEmpty?: boolean\n}\n\nexport interface ResolvedQuiDocsConfig extends QuiDocsConfig {\n appDirectory: string\n /**\n * full path to the cosmiconfig file.\n */\n filePath: string\n pageDirectory: string\n}\n\nexport interface ConfigLoaderOptions {\n /**\n * Path to the qui-docs config file. This is automatically detected if omitted.\n */\n configFile?: string\n}\n\nexport class ConfigLoader {\n private readonly options: ConfigLoaderOptions\n\n constructor(options: ConfigLoaderOptions) {\n this.options = options\n return this\n }\n\n private getCosmiconfig(): LoadedCosmicConfig {\n const explorer = cosmiconfigSync(\"qui-docs\")\n\n const result: CosmiconfigResult | null = this.options.configFile\n ? explorer.load(this.options.configFile)\n : explorer.search()\n\n if (!result) {\n throw new Error(\n \"Config file not found. Please consult the docs at https://docs.qui.qualcomm.com/guide/page-setup#config\",\n )\n }\n\n return result\n }\n\n private resolveConfigFromCosmiconfig(\n config: CosmiconfigResult,\n ): ResolvedQuiDocsConfig {\n const parsed = configSchema.safeParse(config!.config)\n if (!parsed.success) {\n console.dir(parsed.error.issues, {depth: 10})\n throw new Error(\"Failed to parse config file.\")\n }\n const conf = parsed.data\n return {\n ...conf,\n appDirectory: conf.appDirectory || \"app\",\n filePath: config!.filepath,\n pageDirectory: conf.pageDirectory\n ? removeTrailingSlash(conf.pageDirectory)\n : \"routes\",\n }\n }\n\n loadConfig(): ResolvedQuiDocsConfig {\n const config = this.getCosmiconfig()\n return this.resolveConfigFromCosmiconfig(config)\n }\n}\n", "// Copyright (c) Qualcomm Technologies, Inc. and/or its subsidiaries.\n// SPDX-License-Identifier: BSD-3-Clause-Clear\n\nimport {z, type ZodObject, type ZodSchema} from \"zod\"\n\nimport type {\n NavMeta,\n QuiDocsConfig,\n QuiDocsTypeDocOptions,\n RouteMeta,\n} from \"../types\"\n\nimport {implement} from \"./zod\"\n\nexport const navMetaSchema: ZodObject<{}> = implement<NavMeta>().with({\n id: z.never().optional(),\n sectionTitle: z.string().optional(),\n separator: z.boolean().optional(),\n})\n\nexport const routeMetaSchema: ZodSchema<RouteMeta> =\n implement<RouteMeta>().with({\n children: z.array(z.lazy(() => routeMetaSchema)).optional(),\n expanded: z.boolean().optional(),\n group: z.string().optional(),\n groupOrder: z.string().array().optional(),\n hidden: z.boolean().optional(),\n hideBreadcrumbs: z.boolean().optional(),\n hideFromSearch: z.boolean().optional(),\n hidePageLinks: z.boolean().optional(),\n hideSideNav: z.boolean().optional(),\n hideToc: z.boolean().optional(),\n id: z.string(),\n ignoreRouteMetaOrder: z.boolean().optional(),\n restricted: z.boolean().optional(),\n sectionTitle: z.never().optional(),\n separator: z.never().optional(),\n sideNavTitle: z.string().optional(),\n title: z.string().optional(),\n })\n\nconst typeDocPropsSchema = implement<QuiDocsTypeDocOptions>().with({\n includeInSearchIndex: z.boolean().optional(),\n})\n\nexport const configSchema = implement<QuiDocsConfig>().with({\n appDirectory: z.string().optional(),\n disableCache: z.boolean().optional(),\n headings: z\n .array(\n z.union([\n z.literal(\"h1\"),\n z.literal(\"h2\"),\n z.literal(\"h3\"),\n z.literal(\"h4\"),\n z.literal(\"h5\"),\n z.literal(\"h6\"),\n ]),\n )\n .optional(),\n hotUpdateIgnore: z.instanceof(RegExp).optional(),\n navConfig: z.array(z.union([routeMetaSchema, navMetaSchema])).optional(),\n pageDirectory: z.string().optional(),\n routingStrategy: z\n .union([\n z.literal(\"vite-generouted\"),\n z.function(z.tuple([z.string()]), z.array(z.string())),\n ])\n .optional(),\n typeDocProps: z.string().optional(),\n typeDocPropsOptions: typeDocPropsSchema.optional(),\n})\n", "// Copyright (c) Qualcomm Technologies, Inc. and/or its subsidiaries.\n// SPDX-License-Identifier: BSD-3-Clause-Clear\n\nimport {z} from \"zod\"\n\ntype Implements<Model> = {\n [key in keyof Model]-?: undefined extends Model[key]\n ? null extends Model[key]\n ? z.ZodNullableType<z.ZodOptionalType<z.ZodType<Model[key]>>>\n : z.ZodOptionalType<z.ZodType<Model[key]>>\n : null extends Model[key]\n ? z.ZodNullableType<z.ZodType<Model[key]>>\n : z.ZodType<Model[key]> | z.ZodDefault<z.ZodType<Model[key]>>\n}\n\nexport function implement<Model = never>() {\n return {\n with: <\n Schema extends Implements<Model> & {\n [unknownKey in Exclude<keyof Schema, keyof Model>]: never\n },\n >(\n schema: Schema,\n ) => z.object(schema),\n }\n}\n", "// Copyright (c) Qualcomm Technologies, Inc. and/or its subsidiaries.\n// SPDX-License-Identifier: BSD-3-Clause-Clear\n\nimport {z, type ZodObject} from \"zod\"\n\nimport type {PageFrontmatter} from \"@qualcomm-ui/mdx-common\"\n\nimport {implement} from \"./zod\"\n\nexport const isDefined = (\n value: string | boolean | object | null | undefined | number,\n): boolean => typeof value !== \"undefined\" && value !== null\n\nexport function defined<T>(value: T | null | undefined): value is T {\n return typeof value !== \"undefined\" && value !== null\n}\n\n/**\n * Used to validate the MDX frontmatter and emit warnings for pages that violate the\n * schema.\n */\nexport const frontmatterSchema: ZodObject<{}> =\n implement<PageFrontmatter>().with({\n categories: z.string().array().optional(),\n group: z.string().optional(),\n hidden: z.boolean().optional(),\n hideBreadcrumbs: z.boolean().optional(),\n hideFromSearch: z.boolean().optional(),\n hidePageLinks: z.boolean().optional(),\n hideSideNav: z.boolean().optional(),\n hideToc: z.boolean().optional(),\n id: z.string().optional(),\n restricted: z.boolean().optional(),\n sideNavTitle: z.string().optional(),\n title: z.string(),\n })\n\n/**\n * Winblows fix\n */\nexport function fixPath(str: string): string {\n return str.replaceAll(\"\\\\\", \"/\")\n}\n\n/**\n * Removes the trailing slash from a string.\n */\nexport function removeTrailingSlash(str: string): string {\n return str.endsWith(\"/\") ? str.substring(0, str.length - 1) : str\n}\n", "// Copyright (c) Qualcomm Technologies, Inc. and/or its subsidiaries.\n// SPDX-License-Identifier: BSD-3-Clause-Clear\n\nimport chalk from \"chalk\"\n\nimport type {\n NavItem,\n PageFrontmatter,\n PageMap,\n PageSection,\n} from \"@qualcomm-ui/mdx-common\"\nimport type {QuiPropTypes} from \"@qualcomm-ui/typedoc-common\"\n\nimport type {\n RouteMetaInternal,\n RouteMetaNavInternal,\n SearchIndexerOptions,\n} from \"../types\"\n\nimport {\n type CompiledMdxFile,\n type CompiledMdxFileMetadata,\n DocPropsIndexer,\n filterFileGlob,\n getCategoriesFromPathSegments,\n getPathnameFromPathSegments,\n getPathSegmentsFromFileName,\n getRouteMeta,\n type IndexedPage,\n type IndexedSection,\n MarkdownFileReader,\n MarkdownIndexer,\n NavBuilder,\n} from \"./services\"\nimport {transformRouteMetaArray} from \"./transform-route-meta-array\"\nimport {defined, fixPath} from \"./utils\"\n\nexport class SearchIndexer {\n private readonly docPropsIndexer: DocPropsIndexer\n private readonly markdownIndexer: MarkdownIndexer\n private readonly navBuilder: NavBuilder\n private readonly fileCache: MarkdownFileReader\n private readonly allowedHeadings: Set<string>\n private readonly metaJson: RouteMetaInternal\n private readonly routeMetaNav: Record<string, RouteMetaNavInternal> = {}\n\n get cachedFileCount(): number {\n return this.fileCache.cachedFileCount\n }\n\n get pageDocProps(): Record<string, Record<string, QuiPropTypes>> {\n return this._pageDocProps\n }\n private _pageDocProps: Record<string, Record<string, QuiPropTypes>> = {}\n\n get mdxFileCount(): number {\n return this._mdxFileCount\n }\n private _mdxFileCount: number = 0\n\n get navItems(): NavItem[] {\n return this.navBuilder.navItems\n }\n\n get pageMap(): PageMap {\n return this._pageMap\n }\n private _pageMap: PageMap = {}\n\n get searchIndex(): PageSection[] {\n return this._searchIndex\n }\n private _searchIndex: PageSection[] = []\n\n reset(): void {\n this.fileCache.reset()\n this._pageMap = {}\n this._searchIndex = []\n }\n\n constructor(\n public config: SearchIndexerOptions,\n public logWarnings = true,\n // enable composition by making these classes replaceable\n addons: {\n docPropsIndexer?: DocPropsIndexer\n fileCache?: MarkdownFileReader\n markdownIndexer?: MarkdownIndexer\n navBuilder?: NavBuilder\n } = {},\n ) {\n this.allowedHeadings = new Set<string>(\n Array.from(config?.headings || [\"h2\", \"h3\", \"h4\"]),\n )\n this.metaJson = transformRouteMetaArray(\n this.config.navConfig ?? [],\n this.routeMetaNav,\n )\n\n this.markdownIndexer =\n addons.markdownIndexer || new MarkdownIndexer(this.allowedHeadings)\n this.navBuilder =\n addons.navBuilder || new NavBuilder(this.metaJson, this.routeMetaNav)\n this.docPropsIndexer =\n addons.docPropsIndexer ||\n new DocPropsIndexer(this.config.typeDocProps ?? {})\n this.fileCache =\n addons.fileCache ||\n new MarkdownFileReader(\n process.env.NODE_ENV === \"development\" && !this.config.disableCache,\n )\n }\n\n /**\n * Resolves a page's properties from the combined frontmatter and RouteMeta.\n * RouteMeta properties take precedence.\n */\n private getPageEntry(\n filepath: string,\n frontmatter: Partial<PageFrontmatter>,\n ): PageSection {\n const pagePath = filepath.replace(this.config.srcDir, \"\")\n\n const pathSegments = getPathSegmentsFromFileName(\n pagePath,\n this.config.pageDirectory,\n this.config.routingStrategy,\n )\n\n const pathname = getPathnameFromPathSegments(pathSegments)\n\n const routeMeta =\n getRouteMeta(\n pathSegments.length === 0\n ? frontmatter.id\n ? [frontmatter.id]\n : [\"_index\"]\n : pathSegments,\n this.metaJson,\n ) ?? {}\n\n return {\n categories:\n frontmatter.categories ??\n getCategoriesFromPathSegments(\n pathSegments,\n this.metaJson,\n routeMeta?.title || frontmatter.title || \"\",\n ),\n hidden: defined(routeMeta.hidden) ? routeMeta.hidden : frontmatter.hidden,\n hideBreadcrumbs: defined(routeMeta.hideBreadcrumbs)\n ? routeMeta.hideBreadcrumbs\n : frontmatter.hideBreadcrumbs,\n hideFromSearch: defined(routeMeta.hideFromSearch)\n ? routeMeta.hideFromSearch\n : frontmatter.hideFromSearch,\n hidePageLinks: defined(routeMeta.hidePageLinks)\n ? routeMeta.hidePageLinks\n : frontmatter.hidePageLinks,\n hideSideNav: defined(routeMeta.hideSideNav)\n ? routeMeta.hideSideNav\n : frontmatter.hideSideNav,\n hideToc: defined(routeMeta.hideToc)\n ? routeMeta.hideToc\n : frontmatter.hideToc,\n id: pagePath,\n pathname,\n pathSegments,\n restricted: defined(routeMeta.restricted)\n ? routeMeta.restricted\n : frontmatter.restricted,\n title: defined(routeMeta.title)\n ? routeMeta.title || \"\"\n : frontmatter.title || \"\",\n }\n }\n\n /**\n * Parses an MDX file to extract the site data for the nav items, doc props,\n * breadcrumbs, and search index.\n */\n private compileMdxFile(filePath: string): CompiledMdxFile {\n const {cached, fileContents, frontmatter} =\n this.fileCache.readFile(filePath)\n\n const metadata: CompiledMdxFileMetadata = {\n changed: {},\n filePath,\n }\n if (!cached) {\n const previousData = this.fileCache.readCache(filePath)\n if (previousData) {\n const cachedFm = JSON.stringify(previousData.frontmatter)\n const currentFm = JSON.stringify(frontmatter)\n if (cachedFm !== currentFm) {\n metadata.changed.frontmatter = true\n }\n }\n }\n\n this.docPropsIndexer.reset()\n this.markdownIndexer.reset()\n\n const defaultSection: PageSection = this.getPageEntry(filePath, frontmatter)\n if (!defaultSection.categories.length && defaultSection.title) {\n defaultSection.categories = [defaultSection.title]\n }\n\n if (!defaultSection.hidden) {\n this.navBuilder.add(defaultSection, frontmatter)\n }\n\n this._pageMap[defaultSection.pathname] = defaultSection\n\n let indexedPage: IndexedPage\n\n try {\n indexedPage = cached?.page\n ? cached.page\n : this.markdownIndexer.parseMarkdown(fileContents, frontmatter)\n } catch (error) {\n console.debug(\n `${chalk.yellowBright.bold(\n \"Failed to parse mdx page content.\",\n )} ${chalk.blueBright.bold(filePath)}`,\n )\n\n return {metadata, pageSections: [defaultSection]}\n }\n\n const {sections, toc} = indexedPage\n\n if (toc.length) {\n this._pageMap[defaultSection.pathname].toc = toc\n }\n\n let docPropSections: IndexedSection[] = []\n let docProps: Record<string, QuiPropTypes> = {}\n\n if (this.config.typeDocProps) {\n docPropSections =\n cached?.pageDocPropSections ||\n (this.docPropsIndexer.build(fileContents, toc) ?? [])\n docProps = cached?.pageDocProps || this.docPropsIndexer.getDocProps()\n }\n\n if (docPropSections.length) {\n this._pageDocProps[defaultSection.pathname] = docProps\n }\n\n this.fileCache.updateCache(filePath, fileContents, {\n frontmatter,\n page: indexedPage,\n pageDocProps: docProps,\n pageDocPropSections: docPropSections,\n })\n\n // omit entries from pages that are explicitly omitted from the index.\n if (frontmatter.hideFromSearch) {\n return {metadata, pageSections: [defaultSection]}\n }\n\n if (!sections.length && !docPropSections.length) {\n return {metadata, pageSections: [defaultSection]}\n }\n\n const sectionReturn: PageSection[] = [\n ...this.formatSections(sections, defaultSection, false),\n ]\n\n if (this.config.typeDocPropsOptions?.includeInSearchIndex) {\n sectionReturn.push(\n ...this.formatSections(docPropSections, defaultSection, true),\n )\n }\n\n return {metadata, pageSections: sectionReturn}\n }\n\n private formatSections(\n sections: IndexedSection[],\n {toc: _toc, ...defaultSection}: PageSection,\n isDocProp: boolean,\n ): PageSection[] {\n return sections.map((section, index): PageSection => {\n const content = section.content.map((c) => c.text.join(\" \")).join(\" \")\n return {\n ...defaultSection,\n content: content || undefined,\n heading: section.heading?.textContent ?? defaultSection.title,\n headingLevel: section.heading?.headingLevel,\n href:\n section.heading &&\n (this.allowedHeadings.has(section.heading.tagName) || isDocProp)\n ? `${defaultSection.pathname}#${section.heading.id}`\n : defaultSection.pathname,\n id: `${defaultSection.id}-${index}${isDocProp ? \"-prop\" : \"\"}`,\n isDocProp: isDocProp || undefined,\n richContent: section.richContent,\n }\n })\n }\n\n private compileTsxFile(filepath: string) {\n const entry = this.getPageEntry(filepath, {})\n\n const routeMeta = getRouteMeta(\n entry.pathSegments.length === 0 ? [\"_index\"] : entry.pathSegments,\n this.metaJson,\n )\n\n if (!routeMeta) {\n return null\n }\n\n if (!entry.hidden) {\n this.navBuilder.add(entry, {}, routeMeta)\n }\n\n this._pageMap[entry.pathname] = entry\n\n return entry\n }\n\n buildIndex(\n inputFileGlob: string[],\n logWarnings: boolean = true,\n ): CompiledMdxFile[] {\n this.logWarnings = logWarnings\n this.fileCache.logWarnings = logWarnings\n // Windows path fix\n const fileGlob = inputFileGlob.map(fixPath)\n this.navBuilder.reset()\n this.reset()\n\n const mdxFileGlob = filterFileGlob(\n fileGlob,\n \"mdx\",\n this.config.srcDir,\n this.config.routingStrategy,\n )\n\n this._mdxFileCount = mdxFileGlob.length\n const compiledFiles = mdxFileGlob.map((file) => this.compileMdxFile(file))\n\n const mdxIndex = compiledFiles\n .map((fileData) => fileData.pageSections)\n .flat()\n\n filterFileGlob(\n fileGlob,\n \"tsx\",\n this.config.srcDir,\n this.config.routingStrategy,\n ).map((file) => this.compileTsxFile(file))\n\n this._searchIndex.push(...mdxIndex.filter((entry) => !entry.hideFromSearch))\n\n this.navBuilder.build()\n\n return compiledFiles\n }\n}\n", "// Copyright (c) Qualcomm Technologies, Inc. and/or its subsidiaries.\n// SPDX-License-Identifier: BSD-3-Clause-Clear\n\nimport type {MdxJsxAttribute} from \"mdast-util-mdx-jsx\"\nimport remarkMdx from \"remark-mdx\"\nimport remarkParse from \"remark-parse\"\nimport remarkStringify from \"remark-stringify\"\nimport {type Plugin, unified} from \"unified\"\nimport {visit} from \"unist-util-visit\"\n\nimport {\n type PageDocProps,\n type PageHeading,\n type PagePropType,\n UniqueIdService,\n} from \"@qualcomm-ui/mdx-common\"\nimport type {\n QuiPropDeclaration,\n QuiPropTypes,\n} from \"@qualcomm-ui/typedoc-common\"\n\nimport type {IndexedSection} from \"../markdown\"\n\nfunction extractPickPropsRecord(\n node: MdxJsxAttribute,\n): Record<string, string[]> | null {\n if (\n node.name !== \"unionWithPick\" ||\n !node.value ||\n typeof node.value === \"string\"\n ) {\n return null\n }\n\n const estree = node.value.data?.estree\n if (!estree?.body?.[0] || estree.body[0].type !== \"ExpressionStatement\") {\n return null\n }\n\n const expression = estree.body[0].expression\n if (expression.type !== \"ObjectExpression\") {\n return null\n }\n\n const result: Record<string, string[]> = {}\n\n for (const property of expression.properties) {\n if (property.type !== \"Property\" || property.key.type !== \"Identifier\") {\n continue\n }\n\n if (property.value.type !== \"ArrayExpression\") {\n continue\n }\n\n const key = property.key.name\n const values: string[] = []\n\n for (const element of property.value.elements) {\n if (element?.type === \"Literal\" && typeof element.value === \"string\") {\n values.push(element.value)\n }\n }\n\n result[key] = values\n }\n\n return result\n}\n\nconst targetMdxElements: string[] = [\n \"TypeDocProps\",\n \"TypeDocAttributes\",\n \"TypeDocAngularAttributes\",\n]\n\ninterface DocPropEntry {\n name: string\n omitFrom?: string[]\n}\n\nexport class DocPropsIndexer {\n docPropsEntries: DocPropEntry[] = []\n idService: UniqueIdService = new UniqueIdService()\n private readonly props: Record<string, QuiPropTypes>\n private pageDocProps: PageDocProps = {}\n\n constructor(props: Record<string, QuiPropTypes>) {\n this.props = props\n }\n\n reset(): void {\n this.idService.reset()\n this.docPropsEntries = []\n }\n\n private extractNamesFromAttribute(attr: MdxJsxAttribute): string[] {\n if (!attr.value) {\n return []\n }\n\n if (typeof attr.value === \"string\") {\n return [attr.value]\n }\n\n if (attr.value.type === \"mdxJsxAttributeValueExpression\") {\n const estree = attr.value.data?.estree\n if (!estree?.body?.[0] || estree.body[0].type !== \"ExpressionStatement\") {\n return []\n }\n\n const expression = estree.body[0].expression\n\n if (expression.type === \"ArrayExpression\") {\n const names: string[] = []\n for (const element of expression.elements) {\n if (\n element?.type === \"Literal\" &&\n typeof element.value === \"string\"\n ) {\n names.push(element.value)\n }\n }\n return names\n }\n\n // Handle single string expression\n if (\n expression.type === \"Literal\" &&\n typeof expression.value === \"string\"\n ) {\n return [expression.value]\n }\n }\n\n return []\n }\n\n /**\n * Finds all JSX `<TypeDocProps />` nodes on the current page and adds their names\n * to an array. Once all nodes have been collected, we process them into\n * `PageSection` entries for the search index.\n */\n getTypeDocPropsNodes: Plugin = () => {\n return (tree, _file, done) => {\n visit(tree, \"mdxJsxFlowElement\", (node: any) => {\n if (node && \"name\" in node && targetMdxElements.includes(node.name)) {\n const nameAttr = node.attributes?.find(\n (attr: MdxJsxAttribute) => attr.name === \"name\",\n )\n const omitFromAttr = node.attributes?.find(\n (attr: MdxJsxAttribute) => attr.name === \"omitFrom\",\n )\n const omitFrom = omitFromAttr\n ? this.extractNamesFromAttribute(omitFromAttr)\n : undefined\n\n if (nameAttr) {\n const names = this.extractNamesFromAttribute(nameAttr)\n for (const name of names) {\n this.docPropsEntries.push({name, omitFrom})\n if (name.endsWith(\"Props\")) {\n // also index the corresponding component for lookup on this page.\n this.docPropsEntries.push({name: name.slice(0, -5), omitFrom})\n }\n }\n }\n\n const unionWithPickAttr: MdxJsxAttribute = node.attributes?.find(\n (attr: MdxJsxAttribute) => attr.name === \"unionWithPick\",\n )\n if (unionWithPickAttr) {\n try {\n const unionWithPick = extractPickPropsRecord(unionWithPickAttr)\n if (unionWithPick) {\n this.docPropsEntries.push(\n ...Object.keys(unionWithPick).map((entry) => ({\n name: entry,\n omitFrom,\n })),\n )\n }\n } catch (e) {}\n }\n }\n })\n done()\n }\n }\n\n build(fileContents: string, toc: PageHeading[]): IndexedSection[] | null {\n // parse the Markdown into an AST\n unified()\n .use(remarkMdx)\n // find the TypeDocProp nodes\n .use(this.getTypeDocPropsNodes)\n .use(remarkParse)\n .use(remarkStringify)\n .processSync(fileContents)\n\n if (!this.docPropsEntries.length) {\n return null\n }\n\n for (const item of toc) {\n this.idService.add(item.id)\n }\n\n return this.docPropsEntries\n .map((entry): IndexedSection[] => {\n const propTypes = this.props[entry.name]\n if (!propTypes) {\n return []\n }\n\n const omittedProps = new Set<string>(\n (entry.omitFrom ?? [])\n .map((entry) => {\n const propTypes = this.props[entry]\n if (!propTypes) {\n return []\n }\n return [\n propTypes.props,\n propTypes.input,\n propTypes.output,\n propTypes.publicMethods,\n ].reduce((acc: string[], current) => {\n if (current) {\n acc.push(...current.map((prop) => prop.name))\n }\n return acc\n }, [])\n })\n .flat(1)\n .filter(Boolean),\n )\n\n const sections: IndexedSection[] = []\n\n const assembleProps = (\n propsInput: QuiPropDeclaration[] | undefined,\n ): PagePropType[] | undefined => {\n if (!propsInput) {\n return undefined\n }\n const props: PagePropType[] = []\n for (const prop of propsInput) {\n if (omittedProps.has(prop.name)) {\n continue\n }\n const id = this.idService.add(prop.name)\n props.push({...prop, id})\n sections.push(this.assembleProp(prop, id))\n }\n return props\n }\n\n this.pageDocProps[entry.name] = {\n ...this.props[entry.name],\n input: assembleProps(propTypes.input),\n output: assembleProps(propTypes.output),\n props: assembleProps(propTypes.props),\n publicMethods: assembleProps(propTypes.publicMethods),\n }\n return sections\n })\n .flat()\n }\n\n getDocProps(): PageDocProps {\n return this.docPropsEntries.reduce((acc: PageDocProps, entry) => {\n const propTypes = this.pageDocProps[entry.name]\n // TODO: convert code comments to HTML using rehype. Remove markdown-to-jsx\n // in @qualcomm-ui/react-mdx library.\n if (propTypes) {\n acc[entry.name] = propTypes\n }\n return acc\n }, {})\n }\n\n private assembleProp(prop: QuiPropDeclaration, id: string): IndexedSection {\n const name = prop.name\n\n const heading: PageHeading = {\n headingLevel: 4,\n id,\n tagName: \"a\",\n textContent: name,\n }\n\n const comment = prop.comment\n if (!comment) {\n return {content: [], heading, richContent: []}\n }\n\n const content = {\n tagName: \"p\",\n text: [\n comment.summary\n .map((entry) => entry.text.replaceAll(\"\\n\", \" \"))\n .join(\"\"),\n ],\n }\n return {content: [content], heading, richContent: []}\n }\n}\n", "// Copyright (c) Qualcomm Technologies, Inc. and/or its subsidiaries.\n// SPDX-License-Identifier: BSD-3-Clause-Clear\n\nimport chalk from \"chalk\"\nimport {createHash} from \"node:crypto\"\nimport {readFileSync} from \"node:fs\"\nimport remarkFrontmatter from \"remark-frontmatter\"\nimport remarkParse from \"remark-parse\"\nimport remarkParseFrontmatter from \"remark-parse-frontmatter\"\nimport remarkStringify from \"remark-stringify\"\nimport {unified} from \"unified\"\n\nimport type {PageFrontmatter} from \"@qualcomm-ui/mdx-common\"\nimport type {QuiPropTypes} from \"@qualcomm-ui/typedoc-common\"\n\nimport {frontmatterSchema} from \"../../utils\"\n\nimport type {IndexedPage, IndexedSection} from \"./markdown.types\"\n\ninterface PageCache {\n frontmatter: PageFrontmatter\n md5: string\n page: IndexedPage\n pageDocProps: Record<string, QuiPropTypes>\n pageDocPropSections: IndexedSection[]\n}\n\nexport class MarkdownFileReader {\n cachedFileCount = 0\n logWarnings = true\n private mdxCache: Record<string, PageCache> = {}\n\n constructor(public enabled: boolean) {}\n\n private hash(input: string) {\n return createHash(\"md5\").update(input).digest(\"hex\")\n }\n\n reset(): void {\n this.cachedFileCount = 0\n }\n\n readCache(filePath: string): PageCache | null {\n return this.mdxCache[filePath] || null\n }\n\n private checkCache(\n filePath: string,\n fileContents: string,\n ): Omit<PageCache, \"md5\"> | undefined {\n if (!this.enabled) {\n return\n }\n\n const fileMd5 = this.hash(fileContents)\n const cached = this.mdxCache[filePath]\n\n if (cached?.md5 !== fileMd5) {\n return\n }\n\n this.cachedFileCount++\n\n return {\n frontmatter: cached.frontmatter,\n page: cached.page,\n pageDocProps: cached.pageDocProps,\n pageDocPropSections: cached.pageDocPropSections,\n }\n }\n\n readFile(filepath: string): {\n cached: Omit<PageCache, \"md5\"> | undefined\n fileContents: string\n frontmatter: PageFrontmatter\n } {\n const fileContents = readFileSync(filepath, \"utf-8\")\n\n const cached = this.checkCache(filepath, fileContents)\n\n let file:\n | {data: {frontmatter: PageFrontmatter}}\n | ReturnType<typeof unified.processSync>\n if (cached?.frontmatter) {\n file = {data: {frontmatter: cached.frontmatter}}\n } else {\n // only parse the yaml section because we just need the frontmatter at this\n // stage.\n const yamlSection = fileContents.substring(\n 0,\n fileContents.indexOf(\"\\n---\") + 4,\n )\n file = unified()\n .use(remarkParse)\n .use(remarkFrontmatter, [\"yaml\"])\n .use(remarkParseFrontmatter)\n .use(remarkStringify)\n .processSync(yamlSection)\n }\n\n const frontmatter: PageFrontmatter = (file.data\n .frontmatter as PageFrontmatter) ?? {title: \"\"}\n\n if (!frontmatter.title) {\n const lines = fileContents.split(\"\\n\")\n const fallbackTitle = lines.find((line) => line.startsWith(\"# \"))\n if (fallbackTitle) {\n frontmatter.title = fallbackTitle.substring(2).trim()\n }\n }\n // TODO: permit omitting title from frontmatter if provided in the navConfig\n if (!frontmatter.title && this.logWarnings) {\n console.debug(chalk.red.bold(\"Missing title:\"), filepath)\n }\n\n const parsedFrontmatter = frontmatterSchema.safeParse(frontmatter)\n\n if (!parsedFrontmatter.success) {\n console.debug(\n `${chalk.redBright.bold(\"Invalid frontmatter detected for file\")}: ${filepath}\\n`,\n )\n console.debug(chalk.redBright.bold(\"Please check the following fields:\"))\n parsedFrontmatter.error.issues.map((issue: any) => {\n console.debug(`- ${issue.path.join(\".\")}`)\n })\n }\n\n return {cached, fileContents, frontmatter}\n }\n\n updateCache(\n filepath: string,\n fileContents: string,\n cacheData: Omit<PageCache, \"md5\">,\n ): void {\n if (this.enabled) {\n this.mdxCache[filepath] = {...cacheData, md5: this.hash(fileContents)}\n }\n }\n}\n", "// Copyright (c) Qualcomm Technologies, Inc. and/or its subsidiaries.\n// SPDX-License-Identifier: BSD-3-Clause-Clear\n\nimport type {Element} from \"hast\"\nimport {fromHtml} from \"hast-util-from-html\"\nimport {toText} from \"hast-util-to-text\"\nimport {clone, size} from \"lodash-es\"\nimport rehypeParse from \"rehype-parse\"\nimport rehypeStringify from \"rehype-stringify\"\nimport remarkGfm from \"remark-gfm\"\nimport remarkMdx from \"remark-mdx\"\nimport remarkParse from \"remark-parse\"\nimport remarkRehype from \"remark-rehype\"\nimport {unified} from \"unified\"\n\nimport type {\n PageFrontmatter,\n PageHeading,\n RichContentNode,\n} from \"@qualcomm-ui/mdx-common\"\n\nimport {rehypeSlug} from \"../../../rehype/rehype-slug\"\nimport {remarkAlerts} from \"../../../remark/remark-alerts\"\n\nimport type {IndexedPage, IndexedSection} from \"./markdown.types\"\nimport {remarkRemoveMermaidCodeBlocks} from \"./remark-remove-code-blocks\"\nimport {remarkRemoveJsx} from \"./remark-remove-jsx\"\n\n/**\n * Parses an html string into an AST and builds the search index from the tree.\n */\nexport class MarkdownIndexer {\n private sections: IndexedSection[] = []\n private currentSection!: IndexedSection\n private readonly headingLevels: Set<string>\n\n reset(): void {\n this.sections = []\n this._toc = []\n this.resetSection()\n }\n\n resetSection(): void {\n this.currentSection = {\n content: [],\n heading: null,\n richContent: [],\n }\n }\n\n get toc(): PageHeading[] {\n return this._toc\n }\n private _toc: PageHeading[] = []\n\n constructor(headingLevels: Set<string>) {\n this.resetSection()\n this.headingLevels = headingLevels\n }\n\n private appendTocItem(heading: PageHeading) {\n this._toc.push(heading)\n }\n\n private warn(...data: any[]) {\n if (process.env.DEBUG) {\n console.warn(...data)\n }\n // TODO: remove\n console.warn(...data)\n }\n\n private isHeading(element: Element): boolean {\n return this.headingLevels.has(element.tagName)\n }\n\n private isRootHeading(element: Element) {\n return element.tagName === \"h1\"\n }\n\n /**\n * Parses a heading Element node into the indexed heading data structure.\n */\n private parseHeading(headingElement: Element): PageHeading {\n const id = headingElement.properties.id\n const text = toText(headingElement)\n\n return {\n headingLevel: parseInt(headingElement.tagName.charAt(1)),\n id: id ? `${id}` : \"\",\n tagName: headingElement.tagName,\n textContent: text,\n }\n }\n\n private parseElementNode(element: Element) {\n const isRootHeading = this.isRootHeading(element)\n if (this.isHeading(element) || isRootHeading) {\n const currentSection = this.currentSection\n if (currentSection.heading) {\n // the old section is now done, so we add it and start a new one.\n this.sections.push(clone(this.currentSection))\n this.resetSection()\n }\n const heading = this.parseHeading(element)\n if (!isRootHeading) {\n this.appendTocItem(heading)\n }\n this.currentSection.heading = heading\n return\n }\n\n this.currentSection.richContent.push(element as RichContentNode)\n\n const text = toText(element, {whitespace: \"pre-wrap\"})\n .replaceAll(\"\\n\", \"\\t\")\n .split(\"\\t\")\n .filter(size)\n\n if (text.length) {\n this.currentSection.content.push({\n tagName: element.tagName,\n text,\n })\n }\n }\n\n parseMarkdown(\n fileContents: string | Buffer,\n frontmatter: PageFrontmatter,\n ): IndexedPage {\n const file = unified()\n .use(remarkMdx)\n .use(remarkRemoveJsx)\n .use(remarkRemoveMermaidCodeBlocks)\n .use(remarkParse)\n .use(remarkGfm)\n .use(remarkAlerts)\n .use(remarkRehype)\n .use(rehypeStringify)\n .processSync(fileContents)\n\n let contents = file.toString()\n\n contents = contents.substring(contents.indexOf(\"<h1>\"))\n\n for (const [key, value] of Object.entries(frontmatter)) {\n if (typeof value === \"string\" || typeof value === \"number\") {\n contents = contents.replaceAll(`frontmatter.${key}`, `${value}`)\n }\n }\n\n const htmlAst = unified()\n .data(\"settings\", {fragment: true})\n .use(rehypeParse)\n .use(rehypeStringify)\n .use(rehypeSlug)\n .processSync(contents)\n\n contents = htmlAst.toString()\n\n return this.build(contents)\n }\n\n build(html: string): IndexedPage {\n const tree = fromHtml(html, {fragment: true})\n\n for (const child of tree.children) {\n if (child.type === \"element\") {\n this.parseElementNode(child)\n }\n }\n\n // The parser processes sections in order and only appends the content once a\n // new section is encountered. We manually account for the final section here.\n if (this.currentSection.heading?.textContent) {\n this.sections.push(clone(this.currentSection))\n }\n\n return {\n sections: this.sections,\n toc: this.toc,\n }\n }\n}\n", "// Copyright (c) Qualcomm Technologies, Inc. and/or its subsidiaries.\n// SPDX-License-Identifier: BSD-3-Clause-Clear\n\nimport type {Root} from \"hast\"\nimport {headingRank} from \"hast-util-heading-rank\"\nimport {toString} from \"hast-util-to-string\"\nimport type {Plugin} from \"unified\"\nimport {visit} from \"unist-util-visit\"\n\nexport interface RehypeSlugOptions {\n /**\n * @default ['h2', 'h3', 'h4']\n */\n allowedHeadings?: string[]\n prefix?: string\n}\n\nconst emptyOptions: RehypeSlugOptions = {}\n\n/**\n * Converts heading text to URL-friendly slugs. Converts multi-word and PascalCase\n * text to kebab-case. Lowercases single sentence-case words. Appends counter for\n * duplicate slugs.\n */\nexport const rehypeSlug: Plugin<[RehypeSlugOptions?], Root> = (\n options: RehypeSlugOptions | null | undefined,\n) => {\n const settings = options || emptyOptions\n const prefix = settings.prefix || \"\"\n const allowedHeadings = new Set<string>(\n settings.allowedHeadings || [\"h2\", \"h3\", \"h4\"],\n )\n const seenIds = new Map<string, number>()\n\n function createSlug(text: string): string {\n const cleaned = text\n .replace(/[<>]/g, \"\")\n .replace(/[^\\w\\s-]/g, \"\")\n .trim()\n\n let slug: string\n if (cleaned.includes(\" \")) {\n slug = cleaned\n .toLowerCase()\n .replace(/\\s+/g, \"-\")\n .replace(/^-+|-+$/g, \"\")\n } else if ((cleaned.match(/[A-Z]/g) || []).length >= 2) {\n slug = cleaned\n .replace(/([a-z0-9])([A-Z])/g, \"$1-$2\")\n .replace(/([A-Z]+)([A-Z][a-z])/g, \"$1-$2\")\n .toLowerCase()\n } else {\n slug = cleaned.toLowerCase()\n }\n\n const count = seenIds.get(slug) || 0\n seenIds.set(slug, count + 1)\n return count > 0 ? `${slug}-${count}` : slug\n }\n\n return (tree) => {\n seenIds.clear()\n visit(tree, \"element\", function (node) {\n if (\n headingRank(node) &&\n !node.properties.id &&\n allowedHeadings.has(node.tagName)\n ) {\n node.properties.id = prefix + createSlug(toString(node))\n }\n })\n }\n}\n", "// Copyright (c) Qualcomm Technologies, Inc. and/or its subsidiaries.\n// SPDX-License-Identifier: BSD-3-Clause-Clear\n\nimport type {PhrasingContent, Root} from \"mdast\"\nimport type {Plugin} from \"unified\"\nimport {visit} from \"unist-util-visit\"\n\nconst alertLegacyRegex = /^\\[!(NOTE|TIP|SUCCESS|WARNING|CAUTION)(\\/.*)?\\]/i\n\n/**\n * Alerts are a Markdown extension based on the blockquote syntax that you can use\n * to emphasize critical information. On GitHub, they are displayed with distinctive\n * colors and icons to indicate the significance of the content.\n * https://docs.github.com/en/get-started/writing-on-github/getting-started-with-writing-and-formatting-on-github/basic-writing-and-formatting-syntax#alerts\n */\nexport const remarkAlerts: Plugin<[], Root> = () => {\n return (tree) => {\n visit(tree, \"blockquote\", (node) => {\n let alertType = \"\"\n let title = \"\"\n let isNext = true\n const child = node.children.map((item) => {\n if (isNext && item.type === \"paragraph\") {\n const firstNode = item.children[0]\n const text = firstNode.type === \"text\" ? firstNode.value : \"\"\n const reg = alertLegacyRegex\n const match = text.match(reg)\n if (match) {\n isNext = false\n alertType = match[1].toLocaleLowerCase()\n title = match[2] || alertType.toLocaleUpperCase()\n if (text.includes(\"\\n\")) {\n item.children[0] = {\n type: \"text\",\n value: text.replace(reg, \"\").replace(/^\\n+/, \"\"),\n }\n }\n\n if (!text.includes(\"\\n\")) {\n const itemChild: PhrasingContent[] = []\n item.children.forEach((item: any, idx: number) => {\n if (idx === 0) {\n return\n }\n if (idx === 1 && item.type === \"break\") {\n return\n }\n itemChild.push(item)\n })\n item.children = [...itemChild]\n }\n }\n }\n return item\n })\n\n title = title.replace(/^\\//, \"\")\n\n if (!!alertType) {\n node.data = {\n hName: \"div\",\n hProperties: {\n class: `qui-notification__root`,\n \"data-emphasis\":\n alertToEmphasis[alertType as IconType] || \"neutral\",\n \"data-orientation\": \"vertical\",\n dir: \"auto\",\n },\n }\n node.children = [\n {\n children: [getAlertIcon(alertType as IconType)],\n data: {\n hProperties: {\n class: \"qui-notification__icon\",\n \"data-part\": \"status-icon\",\n \"data-scope\": \"inline-notification\",\n },\n },\n type: \"paragraph\",\n },\n {\n children: [\n {\n type: \"text\",\n value: title,\n },\n ],\n data: {\n hProperties: {\n class: \"qui-notification__label\",\n dir: \"auto\",\n },\n },\n type: \"paragraph\",\n },\n {\n children: child,\n data: {\n hName: \"div\",\n hProperties: {\n class: `qui-notification__description`,\n dir: \"auto\",\n },\n },\n type: \"blockquote\",\n },\n ]\n }\n })\n }\n}\n\nexport function getAlertIcon(type: IconType): PhrasingContent {\n const svgChildren = svgData[type] ?? []\n return {\n children: svgChildren,\n data: {\n hName: \"svg\",\n hProperties: {\n ariaHidden: \"true\",\n class: \"lucide\",\n fill: \"transparent\",\n height: \"20\",\n stroke: \"currentColor\",\n strokeLinecap: \"round\",\n strokeLinejoin: \"round\",\n strokeWidth: \"2\",\n viewBox: \"0 0 24 24\",\n width: \"20\",\n },\n },\n type: \"emphasis\",\n }\n}\n\ntype IconType = \"note\" | \"tip\" | \"success\" | \"warning\" | \"caution\"\n\n/**\n * These SVG children correspond to the lucide icons matching our\n * {@link https://react.qui.qualcomm.com/components/inline-alert | Alert} component.\n */\nconst svgData: Record<IconType, PhrasingContent[]> = {\n caution: [\n {\n children: [],\n data: {\n hName: \"polygon\",\n hProperties: {\n points:\n \"7.86 2 16.14 2 22 7.86 22 16.14 16.14 22 7.86 22 2 16.14 2 7.86 7.86 2\",\n },\n },\n type: \"emphasis\",\n },\n {\n children: [],\n data: {\n hName: \"line\",\n hProperties: {\n x1: \"12\",\n x2: \"12\",\n y1: \"8\",\n y2: \"12\",\n },\n },\n type: \"emphasis\",\n },\n {\n children: [],\n data: {\n hName: \"line\",\n hProperties: {\n x1: \"12\",\n x2: \"12.01\",\n y1: \"16\",\n y2: \"16\",\n },\n },\n type: \"emphasis\",\n },\n ],\n note: [\n {\n children: [],\n data: {\n hName: \"circle\",\n hProperties: {\n cx: \"12\",\n cy: \"12\",\n r: \"10\",\n },\n },\n type: \"emphasis\",\n },\n {\n children: [],\n data: {\n hName: \"path\",\n hProperties: {\n d: \"M12 16v-4\",\n },\n },\n type: \"emphasis\",\n },\n {\n children: [],\n data: {\n hName: \"path\",\n hProperties: {\n d: \"M12 8h.01\",\n },\n },\n type: \"emphasis\",\n },\n ],\n success: [\n {\n children: [],\n data: {\n hName: \"path\",\n hProperties: {\n d: \"M20 6 9 17l-5-5\",\n },\n },\n type: \"emphasis\",\n },\n ],\n tip: [\n {\n children: [],\n data: {\n hName: \"path\",\n hProperties: {\n d: \"M15 14c.2-1 .7-1.7 1.5-2.5 1-.9 1.5-2.2 1.5-3.5A6 6 0 0 0 6 8c0 1 .2 2.2 1.5 3.5.7.7 1.3 1.5 1.5 2.5\",\n },\n },\n type: \"emphasis\",\n },\n {\n children: [],\n data: {\n hName: \"path\",\n hProperties: {\n d: \"M9 18h6\",\n },\n },\n type: \"emphasis\",\n },\n {\n children: [],\n data: {\n hName: \"path\",\n hProperties: {\n d: \"M10 22h4\",\n },\n },\n type: \"emphasis\",\n },\n ],\n warning: [\n {\n children: [],\n data: {\n hName: \"path\",\n hProperties: {\n d: \"m21.73 18-8-14a2 2 0 0 0-3.48 0l-8 14A2 2 0 0 0 4 21h16a2 2 0 0 0 1.73-3\",\n },\n },\n type: \"emphasis\",\n },\n {\n children: [],\n data: {\n hName: \"path\",\n hProperties: {\n d: \"M12 9v4\",\n },\n },\n type: \"emphasis\",\n },\n {\n children: [],\n data: {\n hName: \"path\",\n hProperties: {\n d: \"M12 17h.01\",\n },\n },\n type: \"emphasis\",\n },\n ],\n}\n\nconst alertToEmphasis: Record<IconType, string> = {\n caution: \"danger\",\n note: \"neutral\",\n success: \"success\",\n tip: \"info\",\n warning: \"warning\",\n}\n", "// Copyright (c) Qualcomm Technologies, Inc. and/or its subsidiaries.\n// SPDX-License-Identifier: BSD-3-Clause-Clear\n\nimport type {Plugin} from \"unified\"\nimport {remove} from \"unist-util-remove\"\n\nexport const remarkRemoveMermaidCodeBlocks: Plugin = () => {\n return (tree, _file, done) => {\n remove(tree, (node: any) => node.type === \"code\" && node.lang === \"mermaid\")\n done()\n }\n}\n", "// Copyright (c) Qualcomm Technologies, Inc. and/or its subsidiaries.\n// SPDX-License-Identifier: BSD-3-Clause-Clear\n\nimport type {Plugin} from \"unified\"\nimport {remove} from \"unist-util-remove\"\n\nexport const remarkRemoveJsx: Plugin = () => {\n return (tree, _file, done) => {\n remove(tree, \"mdxjsEsm\")\n remove(tree, \"mdxJsxFlowElement\")\n done()\n }\n}\n", "// Copyright (c) Qualcomm Technologies, Inc. and/or its subsidiaries.\n// SPDX-License-Identifier: BSD-3-Clause-Clear\n\nimport type {RouteMetaEntryInternal, RouteMetaInternal} from \"../../../types\"\n\n/**\n * Retrieves the route metadata for a given path based on its path segments.\n */\nexport function getRouteMeta(\n pathSegments: string[],\n metaJson: RouteMetaInternal,\n): RouteMetaEntryInternal | undefined | null {\n const routeMeta = metaJson[pathSegments[0]]\n if (!routeMeta) {\n // backup, fetch using id if provided\n return undefined\n }\n\n if (pathSegments.length === 1) {\n return routeMeta\n }\n\n return pathSegments\n .slice(1)\n .reduce((acc: RouteMetaEntryInternal | undefined | null, segment) => {\n return acc?.children?.[segment]\n }, routeMeta)\n}\n", "// Copyright (c) Qualcomm Technologies, Inc. and/or its subsidiaries.\n// SPDX-License-Identifier: BSD-3-Clause-Clear\n\nimport {sortBy} from \"lodash-es\"\nimport {v4 as uuidv4} from \"uuid\"\n\nimport type {\n NavItem,\n PageFrontmatter,\n PageSection,\n} from \"@qualcomm-ui/mdx-common\"\nimport {capitalCase} from \"@qualcomm-ui/utils/change-case\"\n\nimport type {\n NavMeta,\n RouteMetaEntryInternal,\n RouteMetaInternal,\n} from \"../../../types\"\nimport {defined} from \"../../utils\"\n\nimport {getRouteMeta} from \"./get-route-meta\"\n\ninterface InitialRoute {\n pageFrontmatter: Partial<PageFrontmatter>\n pageSection: PageSection\n routeMeta?: RouteMetaEntryInternal\n}\n\n/**\n * Given a flat remix route structure, computes nested navigation items for the QUI\n * side nav.\n */\nexport class NavBuilder {\n private initialRoutes: InitialRoute[] = []\n private flatNavItems: NavItem[] = []\n\n get navItems(): NavItem[] {\n return this._navItems\n }\n private _navItems: NavItem[] = []\n\n private readonly metaJson: RouteMetaInternal\n private readonly navMeta: Record<number, NavMeta>\n\n constructor(metaJson: RouteMetaInternal, navMeta: Record<number, NavMeta>) {\n this.navMeta = navMeta\n this.metaJson = metaJson\n }\n\n add(\n pageSection: PageSection,\n pageFrontmatter: Partial<PageFrontmatter>,\n routeMeta?: RouteMetaEntryInternal,\n ): void {\n this.initialRoutes.push({pageFrontmatter, pageSection, routeMeta})\n }\n\n reset(): void {\n this.initialRoutes = []\n this.flatNavItems = []\n this._navItems = []\n }\n\n /**\n * Sorts nav items. Nav items with an order defined take precedence over nav items\n * without an order. Nav items with the same order are sorted alphabetically by\n * title.\n */\n private navItemSort(a: NavItem, b: NavItem, groupOrder?: string[]) {\n if (a.depth !== b.depth) {\n return a.depth - b.depth\n }\n\n if (a.order && !b.order) {\n return -1\n }\n if (!a.order && b.order) {\n return 1\n } else if (a.order && b.order && a.order !== b.order) {\n return a.order - b.order\n }\n\n if (groupOrder && a.group && b.group) {\n const aIndex = a.group ? groupOrder.indexOf(a.group) : -1\n const bIndex = b.group ? groupOrder.indexOf(b.group) : -1\n\n if (aIndex === bIndex) {\n // continue\n } else if (aIndex !== -1 && bIndex !== -1) {\n return aIndex - bIndex\n } else if (aIndex !== -1) {\n return -1\n } else if (bIndex !== -1) {\n return 1\n }\n }\n\n // group items with the same group\n if (a.group !== b.group) {\n if (!a.group && b.group) {\n return -1\n }\n if (a.group && !b.group) {\n return 1\n }\n if (a.group && b.group) {\n return a.group.localeCompare(b.group)\n }\n }\n\n return a.title.localeCompare(b.title)\n }\n\n resolveSideNavTitle(\n frontmatter: Partial<PageFrontmatter>,\n routeMeta: Partial<RouteMetaEntryInternal>,\n fallback: string,\n ): string {\n return (\n (defined(routeMeta.sideNavTitle)\n ? routeMeta.sideNavTitle || \"\"\n : frontmatter.sideNavTitle || \"\") || fallback\n )\n }\n\n /**\n * Builds a flat list of nav items from the MDX pages and _meta.json. If a page\n * does not exist, it is not added to the side nav (even if it has an entry in\n * _meta.json).\n */\n private buildNavItem({\n pageFrontmatter,\n pageSection: {pathname, pathSegments, title},\n routeMeta: routeMetaParam,\n }: InitialRoute) {\n const id = pageFrontmatter?.id || \"\"\n\n // handle home page (this route does not have path segments)\n if (!pathSegments.length && pathname === \"/\") {\n const routeMeta =\n routeMetaParam || getRouteMeta(id ? [id] : [], this.metaJson)\n if (!routeMeta) {\n return\n }\n\n this.flatNavItems.push({\n depth: 1,\n expanded: routeMeta?.expanded || false,\n id: `/`,\n order: routeMeta?.order,\n pathname,\n pathSegments: [],\n title: this.resolveSideNavTitle(\n pageFrontmatter,\n routeMeta,\n routeMeta?.title || title,\n ),\n })\n }\n\n pathSegments.forEach((segment, index) => {\n const depth = index + 1\n\n // we only add an item if it doesn't already exist, which we determine by\n // comparing the path segments iteratively.\n const navItem = this.flatNavItems.find((item) =>\n pathSegments\n .slice(0, depth)\n .every((value, i) => value === item.pathSegments[i]),\n )\n\n if (!navItem) {\n const isPage = index === pathSegments.length - 1\n const adjustedSegments = pathSegments.slice(0, depth)\n\n const routeMeta =\n getRouteMeta(\n isPage ? pathSegments : adjustedSegments,\n this.metaJson,\n ) ?? {}\n\n this.flatNavItems.push({\n depth,\n expanded: routeMeta?.expanded || false,\n group: isPage\n ? routeMeta.group || pageFrontmatter.group\n : routeMeta.group,\n id: `/${adjustedSegments.join(\"/\")}`,\n items: [],\n order: routeMeta?.order,\n pathname: isPage ? pathname : undefined,\n pathSegments: adjustedSegments,\n title: this.resolveSideNavTitle(\n pageFrontmatter,\n routeMeta,\n routeMeta?.title\n ? routeMeta.title\n : isPage\n ? title\n : capitalCase(segment),\n ),\n })\n }\n })\n }\n\n /**\n * Iterates through a nav item's path segments and ensures that all of its parent\n * elements exist in the recursive structure.\n */\n private ensureParent(navItem: NavItem) {\n const segments = navItem.pathSegments\n let items: NavItem[] = this.navItems\n let item: NavItem | undefined\n let prevItem: NavItem | undefined = undefined\n\n for (let i = 0; i < segments.length - 1; i++) {\n const segment = segments[i]\n item = items?.find((entry) => entry.pathSegments[i] === segment)\n if (item) {\n // point to the found item's children and keep iterating\n items = item.items ?? []\n prevItem = item\n continue\n }\n if (prevItem) {\n const pathSegments = segments.slice(0, i + 1)\n const routeMeta = getRouteMeta(pathSegments, this.metaJson)\n\n items = []\n const base = {\n depth: pathSegments.length,\n id: `/routes/${pathSegments.join(\"/\")}`,\n items,\n pathSegments,\n title: segment,\n }\n const newItem = routeMeta\n ? {\n ...base,\n expanded: routeMeta.expanded,\n order: routeMeta.order,\n restricted: routeMeta.restricted,\n title: routeMeta.title ?? segment,\n }\n : base\n prevItem.items = prevItem.items\n ? [...prevItem.items, newItem]\n : [newItem]\n }\n prevItem = item\n }\n }\n\n /**\n * Deeply inserts a nav item into the array, iterating through parent routes\n * (based on the pathSegments) and adding them if they don't exist.\n *\n * For example, given a leaf node 4 path segments deep, this function will create\n * all parent nav items as nested children of the top-most nav item.\n */\n private nestedInsert(\n item: NavItem,\n pathSegments: string[],\n items: NavItem[],\n ) {\n const segment = pathSegments[0]\n const parentItem = items.find(\n (parent) =>\n parent.pathSegments[parent.pathSegments.length - 1] === segment,\n )\n if (parentItem) {\n this.nestedInsert(item, pathSegments.slice(1), parentItem.items ?? [])\n } else if (pathSegments.length === 1) {\n items.push(item)\n }\n }\n\n private buildNestedNavItems() {\n for (let i = 0; i < this.flatNavItems.length; i++) {\n const navItem = this.flatNavItems[i]\n if (navItem.depth === 1) {\n this.navItems.push(navItem)\n continue\n }\n\n this.ensureParent(navItem)\n this.nestedInsert(navItem, navItem.pathSegments, this.navItems)\n }\n }\n\n private sortNestedNavItems(items: NavItem[], groupOrder?: string[]) {\n items.sort((a, b) => this.navItemSort(a, b, groupOrder))\n items.forEach((item) => {\n if (item.items?.length) {\n const meta = getRouteMeta(item.pathSegments, this.metaJson)\n this.sortNestedNavItems(item.items, meta?.groupOrder)\n }\n })\n }\n\n /**\n * To be called after every mdx page route has been added through the {@link add}\n * function.\n */\n build(): NavItem[] {\n // We need to process parent items first, so we sort by path segment. Routes\n // with shorter path segments will be processed first.\n sortBy(\n this.initialRoutes,\n (item) => item.pageSection.pathSegments.length,\n ).map((r) => this.buildNavItem(r))\n\n this.buildNestedNavItems()\n\n const rootMeta = getRouteMeta([], this.metaJson)\n this.sortNestedNavItems(this.navItems, rootMeta?.groupOrder)\n\n if (this.navMeta) {\n Object.entries(this.navMeta).forEach(([index, value]) => {\n this._navItems.splice(parseInt(index), 0, {\n depth: 1,\n id: uuidv4(),\n pathSegments: [],\n sectionTitle: value.sectionTitle,\n separator: value.separator,\n title: \"\",\n })\n })\n }\n\n this._navItems = this.groupNavItems(this.navItems)\n this._navItems = this.buildSearchMeta(this.navItems, [])\n return this.navItems\n }\n\n private groupNavItems(items: NavItem[]): NavItem[] {\n const result: NavItem[] = []\n const seenGroups = new Set<string>()\n\n for (const item of items) {\n if (item.group && !seenGroups.has(item.group)) {\n seenGroups.add(item.group)\n result.push({\n depth: item.depth,\n group: item.group,\n id: uuidv4(),\n pathSegments: [],\n sectionTitle: item.group,\n title: \"\",\n })\n }\n\n result.push({\n ...item,\n items: item.items ? this.groupNavItems(item.items) : undefined,\n })\n }\n\n return result\n }\n\n /**\n * Walks over the tree and builds search metadata using the nearest sectionTitle.\n */\n private buildSearchMeta(items: NavItem[], meta: string[]): NavItem[] {\n let sectionTitle = \"\"\n const results: NavItem[] = []\n\n for (const ogItem of items) {\n const item = {...ogItem}\n\n if (item.sectionTitle) {\n sectionTitle = item.sectionTitle\n } else if (item.separator) {\n sectionTitle = \"\"\n }\n\n if (!item.separator) {\n const currentMeta = sectionTitle ? [...meta, sectionTitle] : [...meta]\n const nextMeta = [...(item.searchMeta || []), ...currentMeta]\n if (nextMeta.length) {\n item.searchMeta = [...nextMeta]\n }\n\n if (item.items) {\n item.items = this.buildSearchMeta(item.items, currentMeta)\n }\n }\n\n results.push(item)\n }\n\n return results\n }\n}\n", "// Copyright (c) Qualcomm Technologies, Inc. and/or its subsidiaries.\n// SPDX-License-Identifier: BSD-3-Clause-Clear\n\nimport {join} from \"node:path\"\n\nimport {capitalCase} from \"@qualcomm-ui/utils/change-case\"\n\nimport type {RouteMetaInternal, RoutingStrategy} from \"../../../types\"\n\nimport {getRouteMeta} from \"./get-route-meta\"\n\nexport function getPathnameFromPathSegments(segments: string[]) {\n return `/${segments.join(\"/\")}`\n}\n\nexport function getCategoriesFromPathSegments(\n segments: string[],\n metaJson: RouteMetaInternal,\n // the frontmatter title only applies to the last segment.\n frontmatterTitle: string,\n): string[] {\n return segments.reduce((acc: string[], segment, index) => {\n const pathSegments = segments.slice(0, index + 1)\n if (index === segments.length - 1) {\n acc.push(frontmatterTitle)\n return acc\n }\n const meta = getRouteMeta(pathSegments, metaJson)\n if (meta?.title) {\n acc.push(meta.title)\n } else {\n acc.push(pathSegmentToCategory(segment))\n }\n return acc\n }, [])\n}\n\n// fallback for unmatched path segments\nexport function pathSegmentToCategory(segment: string): string {\n // we don't transform words like `a`, `or`, and `and`\n return segment\n .split(\"-\")\n .map((segment) =>\n /\\b(a|an|and|but|or|in|on|at)\\b/.test(segment)\n ? segment\n : capitalCase(segment),\n )\n .join(\" \")\n}\n\nfunction getGeneroutedPathSegments(filePath: string): string[] {\n const extension = filePath.endsWith(\"mdx\") ? \"mdx\" : \"tsx\"\n\n const segments = filePath\n .substring(0, filePath.lastIndexOf(`.${extension}`))\n .split(\"/\")\n\n if (segments[segments.length - 1] === \"index\") {\n return segments.slice(0, segments.length - 1)\n }\n return segments\n}\n\nconst pathSeparatorRegex = /[\\/\\\\.]/\nfunction isPathSeparator(char: string) {\n return pathSeparatorRegex.test(char)\n}\n\nconst indexRouteRegex =\n /((^|[.]|[+]\\/)(index|_index))(\\/[^\\/]+)?$|(\\/_?index\\/)/\n\nfunction getRemixFlatRoutesSegments(\n name: string,\n index: boolean,\n paramPrefixChar: string = \"$\",\n) {\n let routeSegments: string[] = []\n let i = 0\n let routeSegment = \"\"\n let state = \"START\"\n let subState = \"NORMAL\"\n let hasPlus = false\n\n // ignore layout routes\n if (name.endsWith(\"_layout\")) {\n return []\n }\n\n /*\n * name has already been normalized to use / as path separator.\n * replace `+/_.` with `_+/`\n * this supports the ability to specify parent folder will not be a layout.\n * _public+/_.about.tsx => _public_.about.tsx\n */\n if (/\\+\\/_\\./.test(name)) {\n name = name.replace(/\\+\\/_\\./g, \"_+/\")\n }\n\n /*\n * replace `+/` with `.`\n * this supports folders for organizing flat-files convention.\n * _public+/about.tsx => _public.about.tsx\n */\n if (/\\+\\//.test(name)) {\n name = name.replace(/\\+\\//g, \".\")\n hasPlus = true\n }\n const hasFolder = /\\//.test(name)\n // if name has plus folder, but we still have regular folders\n // then treat ending route as flat-folders\n if (\n ((hasPlus && hasFolder) || !hasPlus) &&\n !(name.endsWith(\".route\") || name.endsWith(\".index\"))\n ) {\n // Do not remove segments ending in .route\n // since these would be part of the route directory name\n // docs/readme.route.tsx => docs/readme\n // Remove last segment since this should just be the route filename, and we only\n // want the directory name docs/_layout.tsx => docs\n const last = name.lastIndexOf(\"/\")\n if (last >= 0) {\n name = name.substring(0, last)\n }\n }\n\n const pushRouteSegment = (routeSegment: string) => {\n if (routeSegment) {\n routeSegments.push(routeSegment)\n }\n }\n\n while (i < name.length) {\n const char = name[i]\n switch (state) {\n case \"START\":\n // process existing segment\n if (\n routeSegment.includes(paramPrefixChar) &&\n !(\n routeSegment.startsWith(paramPrefixChar) ||\n routeSegment.startsWith(`(${paramPrefixChar}`)\n )\n ) {\n throw new Error(\n `Route params must start with prefix char ${paramPrefixChar}: ${routeSegment}`,\n )\n }\n if (\n routeSegment.includes(\"(\") &&\n !routeSegment.startsWith(\"(\") &&\n !routeSegment.endsWith(\")\")\n ) {\n throw new Error(\n `Optional routes must start and end with parentheses: ${routeSegment}`,\n )\n }\n pushRouteSegment(routeSegment)\n routeSegment = \"\"\n state = \"PATH\"\n continue // restart without advancing index\n case \"PATH\":\n if (isPathSeparator(char) && subState === \"NORMAL\") {\n state = \"START\"\n break\n } else if (char === \"[\") {\n subState = \"ESCAPE\"\n break\n } else if (char === \"]\") {\n subState = \"NORMAL\"\n break\n }\n routeSegment += char\n break\n }\n i++ // advance to next character\n }\n // process remaining segment\n pushRouteSegment(routeSegment)\n // strip trailing .route segment\n if (\n routeSegments.at(-1) === \"route\" ||\n routeSegments.at(-1) === \"index\" ||\n routeSegments.at(-1) === \"_index\" ||\n routeSegments.at(-1) === \"_route\"\n ) {\n routeSegments = routeSegments.slice(0, -1)\n }\n // if hasPlus, we need to strip the trailing segment if it starts with _\n // and route is not an index route\n // this is to handle layouts in flat-files\n // _public+/_layout.tsx => _public.tsx\n // _public+/index.tsx => _public.index.tsx\n if (!index && hasPlus && routeSegments.at(-1)?.startsWith(\"_\")) {\n routeSegments = routeSegments.slice(0, -1)\n }\n return routeSegments\n}\n\nfunction getRemixHybridRoutesPathSegments(filePath: string): string[] {\n const routeWithoutExtension = filePath.substring(0, filePath.lastIndexOf(\".\"))\n\n return getRemixFlatRoutesSegments(\n routeWithoutExtension,\n indexRouteRegex.test(routeWithoutExtension),\n )\n}\n\nexport function getPathSegmentsFromFileName(\n filePath: string,\n pageDirectory: string,\n strategy?: RoutingStrategy,\n): string[] {\n const filePathWithoutPageDirectory = filePath.substring(\n filePath.indexOf(pageDirectory) + pageDirectory.length + 1,\n )\n if (typeof strategy === \"function\") {\n return strategy(filePathWithoutPageDirectory)\n }\n switch (strategy) {\n case \"vite-generouted\":\n return getGeneroutedPathSegments(filePathWithoutPageDirectory)\n default:\n return getRemixHybridRoutesPathSegments(filePathWithoutPageDirectory)\n }\n}\n\nexport function filterFileGlob(\n fileGlob: string[],\n ext: string,\n srcDir: string,\n router?: RoutingStrategy,\n): string[] {\n if (typeof router === \"string\" && router === \"vite-generouted\") {\n // vite-generouted: filter routes\n const restrictedPattern = /(\\(.*\\))|(\\[.*\\])/\n // pull out the full path before filtering to avoid potential issues with\n // parent directories.\n const relativeGlobs = fileGlob.map((file) => file.replace(srcDir, \"\"))\n return (\n relativeGlobs\n .filter(\n (file) =>\n file.endsWith(`.${ext}`) &&\n !file.includes(\"/_\") &&\n !file.includes(\"/+\"),\n )\n // filter pathless segments\n .map((file) =>\n file\n .split(\"/\")\n .filter((segment) => !restrictedPattern.test(segment))\n .join(\"/\"),\n )\n // restore full path\n .map((file) => join(srcDir, file))\n )\n }\n return fileGlob.filter((file) => file.endsWith(ext) && !file.includes(\"$\"))\n}\n", "// Copyright (c) Qualcomm Technologies, Inc. and/or its subsidiaries.\n// SPDX-License-Identifier: BSD-3-Clause-Clear\n\nimport type {NavConfig, NavMeta, RouteMeta, RouteMetaInternal} from \"../types\"\n\nexport function transformRouteMetaArray(\n meta: NavConfig[],\n routeMetaNav: Record<string, NavMeta>,\n): RouteMetaInternal {\n let ignoringOrder = 0\n return meta.reduce((acc: RouteMetaInternal, item, index) => {\n // strip the nav meta and populate a separate record. This will be used for\n // lookup while building the nav items.\n if (!(\"id\" in item)) {\n if (\"separator\" in item || \"sectionTitle\" in item) {\n // offset the navMeta index by the number of items that will be sorted to\n // the back of the nav order.\n routeMetaNav[index - ignoringOrder] = item\n }\n return acc\n }\n const current = item as RouteMeta\n if (current.ignoreRouteMetaOrder || current.hidden) {\n // items with ignored order are always sorted to the back of the nav order. We\n // need to account for this when splicing in the navMeta entries.\n ignoringOrder++\n }\n acc[current.id] = {\n children: current.children\n ? transformRouteMetaArray(current.children, routeMetaNav)\n : undefined,\n expanded: current.expanded,\n group: current.group,\n groupOrder: current.groupOrder,\n hidden: current.hidden,\n hideBreadcrumbs: current.hideBreadcrumbs,\n hideFromSearch: current.hideFromSearch,\n hidePageLinks: current.hidePageLinks,\n hideSideNav: current.hideSideNav,\n hideToc: current.hideToc,\n order: current.ignoreRouteMetaOrder ? undefined : index + 1,\n restricted: current.restricted,\n title: current.title,\n }\n return acc\n }, {})\n}\n", "// Copyright (c) Qualcomm Technologies, Inc. and/or its subsidiaries.\n// SPDX-License-Identifier: BSD-3-Clause-Clear\n\nimport rehypeShiki, {type RehypeShikiOptions} from \"@shikijs/rehype\"\nimport {\n transformerNotationDiff,\n transformerNotationErrorLevel,\n transformerNotationFocus,\n transformerNotationHighlight,\n transformerNotationWordHighlight,\n transformerRemoveNotationEscape,\n transformerRenderIndentGuides,\n} from \"@shikijs/transformers\"\nimport {merge} from \"lodash-es\"\nimport type {ShikiTransformer} from \"shiki\"\nimport type {PluggableList} from \"unified\"\n\nimport {quiCustomDarkTheme} from \"@qualcomm-ui/mdx-common\"\n\nimport {\n rehypeMdxCodeProps,\n remarkFrontmatter,\n remarkGfm,\n remarkMdxFrontmatter,\n} from \"../exports\"\n\nimport {ConfigLoader, type ConfigLoaderOptions} from \"./internal\"\nimport {rehypeSectionize, rehypeSlug, type RehypeSlugOptions} from \"./rehype\"\nimport {remarkAlerts, remarkCodeTabs, remarkSpoilers} from \"./remark\"\nimport {transformerCodeAttribute} from \"./shiki\"\n\n/**\n * @deprecated migrate to the {@link getRehypePlugins} function\n */\nexport const quiRehypePlugins: PluggableList = [rehypeSectionize, rehypeSlug]\n\nexport interface QuiRehypePluginOptions extends ConfigLoaderOptions {\n rehypeShikiOptions?: Partial<RehypeShikiOptions>\n}\n\nexport function getShikiTransformers(): ShikiTransformer[] {\n return [\n transformerNotationDiff(),\n transformerNotationFocus(),\n transformerNotationHighlight(),\n transformerNotationWordHighlight(),\n transformerNotationErrorLevel(),\n transformerRenderIndentGuides(),\n transformerRemoveNotationEscape(),\n ]\n}\n\n/**\n * Used to retrieve all the rehype plugins required for QUI Docs MDX.\n * These should be passed to the `mdx` vite plugin from\n */\nexport function getRehypePlugins(\n options: QuiRehypePluginOptions = {},\n): PluggableList {\n const config = new ConfigLoader(options).loadConfig()\n return [\n [rehypeMdxCodeProps, {enforce: \"pre\"}],\n [\n rehypeSlug,\n {allowedHeadings: config.headings} satisfies RehypeSlugOptions,\n ],\n rehypeSectionize,\n [\n rehypeShiki,\n merge(\n {\n defaultColor: \"light-dark()\",\n themes: {\n dark: quiCustomDarkTheme,\n light: \"github-light-high-contrast\",\n },\n transformers: [...getShikiTransformers(), transformerCodeAttribute()],\n } satisfies RehypeShikiOptions,\n options.rehypeShikiOptions,\n ),\n ],\n ]\n}\n\n/**\n * @deprecated migrate to the {@link getRemarkPlugins} function\n */\nexport const quiRemarkPlugins: PluggableList = [remarkAlerts, remarkCodeTabs]\n\n/**\n * @returns every remark plugin needed for QUI Docs MDX.\n *\n * @example\n * ```ts\n * // in your vite config\n * plugins: [\n * mdx({\n * providerImportSource: \"@mdx-js/react\",\n * rehypePlugins: [...getRehypePlugins()],\n * remarkPlugins: [...getRemarkPlugins()],\n * }),\n * quiDocsPlugin(),\n * // ... the rest of your plugins\n * ]\n * ```\n */\nexport function getRemarkPlugins(): PluggableList {\n return [\n remarkFrontmatter,\n remarkMdxFrontmatter,\n remarkGfm,\n remarkAlerts,\n remarkCodeTabs,\n remarkSpoilers,\n ]\n}\n", "// Copyright (c) Qualcomm Technologies, Inc. and/or its subsidiaries.\n// SPDX-License-Identifier: BSD-3-Clause-Clear\n\nimport rehypeMdxCodeProps from \"rehype-mdx-code-props\"\nimport remarkFrontmatter from \"remark-frontmatter\"\nimport remarkGfm from \"remark-gfm\"\nimport remarkMdxFrontmatter from \"remark-mdx-frontmatter\"\n\nimport {rehypeSlug} from \"./docs-plugin/rehype/rehype-slug\"\n\n// Re-export these peerDependencies for more convenient imports.\n// Some of these are not included in the bundled JS, so the user must install them\n// separately.\nexport {\n remarkFrontmatter,\n remarkGfm,\n remarkMdxFrontmatter,\n rehypeMdxCodeProps,\n rehypeSlug,\n}\n", "// Copyright (c) Qualcomm Technologies, Inc. and/or its subsidiaries.\n// SPDX-License-Identifier: BSD-3-Clause-Clear\n\nimport type {Element, Root, RootContent} from \"hast\"\nimport {heading} from \"hast-util-heading\"\nimport {headingRank} from \"hast-util-heading-rank\"\nimport type {Properties} from \"hastscript\"\nimport type {Plugin} from \"unified\"\n\nexport type RehypeSectionizeOptions = {\n enableRootSection?: boolean | undefined\n idPropertyName?: string | undefined\n properties?: Properties | undefined\n rankPropertyName?: string | undefined\n}\n\nconst defaultOptions: Required<RehypeSectionizeOptions> = {\n enableRootSection: false,\n idPropertyName: \"ariaLabelledby\",\n properties: {},\n rankPropertyName: \"dataHeadingRank\",\n}\n\nconst wrappingRank = (\n rootContent: RootContent | undefined,\n rankPropertyName: RehypeSectionizeOptions[\"rankPropertyName\"],\n) => {\n if (\n rootContent == null ||\n rankPropertyName == null ||\n !(\"properties\" in rootContent)\n ) {\n throw new Error(\"rootContent and rankPropertyName must have value\")\n }\n\n const rank = rootContent.properties?.[rankPropertyName]\n if (typeof rank !== \"number\") {\n throw new Error(`rankPropertyName(${rankPropertyName}) must be number`)\n }\n\n return rank\n}\n\nconst createElement = (\n rank: number,\n options: Pick<\n RehypeSectionizeOptions,\n \"properties\" | \"rankPropertyName\" | \"idPropertyName\"\n >,\n children: Element[] = [],\n) => {\n const {idPropertyName, properties, rankPropertyName} = options\n\n if (\n properties != null &&\n rankPropertyName != null &&\n rankPropertyName in properties\n ) {\n throw new Error(\n `rankPropertyName(${rankPropertyName}) dataHeadingRank must exist`,\n )\n }\n\n const id = children.at(0)?.properties?.id\n const element: Element = {\n children,\n properties: {\n className: [\"heading\"],\n ...(rankPropertyName ? {[rankPropertyName]: rank} : {}),\n ...(idPropertyName && typeof id === \"string\"\n ? {[idPropertyName]: id}\n : {}),\n ...(properties ? properties : {}),\n },\n tagName: \"section\",\n type: \"element\",\n }\n\n return element\n}\n\nexport const rehypeSectionize: Plugin<[RehypeSectionizeOptions?], Root> = (\n options = defaultOptions,\n) => {\n const {enableRootSection, ...rest} = {\n enableRootSection:\n options.enableRootSection ?? defaultOptions.enableRootSection,\n idPropertyName: options.idPropertyName ?? defaultOptions.idPropertyName,\n properties: options.properties ?? defaultOptions.properties,\n rankPropertyName:\n options.rankPropertyName ?? defaultOptions.rankPropertyName,\n }\n\n return (root) => {\n const rootWrapper = createElement(0, rest)\n\n const wrapperStack: RootContent[] = []\n wrapperStack.push(rootWrapper)\n\n const lastStackItem = () => {\n const last = wrapperStack.at(-1)\n if (last == null || last.type !== \"element\") {\n throw new Error(\"lastStackItem must be Element\")\n }\n return wrapperStack.at(-1) as Element\n }\n\n for (const rootContent of root.children) {\n if (heading(rootContent)) {\n const rank = headingRank(rootContent)\n if (rank == null) {\n throw new Error(\"heading or headingRank is not working\")\n }\n\n if (rank > wrappingRank(lastStackItem(), rest.rankPropertyName)) {\n const childWrapper = createElement(rank, rest, [rootContent])\n lastStackItem().children.push(childWrapper)\n wrapperStack.push(childWrapper)\n } else if (\n rank <= wrappingRank(lastStackItem(), rest.rankPropertyName)\n ) {\n while (rank <= wrappingRank(lastStackItem(), rest.rankPropertyName)) {\n wrapperStack.pop()\n }\n const siblingWrapper = createElement(rank, rest, [rootContent])\n\n lastStackItem().children.push(siblingWrapper)\n wrapperStack.push(siblingWrapper)\n }\n } else {\n if (rootContent.type === \"doctype\") {\n throw new Error(\"must be used in a fragment\")\n }\n lastStackItem().children.push(rootContent as any)\n }\n }\n\n return {\n ...root,\n children: enableRootSection ? [rootWrapper] : rootWrapper.children,\n }\n }\n}\n", "// Copyright (c) Qualcomm Technologies, Inc. and/or its subsidiaries.\n// SPDX-License-Identifier: BSD-3-Clause-Clear\n\nimport type {Code, Parent, Root} from \"mdast\"\nimport type {Plugin} from \"unified\"\nimport {visit} from \"unist-util-visit\"\n\ninterface Tab {\n index: number\n label: string\n meta: string | undefined\n tabsGroup: string\n}\n\nfunction parseTabAttributes(meta: string): {\n label: string | null\n remainingMeta: string\n tabsGroup: string | null\n} {\n if (!meta) {\n return {label: null, remainingMeta: \"\", tabsGroup: null}\n }\n\n const tabsMatch = meta.match(/tabs=[\"']([^\"']+)[\"']|tabs=(\\S+)/)\n const labelMatch = meta.match(/label=[\"']([^\"']+)[\"']|label=(\\S+)/)\n\n const tabsGroup = tabsMatch ? tabsMatch[1] || tabsMatch[2] : null\n const label = labelMatch ? labelMatch[1] || labelMatch[2] : null\n\n // Remove both tabs and label attributes from meta\n const remainingMeta = meta\n .replace(/\\s*tabs=[\"']([^\"']+)[\"']/g, \"\")\n .replace(/\\s*tabs=(\\S+)/g, \"\")\n .replace(/\\s*label=[\"']([^\"']+)[\"']/g, \"\")\n .replace(/\\s*label=(\\S+)/g, \"\")\n .trim()\n\n return {label, remainingMeta, tabsGroup}\n}\n\nfunction findConsecutiveTabs(\n startIndex: number,\n parent: Parent,\n targetTabsGroup: string,\n): Tab[] {\n const tabs: Tab[] = []\n let currentIndex = startIndex\n\n while (currentIndex < parent.children.length) {\n const currentNode = parent.children[currentIndex]\n\n if (!currentNode || currentNode.type !== \"code\") {\n break\n }\n\n const codeNode = currentNode\n\n if (!codeNode.meta) {\n break\n }\n\n const {label, remainingMeta, tabsGroup} = parseTabAttributes(codeNode.meta)\n\n // Only include if it matches the target tabs group and has a label\n if (!tabsGroup || !label || tabsGroup !== targetTabsGroup) {\n break\n }\n\n // Clean the original node's meta NOW\n codeNode.meta = remainingMeta || undefined\n\n tabs.push({\n index: currentIndex,\n label,\n meta: remainingMeta || undefined,\n tabsGroup,\n })\n\n if (remainingMeta && remainingMeta.includes(\"end\")) {\n break\n }\n\n currentIndex++\n }\n\n return tabs\n}\n\nfunction renderTabs(tabs: Tab[], parent: Parent): any[] {\n const tabsContainer = {\n attributes: [],\n children: [] as any[],\n name: \"CodeTabs\",\n type: \"mdxJsxFlowElement\",\n }\n\n tabs.forEach((tab) => {\n const codeNode = parent.children[tab.index] as Code\n\n const tabAttributes = [\n {\n name: \"label\",\n type: \"mdxJsxAttribute\",\n value: tab.label,\n },\n ]\n\n // Add meta to JSX element if it exists\n if (tab.meta) {\n tabAttributes.push({\n name: \"meta\",\n type: \"mdxJsxAttribute\",\n value: tab.meta,\n })\n }\n\n const tabElement = {\n attributes: tabAttributes,\n children: [\n {\n lang: codeNode.lang,\n meta: codeNode.meta, // This is now clean\n type: \"code\",\n value: codeNode.value,\n },\n ],\n name: \"CodeTab\",\n type: \"mdxJsxFlowElement\",\n }\n\n tabsContainer.children.push(tabElement)\n })\n\n return [tabsContainer]\n}\n\n/**\n * Very cool. TODO: document this https://docs.qui.qualcomm.com/guide/markdown\n *\n * @example\n * ```angular-html tabs=\"demo\" label=\"HTML\"\n * <div class=\"w-72\" q-text-input [invalid]=\"!value()\" [(ngModel)]=\"value\">\n * <label q-text-input-label>Label</label>\n * <input placeholder=\"Enter a value\" q-text-input-input />\n * <div q-text-input-error-text>You must enter a value</div>\n * </div>\n * ```\n *\n * ```angular-ts tabs=\"demo\" label=\"TS\"\n * @Component()\n * export class DemoComponent {\n * readonly value = signal(\"\")\n * }\n * ```\n */\nexport const remarkCodeTabs: Plugin<[], Root> = () => {\n return (tree) => {\n const transformations: Array<{\n endIndex: number\n parent: Parent\n replacement: any[]\n startIndex: number\n }> = []\n\n visit(\n tree,\n \"code\",\n (node: Code, index: number | undefined, parent: Parent | undefined) => {\n if (!node.meta || !parent || index === undefined) {\n return\n }\n\n const {label, tabsGroup} = parseTabAttributes(node.meta)\n if (!tabsGroup || !label) {\n return\n }\n\n const alreadyProcessed = transformations.some(\n (t) =>\n t.parent === parent && index >= t.startIndex && index < t.endIndex,\n )\n\n if (alreadyProcessed) {\n return\n }\n\n const tabs = findConsecutiveTabs(index, parent, tabsGroup)\n\n if (tabs.length > 1) {\n const startIndex = tabs[0].index\n const endIndex = tabs[tabs.length - 1].index + 1\n const newChildren = renderTabs(tabs, parent)\n\n transformations.push({\n endIndex,\n parent,\n replacement: newChildren,\n startIndex,\n })\n }\n },\n )\n\n transformations\n .sort((a, b) => b.startIndex - a.startIndex)\n .forEach((transformation) => {\n transformation.parent.children.splice(\n transformation.startIndex,\n transformation.endIndex - transformation.startIndex,\n ...transformation.replacement,\n )\n })\n }\n}\n", "// Copyright (c) Qualcomm Technologies, Inc. and/or its subsidiaries.\n// SPDX-License-Identifier: BSD-3-Clause-Clear\n\nimport type {Heading, Link, Root} from \"mdast\"\nimport {toString} from \"mdast-util-to-string\"\nimport type {Plugin} from \"unified\"\nimport {visit} from \"unist-util-visit\"\n\nexport interface RemarkSelfLinkOptions {\n /**\n * @default [2, 3, 4]\n */\n allowedLevels?: number[]\n prefix?: string\n}\n\nconst emptyOptions: RemarkSelfLinkOptions = {}\n\nexport function remarkSelfLinkHeadings(\n baseUrl: string = \"\",\n options?: RemarkSelfLinkOptions | null,\n): Plugin<[], Root> {\n if (!baseUrl) {\n return () => {}\n }\n return () => {\n const settings = options || emptyOptions\n const prefix = settings.prefix || \"\"\n const allowedLevels = new Set<number>(settings.allowedLevels || [2, 3, 4])\n const seenIds = new Map<string, number>()\n\n function createSlug(text: string): string {\n const cleaned = text\n .replace(/[<>]/g, \"\")\n .replace(/[^\\w\\s-]/g, \"\")\n .trim()\n\n let slug: string\n if (cleaned.includes(\" \")) {\n slug = cleaned\n .toLowerCase()\n .replace(/\\s+/g, \"-\")\n .replace(/^-+|-+$/g, \"\")\n } else if ((cleaned.match(/[A-Z]/g) || []).length >= 2) {\n slug = cleaned\n .replace(/([a-z0-9])([A-Z])/g, \"$1-$2\")\n .replace(/([A-Z]+)([A-Z][a-z])/g, \"$1-$2\")\n .toLowerCase()\n } else {\n slug = cleaned.toLowerCase()\n }\n\n const count = seenIds.get(slug) || 0\n seenIds.set(slug, count + 1)\n return count > 0 ? `${slug}-${count}` : slug\n }\n\n return (tree) => {\n seenIds.clear()\n visit(tree, \"heading\", (node: Heading) => {\n if (allowedLevels.has(node.depth)) {\n const text = toString(node)\n const slug = prefix + createSlug(text)\n\n const linkNode: Link = {\n children: node.children,\n type: \"link\",\n url: `${baseUrl}#${slug}`,\n }\n\n node.children = [linkNode]\n }\n })\n }\n }\n}\n", "// Copyright (c) Qualcomm Technologies, Inc. and/or its subsidiaries.\n// SPDX-License-Identifier: BSD-3-Clause-Clear\n\nimport type {BlockContent, Root} from \"mdast\"\nimport type {Plugin} from \"unified\"\nimport {visit} from \"unist-util-visit\"\n\ninterface SpoilerOptions {\n defaultSummary?: string\n detailsClassName?: string[]\n summaryClassName?: string[]\n}\n\n/**\n * Transforms spoiler blocks into MDX components.\n *\n * @example\n * ```\n * ::: spoiler Title\n *\n * Content\n *\n * :::\n * ```\n *\n * result:\n *\n * ```jsx\n * <SpoilerRoot>\n * <SpoilerTrigger><p>Title</p></SpoilerTrigger>\n * <SpoilerContent>Content</SpoilerContent>\n * </SpoilerRoot>\n * ```\n */\nexport const remarkSpoilers: Plugin<[SpoilerOptions?], Root> = (\n options = {},\n) => {\n const {\n defaultSummary = \"Open spoiler\",\n detailsClassName = [],\n summaryClassName = [],\n } = options\n\n return (tree) => {\n visit(tree, \"paragraph\", (node, index, parent) => {\n if (!parent || index === undefined) {\n return\n }\n\n const firstChild = node.children[0]\n if (firstChild?.type !== \"text\") {\n return\n }\n\n const match = firstChild.value.match(/^:::\\s*spoiler\\s*(.*)$/)\n if (!match) {\n return\n }\n\n const summary = match[1].trim() || defaultSummary\n let endIndex = index + 1\n const contentNodes: BlockContent[] = []\n\n while (endIndex < parent.children.length) {\n const child = parent.children[endIndex]\n\n if (child.type === \"paragraph\") {\n const firstText = child.children[0]\n if (firstText?.type === \"text\" && firstText.value.trim() === \":::\") {\n break\n }\n }\n\n contentNodes.push(child as BlockContent)\n endIndex++\n }\n\n if (endIndex >= parent.children.length) {\n return\n }\n\n const summaryNode: BlockContent = {\n attributes: summaryClassName.length\n ? [\n {\n name: \"className\",\n type: \"mdxJsxAttribute\",\n value: summaryClassName.join(\" \"),\n },\n ]\n : [],\n children: [\n {\n children: [{type: \"text\", value: summary}],\n type: \"paragraph\",\n },\n ],\n name: \"SpoilerSummary\",\n type: \"mdxJsxFlowElement\",\n }\n\n const contentNode: BlockContent = {\n attributes: [],\n children: contentNodes,\n name: \"SpoilerContent\",\n type: \"mdxJsxFlowElement\",\n }\n\n const detailsNode: BlockContent = {\n attributes: detailsClassName.length\n ? [\n {\n name: \"className\",\n type: \"mdxJsxAttribute\",\n value: detailsClassName.join(\" \"),\n },\n ]\n : [],\n children: [summaryNode, contentNode],\n name: \"SpoilerRoot\",\n type: \"mdxJsxFlowElement\",\n }\n\n parent.children.splice(index, endIndex - index + 1, detailsNode)\n })\n }\n}\n", "// Copyright (c) Qualcomm Technologies, Inc. and/or its subsidiaries.\n// SPDX-License-Identifier: BSD-3-Clause-Clear\n\nexport function removeCodeAnnotations(code: string): string {\n const annotationRegex = /\\/\\/\\s*\\[!code\\s*(?:\\S.*)?\\]/\n\n return code\n .split(\"\\n\")\n .map((line) => {\n // keep the line if it's a ++ diff, as this is used to show the line's\n // addition in code blocks.\n return line.replace(/(?:\\/\\/\\s*)?\\[!code \\+\\+\\]/, \"\")\n })\n .filter((line) => !annotationRegex.test(line))\n .join(\"\\n\")\n}\n", "// Copyright (c) Qualcomm Technologies, Inc. and/or its subsidiaries.\n// SPDX-License-Identifier: BSD-3-Clause-Clear\n\nimport type {ShikiTransformer} from \"shiki\"\n\nimport {removeCodeAnnotations} from \"./utils\"\n\nexport interface TransformerCodeAttributeOptions {\n /**\n * The name of the attribute to add to the pre element.\n *\n * @default 'data-code'\n */\n attributeName?: string\n\n /**\n * Custom formatter for the source code.\n */\n formatter?: (code: string) => string\n}\n\n/**\n * Adds a `data-code` attribute to the `<pre>` element with the code contents,\n * removing any code annotations and unused lines from transformers like\n * `transformerNotationDiff`.\n */\nexport function transformerCodeAttribute(\n opts: TransformerCodeAttributeOptions = {},\n): ShikiTransformer {\n return {\n enforce: \"post\",\n name: \"shiki-transformer-code-attribute\",\n pre(node) {\n const strippedSource = removeCodeAnnotations(this.source)\n node.properties[opts.attributeName ?? \"data-code\"] =\n opts.formatter?.(strippedSource) ?? strippedSource\n },\n }\n}\n", "// Copyright (c) Qualcomm Technologies, Inc. and/or its subsidiaries.\n// SPDX-License-Identifier: BSD-3-Clause-Clear\n\nexport const VIRTUAL_MODULE_IDS = {\n AUTO: \"\\0virtual:qui-demo-scope/auto\",\n CONFIG: \"\\0virtual:qui-demo-scope/config\",\n PAGE_PREFIX: \"\\0virtual:qui-demo-scope/page:\",\n} as const\n\nexport const LOG_PREFIX = \"@qualcomm-ui/mdx-vite/react-demo-plugin:\"\n\nexport const REACT_IMPORTS: string[] = [\n \"useState\",\n \"useEffect\",\n \"useMemo\",\n \"useCallback\",\n \"useRef\",\n \"useContext\",\n \"createContext\",\n \"forwardRef\",\n \"memo\",\n \"lazy\",\n \"Suspense\",\n \"Fragment\",\n] as const\n\nexport const NODE_BUILTINS: string[] = [\n \"fs\",\n \"path\",\n \"url\",\n \"util\",\n \"os\",\n \"crypto\",\n \"events\",\n \"stream\",\n \"buffer\",\n] as const\n", "// Copyright (c) Qualcomm Technologies, Inc. and/or its subsidiaries.\n// SPDX-License-Identifier: BSD-3-Clause-Clear\n\nimport chalk from \"chalk\"\nimport {existsSync, readFileSync} from \"node:fs\"\nimport {readFile} from \"node:fs/promises\"\nimport {dirname, join, relative, resolve, sep} from \"node:path\"\nimport * as ts from \"typescript\"\n\nimport {pascalCase} from \"@qualcomm-ui/utils/change-case\"\n\nimport {LOG_PREFIX, NODE_BUILTINS} from \"./demo-plugin-constants\"\n\ninterface PathAlias {\n pattern: RegExp\n replacement: string\n}\n\nexport interface ImportSpecifier {\n source: string\n specifiers: Array<{\n imported: string\n local: string\n }>\n type: \"thirdParty\"\n}\n\nexport interface RelativeImport {\n resolvedPath: string\n source: string\n specifiers: Array<{\n imported: string\n local: string\n }>\n type: \"relative\"\n}\n\n/**\n * Demo names are created using the PascalCase format of the file name without the\n * extension.\n */\nexport function createDemoName(filePath: string): string {\n const separatorChar = filePath.includes(\"/\") ? \"/\" : \"\\\\\"\n const fileName = filePath.substring(\n filePath.lastIndexOf(separatorChar),\n filePath.lastIndexOf(\".\"),\n )\n if (!fileName) {\n throw new Error(`Failed to create demo name for ${filePath}`)\n }\n return pascalCase(fileName)\n}\n\nexport async function extractFileImports(filePath: string): Promise<{\n relativeImports: RelativeImport[]\n thirdPartyImports: ImportSpecifier[]\n} | null> {\n try {\n const content = await readFile(filePath, \"utf-8\")\n return extractImports(content, filePath)\n } catch (error) {\n console.log(\n `${chalk.magenta.bold(LOG_PREFIX)} ${chalk.yellowBright(\"Failed to parse\")} ${chalk.blueBright.bold(filePath)}:`,\n error,\n )\n return null\n }\n}\n\nfunction extractImports(\n code: string,\n fileName: string,\n): {\n relativeImports: RelativeImport[]\n thirdPartyImports: ImportSpecifier[]\n} {\n const sourceFile = ts.createSourceFile(\n fileName,\n code,\n ts.ScriptTarget.Latest,\n true,\n getScriptKind(fileName),\n )\n const thirdPartyImports: ImportSpecifier[] = []\n const relativeImports: RelativeImport[] = []\n\n function visit(node: ts.Node) {\n if (ts.isImportDeclaration(node)) {\n const importSpec = parseImportDeclaration(node, fileName)\n if (importSpec) {\n if (importSpec.type === \"relative\") {\n relativeImports.push(importSpec)\n } else {\n thirdPartyImports.push(importSpec)\n }\n }\n }\n ts.forEachChild(node, visit)\n }\n\n visit(sourceFile)\n return {relativeImports, thirdPartyImports}\n}\n\nexport function getScriptKind(fileName: string): ts.ScriptKind {\n return fileName.endsWith(\".tsx\") || fileName.endsWith(\".jsx\")\n ? ts.ScriptKind.TSX\n : ts.ScriptKind.TS\n}\n\nfunction parseImportDeclaration(\n node: ts.ImportDeclaration,\n fileName: string,\n): ImportSpecifier | RelativeImport | null {\n const moduleSpecifier = node.moduleSpecifier\n if (!ts.isStringLiteral(moduleSpecifier)) {\n return null\n }\n\n const source = moduleSpecifier.text\n if (node.importClause?.isTypeOnly) {\n return null\n }\n\n const specifiers = extractSpecifiers(node.importClause)\n if (specifiers.length === 0) {\n return null\n }\n\n if (isRelativeImport(source)) {\n const resolvedPath = resolveRelativeImport(source, fileName)\n return {\n resolvedPath,\n source,\n specifiers,\n type: \"relative\",\n }\n }\n\n if (isNodeBuiltin(source)) {\n return null\n }\n\n const pathAliases = loadTsConfigPaths(fileName)\n if (isPathAliasImport(source, pathAliases)) {\n const resolvedPath = resolvePathAlias(source, pathAliases)\n if (resolvedPath) {\n return {\n resolvedPath,\n source,\n specifiers,\n type: \"relative\",\n }\n }\n }\n\n return {\n source,\n specifiers,\n type: \"thirdParty\",\n }\n}\n\nfunction extractSpecifiers(\n importClause: ts.ImportClause | undefined,\n): Array<{imported: string; local: string}> {\n if (!importClause) {\n return []\n }\n\n const specifiers: Array<{imported: string; local: string}> = []\n\n if (importClause.name) {\n specifiers.push({imported: \"default\", local: \"default\"})\n }\n\n if (importClause.namedBindings) {\n if (ts.isNamespaceImport(importClause.namedBindings)) {\n specifiers.push({imported: \"*\", local: \"*\"})\n } else if (ts.isNamedImports(importClause.namedBindings)) {\n importClause.namedBindings.elements.forEach((element) => {\n if (!element.isTypeOnly) {\n const imported = element.propertyName\n ? element.propertyName.text\n : element.name.text\n const local = element.name.text\n specifiers.push({imported, local})\n }\n })\n }\n }\n\n return specifiers\n}\n\nfunction resolveRelativeImport(source: string, fromFile: string): string {\n const fromDir = dirname(fromFile)\n const resolved = resolve(fromDir, source)\n\n const extensions = [\".ts\", \".tsx\", \".js\", \".jsx\"]\n for (const ext of extensions) {\n const withExt = resolved + ext\n if (existsSync(withExt)) {\n return withExt\n }\n }\n\n for (const ext of extensions) {\n const indexFile = join(resolved, `index${ext}`)\n if (existsSync(indexFile)) {\n return indexFile\n }\n }\n\n return resolved\n}\n\nfunction isRelativeImport(source: string): boolean {\n return source.startsWith(\"./\") || source.startsWith(\"../\")\n}\n\nfunction isNodeBuiltin(source: string): boolean {\n return source.startsWith(\"node:\") || NODE_BUILTINS.includes(source)\n}\n\nfunction loadTsConfigPaths(fromFile: string): PathAlias[] {\n let currentDir = dirname(fromFile)\n const pathAliases: PathAlias[] = []\n\n while (currentDir !== dirname(currentDir)) {\n const tsconfigPath = join(currentDir, \"tsconfig.json\")\n if (existsSync(tsconfigPath)) {\n try {\n const configContent = ts.sys.readFile(tsconfigPath)\n if (!configContent) {\n currentDir = dirname(currentDir)\n continue\n }\n\n const parseResult = ts.parseConfigFileTextToJson(\n tsconfigPath,\n configContent,\n )\n if (parseResult.error) {\n currentDir = dirname(currentDir)\n continue\n }\n\n const paths = parseResult.config?.compilerOptions?.paths\n const baseUrl = parseResult.config?.compilerOptions?.baseUrl || \"./\"\n const resolvedBaseUrl = resolve(currentDir, baseUrl)\n\n if (paths) {\n for (const [alias, targets] of Object.entries(paths)) {\n if (Array.isArray(targets) && targets.length > 0) {\n const target = targets[0]\n const pattern = new RegExp(\n `^${alias\n .replace(\"*\", \"(.*)\")\n .replace(/[.*+?^${}()|[\\]\\\\]/g, \"\\\\$&\")\n .replace(\"\\\\(\\\\*\\\\)\", \"(.*)\")}$`,\n )\n const replacement = resolve(\n resolvedBaseUrl,\n target.replace(\"*\", \"$1\"),\n )\n pathAliases.push({pattern, replacement})\n }\n }\n }\n\n const extendsPath = parseResult.config?.extends\n if (extendsPath) {\n const resolvedExtends = resolve(currentDir, extendsPath)\n const extendedAliases = loadTsConfigPathsFromFile(resolvedExtends)\n pathAliases.push(...extendedAliases)\n }\n\n return pathAliases\n } catch (error) {\n currentDir = dirname(currentDir)\n continue\n }\n }\n currentDir = dirname(currentDir)\n }\n\n return pathAliases\n}\n\nfunction loadTsConfigPathsFromFile(tsconfigPath: string): PathAlias[] {\n const pathAliases: PathAlias[] = []\n const configDir = dirname(tsconfigPath)\n\n try {\n const configContent = ts.sys.readFile(tsconfigPath)\n if (!configContent) {\n return pathAliases\n }\n\n const parseResult = ts.parseConfigFileTextToJson(\n tsconfigPath,\n configContent,\n )\n if (parseResult.error) {\n return pathAliases\n }\n\n const paths = parseResult.config?.compilerOptions?.paths\n const baseUrl = parseResult.config?.compilerOptions?.baseUrl || \"./\"\n const resolvedBaseUrl = resolve(configDir, baseUrl)\n\n if (paths) {\n for (const [alias, targets] of Object.entries(paths)) {\n if (Array.isArray(targets) && targets.length > 0) {\n const target = targets[0]\n const pattern = new RegExp(\n `^${alias\n .replace(\"*\", \"(.*)\")\n .replace(/[.*+?^${}()|[\\]\\\\]/g, \"\\\\$&\")\n .replace(\"\\\\(\\\\*\\\\)\", \"(.*)\")}$`,\n )\n const replacement = resolve(\n resolvedBaseUrl,\n target.replace(\"*\", \"$1\"),\n )\n pathAliases.push({pattern, replacement})\n }\n }\n }\n\n const extendsPath = parseResult.config?.extends\n if (extendsPath) {\n let resolvedExtends = resolve(configDir, extendsPath)\n if (!resolvedExtends.endsWith(\".json\")) {\n resolvedExtends += \".json\"\n }\n if (existsSync(resolvedExtends)) {\n const extendedAliases = loadTsConfigPathsFromFile(resolvedExtends)\n pathAliases.push(...extendedAliases)\n }\n }\n } catch (error) {\n return pathAliases\n }\n\n return pathAliases\n}\n\nfunction isPathAliasImport(source: string, pathAliases: PathAlias[]): boolean {\n return pathAliases.some((alias) => alias.pattern.test(source))\n}\n\nfunction resolvePathAlias(\n source: string,\n pathAliases: PathAlias[],\n): string | null {\n for (const alias of pathAliases) {\n if (alias.pattern.test(source)) {\n const resolvedPath = source.replace(alias.pattern, alias.replacement)\n const extensions = [\".ts\", \".tsx\", \".js\", \".jsx\"]\n\n for (const ext of extensions) {\n const withExt = resolvedPath + ext\n if (existsSync(withExt)) {\n return withExt\n }\n }\n\n for (const ext of extensions) {\n const indexFile = join(resolvedPath, `index${ext}`)\n if (existsSync(indexFile)) {\n return indexFile\n }\n }\n\n return resolvedPath\n }\n }\n return null\n}\n\nexport function extractPageId(filePath: string, routesDir: string): string {\n const relativePath = relative(routesDir, filePath)\n const pathParts = relativePath.split(sep)\n if (pathParts.includes(\"demos\")) {\n const demosIndex = pathParts.indexOf(\"demos\")\n return pathParts.slice(0, demosIndex).join(sep)\n }\n return dirname(relativePath)\n}\n\nexport function isCssAsset(filePath: string) {\n return filePath.endsWith(\".css\")\n}\n\nexport function isDemoFile(filePath: string): boolean {\n try {\n return (\n filePath.includes(\"/demos/\") &&\n filePath.endsWith(\".tsx\") &&\n !readFileSync(filePath).includes(\"export default\")\n )\n } catch (error) {\n return false\n }\n}\n", "// Copyright (c) Qualcomm Technologies, Inc. and/or its subsidiaries.\n// SPDX-License-Identifier: BSD-3-Clause-Clear\n\nimport chalk from \"chalk\"\nimport {glob} from \"glob\"\nimport {readFile} from \"node:fs/promises\"\nimport {basename, resolve} from \"node:path\"\nimport {createHighlighter, type Highlighter} from \"shiki\"\nimport * as ts from \"typescript\"\nimport type {Plugin} from \"vite\"\n\nimport {quiCustomDarkTheme, type ReactDemoData} from \"@qualcomm-ui/mdx-common\"\nimport {dedent} from \"@qualcomm-ui/utils/dedent\"\n\nimport {getShikiTransformers} from \"../docs-plugin\"\n\nimport {LOG_PREFIX, VIRTUAL_MODULE_IDS} from \"./demo-plugin-constants\"\nimport type {QuiDemoPluginOptions} from \"./demo-plugin-types\"\nimport {\n createDemoName,\n extractFileImports,\n extractPageId,\n getScriptKind,\n isCssAsset,\n isDemoFile,\n} from \"./demo-plugin-utils\"\n\ninterface HandleUpdateOptions {\n demoName?: string\n filePath: string\n}\n\nlet highlighter: Highlighter | null = null\nlet initializingHighlighter = false\n\nconst demoRegistry = new Map<string, ReactDemoData>()\nconst pageFiles = new Map<string, string[]>()\nconst relativeImportDependents = new Map<string, Set<string>>()\n\n/**\n * Generates virtual modules for React demo components. Virtual modules contain\n * highlighted source code and metadata about each demo.\n */\nexport function reactDemoPlugin({\n demoPattern = \"src/routes/**/demos/*.tsx\",\n routesDir = \"src/routes\",\n theme = {\n dark: quiCustomDarkTheme,\n light: \"github-light-high-contrast\",\n },\n transformers = [],\n transformLine,\n}: QuiDemoPluginOptions = {}): Plugin {\n return {\n apply(config, env) {\n return (\n (env.mode === \"development\" && env.command === \"serve\") ||\n (env.mode === \"production\" && env.command === \"build\")\n )\n },\n async buildStart() {\n if (!highlighter && !initializingHighlighter) {\n initializingHighlighter = true\n try {\n highlighter = await createHighlighter({\n langs: [\"tsx\", \"typescript\"],\n themes: [theme.dark, theme.light],\n }).finally(() => {\n initializingHighlighter = false\n })\n console.log(\n `${chalk.magenta.bold(LOG_PREFIX)} Shiki highlighter initialized`,\n )\n } catch (error) {\n console.warn(\n `${chalk.magenta.bold(LOG_PREFIX)} Failed to initialize highlighter:`,\n error,\n )\n }\n }\n\n await collectReactDemos()\n },\n\n async handleHotUpdate({file, modules, server}) {\n if (isCssAsset(file)) {\n return modules\n }\n\n if (file.endsWith(\".mdx\")) {\n return []\n }\n\n if (isDemoFile(file)) {\n await handleDemoAdditionOrUpdate({filePath: file})\n } else {\n const normalizedFile = resolve(file)\n const dependentDemos = relativeImportDependents.get(normalizedFile)\n if (!dependentDemos?.size) {\n return []\n }\n for (const demoName of Array.from(dependentDemos)) {\n const demo = demoRegistry.get(demoName)\n if (demo) {\n await handleDemoAdditionOrUpdate({\n filePath: demo.filePath,\n })\n }\n }\n }\n\n const autoModule = server.moduleGraph.getModuleById(\n VIRTUAL_MODULE_IDS.AUTO,\n )\n if (autoModule) {\n server.moduleGraph.invalidateModule(autoModule)\n await server.reloadModule(autoModule)\n }\n return []\n },\n\n async load(id) {\n if (id === VIRTUAL_MODULE_IDS.AUTO) {\n return generateAutoScopeModule()\n }\n },\n\n name: \"auto-demo-scope\",\n\n resolveId(id) {\n if (id === \"virtual:qui-demo-scope/auto\") {\n return VIRTUAL_MODULE_IDS.AUTO\n }\n },\n\n writeBundle() {\n console.log(\n `${chalk.blue.bold(LOG_PREFIX)} Successfully integrated ${chalk.green(demoRegistry.size)} component demos`,\n )\n },\n }\n\n async function handleDemoAdditionOrUpdate({\n filePath,\n }: HandleUpdateOptions): Promise<void> {\n const pageId = extractPageId(filePath, routesDir)\n const demoName = createDemoName(filePath)\n\n const existingFiles = pageFiles.get(pageId) ?? []\n if (!existingFiles.includes(filePath)) {\n existingFiles.push(filePath)\n pageFiles.set(pageId, existingFiles)\n }\n\n const fileData = await extractFileData(filePath)\n if (fileData) {\n demoRegistry.set(demoName, {\n ...fileData,\n demoName,\n pageId,\n })\n\n const fileImports = await extractFileImports(filePath)\n if (fileImports) {\n for (const relativeImport of fileImports.relativeImports) {\n const dependents =\n relativeImportDependents.get(relativeImport.resolvedPath) ??\n new Set()\n dependents.add(demoName)\n relativeImportDependents.set(relativeImport.resolvedPath, dependents)\n }\n }\n }\n }\n\n function isPreviewLine(trimmedLine: string): boolean {\n return (\n trimmedLine === \"// preview\" ||\n /^\\{\\s*\\/\\*\\s*preview\\s*\\*\\/\\s*\\}$/.test(trimmedLine)\n )\n }\n\n function extractPreviewsAndCleanSource(code: string): {\n formattedPreview: string\n sourceWithoutSnippetComments: string\n } {\n const lines = code.split(\"\\n\")\n const previewBlocks: string[] = []\n const cleanedLines: string[] = []\n let inPreview = false\n let currentBlock: string[] = []\n\n for (const line of lines) {\n const trimmedLine = line.trim()\n\n if (isPreviewLine(trimmedLine)) {\n if (inPreview) {\n previewBlocks.push(currentBlock.join(\"\\n\"))\n currentBlock = []\n inPreview = false\n } else {\n inPreview = true\n }\n continue\n }\n\n cleanedLines.push(line)\n if (inPreview) {\n currentBlock.push(line)\n }\n }\n\n const joined = previewBlocks.join(\"\\n\")\n const split = joined.split(\"\\n\")\n if (!split.at(-1)?.trim()) {\n split.pop()\n }\n\n return {\n formattedPreview: dedent(split.join(\"\\n\")).trim(),\n sourceWithoutSnippetComments: cleanedLines.join(\"\\n\"),\n }\n }\n\n async function highlightCode(code: string): Promise<string> {\n if (!highlighter) {\n return code\n }\n try {\n return highlighter.codeToHtml(code, {\n defaultColor: \"light-dark()\",\n lang: \"tsx\",\n themes: {\n dark: theme.dark,\n light: theme.light,\n },\n transformers: [\n ...getShikiTransformers(),\n {\n enforce: \"post\",\n name: \"shiki-transformer-trim\",\n preprocess(code) {\n return code.trim()\n },\n },\n ...transformers,\n ],\n })\n } catch (error) {\n console.warn(\n `${chalk.magenta.bold(LOG_PREFIX)} Failed to highlight code:`,\n error,\n )\n return code\n }\n }\n\n async function collectReactDemos() {\n if (demoRegistry.size) {\n return\n }\n\n const demoFiles = (await glob(demoPattern)).filter(isDemoFile)\n\n for (const filePath of demoFiles) {\n const pageId = extractPageId(filePath, routesDir)\n const existingFiles = pageFiles.get(pageId) ?? []\n existingFiles.push(filePath)\n pageFiles.set(pageId, existingFiles)\n\n const fileData = await extractFileData(filePath)\n if (fileData) {\n const demoName = createDemoName(filePath)\n demoRegistry.set(demoName, {\n ...fileData,\n pageId,\n })\n }\n\n const fileImports = await extractFileImports(filePath)\n if (fileImports) {\n for (const relativeImport of fileImports.relativeImports) {\n const demoName = createDemoName(filePath)\n const dependents =\n relativeImportDependents.get(relativeImport.resolvedPath) ??\n new Set()\n dependents.add(demoName)\n relativeImportDependents.set(relativeImport.resolvedPath, dependents)\n }\n }\n }\n }\n\n function generateAutoScopeModule(): string {\n const registryCode = generateDemoRegistry(demoRegistry)\n return [\n \"// Auto-generated demo scope resolver (PROD MODE)\",\n registryCode,\n generateExportedFunctions(),\n ].join(\"\\n\\n\")\n }\n\n function extractHighlightedVariants(highlightedHtml: string): {\n highlightedPreview: string\n highlightedWithoutPreview: string\n } {\n const preMatch = highlightedHtml.match(/^<pre[^>]*><code>/)?.[0] || \"\"\n const postMatch = highlightedHtml.match(/<\\/code><\\/pre>$/)?.[0] || \"\"\n const content = highlightedHtml.slice(preMatch.length, -postMatch.length)\n const lines = content.split(\"\\n\")\n const previewLines: string[] = []\n const withoutPreviewLines: string[] = []\n let inPreview = false\n\n for (const line of lines) {\n const textContent = line\n .replace(/<[^>]*>/g, \"\")\n .replace(/</g, \"<\")\n .replace(/>/g, \">\")\n .trim()\n if (textContent === \"// preview\" || textContent === \"{/* preview */}\") {\n inPreview = !inPreview\n continue\n }\n if (inPreview) {\n previewLines.push(line)\n }\n withoutPreviewLines.push(line)\n }\n\n const normalizedPreviewLines = normalizeIndentation(previewLines)\n const highlightedPreview =\n normalizedPreviewLines.length > 0\n ? `${preMatch}${normalizedPreviewLines.join(\"\\n\")}${postMatch}`\n : \"\"\n const highlightedWithoutPreview = `${preMatch}${withoutPreviewLines.join(\"\\n\")}${postMatch}`\n return {highlightedPreview, highlightedWithoutPreview}\n }\n\n function normalizeIndentation(lines: string[]): string[] {\n if (lines.length === 0) {\n return []\n }\n const nonEmptyLines = lines.filter(\n (line) => line.replace(/<[^>]*>/g, \"\").trim().length > 0,\n )\n if (nonEmptyLines.length === 0) {\n return lines\n }\n let minIndent = Infinity\n for (const line of nonEmptyLines) {\n const matches = line.match(/<span class=\"indent\">/g)\n if (matches) {\n minIndent = Math.min(minIndent, matches.length)\n } else {\n minIndent = 0\n break\n }\n }\n if (minIndent === 0 || minIndent === Infinity) {\n return lines\n }\n return lines.map((line) => {\n let result = line\n for (let i = 0; i < minIndent; i++) {\n result = result.replace(/<span class=\"indent\">(\\s*)<\\/span>/, \"\")\n }\n return result\n })\n }\n\n function transformLines(code: string): string {\n if (!transformLine) {\n return code\n }\n const result: string[] = []\n for (const line of code.split(\"\\n\")) {\n if (line.trim()) {\n const transformed = transformLine(line)\n if (transformed) {\n result.push(transformed)\n }\n } else {\n // include all empty lines\n result.push(line)\n }\n }\n return result.join(\"\\n\")\n }\n\n async function extractFileData(\n filePath: string,\n ): Promise<Omit<ReactDemoData, \"pageId\"> | null> {\n try {\n const code = await readFile(filePath, \"utf-8\").then(transformLines)\n\n const {imports, strippedCode: codeWithoutImports} = stripImports(\n code,\n filePath,\n )\n const fileName = basename(filePath)\n const {formattedPreview, sourceWithoutSnippetComments} =\n extractPreviewsAndCleanSource(code)\n\n const highlightedFull = await highlightCode(code)\n\n const {highlightedPreview, highlightedWithoutPreview} =\n extractHighlightedVariants(highlightedFull)\n\n const sourceCode = [\n {\n fileName,\n highlighted: {\n full: highlightedWithoutPreview,\n preview: highlightedPreview,\n },\n raw: {\n full: sourceWithoutSnippetComments,\n preview: formattedPreview,\n withoutImports: codeWithoutImports,\n },\n },\n ]\n\n const fileImports = await extractFileImports(filePath)\n if (fileImports) {\n for (const relativeImport of fileImports.relativeImports) {\n try {\n const importedCode = await readFile(\n relativeImport.resolvedPath,\n \"utf-8\",\n ).then(transformLines)\n\n const {strippedCode: importedCodeWithoutImports} = stripImports(\n importedCode,\n relativeImport.resolvedPath,\n )\n const {\n sourceWithoutSnippetComments: importedSourceWithoutSnippets,\n } = extractPreviewsAndCleanSource(importedCode)\n const importedFileName = basename(relativeImport.resolvedPath)\n const highlightedImportedSource = await highlightCode(\n importedSourceWithoutSnippets,\n )\n sourceCode.push({\n fileName: importedFileName,\n highlighted: {\n full: highlightedImportedSource,\n preview: \"\",\n },\n raw: {\n full: importedSourceWithoutSnippets,\n preview: \"\",\n withoutImports: importedCodeWithoutImports,\n },\n })\n } catch {}\n }\n }\n\n return {\n demoName: createDemoName(filePath),\n fileName,\n filePath,\n imports,\n sourceCode,\n }\n } catch {\n return null\n }\n }\n\n function stripImports(\n code: string,\n fileName: string,\n ): {\n imports: string[]\n strippedCode: string\n } {\n try {\n const sourceFile = ts.createSourceFile(\n fileName,\n code,\n ts.ScriptTarget.Latest,\n true,\n getScriptKind(fileName),\n )\n\n const importRanges: Array<{end: number; start: number}> = []\n\n function visit(node: ts.Node) {\n if (ts.isImportDeclaration(node)) {\n importRanges.push({\n end: node.getEnd(),\n start: node.getFullStart(),\n })\n }\n ts.forEachChild(node, visit)\n }\n\n visit(sourceFile)\n\n const imports = importRanges.map((range) => {\n let endPos = range.end\n if (code[endPos] === \"\\n\") {\n endPos++\n }\n return code.slice(range.start, endPos).trim()\n })\n\n importRanges.sort((a, b) => b.start - a.start)\n\n let strippedCode = code\n for (const range of importRanges) {\n let endPos = range.end\n if (strippedCode[endPos] === \"\\n\") {\n endPos++\n }\n strippedCode =\n strippedCode.slice(0, range.start) + strippedCode.slice(endPos)\n }\n\n strippedCode = strippedCode.trim()\n\n return {\n imports,\n strippedCode: strippedCode.replace(/^\\n+/, \"\"),\n }\n } catch (error) {\n return {\n imports: [],\n strippedCode: code,\n }\n }\n }\n\n function generateDemoRegistry(registry: Map<string, ReactDemoData>): string {\n const entries = Array.from(registry.entries())\n .map(([demoName, {fileName, imports, pageId, sourceCode}]) => {\n return ` [\"${demoName}\", { fileName: \"${fileName}\", imports: ${JSON.stringify(imports)}, pageId: \"${pageId}\", sourceCode: ${JSON.stringify(sourceCode)}, demoName: \"${demoName}\" }]`\n })\n .join(\",\\n\")\n return `const demoRegistry = new Map([\\n${entries}\\n])`\n }\n\n function generateExportedFunctions(): string {\n return dedent`\n export function getDemo(demoName) {\n const demo = demoRegistry.get(demoName)\n if (!demo) {\n return {\n fileName: \"\",\n imports: [],\n errorMessage: \\`Demo \"\\${demoName}\" not found.\\`,\n pageId: \"\",\n sourceCode: [],\n }\n }\n return demo\n }\n `\n }\n}\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
|
+
"names": ["isCssAsset", "mainModule", "pageModuleId", "pageModule", "normalizeIndentation", "lines", "visit", "isRelativeImport", "resolveRelativeImport", "isNodeBuiltin", "loadTsConfigPaths", "extractPageId", "routesDir", "NODE_BUILTINS", "chalk", "glob", "readFileSync", "resolve", "z", "z", "z", "z", "chalk", "entry", "propTypes", "heading", "chalk", "remarkParse", "remarkStringify", "unified", "unified", "remarkParse", "remarkStringify", "chalk", "remarkMdx", "remarkParse", "unified", "visit", "visit", "item", "remove", "heading", "unified", "remarkMdx", "remarkParse", "join", "capitalCase", "segment", "capitalCase", "state", "routeSegment", "join", "chalk", "VIRTUAL_MODULE_ID", "readFileSync", "resolve", "glob", "chalk", "config", "file", "transformerRenderIndentGuides", "quiCustomDarkTheme", "remarkFrontmatter", "remarkGfm", "headingRank", "visit", "toString", "visit", "emptyOptions", "visit", "transformerRenderIndentGuides", "quiCustomDarkTheme", "remarkFrontmatter", "remarkGfm", "LOG_PREFIX", "chalk", "existsSync", "readFileSync", "readFile", "dirname", "join", "relative", "resolve", "ts", "readFile", "chalk", "LOG_PREFIX", "visit", "isPathAliasImport", "resolvePathAlias", "dirname", "resolve", "existsSync", "join", "loadTsConfigPathsFromFile", "relative", "readFileSync", "chalk", "glob", "readFile", "basename", "resolve", "createHighlighter", "ts", "quiCustomDarkTheme", "highlighter", "demoRegistry", "quiCustomDarkTheme", "createHighlighter", "chalk", "LOG_PREFIX", "resolve", "code", "glob", "readFile", "basename", "visit"]
|
|
7
7
|
}
|