@docusaurus/plugin-content-docs 2.0.0-beta.fbdeefcac → 2.0.0-rc.1
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/lib/categoryGeneratedIndex.d.ts +12 -0
- package/lib/categoryGeneratedIndex.js +37 -0
- package/lib/cli.d.ts +3 -2
- package/lib/cli.js +57 -72
- package/lib/client/docsClientUtils.d.ts +9 -28
- package/lib/client/docsClientUtils.js +34 -43
- package/lib/client/index.d.ts +81 -0
- package/lib/client/index.js +67 -0
- package/lib/constants.d.ts +4 -0
- package/lib/constants.js +4 -1
- package/lib/docs.d.ts +34 -7
- package/lib/docs.js +202 -79
- package/{src/__tests__/__fixtures__/site-with-autogenerated-sidebar/docusaurus.config.js → lib/frontMatter.d.ts} +4 -8
- package/lib/{docFrontMatter.js → frontMatter.js} +22 -3
- package/lib/globalData.d.ts +3 -3
- package/lib/globalData.js +35 -6
- package/lib/index.d.ts +3 -3
- package/lib/index.js +124 -154
- package/lib/lastUpdate.d.ts +4 -6
- package/lib/lastUpdate.js +22 -26
- package/lib/markdown/index.d.ts +3 -6
- package/lib/markdown/index.js +3 -3
- package/lib/markdown/linkify.d.ts +1 -1
- package/lib/markdown/linkify.js +6 -3
- package/lib/numberPrefix.d.ts +1 -1
- package/lib/numberPrefix.js +16 -21
- package/lib/options.d.ts +3 -5
- package/lib/options.js +56 -23
- package/lib/props.d.ts +7 -2
- package/lib/props.js +84 -14
- package/lib/routes.d.ts +29 -0
- package/lib/routes.js +96 -0
- package/lib/server-export.d.ts +9 -0
- package/lib/server-export.js +25 -0
- package/lib/{sidebarItemsGenerator.d.ts → sidebars/generator.d.ts} +1 -6
- package/lib/sidebars/generator.js +209 -0
- package/lib/sidebars/index.d.ts +13 -0
- package/lib/sidebars/index.js +92 -0
- package/lib/sidebars/normalization.d.ts +13 -0
- package/lib/sidebars/normalization.js +59 -0
- package/lib/sidebars/postProcessor.d.ts +11 -0
- package/lib/sidebars/postProcessor.js +81 -0
- package/lib/sidebars/processor.d.ts +10 -0
- package/lib/sidebars/processor.js +79 -0
- package/lib/sidebars/types.d.ts +183 -0
- package/lib/{docFrontMatter.d.ts → sidebars/types.js} +2 -2
- package/lib/sidebars/utils.d.ts +55 -0
- package/lib/sidebars/utils.js +259 -0
- package/lib/sidebars/validation.d.ts +11 -0
- package/lib/sidebars/validation.js +143 -0
- package/lib/slug.d.ts +5 -4
- package/lib/slug.js +28 -18
- package/{src/__tests__/__fixtures__/sidebars/sidebars-first-level-not-category.js → lib/tags.d.ts} +3 -14
- package/lib/tags.js +21 -0
- package/lib/translations.d.ts +3 -3
- package/lib/translations.js +100 -93
- package/lib/types.d.ts +13 -185
- package/lib/versions/files.d.ts +50 -0
- package/lib/versions/files.js +141 -0
- package/lib/versions/index.d.ts +36 -0
- package/lib/versions/index.js +154 -0
- package/lib/versions/validation.d.ts +17 -0
- package/lib/versions/validation.js +71 -0
- package/package.json +44 -30
- package/src/categoryGeneratedIndex.ts +60 -0
- package/src/cli.ts +88 -114
- package/src/client/docsClientUtils.ts +44 -71
- package/src/client/index.ts +158 -0
- package/src/constants.ts +4 -2
- package/src/docs.ts +281 -83
- package/src/frontMatter.ts +63 -0
- package/src/globalData.ts +57 -7
- package/src/index.ts +183 -224
- package/src/lastUpdate.ts +27 -38
- package/src/markdown/index.ts +10 -16
- package/src/markdown/linkify.ts +7 -4
- package/src/numberPrefix.ts +19 -26
- package/src/options.ts +61 -29
- package/src/plugin-content-docs.d.ts +569 -93
- package/src/props.ts +121 -21
- package/src/routes.ts +159 -0
- package/src/server-export.ts +26 -0
- package/src/sidebars/README.md +10 -0
- package/src/sidebars/generator.ts +292 -0
- package/src/sidebars/index.ts +118 -0
- package/src/sidebars/normalization.ts +91 -0
- package/src/sidebars/postProcessor.ts +112 -0
- package/src/sidebars/processor.ts +123 -0
- package/src/sidebars/types.ts +280 -0
- package/src/sidebars/utils.ts +393 -0
- package/src/sidebars/validation.ts +179 -0
- package/src/slug.ts +41 -22
- package/src/tags.ts +20 -0
- package/src/translations.ts +155 -124
- package/src/types.ts +17 -250
- package/src/versions/files.ts +216 -0
- package/src/versions/index.ts +246 -0
- package/src/versions/validation.ts +115 -0
- package/lib/.tsbuildinfo +0 -1
- package/lib/sidebarItemsGenerator.js +0 -211
- package/lib/sidebars.d.ts +0 -43
- package/lib/sidebars.js +0 -320
- package/lib/theme/hooks/useDocs.d.ts +0 -20
- package/lib/theme/hooks/useDocs.js +0 -75
- package/lib/versions.d.ts +0 -16
- package/lib/versions.js +0 -319
- package/src/__tests__/__fixtures__/bad-id-site/docs/invalid-id.md +0 -5
- package/src/__tests__/__fixtures__/bad-slug-on-doc-home-site/docs/docWithSlug.md +0 -5
- package/src/__tests__/__fixtures__/empty-site/docusaurus.config.js +0 -16
- package/src/__tests__/__fixtures__/empty-site/sidebars.json +0 -1
- package/src/__tests__/__fixtures__/sidebars/sidebars-category-shorthand.js +0 -34
- package/src/__tests__/__fixtures__/sidebars/sidebars-category-wrong-items.json +0 -11
- package/src/__tests__/__fixtures__/sidebars/sidebars-category-wrong-label.json +0 -11
- package/src/__tests__/__fixtures__/sidebars/sidebars-category.js +0 -44
- package/src/__tests__/__fixtures__/sidebars/sidebars-collapsed-first-level.json +0 -20
- package/src/__tests__/__fixtures__/sidebars/sidebars-collapsed.json +0 -21
- package/src/__tests__/__fixtures__/sidebars/sidebars-doc-id-not-string.json +0 -10
- package/src/__tests__/__fixtures__/sidebars/sidebars-link-wrong-href.json +0 -11
- package/src/__tests__/__fixtures__/sidebars/sidebars-link-wrong-label.json +0 -11
- package/src/__tests__/__fixtures__/sidebars/sidebars-link.json +0 -11
- package/src/__tests__/__fixtures__/sidebars/sidebars-unknown-type.json +0 -14
- package/src/__tests__/__fixtures__/sidebars/sidebars-wrong-field.json +0 -20
- package/src/__tests__/__fixtures__/sidebars/sidebars.json +0 -20
- package/src/__tests__/__fixtures__/simple-site/docs/foo/bar.md +0 -69
- package/src/__tests__/__fixtures__/simple-site/docs/foo/baz.md +0 -70
- package/src/__tests__/__fixtures__/simple-site/docs/headingAsTitle.md +0 -1
- package/src/__tests__/__fixtures__/simple-site/docs/hello.md +0 -53
- package/src/__tests__/__fixtures__/simple-site/docs/ipsum.md +0 -5
- package/src/__tests__/__fixtures__/simple-site/docs/lorem.md +0 -6
- package/src/__tests__/__fixtures__/simple-site/docs/rootAbsoluteSlug.md +0 -5
- package/src/__tests__/__fixtures__/simple-site/docs/rootRelativeSlug.md +0 -5
- package/src/__tests__/__fixtures__/simple-site/docs/rootResolvedSlug.md +0 -5
- package/src/__tests__/__fixtures__/simple-site/docs/rootTryToEscapeSlug.md +0 -5
- package/src/__tests__/__fixtures__/simple-site/docs/slugs/absoluteSlug.md +0 -5
- package/src/__tests__/__fixtures__/simple-site/docs/slugs/relativeSlug.md +0 -5
- package/src/__tests__/__fixtures__/simple-site/docs/slugs/resolvedSlug.md +0 -5
- package/src/__tests__/__fixtures__/simple-site/docs/slugs/tryToEscapeSlug.md +0 -5
- package/src/__tests__/__fixtures__/simple-site/docusaurus.config.js +0 -14
- package/src/__tests__/__fixtures__/simple-site/sidebars.json +0 -23
- package/src/__tests__/__fixtures__/simple-site/wrong-sidebars.json +0 -7
- package/src/__tests__/__fixtures__/site-with-autogenerated-sidebar/docs/0-getting-started.md +0 -3
- package/src/__tests__/__fixtures__/site-with-autogenerated-sidebar/docs/1-installation.md +0 -3
- package/src/__tests__/__fixtures__/site-with-autogenerated-sidebar/docs/3-API/00_api-overview.md +0 -3
- package/src/__tests__/__fixtures__/site-with-autogenerated-sidebar/docs/3-API/01_Core APIs/0 --- Client API.md +0 -1
- package/src/__tests__/__fixtures__/site-with-autogenerated-sidebar/docs/3-API/01_Core APIs/1 --- Server API.md +0 -1
- package/src/__tests__/__fixtures__/site-with-autogenerated-sidebar/docs/3-API/02_Extension APIs/0. Plugin API.md +0 -1
- package/src/__tests__/__fixtures__/site-with-autogenerated-sidebar/docs/3-API/02_Extension APIs/1. Theme API.md +0 -1
- package/src/__tests__/__fixtures__/site-with-autogenerated-sidebar/docs/3-API/02_Extension APIs/_category_.yml +0 -1
- package/src/__tests__/__fixtures__/site-with-autogenerated-sidebar/docs/3-API/03_api-end.md +0 -3
- package/src/__tests__/__fixtures__/site-with-autogenerated-sidebar/docs/3-API/_category_.json +0 -3
- package/src/__tests__/__fixtures__/site-with-autogenerated-sidebar/docs/Guides/0-guide2.5.md +0 -8
- package/src/__tests__/__fixtures__/site-with-autogenerated-sidebar/docs/Guides/02-guide2.md +0 -7
- package/src/__tests__/__fixtures__/site-with-autogenerated-sidebar/docs/Guides/_category_.json +0 -3
- package/src/__tests__/__fixtures__/site-with-autogenerated-sidebar/docs/Guides/a-guide4.md +0 -7
- package/src/__tests__/__fixtures__/site-with-autogenerated-sidebar/docs/Guides/b-guide5.md +0 -7
- package/src/__tests__/__fixtures__/site-with-autogenerated-sidebar/docs/Guides/guide3.md +0 -8
- package/src/__tests__/__fixtures__/site-with-autogenerated-sidebar/docs/Guides/z-guide1.md +0 -8
- package/src/__tests__/__fixtures__/site-with-autogenerated-sidebar/partialAutogeneratedSidebars.js +0 -23
- package/src/__tests__/__fixtures__/site-with-autogenerated-sidebar/partialAutogeneratedSidebars2.js +0 -16
- package/src/__tests__/__fixtures__/site-with-doc-label/docs/hello-1.md +0 -7
- package/src/__tests__/__fixtures__/site-with-doc-label/docs/hello-2.md +0 -8
- package/src/__tests__/__fixtures__/site-with-doc-label/docusaurus.config.js +0 -14
- package/src/__tests__/__fixtures__/site-with-doc-label/sidebars.json +0 -14
- package/src/__tests__/__fixtures__/versioned-site/community/team.md +0 -1
- package/src/__tests__/__fixtures__/versioned-site/community_sidebars.json +0 -3
- package/src/__tests__/__fixtures__/versioned-site/community_versioned_docs/version-1.0.0/team.md +0 -1
- package/src/__tests__/__fixtures__/versioned-site/community_versioned_sidebars/version-1.0.0-sidebars.json +0 -3
- package/src/__tests__/__fixtures__/versioned-site/community_versions.json +0 -1
- package/src/__tests__/__fixtures__/versioned-site/docs/foo/bar.md +0 -4
- package/src/__tests__/__fixtures__/versioned-site/docs/hello.md +0 -1
- package/src/__tests__/__fixtures__/versioned-site/docs/slugs/absoluteSlug.md +0 -5
- package/src/__tests__/__fixtures__/versioned-site/docs/slugs/relativeSlug.md +0 -5
- package/src/__tests__/__fixtures__/versioned-site/docs/slugs/resolvedSlug.md +0 -5
- package/src/__tests__/__fixtures__/versioned-site/docs/slugs/tryToEscapeSlug.md +0 -5
- package/src/__tests__/__fixtures__/versioned-site/docusaurus.config.js +0 -18
- package/src/__tests__/__fixtures__/versioned-site/i18n/en/docusaurus-plugin-content-docs/version-1.0.0/hello.md +0 -1
- package/src/__tests__/__fixtures__/versioned-site/i18n/en/docusaurus-plugin-content-docs-community/current/team.md +0 -5
- package/src/__tests__/__fixtures__/versioned-site/i18n/fr/docusaurus-plugin-content-docs/version-1.0.0/hello.md +0 -1
- package/src/__tests__/__fixtures__/versioned-site/sidebars.json +0 -10
- package/src/__tests__/__fixtures__/versioned-site/versioned_docs/version-1.0.0/foo/bar.md +0 -4
- package/src/__tests__/__fixtures__/versioned-site/versioned_docs/version-1.0.0/foo/baz.md +0 -1
- package/src/__tests__/__fixtures__/versioned-site/versioned_docs/version-1.0.0/hello.md +0 -1
- package/src/__tests__/__fixtures__/versioned-site/versioned_docs/version-1.0.1/foo/bar.md +0 -1
- package/src/__tests__/__fixtures__/versioned-site/versioned_docs/version-1.0.1/hello.md +0 -1
- package/src/__tests__/__fixtures__/versioned-site/versioned_docs/version-withSlugs/rootAbsoluteSlug.md +0 -5
- package/src/__tests__/__fixtures__/versioned-site/versioned_docs/version-withSlugs/rootRelativeSlug.md +0 -5
- package/src/__tests__/__fixtures__/versioned-site/versioned_docs/version-withSlugs/rootResolvedSlug.md +0 -5
- package/src/__tests__/__fixtures__/versioned-site/versioned_docs/version-withSlugs/rootTryToEscapeSlug.md +0 -5
- package/src/__tests__/__fixtures__/versioned-site/versioned_docs/version-withSlugs/slugs/absoluteSlug.md +0 -5
- package/src/__tests__/__fixtures__/versioned-site/versioned_docs/version-withSlugs/slugs/relativeSlug.md +0 -5
- package/src/__tests__/__fixtures__/versioned-site/versioned_docs/version-withSlugs/slugs/resolvedSlug.md +0 -5
- package/src/__tests__/__fixtures__/versioned-site/versioned_docs/version-withSlugs/slugs/tryToEscapeSlug.md +0 -5
- package/src/__tests__/__fixtures__/versioned-site/versioned_sidebars/version-1.0.0-sidebars.json +0 -11
- package/src/__tests__/__fixtures__/versioned-site/versioned_sidebars/version-1.0.1-sidebars.json +0 -10
- package/src/__tests__/__fixtures__/versioned-site/versioned_sidebars/version-withSlugs-sidebars.json +0 -5
- package/src/__tests__/__fixtures__/versioned-site/versions.json +0 -5
- package/src/__tests__/__snapshots__/cli.test.ts.snap +0 -90
- package/src/__tests__/__snapshots__/index.test.ts.snap +0 -1916
- package/src/__tests__/__snapshots__/sidebars.test.ts.snap +0 -218
- package/src/__tests__/__snapshots__/translations.test.ts.snap +0 -487
- package/src/__tests__/cli.test.ts +0 -333
- package/src/__tests__/docFrontMatter.test.ts +0 -244
- package/src/__tests__/docs.test.ts +0 -878
- package/src/__tests__/index.test.ts +0 -1871
- package/src/__tests__/lastUpdate.test.ts +0 -69
- package/src/__tests__/numberPrefix.test.ts +0 -199
- package/src/__tests__/options.test.ts +0 -231
- package/src/__tests__/sidebarItemsGenerator.test.ts +0 -336
- package/src/__tests__/sidebars.test.ts +0 -639
- package/src/__tests__/slug.test.ts +0 -109
- package/src/__tests__/translations.test.ts +0 -159
- package/src/__tests__/versions.test.ts +0 -741
- package/src/client/__tests__/docsClientUtils.test.ts +0 -371
- package/src/docFrontMatter.ts +0 -41
- package/src/markdown/__tests__/__fixtures__/docs/doc-localized.md +0 -1
- package/src/markdown/__tests__/__fixtures__/docs/doc1.md +0 -13
- package/src/markdown/__tests__/__fixtures__/docs/doc2.md +0 -12
- package/src/markdown/__tests__/__fixtures__/docs/doc4.md +0 -19
- package/src/markdown/__tests__/__fixtures__/docs/doc5.md +0 -6
- package/src/markdown/__tests__/__fixtures__/docs/subdir/doc3.md +0 -3
- package/src/markdown/__tests__/__fixtures__/versioned_docs/version-1.0.0/doc2.md +0 -7
- package/src/markdown/__tests__/__fixtures__/versioned_docs/version-1.0.0/subdir/doc1.md +0 -3
- package/src/markdown/__tests__/__snapshots__/linkify.test.ts.snap +0 -82
- package/src/markdown/__tests__/linkify.test.ts +0 -190
- package/src/sidebarItemsGenerator.ts +0 -307
- package/src/sidebars.ts +0 -522
- package/src/theme/hooks/useDocs.ts +0 -103
- package/src/versions.ts +0 -572
- package/tsconfig.json +0 -9
- package/types.d.ts +0 -13
|
@@ -0,0 +1,118 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Copyright (c) Facebook, Inc. and its affiliates.
|
|
3
|
+
*
|
|
4
|
+
* This source code is licensed under the MIT license found in the
|
|
5
|
+
* LICENSE file in the root directory of this source tree.
|
|
6
|
+
*/
|
|
7
|
+
|
|
8
|
+
import fs from 'fs-extra';
|
|
9
|
+
import path from 'path';
|
|
10
|
+
import _ from 'lodash';
|
|
11
|
+
import logger from '@docusaurus/logger';
|
|
12
|
+
import {Globby} from '@docusaurus/utils';
|
|
13
|
+
import Yaml from 'js-yaml';
|
|
14
|
+
import combinePromises from 'combine-promises';
|
|
15
|
+
import importFresh from 'import-fresh';
|
|
16
|
+
import {validateSidebars, validateCategoryMetadataFile} from './validation';
|
|
17
|
+
import {normalizeSidebars} from './normalization';
|
|
18
|
+
import {processSidebars} from './processor';
|
|
19
|
+
import {postProcessSidebars} from './postProcessor';
|
|
20
|
+
import type {PluginOptions} from '@docusaurus/plugin-content-docs';
|
|
21
|
+
import type {SidebarsConfig, Sidebars, SidebarProcessorParams} from './types';
|
|
22
|
+
|
|
23
|
+
export const DefaultSidebars: SidebarsConfig = {
|
|
24
|
+
defaultSidebar: [
|
|
25
|
+
{
|
|
26
|
+
type: 'autogenerated',
|
|
27
|
+
dirName: '.',
|
|
28
|
+
},
|
|
29
|
+
],
|
|
30
|
+
};
|
|
31
|
+
|
|
32
|
+
export const DisabledSidebars: SidebarsConfig = {};
|
|
33
|
+
|
|
34
|
+
// If a path is provided, make it absolute
|
|
35
|
+
export function resolveSidebarPathOption(
|
|
36
|
+
siteDir: string,
|
|
37
|
+
sidebarPathOption: PluginOptions['sidebarPath'],
|
|
38
|
+
): PluginOptions['sidebarPath'] {
|
|
39
|
+
return sidebarPathOption
|
|
40
|
+
? path.resolve(siteDir, sidebarPathOption)
|
|
41
|
+
: sidebarPathOption;
|
|
42
|
+
}
|
|
43
|
+
|
|
44
|
+
async function readCategoriesMetadata(contentPath: string) {
|
|
45
|
+
const categoryFiles = await Globby('**/_category_.{json,yml,yaml}', {
|
|
46
|
+
cwd: contentPath,
|
|
47
|
+
});
|
|
48
|
+
const categoryToFile = _.groupBy(categoryFiles, path.dirname);
|
|
49
|
+
return combinePromises(
|
|
50
|
+
_.mapValues(categoryToFile, async (files, folder) => {
|
|
51
|
+
const filePath = files[0]!;
|
|
52
|
+
if (files.length > 1) {
|
|
53
|
+
logger.warn`There are more than one category metadata files for path=${folder}: ${files.join(
|
|
54
|
+
', ',
|
|
55
|
+
)}. The behavior is undetermined.`;
|
|
56
|
+
}
|
|
57
|
+
const content = await fs.readFile(
|
|
58
|
+
path.join(contentPath, filePath),
|
|
59
|
+
'utf-8',
|
|
60
|
+
);
|
|
61
|
+
try {
|
|
62
|
+
return validateCategoryMetadataFile(Yaml.load(content));
|
|
63
|
+
} catch (err) {
|
|
64
|
+
logger.error`The docs sidebar category metadata file path=${filePath} looks invalid!`;
|
|
65
|
+
throw err;
|
|
66
|
+
}
|
|
67
|
+
}),
|
|
68
|
+
);
|
|
69
|
+
}
|
|
70
|
+
|
|
71
|
+
export async function loadSidebarsFileUnsafe(
|
|
72
|
+
sidebarFilePath: string | false | undefined,
|
|
73
|
+
): Promise<SidebarsConfig> {
|
|
74
|
+
// false => no sidebars
|
|
75
|
+
if (sidebarFilePath === false) {
|
|
76
|
+
return DisabledSidebars;
|
|
77
|
+
}
|
|
78
|
+
|
|
79
|
+
// undefined => defaults to autogenerated sidebars
|
|
80
|
+
if (typeof sidebarFilePath === 'undefined') {
|
|
81
|
+
return DefaultSidebars;
|
|
82
|
+
}
|
|
83
|
+
|
|
84
|
+
// Non-existent sidebars file: no sidebars
|
|
85
|
+
// Note: this edge case can happen on versioned docs, not current version
|
|
86
|
+
// We avoid creating empty versioned sidebars file with the CLI
|
|
87
|
+
if (!(await fs.pathExists(sidebarFilePath))) {
|
|
88
|
+
return DisabledSidebars;
|
|
89
|
+
}
|
|
90
|
+
|
|
91
|
+
// We don't want sidebars to be cached because of hot reloading.
|
|
92
|
+
return importFresh(sidebarFilePath);
|
|
93
|
+
}
|
|
94
|
+
|
|
95
|
+
export async function loadSidebars(
|
|
96
|
+
sidebarFilePath: string | false | undefined,
|
|
97
|
+
options: SidebarProcessorParams,
|
|
98
|
+
): Promise<Sidebars> {
|
|
99
|
+
try {
|
|
100
|
+
const sidebarsConfig = await loadSidebarsFileUnsafe(sidebarFilePath);
|
|
101
|
+
const normalizedSidebars = normalizeSidebars(sidebarsConfig);
|
|
102
|
+
validateSidebars(normalizedSidebars);
|
|
103
|
+
const categoriesMetadata = await readCategoriesMetadata(
|
|
104
|
+
options.version.contentPath,
|
|
105
|
+
);
|
|
106
|
+
const processedSidebars = await processSidebars(
|
|
107
|
+
normalizedSidebars,
|
|
108
|
+
categoriesMetadata,
|
|
109
|
+
options,
|
|
110
|
+
);
|
|
111
|
+
return postProcessSidebars(processedSidebars, options);
|
|
112
|
+
} catch (err) {
|
|
113
|
+
logger.error`Sidebars file at path=${
|
|
114
|
+
sidebarFilePath as string
|
|
115
|
+
} failed to be loaded.`;
|
|
116
|
+
throw err;
|
|
117
|
+
}
|
|
118
|
+
}
|
|
@@ -0,0 +1,91 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Copyright (c) Facebook, Inc. and its affiliates.
|
|
3
|
+
*
|
|
4
|
+
* This source code is licensed under the MIT license found in the
|
|
5
|
+
* LICENSE file in the root directory of this source tree.
|
|
6
|
+
*/
|
|
7
|
+
|
|
8
|
+
import _ from 'lodash';
|
|
9
|
+
import logger from '@docusaurus/logger';
|
|
10
|
+
import {isCategoriesShorthand} from './utils';
|
|
11
|
+
import type {
|
|
12
|
+
NormalizedSidebarItem,
|
|
13
|
+
NormalizedSidebar,
|
|
14
|
+
NormalizedSidebars,
|
|
15
|
+
SidebarCategoriesShorthand,
|
|
16
|
+
SidebarItemCategoryConfig,
|
|
17
|
+
SidebarItemConfig,
|
|
18
|
+
SidebarConfig,
|
|
19
|
+
SidebarsConfig,
|
|
20
|
+
NormalizedSidebarItemCategory,
|
|
21
|
+
} from './types';
|
|
22
|
+
|
|
23
|
+
function normalizeCategoriesShorthand(
|
|
24
|
+
sidebar: SidebarCategoriesShorthand,
|
|
25
|
+
): SidebarItemCategoryConfig[] {
|
|
26
|
+
return Object.entries(sidebar).map(([label, items]) => ({
|
|
27
|
+
type: 'category',
|
|
28
|
+
label,
|
|
29
|
+
items,
|
|
30
|
+
}));
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
/**
|
|
34
|
+
* Normalizes recursively item and all its children. Ensures that at the end
|
|
35
|
+
* each item will be an object with the corresponding type.
|
|
36
|
+
*/
|
|
37
|
+
export function normalizeItem(
|
|
38
|
+
item: SidebarItemConfig,
|
|
39
|
+
): NormalizedSidebarItem[] {
|
|
40
|
+
if (typeof item === 'string') {
|
|
41
|
+
return [{type: 'doc', id: item}];
|
|
42
|
+
}
|
|
43
|
+
if (isCategoriesShorthand(item)) {
|
|
44
|
+
// This will never throw anyways
|
|
45
|
+
return normalizeSidebar(item, 'sidebar items slice');
|
|
46
|
+
}
|
|
47
|
+
if (
|
|
48
|
+
(item.type === 'doc' || item.type === 'ref') &&
|
|
49
|
+
typeof item.label === 'string'
|
|
50
|
+
) {
|
|
51
|
+
return [{...item, translatable: true}];
|
|
52
|
+
}
|
|
53
|
+
if (item.type === 'category') {
|
|
54
|
+
const normalizedCategory: NormalizedSidebarItemCategory = {
|
|
55
|
+
...item,
|
|
56
|
+
items: normalizeSidebar(
|
|
57
|
+
item.items,
|
|
58
|
+
logger.interpolate`code=${'items'} of the category name=${item.label}`,
|
|
59
|
+
),
|
|
60
|
+
};
|
|
61
|
+
return [normalizedCategory];
|
|
62
|
+
}
|
|
63
|
+
return [item];
|
|
64
|
+
}
|
|
65
|
+
|
|
66
|
+
function normalizeSidebar(
|
|
67
|
+
sidebar: SidebarConfig,
|
|
68
|
+
place: string,
|
|
69
|
+
): NormalizedSidebar {
|
|
70
|
+
if (!Array.isArray(sidebar) && !isCategoriesShorthand(sidebar)) {
|
|
71
|
+
throw new Error(
|
|
72
|
+
logger.interpolate`Invalid sidebar items collection code=${JSON.stringify(
|
|
73
|
+
sidebar,
|
|
74
|
+
)} in ${place}: it must either be an array of sidebar items or a shorthand notation (which doesn't contain a code=${'type'} property). See url=${'https://docusaurus.io/docs/sidebar/items'} for all valid syntaxes.`,
|
|
75
|
+
);
|
|
76
|
+
}
|
|
77
|
+
|
|
78
|
+
const normalizedSidebar = Array.isArray(sidebar)
|
|
79
|
+
? sidebar
|
|
80
|
+
: normalizeCategoriesShorthand(sidebar);
|
|
81
|
+
|
|
82
|
+
return normalizedSidebar.flatMap((subItem) => normalizeItem(subItem));
|
|
83
|
+
}
|
|
84
|
+
|
|
85
|
+
export function normalizeSidebars(
|
|
86
|
+
sidebars: SidebarsConfig,
|
|
87
|
+
): NormalizedSidebars {
|
|
88
|
+
return _.mapValues(sidebars, (sidebar, id) =>
|
|
89
|
+
normalizeSidebar(sidebar, logger.interpolate`sidebar name=${id}`),
|
|
90
|
+
);
|
|
91
|
+
}
|
|
@@ -0,0 +1,112 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Copyright (c) Facebook, Inc. and its affiliates.
|
|
3
|
+
*
|
|
4
|
+
* This source code is licensed under the MIT license found in the
|
|
5
|
+
* LICENSE file in the root directory of this source tree.
|
|
6
|
+
*/
|
|
7
|
+
|
|
8
|
+
import _ from 'lodash';
|
|
9
|
+
import {normalizeUrl} from '@docusaurus/utils';
|
|
10
|
+
import {getDocIds} from '../docs';
|
|
11
|
+
import type {
|
|
12
|
+
SidebarItem,
|
|
13
|
+
Sidebars,
|
|
14
|
+
SidebarProcessorParams,
|
|
15
|
+
ProcessedSidebarItemCategory,
|
|
16
|
+
ProcessedSidebarItem,
|
|
17
|
+
ProcessedSidebars,
|
|
18
|
+
SidebarItemCategoryLink,
|
|
19
|
+
} from './types';
|
|
20
|
+
|
|
21
|
+
export type SidebarPostProcessorParams = SidebarProcessorParams & {
|
|
22
|
+
draftIds: Set<string>;
|
|
23
|
+
};
|
|
24
|
+
|
|
25
|
+
function normalizeCategoryLink(
|
|
26
|
+
category: ProcessedSidebarItemCategory,
|
|
27
|
+
params: SidebarPostProcessorParams,
|
|
28
|
+
): SidebarItemCategoryLink | undefined {
|
|
29
|
+
if (category.link?.type === 'doc' && params.draftIds.has(category.link.id)) {
|
|
30
|
+
return undefined;
|
|
31
|
+
}
|
|
32
|
+
if (category.link?.type === 'generated-index') {
|
|
33
|
+
// Default slug logic can be improved
|
|
34
|
+
const getDefaultSlug = () =>
|
|
35
|
+
`/category/${params.categoryLabelSlugger.slug(category.label)}`;
|
|
36
|
+
const slug = category.link.slug ?? getDefaultSlug();
|
|
37
|
+
const permalink = normalizeUrl([params.version.path, slug]);
|
|
38
|
+
return {
|
|
39
|
+
...category.link,
|
|
40
|
+
slug,
|
|
41
|
+
permalink,
|
|
42
|
+
};
|
|
43
|
+
}
|
|
44
|
+
return category.link;
|
|
45
|
+
}
|
|
46
|
+
|
|
47
|
+
function postProcessSidebarItem(
|
|
48
|
+
item: ProcessedSidebarItem,
|
|
49
|
+
params: SidebarPostProcessorParams,
|
|
50
|
+
): SidebarItem | null {
|
|
51
|
+
if (item.type === 'category') {
|
|
52
|
+
// Fail-fast if there's actually no subitems, no because all subitems are
|
|
53
|
+
// drafts. This is likely a configuration mistake.
|
|
54
|
+
if (item.items.length === 0 && !item.link) {
|
|
55
|
+
throw new Error(
|
|
56
|
+
`Sidebar category ${item.label} has neither any subitem nor a link. This makes this item not able to link to anything.`,
|
|
57
|
+
);
|
|
58
|
+
}
|
|
59
|
+
const category = {
|
|
60
|
+
...item,
|
|
61
|
+
collapsed: item.collapsed ?? params.sidebarOptions.sidebarCollapsed,
|
|
62
|
+
collapsible: item.collapsible ?? params.sidebarOptions.sidebarCollapsible,
|
|
63
|
+
link: normalizeCategoryLink(item, params),
|
|
64
|
+
items: item.items
|
|
65
|
+
.map((subItem) => postProcessSidebarItem(subItem, params))
|
|
66
|
+
.filter((v): v is SidebarItem => Boolean(v)),
|
|
67
|
+
};
|
|
68
|
+
// If the current category doesn't have subitems, we render a normal link
|
|
69
|
+
// instead.
|
|
70
|
+
if (category.items.length === 0) {
|
|
71
|
+
// Doesn't make sense to render an empty generated index page, so we
|
|
72
|
+
// filter the entire category out as well.
|
|
73
|
+
if (
|
|
74
|
+
!category.link ||
|
|
75
|
+
category.link.type === 'generated-index' ||
|
|
76
|
+
params.draftIds.has(category.link.id)
|
|
77
|
+
) {
|
|
78
|
+
return null;
|
|
79
|
+
}
|
|
80
|
+
return {
|
|
81
|
+
type: 'doc',
|
|
82
|
+
label: category.label,
|
|
83
|
+
id: category.link.id,
|
|
84
|
+
};
|
|
85
|
+
}
|
|
86
|
+
// A non-collapsible category can't be collapsed!
|
|
87
|
+
if (!category.collapsible) {
|
|
88
|
+
category.collapsed = false;
|
|
89
|
+
}
|
|
90
|
+
return category;
|
|
91
|
+
}
|
|
92
|
+
if (
|
|
93
|
+
(item.type === 'doc' || item.type === 'ref') &&
|
|
94
|
+
params.draftIds.has(item.id)
|
|
95
|
+
) {
|
|
96
|
+
return null;
|
|
97
|
+
}
|
|
98
|
+
return item;
|
|
99
|
+
}
|
|
100
|
+
|
|
101
|
+
export function postProcessSidebars(
|
|
102
|
+
sidebars: ProcessedSidebars,
|
|
103
|
+
params: SidebarProcessorParams,
|
|
104
|
+
): Sidebars {
|
|
105
|
+
const draftIds = new Set(params.drafts.flatMap(getDocIds));
|
|
106
|
+
|
|
107
|
+
return _.mapValues(sidebars, (sidebar) =>
|
|
108
|
+
sidebar
|
|
109
|
+
.map((item) => postProcessSidebarItem(item, {...params, draftIds}))
|
|
110
|
+
.filter((v): v is SidebarItem => Boolean(v)),
|
|
111
|
+
);
|
|
112
|
+
}
|
|
@@ -0,0 +1,123 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Copyright (c) Facebook, Inc. and its affiliates.
|
|
3
|
+
*
|
|
4
|
+
* This source code is licensed under the MIT license found in the
|
|
5
|
+
* LICENSE file in the root directory of this source tree.
|
|
6
|
+
*/
|
|
7
|
+
|
|
8
|
+
import _ from 'lodash';
|
|
9
|
+
import combinePromises from 'combine-promises';
|
|
10
|
+
import {DefaultSidebarItemsGenerator} from './generator';
|
|
11
|
+
import {validateSidebars} from './validation';
|
|
12
|
+
import {isCategoryIndex} from '../docs';
|
|
13
|
+
import type {
|
|
14
|
+
DocMetadataBase,
|
|
15
|
+
VersionMetadata,
|
|
16
|
+
} from '@docusaurus/plugin-content-docs';
|
|
17
|
+
import type {
|
|
18
|
+
NormalizedSidebarItem,
|
|
19
|
+
NormalizedSidebar,
|
|
20
|
+
NormalizedSidebars,
|
|
21
|
+
SidebarItemsGeneratorDoc,
|
|
22
|
+
SidebarItemsGeneratorVersion,
|
|
23
|
+
SidebarItemAutogenerated,
|
|
24
|
+
ProcessedSidebarItem,
|
|
25
|
+
ProcessedSidebar,
|
|
26
|
+
ProcessedSidebars,
|
|
27
|
+
SidebarProcessorParams,
|
|
28
|
+
CategoryMetadataFile,
|
|
29
|
+
} from './types';
|
|
30
|
+
|
|
31
|
+
function toSidebarItemsGeneratorDoc(
|
|
32
|
+
doc: DocMetadataBase,
|
|
33
|
+
): SidebarItemsGeneratorDoc {
|
|
34
|
+
return _.pick(doc, [
|
|
35
|
+
'id',
|
|
36
|
+
'unversionedId',
|
|
37
|
+
'title',
|
|
38
|
+
'frontMatter',
|
|
39
|
+
'source',
|
|
40
|
+
'sourceDirName',
|
|
41
|
+
'sidebarPosition',
|
|
42
|
+
]);
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
function toSidebarItemsGeneratorVersion(
|
|
46
|
+
version: VersionMetadata,
|
|
47
|
+
): SidebarItemsGeneratorVersion {
|
|
48
|
+
return _.pick(version, ['versionName', 'contentPath']);
|
|
49
|
+
}
|
|
50
|
+
|
|
51
|
+
// Handle the generation of autogenerated sidebar items and other
|
|
52
|
+
// post-processing checks
|
|
53
|
+
async function processSidebar(
|
|
54
|
+
unprocessedSidebar: NormalizedSidebar,
|
|
55
|
+
categoriesMetadata: {[filePath: string]: CategoryMetadataFile},
|
|
56
|
+
params: SidebarProcessorParams,
|
|
57
|
+
): Promise<ProcessedSidebar> {
|
|
58
|
+
const {sidebarItemsGenerator, numberPrefixParser, docs, version} = params;
|
|
59
|
+
|
|
60
|
+
// Just a minor lazy transformation optimization
|
|
61
|
+
const getSidebarItemsGeneratorDocsAndVersion = _.memoize(() => ({
|
|
62
|
+
docs: docs.map(toSidebarItemsGeneratorDoc),
|
|
63
|
+
version: toSidebarItemsGeneratorVersion(version),
|
|
64
|
+
}));
|
|
65
|
+
|
|
66
|
+
async function processAutoGeneratedItem(
|
|
67
|
+
item: SidebarItemAutogenerated,
|
|
68
|
+
): Promise<ProcessedSidebarItem[]> {
|
|
69
|
+
const generatedItems = await sidebarItemsGenerator({
|
|
70
|
+
item,
|
|
71
|
+
numberPrefixParser,
|
|
72
|
+
defaultSidebarItemsGenerator: DefaultSidebarItemsGenerator,
|
|
73
|
+
isCategoryIndex,
|
|
74
|
+
...getSidebarItemsGeneratorDocsAndVersion(),
|
|
75
|
+
categoriesMetadata,
|
|
76
|
+
});
|
|
77
|
+
// Process again... weird but sidebar item generated might generate some
|
|
78
|
+
// auto-generated items?
|
|
79
|
+
// TODO repeatedly process & unwrap autogenerated items until there are no
|
|
80
|
+
// more autogenerated items, or when loop count (e.g. 10) is reached
|
|
81
|
+
return processItems(generatedItems);
|
|
82
|
+
}
|
|
83
|
+
|
|
84
|
+
async function processItem(
|
|
85
|
+
item: NormalizedSidebarItem,
|
|
86
|
+
): Promise<ProcessedSidebarItem[]> {
|
|
87
|
+
if (item.type === 'category') {
|
|
88
|
+
return [
|
|
89
|
+
{
|
|
90
|
+
...item,
|
|
91
|
+
items: (await Promise.all(item.items.map(processItem))).flat(),
|
|
92
|
+
},
|
|
93
|
+
];
|
|
94
|
+
}
|
|
95
|
+
if (item.type === 'autogenerated') {
|
|
96
|
+
return processAutoGeneratedItem(item);
|
|
97
|
+
}
|
|
98
|
+
return [item];
|
|
99
|
+
}
|
|
100
|
+
|
|
101
|
+
async function processItems(
|
|
102
|
+
items: NormalizedSidebarItem[],
|
|
103
|
+
): Promise<ProcessedSidebarItem[]> {
|
|
104
|
+
return (await Promise.all(items.map(processItem))).flat();
|
|
105
|
+
}
|
|
106
|
+
|
|
107
|
+
const processedSidebar = await processItems(unprocessedSidebar);
|
|
108
|
+
return processedSidebar;
|
|
109
|
+
}
|
|
110
|
+
|
|
111
|
+
export async function processSidebars(
|
|
112
|
+
unprocessedSidebars: NormalizedSidebars,
|
|
113
|
+
categoriesMetadata: {[filePath: string]: CategoryMetadataFile},
|
|
114
|
+
params: SidebarProcessorParams,
|
|
115
|
+
): Promise<ProcessedSidebars> {
|
|
116
|
+
const processedSidebars = await combinePromises(
|
|
117
|
+
_.mapValues(unprocessedSidebars, (unprocessedSidebar) =>
|
|
118
|
+
processSidebar(unprocessedSidebar, categoriesMetadata, params),
|
|
119
|
+
),
|
|
120
|
+
);
|
|
121
|
+
validateSidebars(processedSidebars);
|
|
122
|
+
return processedSidebars;
|
|
123
|
+
}
|