docusaurus/v2/lib/load/routes.js
Endilie Yacop Sucipto 2ad7413dd7 refactor(v2): determine all available routes/url (#1264)
* refactor(v2): determine all available routes/url

* nits

* test(v2): routes snapshot

* sort for consistent snapshot test due to async ordering
2019-03-06 10:51:16 -08:00

148 lines
3.2 KiB
JavaScript

/**
* Copyright (c) 2017-present, Facebook, Inc.
*
* This source code is licensed under the MIT license found in the
* LICENSE file in the root directory of this source tree.
*/
const {normalizeUrl} = require('./utils');
async function loadRoutes({
siteConfig = {},
docsMetadatas = {},
pagesMetadatas = [],
pluginRouteConfigs = [],
}) {
const imports = [
`import React from 'react';`,
`import Loadable from 'react-loadable';`,
`import Loading from '@theme/Loading';`,
`import Doc from '@theme/Doc';`,
`import DocBody from '@theme/DocBody';`,
`import Pages from '@theme/Pages';`,
`import NotFound from '@theme/NotFound';`,
];
const routesPaths = [];
const addRoutesPath = permalink => {
if (permalink && !/:|\*/.test(permalink)) {
routesPaths.push(permalink);
}
};
// Docs.
const {docsUrl, baseUrl} = siteConfig;
function genDocsRoute(metadata) {
const {permalink, source} = metadata;
addRoutesPath(permalink);
return `
{
path: '${permalink}',
exact: true,
component: Loadable({
loader: () => import('${source}'),
loading: Loading,
render(loaded, props) {
let Content = loaded.default;
return (
<DocBody {...props} metadata={${JSON.stringify(metadata)}}>
<Content />
</DocBody>
);
}
})
}`;
}
const rootDocsUrl = normalizeUrl([baseUrl, docsUrl]);
const docsRoutes = `
{
path: '${rootDocsUrl}',
component: Doc,
routes: [${Object.values(docsMetadatas)
.map(genDocsRoute)
.join(',')}],
}`;
// Pages.
function genPagesRoute(metadata) {
const {permalink, source} = metadata;
addRoutesPath(permalink);
return `
{
path: '${permalink}',
exact: true,
component: Loadable({
loader: () => import('${source}'),
loading: Loading,
render(loaded, props) {
let Content = loaded.default;
return (
<Pages {...props} metadata={${JSON.stringify(metadata)}}>
<Content {...props} metadata={${JSON.stringify(metadata)}} />
</Pages>
);
}
})
}`;
}
const notFoundRoute = `
{
path: '*',
component: NotFound,
}`;
const routes = pluginRouteConfigs.map(pluginRouteConfig => {
const {path, component, metadata, modules} = pluginRouteConfig;
addRoutesPath(path);
return `
{
path: '${path}',
exact: true,
component: Loadable.Map({
loader: {
${modules
.map(
(module, index) => ` Module${index}: () => import('${module}'),`,
)
.join('\n')}
Component: () => import('${component}'),
},
loading: Loading,
render(loaded, props) {
const Component = loaded.Component.default;
const modules = [
${modules
.map((module, index) => ` loaded.Module${index}.default,`)
.join('\n')}
];
return (
<Component {...props} metadata={${JSON.stringify(
metadata,
)}} modules={modules}/>
);
}
})
}`;
});
const routesConfig = `
${imports.join('\n')}
const routes = [
// Docs.${pagesMetadatas.map(genPagesRoute).join(',')},
// Pages.${docsRoutes},
// Plugins.${routes.join(',')},
// Not Found.${notFoundRoute},
];
export default routes;\n`;
return {routesConfig, routesPaths};
}
module.exports = loadRoutes;