const path = require('path'); const {fileToComponentName} = require('./utils'); async function genRoutesConfig({docsData, docsDir, pagesDir, pagesData}) { function genDocsRoute({path: docsPath, source}) { const componentName = fileToComponentName(source); return ` { path: ${JSON.stringify(docsPath)}, component: () => <${componentName} /> }`; } function genDocsImport({source}) { const filePath = path.resolve(docsDir, source); const componentName = fileToComponentName(source); return `import ${componentName} from ${JSON.stringify(filePath)}`; } function genPagesRoute({path: pagesPath, source}) { const componentName = fileToComponentName(source); return ` { path: ${JSON.stringify(pagesPath)}, component: ${componentName} }`; } function genPagesImport({source}) { const componentName = fileToComponentName(source); return `import ${componentName} from '@pages/${source}'`; } const notFoundRoute = `, { path: '*', component: NotFound }`; return ( `import React from 'react';\n` + `import Docs from '@theme/Docs';\n` + `import NotFound from '@theme/NotFound';\n` + `${pagesData.map(genPagesImport).join('\n')}\n` + `${docsData.map(genDocsImport).join('\n')}\n` + `const routes = [${docsData.map(genDocsRoute).join(',')},${pagesData .map(genPagesRoute) .join(',')}${notFoundRoute}\n];\n` + `export default routes;\n` ); } module.exports = genRoutesConfig;