@docusaurus/plugin-content-docs 2.0.0-beta.ff31de0ff → 2.0.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.
Files changed (231) hide show
  1. package/lib/categoryGeneratedIndex.d.ts +12 -0
  2. package/lib/categoryGeneratedIndex.js +37 -0
  3. package/lib/cli.d.ts +3 -2
  4. package/lib/cli.js +62 -72
  5. package/lib/client/docsClientUtils.d.ts +9 -28
  6. package/lib/client/docsClientUtils.js +35 -51
  7. package/lib/client/index.d.ts +81 -0
  8. package/lib/client/index.js +67 -0
  9. package/lib/constants.d.ts +4 -0
  10. package/lib/constants.js +4 -1
  11. package/lib/docs.d.ts +35 -8
  12. package/lib/docs.js +211 -78
  13. package/{src/__tests__/__fixtures__/site-with-autogenerated-sidebar/partialAutogeneratedSidebars2.js → lib/frontMatter.d.ts} +4 -10
  14. package/lib/frontMatter.js +53 -0
  15. package/lib/globalData.d.ts +3 -3
  16. package/lib/globalData.js +35 -6
  17. package/lib/index.d.ts +3 -3
  18. package/lib/index.js +137 -146
  19. package/lib/lastUpdate.d.ts +4 -6
  20. package/lib/lastUpdate.js +22 -26
  21. package/lib/markdown/index.d.ts +3 -6
  22. package/lib/markdown/index.js +3 -3
  23. package/lib/markdown/linkify.d.ts +1 -1
  24. package/lib/markdown/linkify.js +7 -4
  25. package/lib/numberPrefix.d.ts +1 -1
  26. package/lib/numberPrefix.js +16 -21
  27. package/lib/options.d.ts +3 -5
  28. package/lib/options.js +57 -29
  29. package/lib/props.d.ts +7 -2
  30. package/lib/props.js +87 -16
  31. package/lib/routes.d.ts +29 -0
  32. package/lib/routes.js +96 -0
  33. package/lib/server-export.d.ts +9 -0
  34. package/lib/server-export.js +25 -0
  35. package/lib/{sidebarItemsGenerator.d.ts → sidebars/generator.d.ts} +1 -6
  36. package/lib/sidebars/generator.js +209 -0
  37. package/lib/sidebars/index.d.ts +13 -0
  38. package/lib/sidebars/index.js +92 -0
  39. package/lib/sidebars/normalization.d.ts +13 -0
  40. package/lib/sidebars/normalization.js +59 -0
  41. package/lib/sidebars/postProcessor.d.ts +11 -0
  42. package/lib/sidebars/postProcessor.js +81 -0
  43. package/lib/sidebars/processor.d.ts +10 -0
  44. package/lib/sidebars/processor.js +79 -0
  45. package/lib/sidebars/types.d.ts +183 -0
  46. package/{types.d.ts → lib/sidebars/types.js} +2 -7
  47. package/lib/sidebars/utils.d.ts +55 -0
  48. package/lib/sidebars/utils.js +259 -0
  49. package/lib/sidebars/validation.d.ts +11 -0
  50. package/lib/sidebars/validation.js +143 -0
  51. package/lib/slug.d.ts +5 -4
  52. package/lib/slug.js +29 -19
  53. package/{src/__tests__/__fixtures__/sidebars/sidebars-first-level-not-category.js → lib/tags.d.ts} +3 -14
  54. package/lib/tags.js +21 -0
  55. package/lib/translations.d.ts +3 -3
  56. package/lib/translations.js +100 -93
  57. package/lib/types.d.ts +13 -172
  58. package/lib/versions/files.d.ts +50 -0
  59. package/lib/versions/files.js +141 -0
  60. package/lib/versions/index.d.ts +36 -0
  61. package/lib/versions/index.js +154 -0
  62. package/lib/versions/validation.d.ts +17 -0
  63. package/lib/versions/validation.js +71 -0
  64. package/package.json +44 -29
  65. package/src/categoryGeneratedIndex.ts +60 -0
  66. package/src/cli.ts +94 -114
  67. package/src/client/docsClientUtils.ts +47 -84
  68. package/src/client/index.ts +158 -0
  69. package/src/constants.ts +4 -2
  70. package/src/docs.ts +294 -78
  71. package/src/frontMatter.ts +63 -0
  72. package/src/globalData.ts +57 -7
  73. package/src/index.ts +200 -204
  74. package/src/lastUpdate.ts +27 -34
  75. package/src/markdown/index.ts +10 -16
  76. package/src/markdown/linkify.ts +8 -5
  77. package/src/numberPrefix.ts +19 -26
  78. package/src/options.ts +61 -43
  79. package/src/plugin-content-docs.d.ts +575 -78
  80. package/src/props.ts +128 -23
  81. package/src/routes.ts +159 -0
  82. package/src/server-export.ts +26 -0
  83. package/src/sidebars/README.md +10 -0
  84. package/src/sidebars/generator.ts +292 -0
  85. package/src/sidebars/index.ts +118 -0
  86. package/src/sidebars/normalization.ts +91 -0
  87. package/src/sidebars/postProcessor.ts +112 -0
  88. package/src/sidebars/processor.ts +123 -0
  89. package/src/sidebars/types.ts +280 -0
  90. package/src/sidebars/utils.ts +393 -0
  91. package/src/sidebars/validation.ts +179 -0
  92. package/src/slug.ts +42 -23
  93. package/src/tags.ts +20 -0
  94. package/src/translations.ts +155 -124
  95. package/src/types.ts +17 -234
  96. package/src/versions/files.ts +216 -0
  97. package/src/versions/index.ts +246 -0
  98. package/src/versions/validation.ts +115 -0
  99. package/lib/.tsbuildinfo +0 -4673
  100. package/lib/docFrontMatter.d.ts +0 -21
  101. package/lib/docFrontMatter.js +0 -33
  102. package/lib/sidebarItemsGenerator.js +0 -211
  103. package/lib/sidebars.d.ts +0 -42
  104. package/lib/sidebars.js +0 -309
  105. package/lib/theme/hooks/useDocs.d.ts +0 -20
  106. package/lib/theme/hooks/useDocs.js +0 -72
  107. package/lib/versions.d.ts +0 -16
  108. package/lib/versions.js +0 -287
  109. package/src/__tests__/__fixtures__/bad-id-site/docs/invalid-id.md +0 -5
  110. package/src/__tests__/__fixtures__/bad-slug-on-doc-home-site/docs/docWithSlug.md +0 -5
  111. package/src/__tests__/__fixtures__/empty-site/docusaurus.config.js +0 -16
  112. package/src/__tests__/__fixtures__/empty-site/sidebars.json +0 -1
  113. package/src/__tests__/__fixtures__/sidebars/sidebars-category-shorthand.js +0 -34
  114. package/src/__tests__/__fixtures__/sidebars/sidebars-category-wrong-items.json +0 -11
  115. package/src/__tests__/__fixtures__/sidebars/sidebars-category-wrong-label.json +0 -11
  116. package/src/__tests__/__fixtures__/sidebars/sidebars-category.js +0 -44
  117. package/src/__tests__/__fixtures__/sidebars/sidebars-collapsed-first-level.json +0 -20
  118. package/src/__tests__/__fixtures__/sidebars/sidebars-collapsed.json +0 -21
  119. package/src/__tests__/__fixtures__/sidebars/sidebars-doc-id-not-string.json +0 -10
  120. package/src/__tests__/__fixtures__/sidebars/sidebars-link-wrong-href.json +0 -11
  121. package/src/__tests__/__fixtures__/sidebars/sidebars-link-wrong-label.json +0 -11
  122. package/src/__tests__/__fixtures__/sidebars/sidebars-link.json +0 -11
  123. package/src/__tests__/__fixtures__/sidebars/sidebars-unknown-type.json +0 -14
  124. package/src/__tests__/__fixtures__/sidebars/sidebars-wrong-field.json +0 -20
  125. package/src/__tests__/__fixtures__/sidebars/sidebars.json +0 -20
  126. package/src/__tests__/__fixtures__/simple-site/docs/foo/bar.md +0 -69
  127. package/src/__tests__/__fixtures__/simple-site/docs/foo/baz.md +0 -67
  128. package/src/__tests__/__fixtures__/simple-site/docs/headingAsTitle.md +0 -1
  129. package/src/__tests__/__fixtures__/simple-site/docs/hello.md +0 -52
  130. package/src/__tests__/__fixtures__/simple-site/docs/ipsum.md +0 -5
  131. package/src/__tests__/__fixtures__/simple-site/docs/lorem.md +0 -6
  132. package/src/__tests__/__fixtures__/simple-site/docs/rootAbsoluteSlug.md +0 -5
  133. package/src/__tests__/__fixtures__/simple-site/docs/rootRelativeSlug.md +0 -5
  134. package/src/__tests__/__fixtures__/simple-site/docs/rootResolvedSlug.md +0 -5
  135. package/src/__tests__/__fixtures__/simple-site/docs/rootTryToEscapeSlug.md +0 -5
  136. package/src/__tests__/__fixtures__/simple-site/docs/slugs/absoluteSlug.md +0 -5
  137. package/src/__tests__/__fixtures__/simple-site/docs/slugs/relativeSlug.md +0 -5
  138. package/src/__tests__/__fixtures__/simple-site/docs/slugs/resolvedSlug.md +0 -5
  139. package/src/__tests__/__fixtures__/simple-site/docs/slugs/tryToEscapeSlug.md +0 -5
  140. package/src/__tests__/__fixtures__/simple-site/docusaurus.config.js +0 -14
  141. package/src/__tests__/__fixtures__/simple-site/sidebars.json +0 -23
  142. package/src/__tests__/__fixtures__/simple-site/wrong-sidebars.json +0 -7
  143. package/src/__tests__/__fixtures__/site-with-autogenerated-sidebar/docs/0-getting-started.md +0 -3
  144. package/src/__tests__/__fixtures__/site-with-autogenerated-sidebar/docs/1-installation.md +0 -3
  145. package/src/__tests__/__fixtures__/site-with-autogenerated-sidebar/docs/3-API/00_api-overview.md +0 -3
  146. package/src/__tests__/__fixtures__/site-with-autogenerated-sidebar/docs/3-API/01_Core APIs/0 --- Client API.md +0 -1
  147. package/src/__tests__/__fixtures__/site-with-autogenerated-sidebar/docs/3-API/01_Core APIs/1 --- Server API.md +0 -1
  148. package/src/__tests__/__fixtures__/site-with-autogenerated-sidebar/docs/3-API/02_Extension APIs/0. Plugin API.md +0 -1
  149. package/src/__tests__/__fixtures__/site-with-autogenerated-sidebar/docs/3-API/02_Extension APIs/1. Theme API.md +0 -1
  150. package/src/__tests__/__fixtures__/site-with-autogenerated-sidebar/docs/3-API/02_Extension APIs/_category_.yml +0 -1
  151. package/src/__tests__/__fixtures__/site-with-autogenerated-sidebar/docs/3-API/03_api-end.md +0 -3
  152. package/src/__tests__/__fixtures__/site-with-autogenerated-sidebar/docs/3-API/_category_.json +0 -3
  153. package/src/__tests__/__fixtures__/site-with-autogenerated-sidebar/docs/Guides/0-guide2.5.md +0 -8
  154. package/src/__tests__/__fixtures__/site-with-autogenerated-sidebar/docs/Guides/02-guide2.md +0 -7
  155. package/src/__tests__/__fixtures__/site-with-autogenerated-sidebar/docs/Guides/_category_.json +0 -3
  156. package/src/__tests__/__fixtures__/site-with-autogenerated-sidebar/docs/Guides/a-guide4.md +0 -7
  157. package/src/__tests__/__fixtures__/site-with-autogenerated-sidebar/docs/Guides/b-guide5.md +0 -7
  158. package/src/__tests__/__fixtures__/site-with-autogenerated-sidebar/docs/Guides/guide3.md +0 -8
  159. package/src/__tests__/__fixtures__/site-with-autogenerated-sidebar/docs/Guides/z-guide1.md +0 -8
  160. package/src/__tests__/__fixtures__/site-with-autogenerated-sidebar/docusaurus.config.js +0 -14
  161. package/src/__tests__/__fixtures__/site-with-autogenerated-sidebar/partialAutogeneratedSidebars.js +0 -23
  162. package/src/__tests__/__fixtures__/site-with-doc-label/docs/hello-1.md +0 -7
  163. package/src/__tests__/__fixtures__/site-with-doc-label/docs/hello-2.md +0 -8
  164. package/src/__tests__/__fixtures__/site-with-doc-label/docusaurus.config.js +0 -14
  165. package/src/__tests__/__fixtures__/site-with-doc-label/sidebars.json +0 -14
  166. package/src/__tests__/__fixtures__/versioned-site/community/team.md +0 -1
  167. package/src/__tests__/__fixtures__/versioned-site/community_sidebars.json +0 -3
  168. package/src/__tests__/__fixtures__/versioned-site/community_versioned_docs/version-1.0.0/team.md +0 -1
  169. package/src/__tests__/__fixtures__/versioned-site/community_versioned_sidebars/version-1.0.0-sidebars.json +0 -3
  170. package/src/__tests__/__fixtures__/versioned-site/community_versions.json +0 -1
  171. package/src/__tests__/__fixtures__/versioned-site/docs/foo/bar.md +0 -4
  172. package/src/__tests__/__fixtures__/versioned-site/docs/hello.md +0 -1
  173. package/src/__tests__/__fixtures__/versioned-site/docs/slugs/absoluteSlug.md +0 -5
  174. package/src/__tests__/__fixtures__/versioned-site/docs/slugs/relativeSlug.md +0 -5
  175. package/src/__tests__/__fixtures__/versioned-site/docs/slugs/resolvedSlug.md +0 -5
  176. package/src/__tests__/__fixtures__/versioned-site/docs/slugs/tryToEscapeSlug.md +0 -5
  177. package/src/__tests__/__fixtures__/versioned-site/docusaurus.config.js +0 -18
  178. package/src/__tests__/__fixtures__/versioned-site/i18n/en/docusaurus-plugin-content-docs/version-1.0.0/hello.md +0 -1
  179. package/src/__tests__/__fixtures__/versioned-site/i18n/en/docusaurus-plugin-content-docs-community/current/team.md +0 -5
  180. package/src/__tests__/__fixtures__/versioned-site/i18n/fr/docusaurus-plugin-content-docs/version-1.0.0/hello.md +0 -1
  181. package/src/__tests__/__fixtures__/versioned-site/sidebars.json +0 -10
  182. package/src/__tests__/__fixtures__/versioned-site/versioned_docs/version-1.0.0/foo/bar.md +0 -4
  183. package/src/__tests__/__fixtures__/versioned-site/versioned_docs/version-1.0.0/foo/baz.md +0 -1
  184. package/src/__tests__/__fixtures__/versioned-site/versioned_docs/version-1.0.0/hello.md +0 -1
  185. package/src/__tests__/__fixtures__/versioned-site/versioned_docs/version-1.0.1/foo/bar.md +0 -1
  186. package/src/__tests__/__fixtures__/versioned-site/versioned_docs/version-1.0.1/hello.md +0 -1
  187. package/src/__tests__/__fixtures__/versioned-site/versioned_docs/version-withSlugs/rootAbsoluteSlug.md +0 -5
  188. package/src/__tests__/__fixtures__/versioned-site/versioned_docs/version-withSlugs/rootRelativeSlug.md +0 -5
  189. package/src/__tests__/__fixtures__/versioned-site/versioned_docs/version-withSlugs/rootResolvedSlug.md +0 -5
  190. package/src/__tests__/__fixtures__/versioned-site/versioned_docs/version-withSlugs/rootTryToEscapeSlug.md +0 -5
  191. package/src/__tests__/__fixtures__/versioned-site/versioned_docs/version-withSlugs/slugs/absoluteSlug.md +0 -5
  192. package/src/__tests__/__fixtures__/versioned-site/versioned_docs/version-withSlugs/slugs/relativeSlug.md +0 -5
  193. package/src/__tests__/__fixtures__/versioned-site/versioned_docs/version-withSlugs/slugs/resolvedSlug.md +0 -5
  194. package/src/__tests__/__fixtures__/versioned-site/versioned_docs/version-withSlugs/slugs/tryToEscapeSlug.md +0 -5
  195. package/src/__tests__/__fixtures__/versioned-site/versioned_sidebars/version-1.0.0-sidebars.json +0 -11
  196. package/src/__tests__/__fixtures__/versioned-site/versioned_sidebars/version-1.0.1-sidebars.json +0 -10
  197. package/src/__tests__/__fixtures__/versioned-site/versioned_sidebars/version-withSlugs-sidebars.json +0 -5
  198. package/src/__tests__/__fixtures__/versioned-site/versions.json +0 -5
  199. package/src/__tests__/__snapshots__/cli.test.ts.snap +0 -90
  200. package/src/__tests__/__snapshots__/index.test.ts.snap +0 -1907
  201. package/src/__tests__/__snapshots__/sidebars.test.ts.snap +0 -218
  202. package/src/__tests__/__snapshots__/translations.test.ts.snap +0 -487
  203. package/src/__tests__/cli.test.ts +0 -333
  204. package/src/__tests__/docFrontMatter.test.ts +0 -204
  205. package/src/__tests__/docs.test.ts +0 -875
  206. package/src/__tests__/index.test.ts +0 -1831
  207. package/src/__tests__/lastUpdate.test.ts +0 -68
  208. package/src/__tests__/numberPrefix.test.ts +0 -199
  209. package/src/__tests__/options.test.ts +0 -232
  210. package/src/__tests__/sidebarItemsGenerator.test.ts +0 -336
  211. package/src/__tests__/sidebars.test.ts +0 -638
  212. package/src/__tests__/slug.test.ts +0 -109
  213. package/src/__tests__/translations.test.ts +0 -159
  214. package/src/__tests__/versions.test.ts +0 -718
  215. package/src/client/__tests__/docsClientUtils.test.ts +0 -372
  216. package/src/docFrontMatter.ts +0 -53
  217. package/src/markdown/__tests__/__fixtures__/docs/doc-localized.md +0 -1
  218. package/src/markdown/__tests__/__fixtures__/docs/doc1.md +0 -13
  219. package/src/markdown/__tests__/__fixtures__/docs/doc2.md +0 -12
  220. package/src/markdown/__tests__/__fixtures__/docs/doc4.md +0 -19
  221. package/src/markdown/__tests__/__fixtures__/docs/doc5.md +0 -6
  222. package/src/markdown/__tests__/__fixtures__/docs/subdir/doc3.md +0 -3
  223. package/src/markdown/__tests__/__fixtures__/versioned_docs/version-1.0.0/doc2.md +0 -7
  224. package/src/markdown/__tests__/__fixtures__/versioned_docs/version-1.0.0/subdir/doc1.md +0 -3
  225. package/src/markdown/__tests__/__snapshots__/linkify.test.ts.snap +0 -82
  226. package/src/markdown/__tests__/linkify.test.ts +0 -190
  227. package/src/sidebarItemsGenerator.ts +0 -307
  228. package/src/sidebars.ts +0 -489
  229. package/src/theme/hooks/useDocs.ts +0 -99
  230. package/src/versions.ts +0 -511
  231. package/tsconfig.json +0 -9
package/lib/options.js CHANGED
@@ -1,44 +1,59 @@
1
1
  "use strict";
2
+ /**
3
+ * Copyright (c) Facebook, Inc. and its affiliates.
4
+ *
5
+ * This source code is licensed under the MIT license found in the
6
+ * LICENSE file in the root directory of this source tree.
7
+ */
2
8
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.validateOptions = exports.OptionsSchema = exports.DEFAULT_OPTIONS = void 0;
9
+ exports.validateOptions = exports.DEFAULT_OPTIONS = void 0;
4
10
  const tslib_1 = require("tslib");
11
+ const logger_1 = tslib_1.__importDefault(require("@docusaurus/logger"));
5
12
  const utils_validation_1 = require("@docusaurus/utils-validation");
6
- const chalk_1 = tslib_1.__importDefault(require("chalk"));
7
- const remark_admonitions_1 = tslib_1.__importDefault(require("remark-admonitions"));
8
- const sidebarItemsGenerator_1 = require("./sidebarItemsGenerator");
13
+ const utils_1 = require("@docusaurus/utils");
14
+ const generator_1 = require("./sidebars/generator");
9
15
  const numberPrefix_1 = require("./numberPrefix");
10
16
  exports.DEFAULT_OPTIONS = {
11
17
  path: 'docs',
12
18
  routeBasePath: 'docs',
13
- homePageId: undefined,
19
+ tagsBasePath: 'tags',
14
20
  include: ['**/*.{md,mdx}'],
15
- sidebarItemsGenerator: sidebarItemsGenerator_1.DefaultSidebarItemsGenerator,
21
+ exclude: utils_1.GlobExcludeDefault,
22
+ sidebarItemsGenerator: generator_1.DefaultSidebarItemsGenerator,
16
23
  numberPrefixParser: numberPrefix_1.DefaultNumberPrefixParser,
17
24
  docLayoutComponent: '@theme/DocPage',
18
25
  docItemComponent: '@theme/DocItem',
26
+ docTagDocListComponent: '@theme/DocTagDocListPage',
27
+ docTagsListComponent: '@theme/DocTagsListPage',
28
+ docCategoryGeneratedIndexComponent: '@theme/DocCategoryGeneratedIndexPage',
19
29
  remarkPlugins: [],
20
30
  rehypePlugins: [],
21
31
  beforeDefaultRemarkPlugins: [],
22
32
  beforeDefaultRehypePlugins: [],
23
33
  showLastUpdateTime: false,
24
34
  showLastUpdateAuthor: false,
25
- admonitions: {},
26
- excludeNextVersionDocs: false,
35
+ admonitions: true,
27
36
  includeCurrentVersion: true,
28
37
  disableVersioning: false,
29
38
  lastVersion: undefined,
30
39
  versions: {},
31
40
  editCurrentVersion: false,
32
41
  editLocalizedFiles: false,
42
+ sidebarCollapsible: true,
43
+ sidebarCollapsed: true,
44
+ breadcrumbs: true,
33
45
  };
34
46
  const VersionOptionsSchema = utils_validation_1.Joi.object({
35
47
  path: utils_validation_1.Joi.string().allow('').optional(),
36
48
  label: utils_validation_1.Joi.string().optional(),
49
+ banner: utils_validation_1.Joi.string().equal('none', 'unreleased', 'unmaintained').optional(),
50
+ badge: utils_validation_1.Joi.boolean().optional(),
51
+ className: utils_validation_1.Joi.string().optional(),
37
52
  });
38
53
  const VersionsOptionsSchema = utils_validation_1.Joi.object()
39
54
  .pattern(utils_validation_1.Joi.string().required(), VersionOptionsSchema)
40
55
  .default(exports.DEFAULT_OPTIONS.versions);
41
- exports.OptionsSchema = utils_validation_1.Joi.object({
56
+ const OptionsSchema = utils_validation_1.Joi.object({
42
57
  path: utils_validation_1.Joi.string().default(exports.DEFAULT_OPTIONS.path),
43
58
  editUrl: utils_validation_1.Joi.alternatives().try(utils_validation_1.URISchema, utils_validation_1.Joi.function()),
44
59
  editCurrentVersion: utils_validation_1.Joi.boolean().default(exports.DEFAULT_OPTIONS.editCurrentVersion),
@@ -47,10 +62,17 @@ exports.OptionsSchema = utils_validation_1.Joi.object({
47
62
  // '' not allowed, see https://github.com/facebook/docusaurus/issues/3374
48
63
  // .allow('') ""
49
64
  .default(exports.DEFAULT_OPTIONS.routeBasePath),
50
- homePageId: utils_validation_1.Joi.string().optional(),
65
+ tagsBasePath: utils_validation_1.Joi.string().default(exports.DEFAULT_OPTIONS.tagsBasePath),
66
+ // @ts-expect-error: deprecated
67
+ homePageId: utils_validation_1.Joi.any().forbidden().messages({
68
+ 'any.unknown': 'The docs plugin option homePageId is not supported anymore. To make a doc the "home", please add "slug: /" in its front matter. See: https://docusaurus.io/docs/next/docs-introduction#home-page-docs',
69
+ }),
51
70
  include: utils_validation_1.Joi.array().items(utils_validation_1.Joi.string()).default(exports.DEFAULT_OPTIONS.include),
71
+ exclude: utils_validation_1.Joi.array().items(utils_validation_1.Joi.string()).default(exports.DEFAULT_OPTIONS.exclude),
52
72
  sidebarPath: utils_validation_1.Joi.alternatives().try(utils_validation_1.Joi.boolean().invalid(true), utils_validation_1.Joi.string()),
53
73
  sidebarItemsGenerator: utils_validation_1.Joi.function().default(() => exports.DEFAULT_OPTIONS.sidebarItemsGenerator),
74
+ sidebarCollapsible: utils_validation_1.Joi.boolean().default(exports.DEFAULT_OPTIONS.sidebarCollapsible),
75
+ sidebarCollapsed: utils_validation_1.Joi.boolean().default(exports.DEFAULT_OPTIONS.sidebarCollapsed),
54
76
  numberPrefixParser: utils_validation_1.Joi.alternatives()
55
77
  .try(utils_validation_1.Joi.function(),
56
78
  // Convert boolean values to functions
@@ -60,38 +82,44 @@ exports.OptionsSchema = utils_validation_1.Joi.object({
60
82
  .default(() => exports.DEFAULT_OPTIONS.numberPrefixParser),
61
83
  docLayoutComponent: utils_validation_1.Joi.string().default(exports.DEFAULT_OPTIONS.docLayoutComponent),
62
84
  docItemComponent: utils_validation_1.Joi.string().default(exports.DEFAULT_OPTIONS.docItemComponent),
85
+ docTagsListComponent: utils_validation_1.Joi.string().default(exports.DEFAULT_OPTIONS.docTagsListComponent),
86
+ docTagDocListComponent: utils_validation_1.Joi.string().default(exports.DEFAULT_OPTIONS.docTagDocListComponent),
87
+ docCategoryGeneratedIndexComponent: utils_validation_1.Joi.string().default(exports.DEFAULT_OPTIONS.docCategoryGeneratedIndexComponent),
63
88
  remarkPlugins: utils_validation_1.RemarkPluginsSchema.default(exports.DEFAULT_OPTIONS.remarkPlugins),
64
89
  rehypePlugins: utils_validation_1.RehypePluginsSchema.default(exports.DEFAULT_OPTIONS.rehypePlugins),
65
90
  beforeDefaultRemarkPlugins: utils_validation_1.RemarkPluginsSchema.default(exports.DEFAULT_OPTIONS.beforeDefaultRemarkPlugins),
66
91
  beforeDefaultRehypePlugins: utils_validation_1.RehypePluginsSchema.default(exports.DEFAULT_OPTIONS.beforeDefaultRehypePlugins),
67
- admonitions: utils_validation_1.Joi.alternatives()
68
- .try(utils_validation_1.AdmonitionsSchema, utils_validation_1.Joi.boolean().invalid(true))
69
- .default(exports.DEFAULT_OPTIONS.admonitions),
92
+ admonitions: utils_validation_1.AdmonitionsSchema.default(exports.DEFAULT_OPTIONS.admonitions),
70
93
  showLastUpdateTime: utils_validation_1.Joi.bool().default(exports.DEFAULT_OPTIONS.showLastUpdateTime),
71
94
  showLastUpdateAuthor: utils_validation_1.Joi.bool().default(exports.DEFAULT_OPTIONS.showLastUpdateAuthor),
72
- excludeNextVersionDocs: utils_validation_1.Joi.bool().default(exports.DEFAULT_OPTIONS.excludeNextVersionDocs),
73
95
  includeCurrentVersion: utils_validation_1.Joi.bool().default(exports.DEFAULT_OPTIONS.includeCurrentVersion),
74
96
  onlyIncludeVersions: utils_validation_1.Joi.array().items(utils_validation_1.Joi.string().required()).optional(),
75
97
  disableVersioning: utils_validation_1.Joi.bool().default(exports.DEFAULT_OPTIONS.disableVersioning),
76
98
  lastVersion: utils_validation_1.Joi.string().optional(),
77
99
  versions: VersionsOptionsSchema,
100
+ breadcrumbs: utils_validation_1.Joi.bool().default(exports.DEFAULT_OPTIONS.breadcrumbs),
78
101
  });
79
- function validateOptions({ validate, options, }) {
80
- // TODO remove homePageId before end of 2020
81
- // "slug: /" is better because the home doc can be different across versions
82
- if (options.homePageId) {
83
- console.log(chalk_1.default.red(`The docs plugin option homePageId=${options.homePageId} is deprecated. To make a doc the "home", prefer frontmatter: "slug: /"`));
84
- }
85
- if (typeof options.excludeNextVersionDocs !== 'undefined') {
86
- console.log(chalk_1.default.red(`The docs plugin option excludeNextVersionDocs=${options.excludeNextVersionDocs} is deprecated. Use the includeCurrentVersion=${!options.excludeNextVersionDocs} option instead!"`));
87
- options.includeCurrentVersion = !options.excludeNextVersionDocs;
88
- }
89
- const normalizedOptions = validate(exports.OptionsSchema, options);
90
- if (normalizedOptions.admonitions) {
91
- normalizedOptions.remarkPlugins = normalizedOptions.remarkPlugins.concat([
92
- [remark_admonitions_1.default, normalizedOptions.admonitions],
93
- ]);
102
+ function validateOptions({ validate, options: userOptions, }) {
103
+ let options = userOptions;
104
+ if (options.sidebarCollapsible === false) {
105
+ // When sidebarCollapsible=false and sidebarCollapsed=undefined, we don't
106
+ // want to have the inconsistency warning. We let options.sidebarCollapsible
107
+ // become the default value for options.sidebarCollapsed
108
+ if (typeof options.sidebarCollapsed === 'undefined') {
109
+ options = {
110
+ ...options,
111
+ sidebarCollapsed: false,
112
+ };
113
+ }
114
+ if (options.sidebarCollapsed) {
115
+ logger_1.default.warn `The docs plugin config is inconsistent. It does not make sense to use code=${'sidebarCollapsible: false'} and code=${'sidebarCollapsed: true'} at the same time. code=${'sidebarCollapsed: true'} will be ignored.`;
116
+ options = {
117
+ ...options,
118
+ sidebarCollapsed: false,
119
+ };
120
+ }
94
121
  }
122
+ const normalizedOptions = validate(OptionsSchema, options);
95
123
  return normalizedOptions;
96
124
  }
97
125
  exports.validateOptions = validateOptions;
package/lib/props.d.ts CHANGED
@@ -4,7 +4,12 @@
4
4
  * This source code is licensed under the MIT license found in the
5
5
  * LICENSE file in the root directory of this source tree.
6
6
  */
7
- import { LoadedVersion } from './types';
8
- import { PropSidebars, PropVersionMetadata } from '@docusaurus/plugin-content-docs-types';
7
+ import type { VersionTag } from './types';
8
+ import type { PropSidebars, PropVersionMetadata, PropTagDocList, DocMetadata, LoadedVersion } from '@docusaurus/plugin-content-docs';
9
9
  export declare function toSidebarsProp(loadedVersion: LoadedVersion): PropSidebars;
10
10
  export declare function toVersionMetadataProp(pluginId: string, loadedVersion: LoadedVersion): PropVersionMetadata;
11
+ export declare function toTagDocListProp({ allTagsPath, tag, docs, }: {
12
+ allTagsPath: string;
13
+ tag: VersionTag;
14
+ docs: DocMetadata[];
15
+ }): PropTagDocList;
package/lib/props.js CHANGED
@@ -6,30 +6,66 @@
6
6
  * LICENSE file in the root directory of this source tree.
7
7
  */
8
8
  Object.defineProperty(exports, "__esModule", { value: true });
9
- exports.toVersionMetadataProp = exports.toSidebarsProp = void 0;
10
- const lodash_1 = require("lodash");
9
+ exports.toTagDocListProp = exports.toVersionMetadataProp = exports.toSidebarsProp = void 0;
10
+ const tslib_1 = require("tslib");
11
+ const lodash_1 = tslib_1.__importDefault(require("lodash"));
12
+ const docs_1 = require("./docs");
11
13
  function toSidebarsProp(loadedVersion) {
12
- const docsById = lodash_1.keyBy(loadedVersion.docs, (doc) => doc.id);
13
- const convertDocLink = (item) => {
14
- const docId = item.id;
14
+ const docsById = (0, docs_1.createDocsByIdIndex)(loadedVersion.docs);
15
+ function getDocById(docId) {
15
16
  const docMetadata = docsById[docId];
16
17
  if (!docMetadata) {
17
- throw new Error(`Bad sidebars file. The document id '${docId}' was used in the sidebar, but no document with this id could be found.
18
- Available document ids=
18
+ throw new Error(`Invalid sidebars file. The document with id "${docId}" was used in the sidebar, but no document with this id could be found.
19
+ Available document ids are:
19
20
  - ${Object.keys(docsById).sort().join('\n- ')}`);
20
21
  }
21
- const { title, permalink, sidebar_label: sidebarLabel } = docMetadata;
22
+ return docMetadata;
23
+ }
24
+ const convertDocLink = (item) => {
25
+ const docMetadata = getDocById(item.id);
26
+ const { title, permalink, frontMatter: { sidebar_label: sidebarLabel }, } = docMetadata;
22
27
  return {
23
28
  type: 'link',
24
- label: sidebarLabel || item.label || title,
29
+ label: sidebarLabel ?? item.label ?? title,
25
30
  href: permalink,
26
- customProps: item.customProps,
31
+ className: item.className,
32
+ customProps: item.customProps ?? docMetadata.frontMatter.sidebar_custom_props,
33
+ docId: docMetadata.unversionedId,
27
34
  };
28
35
  };
29
- const normalizeItem = (item) => {
36
+ function getCategoryLinkHref(link) {
37
+ switch (link?.type) {
38
+ case 'doc':
39
+ return getDocById(link.id).permalink;
40
+ case 'generated-index':
41
+ return link.permalink;
42
+ default:
43
+ return undefined;
44
+ }
45
+ }
46
+ function getCategoryLinkCustomProps(link) {
47
+ switch (link?.type) {
48
+ case 'doc':
49
+ return getDocById(link.id).frontMatter.sidebar_custom_props;
50
+ default:
51
+ return undefined;
52
+ }
53
+ }
54
+ function convertCategory(item) {
55
+ const { link, ...rest } = item;
56
+ const href = getCategoryLinkHref(link);
57
+ const customProps = item.customProps ?? getCategoryLinkCustomProps(link);
58
+ return {
59
+ ...rest,
60
+ items: item.items.map(normalizeItem),
61
+ ...(href && { href }),
62
+ ...(customProps && { customProps }),
63
+ };
64
+ }
65
+ function normalizeItem(item) {
30
66
  switch (item.type) {
31
67
  case 'category':
32
- return { ...item, items: item.items.map(normalizeItem) };
68
+ return convertCategory(item);
33
69
  case 'ref':
34
70
  case 'doc':
35
71
  return convertDocLink(item);
@@ -37,21 +73,56 @@ Available document ids=
37
73
  default:
38
74
  return item;
39
75
  }
40
- };
76
+ }
41
77
  // Transform the sidebar so that all sidebar item will be in the
42
78
  // form of 'link' or 'category' only.
43
79
  // This is what will be passed as props to the UI component.
44
- return lodash_1.mapValues(loadedVersion.sidebars, (items) => items.map(normalizeItem));
80
+ return lodash_1.default.mapValues(loadedVersion.sidebars, (items) => items.map(normalizeItem));
45
81
  }
46
82
  exports.toSidebarsProp = toSidebarsProp;
83
+ function toVersionDocsProp(loadedVersion) {
84
+ return Object.fromEntries(loadedVersion.docs.map((doc) => [
85
+ doc.unversionedId,
86
+ {
87
+ id: doc.unversionedId,
88
+ title: doc.title,
89
+ description: doc.description,
90
+ sidebar: doc.sidebar,
91
+ },
92
+ ]));
93
+ }
47
94
  function toVersionMetadataProp(pluginId, loadedVersion) {
48
95
  return {
49
96
  pluginId,
50
97
  version: loadedVersion.versionName,
51
- label: loadedVersion.versionLabel,
98
+ label: loadedVersion.label,
99
+ banner: loadedVersion.banner,
100
+ badge: loadedVersion.badge,
101
+ className: loadedVersion.className,
52
102
  isLast: loadedVersion.isLast,
53
103
  docsSidebars: toSidebarsProp(loadedVersion),
54
- permalinkToSidebar: loadedVersion.permalinkToSidebar,
104
+ docs: toVersionDocsProp(loadedVersion),
55
105
  };
56
106
  }
57
107
  exports.toVersionMetadataProp = toVersionMetadataProp;
108
+ function toTagDocListProp({ allTagsPath, tag, docs, }) {
109
+ function toDocListProp() {
110
+ const list = lodash_1.default.compact(tag.docIds.map((id) => docs.find((doc) => doc.id === id)));
111
+ // Sort docs by title
112
+ list.sort((doc1, doc2) => doc1.title.localeCompare(doc2.title));
113
+ return list.map((doc) => ({
114
+ id: doc.id,
115
+ title: doc.title,
116
+ description: doc.description,
117
+ permalink: doc.permalink,
118
+ }));
119
+ }
120
+ return {
121
+ label: tag.label,
122
+ permalink: tag.permalink,
123
+ allTagsPath,
124
+ count: tag.docIds.length,
125
+ items: toDocListProp(),
126
+ };
127
+ }
128
+ exports.toTagDocListProp = toTagDocListProp;
@@ -0,0 +1,29 @@
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
+ import type { PluginContentLoadedActions, RouteConfig } from '@docusaurus/types';
8
+ import type { FullVersion } from './types';
9
+ import type { DocMetadata } from '@docusaurus/plugin-content-docs';
10
+ export declare function createCategoryGeneratedIndexRoutes({ version, actions, docCategoryGeneratedIndexComponent, aliasedSource, }: {
11
+ version: FullVersion;
12
+ actions: PluginContentLoadedActions;
13
+ docCategoryGeneratedIndexComponent: string;
14
+ aliasedSource: (str: string) => string;
15
+ }): Promise<RouteConfig[]>;
16
+ export declare function createDocRoutes({ docs, actions, docItemComponent, }: {
17
+ docs: DocMetadata[];
18
+ actions: PluginContentLoadedActions;
19
+ docItemComponent: string;
20
+ }): Promise<RouteConfig[]>;
21
+ export declare function createVersionRoutes({ version, actions, docItemComponent, docLayoutComponent, docCategoryGeneratedIndexComponent, pluginId, aliasedSource, }: {
22
+ version: FullVersion;
23
+ actions: PluginContentLoadedActions;
24
+ docLayoutComponent: string;
25
+ docItemComponent: string;
26
+ docCategoryGeneratedIndexComponent: string;
27
+ pluginId: string;
28
+ aliasedSource: (str: string) => string;
29
+ }): Promise<void>;
package/lib/routes.js ADDED
@@ -0,0 +1,96 @@
1
+ "use strict";
2
+ /**
3
+ * Copyright (c) Facebook, Inc. and its affiliates.
4
+ *
5
+ * This source code is licensed under the MIT license found in the
6
+ * LICENSE file in the root directory of this source tree.
7
+ */
8
+ Object.defineProperty(exports, "__esModule", { value: true });
9
+ exports.createVersionRoutes = exports.createDocRoutes = exports.createCategoryGeneratedIndexRoutes = void 0;
10
+ const tslib_1 = require("tslib");
11
+ const logger_1 = tslib_1.__importDefault(require("@docusaurus/logger"));
12
+ const utils_1 = require("@docusaurus/utils");
13
+ const props_1 = require("./props");
14
+ async function createCategoryGeneratedIndexRoutes({ version, actions, docCategoryGeneratedIndexComponent, aliasedSource, }) {
15
+ const slugs = (0, utils_1.createSlugger)();
16
+ async function createCategoryGeneratedIndexRoute(categoryGeneratedIndex) {
17
+ const { sidebar, ...prop } = categoryGeneratedIndex;
18
+ const propFileName = slugs.slug(`${version.path}-${categoryGeneratedIndex.sidebar}-category-${categoryGeneratedIndex.title}`);
19
+ const propData = await actions.createData(`${(0, utils_1.docuHash)(`category/${propFileName}`)}.json`, JSON.stringify(prop, null, 2));
20
+ return {
21
+ path: categoryGeneratedIndex.permalink,
22
+ component: docCategoryGeneratedIndexComponent,
23
+ exact: true,
24
+ modules: {
25
+ categoryGeneratedIndex: aliasedSource(propData),
26
+ },
27
+ // Same as doc, this sidebar route attribute permits to associate this
28
+ // subpage to the given sidebar
29
+ ...(sidebar && { sidebar }),
30
+ };
31
+ }
32
+ return Promise.all(version.categoryGeneratedIndices.map(createCategoryGeneratedIndexRoute));
33
+ }
34
+ exports.createCategoryGeneratedIndexRoutes = createCategoryGeneratedIndexRoutes;
35
+ async function createDocRoutes({ docs, actions, docItemComponent, }) {
36
+ return Promise.all(docs.map(async (metadataItem) => {
37
+ await actions.createData(
38
+ // Note that this created data path must be in sync with
39
+ // metadataPath provided to mdx-loader.
40
+ `${(0, utils_1.docuHash)(metadataItem.source)}.json`, JSON.stringify(metadataItem, null, 2));
41
+ const docRoute = {
42
+ path: metadataItem.permalink,
43
+ component: docItemComponent,
44
+ exact: true,
45
+ modules: {
46
+ content: metadataItem.source,
47
+ },
48
+ // Because the parent (DocPage) comp need to access it easily
49
+ // This permits to render the sidebar once without unmount/remount when
50
+ // navigating (and preserve sidebar state)
51
+ ...(metadataItem.sidebar && {
52
+ sidebar: metadataItem.sidebar,
53
+ }),
54
+ };
55
+ return docRoute;
56
+ }));
57
+ }
58
+ exports.createDocRoutes = createDocRoutes;
59
+ async function createVersionRoutes({ version, actions, docItemComponent, docLayoutComponent, docCategoryGeneratedIndexComponent, pluginId, aliasedSource, }) {
60
+ async function doCreateVersionRoutes() {
61
+ const versionMetadata = (0, props_1.toVersionMetadataProp)(pluginId, version);
62
+ const versionMetadataPropPath = await actions.createData(`${(0, utils_1.docuHash)(`version-${version.versionName}-metadata-prop`)}.json`, JSON.stringify(versionMetadata, null, 2));
63
+ async function createVersionSubRoutes() {
64
+ const [docRoutes, sidebarsRoutes] = await Promise.all([
65
+ createDocRoutes({ docs: version.docs, actions, docItemComponent }),
66
+ createCategoryGeneratedIndexRoutes({
67
+ version,
68
+ actions,
69
+ docCategoryGeneratedIndexComponent,
70
+ aliasedSource,
71
+ }),
72
+ ]);
73
+ const routes = [...docRoutes, ...sidebarsRoutes];
74
+ return routes.sort((a, b) => a.path.localeCompare(b.path));
75
+ }
76
+ actions.addRoute({
77
+ path: version.path,
78
+ // Allow matching /docs/* since this is the wrapping route
79
+ exact: false,
80
+ component: docLayoutComponent,
81
+ routes: await createVersionSubRoutes(),
82
+ modules: {
83
+ versionMetadata: aliasedSource(versionMetadataPropPath),
84
+ },
85
+ priority: version.routePriority,
86
+ });
87
+ }
88
+ try {
89
+ return await doCreateVersionRoutes();
90
+ }
91
+ catch (err) {
92
+ logger_1.default.error `Can't create version routes for version name=${version.versionName}`;
93
+ throw err;
94
+ }
95
+ }
96
+ exports.createVersionRoutes = createVersionRoutes;
@@ -0,0 +1,9 @@
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
+ export { CURRENT_VERSION_NAME, VERSIONED_DOCS_DIR, VERSIONED_SIDEBARS_DIR, VERSIONS_JSON_FILE, } from './constants';
8
+ export { filterVersions, getDefaultVersionBanner, getVersionBadge, getVersionBanner, } from './versions';
9
+ export { readVersionNames } from './versions/files';
@@ -0,0 +1,25 @@
1
+ "use strict";
2
+ /**
3
+ * Copyright (c) Facebook, Inc. and its affiliates.
4
+ *
5
+ * This source code is licensed under the MIT license found in the
6
+ * LICENSE file in the root directory of this source tree.
7
+ */
8
+ Object.defineProperty(exports, "__esModule", { value: true });
9
+ exports.readVersionNames = exports.getVersionBanner = exports.getVersionBadge = exports.getDefaultVersionBanner = exports.filterVersions = exports.VERSIONS_JSON_FILE = exports.VERSIONED_SIDEBARS_DIR = exports.VERSIONED_DOCS_DIR = exports.CURRENT_VERSION_NAME = void 0;
10
+ // APIs available to Node.js
11
+ // Those are undocumented but used by some third-party plugins
12
+ // For this reason it's preferable to avoid doing breaking changes
13
+ // See also https://github.com/facebook/docusaurus/pull/6477
14
+ var constants_1 = require("./constants");
15
+ Object.defineProperty(exports, "CURRENT_VERSION_NAME", { enumerable: true, get: function () { return constants_1.CURRENT_VERSION_NAME; } });
16
+ Object.defineProperty(exports, "VERSIONED_DOCS_DIR", { enumerable: true, get: function () { return constants_1.VERSIONED_DOCS_DIR; } });
17
+ Object.defineProperty(exports, "VERSIONED_SIDEBARS_DIR", { enumerable: true, get: function () { return constants_1.VERSIONED_SIDEBARS_DIR; } });
18
+ Object.defineProperty(exports, "VERSIONS_JSON_FILE", { enumerable: true, get: function () { return constants_1.VERSIONS_JSON_FILE; } });
19
+ var versions_1 = require("./versions");
20
+ Object.defineProperty(exports, "filterVersions", { enumerable: true, get: function () { return versions_1.filterVersions; } });
21
+ Object.defineProperty(exports, "getDefaultVersionBanner", { enumerable: true, get: function () { return versions_1.getDefaultVersionBanner; } });
22
+ Object.defineProperty(exports, "getVersionBadge", { enumerable: true, get: function () { return versions_1.getVersionBadge; } });
23
+ Object.defineProperty(exports, "getVersionBanner", { enumerable: true, get: function () { return versions_1.getVersionBanner; } });
24
+ var files_1 = require("./versions/files");
25
+ Object.defineProperty(exports, "readVersionNames", { enumerable: true, get: function () { return files_1.readVersionNames; } });
@@ -4,12 +4,7 @@
4
4
  * This source code is licensed under the MIT license found in the
5
5
  * LICENSE file in the root directory of this source tree.
6
6
  */
7
- import { SidebarItemsGenerator } from './types';
7
+ import type { SidebarItemsGenerator } from './types';
8
8
  export declare const CategoryMetadataFilenameBase = "_category_";
9
9
  export declare const CategoryMetadataFilenamePattern = "_category_.{json,yml,yaml}";
10
- export declare type CategoryMetadatasFile = {
11
- label?: string;
12
- position?: number;
13
- collapsed?: boolean;
14
- };
15
10
  export declare const DefaultSidebarItemsGenerator: SidebarItemsGenerator;