mirror of
https://github.com/facebook/docusaurus.git
synced 2025-04-30 18:58:36 +02:00
* feat(v2): pluginify docs * feat(v2): implement docs plugin * fix(v2): fix bugs in docs plugin for translation and versioning
109 lines
3.1 KiB
JavaScript
109 lines
3.1 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 globby = require('globby');
|
|
const path = require('path');
|
|
const {encodePath, fileToPath, idx} = require('@docusaurus/utils');
|
|
|
|
const DEFAULT_OPTIONS = {
|
|
metadataKey: 'pagesMetadata',
|
|
metadataFileName: 'pagesMetadata.json',
|
|
path: 'pages', // Path to data on filesystem, relative to site dir.
|
|
routeBasePath: '', // URL Route.
|
|
include: ['**/*.{js,jsx}'], // Extensions to include.
|
|
component: '@theme/Pages',
|
|
};
|
|
|
|
class DocusaurusPluginContentPages {
|
|
constructor(opts, context) {
|
|
this.options = {...DEFAULT_OPTIONS, ...opts};
|
|
this.context = context;
|
|
this.contentPath = path.resolve(this.context.siteDir, this.options.path);
|
|
}
|
|
|
|
getName() {
|
|
return 'docusaurus-plugin-content-pages';
|
|
}
|
|
|
|
getPathsToWatch() {
|
|
return [this.contentPath];
|
|
}
|
|
|
|
async loadContent() {
|
|
const {include} = this.options;
|
|
const {env, siteConfig} = this.context;
|
|
const pagesDir = this.contentPath;
|
|
|
|
const {baseUrl} = siteConfig;
|
|
const pagesFiles = await globby(include, {
|
|
cwd: pagesDir,
|
|
});
|
|
|
|
// Prepare metadata container.
|
|
const pagesMetadatas = [];
|
|
|
|
// Translation.
|
|
const translationEnabled = idx(env, ['translation', 'enabled']);
|
|
const enabledLanguages =
|
|
translationEnabled && idx(env, ['translation', 'enabledLanguages']);
|
|
const enabledLangTags =
|
|
(enabledLanguages && enabledLanguages.map(lang => lang.tag)) || [];
|
|
const defaultLangTag = idx(env, ['translation', 'defaultLanguage', 'tag']);
|
|
|
|
await Promise.all(
|
|
pagesFiles.map(async relativeSource => {
|
|
const source = path.join(pagesDir, relativeSource);
|
|
const pathName = encodePath(fileToPath(relativeSource));
|
|
if (translationEnabled && enabledLangTags.length > 0) {
|
|
enabledLangTags.forEach(langTag => {
|
|
// Default lang should also be available. E.g: /en/users and /users is the same.
|
|
if (langTag === defaultLangTag) {
|
|
pagesMetadatas.push({
|
|
permalink: pathName.replace(/^\//, baseUrl),
|
|
language: langTag,
|
|
source,
|
|
});
|
|
}
|
|
|
|
const metadata = {
|
|
permalink: pathName.replace(/^\//, `${baseUrl}${langTag}/`),
|
|
language: langTag,
|
|
source,
|
|
};
|
|
pagesMetadatas.push(metadata);
|
|
});
|
|
} else {
|
|
// Default Language.
|
|
const metadata = {
|
|
permalink: pathName.replace(/^\//, baseUrl),
|
|
source,
|
|
};
|
|
pagesMetadatas.push(metadata);
|
|
}
|
|
}),
|
|
);
|
|
|
|
return pagesMetadatas;
|
|
}
|
|
|
|
async contentLoaded({content, actions}) {
|
|
const {component} = this.options;
|
|
const {addRoute} = actions;
|
|
|
|
content.forEach(metadataItem => {
|
|
const {permalink, source} = metadataItem;
|
|
addRoute({
|
|
path: permalink,
|
|
component,
|
|
metadata: metadataItem,
|
|
modules: [source],
|
|
});
|
|
});
|
|
}
|
|
}
|
|
|
|
module.exports = DocusaurusPluginContentPages;
|