mirror of
https://github.com/facebook/docusaurus.git
synced 2025-05-10 07:37:19 +02:00
feat(docs): allow to configure noIndex per doc version (#7963)
This commit is contained in:
parent
a335a69982
commit
eac3239757
12 changed files with 103 additions and 42 deletions
|
@ -901,6 +901,7 @@ exports[`simple website content: data 1`] = `
|
|||
"label": "Next",
|
||||
"banner": null,
|
||||
"badge": false,
|
||||
"noIndex": false,
|
||||
"className": "docs-version-current",
|
||||
"isLast": true,
|
||||
"docsSidebars": {
|
||||
|
@ -2608,6 +2609,7 @@ exports[`versioned website (community) content: data 1`] = `
|
|||
"label": "1.0.0",
|
||||
"banner": null,
|
||||
"badge": true,
|
||||
"noIndex": false,
|
||||
"className": "docs-version-1.0.0",
|
||||
"isLast": true,
|
||||
"docsSidebars": {
|
||||
|
@ -2635,6 +2637,7 @@ exports[`versioned website (community) content: data 1`] = `
|
|||
"label": "Next",
|
||||
"banner": "unreleased",
|
||||
"badge": true,
|
||||
"noIndex": false,
|
||||
"className": "docs-version-current",
|
||||
"isLast": false,
|
||||
"docsSidebars": {
|
||||
|
@ -3477,6 +3480,7 @@ exports[`versioned website content: data 1`] = `
|
|||
"label": "1.0.0",
|
||||
"banner": "unmaintained",
|
||||
"badge": true,
|
||||
"noIndex": false,
|
||||
"className": "docs-version-1.0.0",
|
||||
"isLast": false,
|
||||
"docsSidebars": {
|
||||
|
@ -3544,6 +3548,7 @@ exports[`versioned website content: data 1`] = `
|
|||
"label": "1.0.1",
|
||||
"banner": null,
|
||||
"badge": true,
|
||||
"noIndex": true,
|
||||
"className": "docs-version-1.0.1",
|
||||
"isLast": true,
|
||||
"docsSidebars": {
|
||||
|
@ -3599,6 +3604,7 @@ exports[`versioned website content: data 1`] = `
|
|||
"label": "Next",
|
||||
"banner": "unreleased",
|
||||
"badge": true,
|
||||
"noIndex": false,
|
||||
"className": "docs-version-current",
|
||||
"isLast": false,
|
||||
"docsSidebars": {
|
||||
|
@ -3674,6 +3680,7 @@ exports[`versioned website content: data 1`] = `
|
|||
"label": "withSlugs",
|
||||
"banner": "unmaintained",
|
||||
"badge": true,
|
||||
"noIndex": false,
|
||||
"className": "docs-version-withSlugs",
|
||||
"isLast": false,
|
||||
"docsSidebars": {
|
||||
|
|
|
@ -362,6 +362,11 @@ describe('versioned website', () => {
|
|||
options: {
|
||||
routeBasePath,
|
||||
sidebarPath,
|
||||
versions: {
|
||||
'1.0.1': {
|
||||
noIndex: true,
|
||||
},
|
||||
},
|
||||
},
|
||||
});
|
||||
const plugin = await pluginContentDocs(context, options);
|
||||
|
|
|
@ -76,6 +76,7 @@ describe('normalizeDocsPluginOptions', () => {
|
|||
version1: {
|
||||
path: 'hello',
|
||||
label: 'world',
|
||||
noIndex: true,
|
||||
},
|
||||
},
|
||||
sidebarCollapsible: false,
|
||||
|
|
|
@ -59,6 +59,7 @@ const VersionOptionsSchema = Joi.object({
|
|||
banner: Joi.string().equal('none', 'unreleased', 'unmaintained').optional(),
|
||||
badge: Joi.boolean().optional(),
|
||||
className: Joi.string().optional(),
|
||||
noIndex: Joi.boolean().optional(),
|
||||
});
|
||||
|
||||
const VersionsOptionsSchema = Joi.object()
|
||||
|
|
|
@ -125,6 +125,25 @@ declare module '@docusaurus/plugin-content-docs' {
|
|||
// TODO support custom version banner?
|
||||
// {type: "error", content: "html content"}
|
||||
export type VersionBanner = 'unreleased' | 'unmaintained';
|
||||
|
||||
export type VersionOptions = {
|
||||
/**
|
||||
* The base path of the version, will be appended to `baseUrl` +
|
||||
* `routeBasePath`.
|
||||
*/
|
||||
path?: string;
|
||||
/** The label of the version to be used in badges, dropdowns, etc. */
|
||||
label?: string;
|
||||
/** The banner to show at the top of a doc of that version. */
|
||||
banner?: 'none' | VersionBanner;
|
||||
/** Show a badge with the version label at the top of each doc. */
|
||||
badge?: boolean;
|
||||
/** Prevents search engines from indexing this version */
|
||||
noIndex?: boolean;
|
||||
/** Add a custom class name to the <html> element of each doc. */
|
||||
className?: string;
|
||||
};
|
||||
|
||||
export type VersionsOptions = {
|
||||
/**
|
||||
* The version navigated to in priority and displayed by default for docs
|
||||
|
@ -144,23 +163,7 @@ declare module '@docusaurus/plugin-content-docs' {
|
|||
/** Include the current version of your docs. */
|
||||
includeCurrentVersion: boolean;
|
||||
/** Independent customization of each version's properties. */
|
||||
versions: {
|
||||
[versionName: string]: {
|
||||
/**
|
||||
* The base path of the version, will be appended to `baseUrl` +
|
||||
* `routeBasePath`.
|
||||
*/
|
||||
path?: string;
|
||||
/** The label of the version to be used in badges, dropdowns, etc. */
|
||||
label?: string;
|
||||
/** The banner to show at the top of a doc of that version. */
|
||||
banner?: 'none' | VersionBanner;
|
||||
/** Show a badge with the version label at the top of each doc. */
|
||||
badge?: boolean;
|
||||
/** Add a custom class name to the <html> element of each doc. */
|
||||
className?: string;
|
||||
};
|
||||
};
|
||||
versions: {[versionName: string]: VersionOptions};
|
||||
};
|
||||
export type SidebarOptions = {
|
||||
/**
|
||||
|
@ -263,6 +266,8 @@ declare module '@docusaurus/plugin-content-docs' {
|
|||
banner: VersionBanner | null;
|
||||
/** Show a badge with the version label at the top of each doc. */
|
||||
badge: boolean;
|
||||
/** Prevents search engines from indexing this version */
|
||||
noIndex: boolean;
|
||||
/** Add a custom class name to the <html> element of each doc. */
|
||||
className: string;
|
||||
/**
|
||||
|
@ -500,7 +505,7 @@ declare module '@docusaurus/plugin-content-docs' {
|
|||
|
||||
export type PropVersionMetadata = Pick<
|
||||
VersionMetadata,
|
||||
'label' | 'banner' | 'badge' | 'className' | 'isLast'
|
||||
'label' | 'banner' | 'badge' | 'className' | 'isLast' | 'noIndex'
|
||||
> & {
|
||||
/** ID of the docs plugin this version belongs to. */
|
||||
pluginId: string;
|
||||
|
|
|
@ -142,6 +142,7 @@ export function toVersionMetadataProp(
|
|||
label: loadedVersion.label,
|
||||
banner: loadedVersion.banner,
|
||||
badge: loadedVersion.badge,
|
||||
noIndex: loadedVersion.noIndex,
|
||||
className: loadedVersion.className,
|
||||
isLast: loadedVersion.isLast,
|
||||
docsSidebars: toSidebarsProp(loadedVersion),
|
||||
|
|
|
@ -56,6 +56,7 @@ describe('readVersionsMetadata', () => {
|
|||
path: '/docs',
|
||||
banner: null,
|
||||
badge: false,
|
||||
noIndex: false,
|
||||
className: 'docs-version-current',
|
||||
};
|
||||
return {simpleSiteDir, defaultOptions, defaultContext, vCurrent};
|
||||
|
@ -218,6 +219,7 @@ describe('readVersionsMetadata', () => {
|
|||
path: '/docs/next',
|
||||
banner: 'unreleased',
|
||||
badge: true,
|
||||
noIndex: false,
|
||||
className: 'docs-version-current',
|
||||
};
|
||||
|
||||
|
@ -242,6 +244,7 @@ describe('readVersionsMetadata', () => {
|
|||
path: '/docs',
|
||||
banner: null,
|
||||
badge: true,
|
||||
noIndex: false,
|
||||
className: 'docs-version-1.0.1',
|
||||
};
|
||||
|
||||
|
@ -266,6 +269,7 @@ describe('readVersionsMetadata', () => {
|
|||
path: '/docs/1.0.0',
|
||||
banner: 'unmaintained',
|
||||
badge: true,
|
||||
noIndex: false,
|
||||
className: 'docs-version-1.0.0',
|
||||
};
|
||||
|
||||
|
@ -290,6 +294,7 @@ describe('readVersionsMetadata', () => {
|
|||
path: '/docs/withSlugs',
|
||||
banner: 'unmaintained',
|
||||
badge: true,
|
||||
noIndex: false,
|
||||
className: 'docs-version-withSlugs',
|
||||
};
|
||||
|
||||
|
@ -657,6 +662,7 @@ describe('readVersionsMetadata', () => {
|
|||
path: '/communityBasePath/next',
|
||||
banner: 'unreleased',
|
||||
badge: true,
|
||||
noIndex: false,
|
||||
className: 'docs-version-current',
|
||||
};
|
||||
|
||||
|
@ -681,6 +687,7 @@ describe('readVersionsMetadata', () => {
|
|||
path: '/communityBasePath',
|
||||
banner: null,
|
||||
badge: true,
|
||||
noIndex: false,
|
||||
className: 'docs-version-1.0.0',
|
||||
};
|
||||
|
||||
|
|
|
@ -122,6 +122,13 @@ export function getVersionBadge({
|
|||
return options.versions[versionName]?.badge ?? defaultVersionBadge;
|
||||
}
|
||||
|
||||
export function getVersionNoIndex({
|
||||
versionName,
|
||||
options,
|
||||
}: VersionContext): VersionMetadata['noIndex'] {
|
||||
return options.versions[versionName]?.noIndex ?? false;
|
||||
}
|
||||
|
||||
function getVersionClassName({
|
||||
versionName,
|
||||
options,
|
||||
|
@ -179,6 +186,7 @@ async function createVersionMetadata(
|
|||
label: getVersionLabel(context),
|
||||
banner: getVersionBanner(context),
|
||||
badge: getVersionBadge(context),
|
||||
noIndex: getVersionNoIndex(context),
|
||||
className: getVersionClassName(context),
|
||||
path: routePath,
|
||||
tagsPath: normalizeUrl([routePath, options.tagsBasePath]),
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue