@docusaurus/plugin-content-docs 2.0.0-beta.15d451942 → 2.0.0-beta.16

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 (214) hide show
  1. package/lib/categoryGeneratedIndex.d.ts +12 -0
  2. package/lib/categoryGeneratedIndex.js +39 -0
  3. package/lib/cli.d.ts +2 -2
  4. package/lib/cli.js +40 -52
  5. package/lib/client/docsClientUtils.d.ts +3 -25
  6. package/lib/client/docsClientUtils.js +27 -33
  7. package/lib/{theme/hooks/useDocs.d.ts → client/index.d.ts} +1 -2
  8. package/lib/client/index.js +75 -0
  9. package/lib/docFrontMatter.d.ts +1 -14
  10. package/lib/docFrontMatter.js +13 -6
  11. package/lib/docs.d.ts +40 -4
  12. package/lib/docs.js +170 -54
  13. package/lib/globalData.d.ts +5 -1
  14. package/lib/globalData.js +35 -2
  15. package/lib/index.d.ts +4 -3
  16. package/lib/index.js +124 -136
  17. package/lib/lastUpdate.js +16 -29
  18. package/lib/markdown/index.d.ts +3 -6
  19. package/lib/markdown/index.js +3 -3
  20. package/lib/markdown/linkify.d.ts +1 -1
  21. package/lib/markdown/linkify.js +3 -3
  22. package/lib/numberPrefix.d.ts +1 -1
  23. package/lib/numberPrefix.js +7 -6
  24. package/lib/options.d.ts +3 -3
  25. package/lib/options.js +52 -17
  26. package/lib/props.d.ts +7 -2
  27. package/lib/props.js +71 -14
  28. package/lib/routes.d.ts +28 -0
  29. package/lib/routes.js +110 -0
  30. package/lib/server-export.d.ts +8 -0
  31. package/lib/server-export.js +23 -0
  32. package/lib/{sidebarItemsGenerator.d.ts → sidebars/generator.d.ts} +1 -6
  33. package/lib/sidebars/generator.js +190 -0
  34. package/lib/sidebars/index.d.ts +13 -0
  35. package/lib/sidebars/index.js +88 -0
  36. package/lib/sidebars/normalization.d.ts +13 -0
  37. package/lib/sidebars/normalization.js +55 -0
  38. package/lib/sidebars/postProcessor.d.ts +8 -0
  39. package/lib/sidebars/postProcessor.js +72 -0
  40. package/lib/sidebars/processor.d.ts +8 -0
  41. package/lib/sidebars/processor.js +79 -0
  42. package/lib/sidebars/types.d.ts +166 -0
  43. package/{src/__tests__/__fixtures__/site-with-autogenerated-sidebar/partialAutogeneratedSidebars2.js → lib/sidebars/types.js} +2 -10
  44. package/lib/sidebars/utils.d.ts +43 -0
  45. package/lib/sidebars/utils.js +265 -0
  46. package/lib/sidebars/validation.d.ts +9 -0
  47. package/lib/sidebars/validation.js +137 -0
  48. package/lib/slug.d.ts +6 -4
  49. package/lib/slug.js +29 -18
  50. package/{src/__tests__/__fixtures__/site-with-doc-label/docusaurus.config.js → lib/tags.d.ts} +2 -8
  51. package/lib/tags.js +21 -0
  52. package/lib/translations.d.ts +2 -2
  53. package/lib/translations.js +87 -44
  54. package/lib/types.d.ts +55 -128
  55. package/lib/versions.d.ts +29 -4
  56. package/lib/versions.js +131 -89
  57. package/package.json +30 -26
  58. package/src/categoryGeneratedIndex.ts +59 -0
  59. package/src/cli.ts +48 -62
  60. package/src/client/docsClientUtils.ts +36 -71
  61. package/src/{theme/hooks/useDocs.ts → client/index.ts} +15 -10
  62. package/{types.d.ts → src/deps.d.ts} +0 -0
  63. package/src/docFrontMatter.ts +17 -22
  64. package/src/docs.ts +229 -45
  65. package/src/globalData.ts +53 -2
  66. package/src/index.ts +168 -177
  67. package/src/lastUpdate.ts +14 -33
  68. package/src/markdown/index.ts +9 -13
  69. package/src/markdown/linkify.ts +2 -2
  70. package/src/numberPrefix.ts +11 -8
  71. package/src/options.ts +59 -29
  72. package/src/plugin-content-docs.d.ts +256 -40
  73. package/src/props.ts +105 -21
  74. package/src/routes.ts +185 -0
  75. package/src/server-export.ts +24 -0
  76. package/src/sidebars/README.md +9 -0
  77. package/src/sidebars/generator.ts +263 -0
  78. package/src/sidebars/index.ts +113 -0
  79. package/src/sidebars/normalization.ts +85 -0
  80. package/src/sidebars/postProcessor.ts +94 -0
  81. package/src/sidebars/processor.ts +126 -0
  82. package/src/sidebars/types.ts +273 -0
  83. package/src/sidebars/utils.ts +392 -0
  84. package/src/sidebars/validation.ts +173 -0
  85. package/src/slug.ts +40 -22
  86. package/src/tags.ts +19 -0
  87. package/src/translations.ts +121 -62
  88. package/src/types.ts +62 -183
  89. package/src/versions.ts +202 -107
  90. package/lib/.tsbuildinfo +0 -4717
  91. package/lib/sidebarItemsGenerator.js +0 -211
  92. package/lib/sidebars.d.ts +0 -42
  93. package/lib/sidebars.js +0 -309
  94. package/lib/theme/hooks/useDocs.js +0 -72
  95. package/src/__tests__/__fixtures__/bad-id-site/docs/invalid-id.md +0 -5
  96. package/src/__tests__/__fixtures__/bad-slug-on-doc-home-site/docs/docWithSlug.md +0 -5
  97. package/src/__tests__/__fixtures__/empty-site/docusaurus.config.js +0 -16
  98. package/src/__tests__/__fixtures__/empty-site/sidebars.json +0 -1
  99. package/src/__tests__/__fixtures__/sidebars/sidebars-category-shorthand.js +0 -34
  100. package/src/__tests__/__fixtures__/sidebars/sidebars-category-wrong-items.json +0 -11
  101. package/src/__tests__/__fixtures__/sidebars/sidebars-category-wrong-label.json +0 -11
  102. package/src/__tests__/__fixtures__/sidebars/sidebars-category.js +0 -44
  103. package/src/__tests__/__fixtures__/sidebars/sidebars-collapsed-first-level.json +0 -20
  104. package/src/__tests__/__fixtures__/sidebars/sidebars-collapsed.json +0 -21
  105. package/src/__tests__/__fixtures__/sidebars/sidebars-doc-id-not-string.json +0 -10
  106. package/src/__tests__/__fixtures__/sidebars/sidebars-first-level-not-category.js +0 -20
  107. package/src/__tests__/__fixtures__/sidebars/sidebars-link-wrong-href.json +0 -11
  108. package/src/__tests__/__fixtures__/sidebars/sidebars-link-wrong-label.json +0 -11
  109. package/src/__tests__/__fixtures__/sidebars/sidebars-link.json +0 -11
  110. package/src/__tests__/__fixtures__/sidebars/sidebars-unknown-type.json +0 -14
  111. package/src/__tests__/__fixtures__/sidebars/sidebars-wrong-field.json +0 -20
  112. package/src/__tests__/__fixtures__/sidebars/sidebars.json +0 -20
  113. package/src/__tests__/__fixtures__/simple-site/docs/foo/bar.md +0 -69
  114. package/src/__tests__/__fixtures__/simple-site/docs/foo/baz.md +0 -67
  115. package/src/__tests__/__fixtures__/simple-site/docs/headingAsTitle.md +0 -1
  116. package/src/__tests__/__fixtures__/simple-site/docs/hello.md +0 -52
  117. package/src/__tests__/__fixtures__/simple-site/docs/ipsum.md +0 -5
  118. package/src/__tests__/__fixtures__/simple-site/docs/lorem.md +0 -6
  119. package/src/__tests__/__fixtures__/simple-site/docs/rootAbsoluteSlug.md +0 -5
  120. package/src/__tests__/__fixtures__/simple-site/docs/rootRelativeSlug.md +0 -5
  121. package/src/__tests__/__fixtures__/simple-site/docs/rootResolvedSlug.md +0 -5
  122. package/src/__tests__/__fixtures__/simple-site/docs/rootTryToEscapeSlug.md +0 -5
  123. package/src/__tests__/__fixtures__/simple-site/docs/slugs/absoluteSlug.md +0 -5
  124. package/src/__tests__/__fixtures__/simple-site/docs/slugs/relativeSlug.md +0 -5
  125. package/src/__tests__/__fixtures__/simple-site/docs/slugs/resolvedSlug.md +0 -5
  126. package/src/__tests__/__fixtures__/simple-site/docs/slugs/tryToEscapeSlug.md +0 -5
  127. package/src/__tests__/__fixtures__/simple-site/docusaurus.config.js +0 -14
  128. package/src/__tests__/__fixtures__/simple-site/sidebars.json +0 -23
  129. package/src/__tests__/__fixtures__/simple-site/wrong-sidebars.json +0 -7
  130. package/src/__tests__/__fixtures__/site-with-autogenerated-sidebar/docs/0-getting-started.md +0 -3
  131. package/src/__tests__/__fixtures__/site-with-autogenerated-sidebar/docs/1-installation.md +0 -3
  132. package/src/__tests__/__fixtures__/site-with-autogenerated-sidebar/docs/3-API/00_api-overview.md +0 -3
  133. package/src/__tests__/__fixtures__/site-with-autogenerated-sidebar/docs/3-API/01_Core APIs/0 --- Client API.md +0 -1
  134. package/src/__tests__/__fixtures__/site-with-autogenerated-sidebar/docs/3-API/01_Core APIs/1 --- Server API.md +0 -1
  135. package/src/__tests__/__fixtures__/site-with-autogenerated-sidebar/docs/3-API/02_Extension APIs/0. Plugin API.md +0 -1
  136. package/src/__tests__/__fixtures__/site-with-autogenerated-sidebar/docs/3-API/02_Extension APIs/1. Theme API.md +0 -1
  137. package/src/__tests__/__fixtures__/site-with-autogenerated-sidebar/docs/3-API/02_Extension APIs/_category_.yml +0 -1
  138. package/src/__tests__/__fixtures__/site-with-autogenerated-sidebar/docs/3-API/03_api-end.md +0 -3
  139. package/src/__tests__/__fixtures__/site-with-autogenerated-sidebar/docs/3-API/_category_.json +0 -3
  140. package/src/__tests__/__fixtures__/site-with-autogenerated-sidebar/docs/Guides/0-guide2.5.md +0 -8
  141. package/src/__tests__/__fixtures__/site-with-autogenerated-sidebar/docs/Guides/02-guide2.md +0 -7
  142. package/src/__tests__/__fixtures__/site-with-autogenerated-sidebar/docs/Guides/_category_.json +0 -3
  143. package/src/__tests__/__fixtures__/site-with-autogenerated-sidebar/docs/Guides/a-guide4.md +0 -7
  144. package/src/__tests__/__fixtures__/site-with-autogenerated-sidebar/docs/Guides/b-guide5.md +0 -7
  145. package/src/__tests__/__fixtures__/site-with-autogenerated-sidebar/docs/Guides/guide3.md +0 -8
  146. package/src/__tests__/__fixtures__/site-with-autogenerated-sidebar/docs/Guides/z-guide1.md +0 -8
  147. package/src/__tests__/__fixtures__/site-with-autogenerated-sidebar/docusaurus.config.js +0 -14
  148. package/src/__tests__/__fixtures__/site-with-autogenerated-sidebar/partialAutogeneratedSidebars.js +0 -23
  149. package/src/__tests__/__fixtures__/site-with-doc-label/docs/hello-1.md +0 -7
  150. package/src/__tests__/__fixtures__/site-with-doc-label/docs/hello-2.md +0 -8
  151. package/src/__tests__/__fixtures__/site-with-doc-label/sidebars.json +0 -14
  152. package/src/__tests__/__fixtures__/versioned-site/community/team.md +0 -1
  153. package/src/__tests__/__fixtures__/versioned-site/community_sidebars.json +0 -3
  154. package/src/__tests__/__fixtures__/versioned-site/community_versioned_docs/version-1.0.0/team.md +0 -1
  155. package/src/__tests__/__fixtures__/versioned-site/community_versioned_sidebars/version-1.0.0-sidebars.json +0 -3
  156. package/src/__tests__/__fixtures__/versioned-site/community_versions.json +0 -1
  157. package/src/__tests__/__fixtures__/versioned-site/docs/foo/bar.md +0 -4
  158. package/src/__tests__/__fixtures__/versioned-site/docs/hello.md +0 -1
  159. package/src/__tests__/__fixtures__/versioned-site/docs/slugs/absoluteSlug.md +0 -5
  160. package/src/__tests__/__fixtures__/versioned-site/docs/slugs/relativeSlug.md +0 -5
  161. package/src/__tests__/__fixtures__/versioned-site/docs/slugs/resolvedSlug.md +0 -5
  162. package/src/__tests__/__fixtures__/versioned-site/docs/slugs/tryToEscapeSlug.md +0 -5
  163. package/src/__tests__/__fixtures__/versioned-site/docusaurus.config.js +0 -18
  164. package/src/__tests__/__fixtures__/versioned-site/i18n/en/docusaurus-plugin-content-docs/version-1.0.0/hello.md +0 -1
  165. package/src/__tests__/__fixtures__/versioned-site/i18n/en/docusaurus-plugin-content-docs-community/current/team.md +0 -5
  166. package/src/__tests__/__fixtures__/versioned-site/i18n/fr/docusaurus-plugin-content-docs/version-1.0.0/hello.md +0 -1
  167. package/src/__tests__/__fixtures__/versioned-site/sidebars.json +0 -10
  168. package/src/__tests__/__fixtures__/versioned-site/versioned_docs/version-1.0.0/foo/bar.md +0 -4
  169. package/src/__tests__/__fixtures__/versioned-site/versioned_docs/version-1.0.0/foo/baz.md +0 -1
  170. package/src/__tests__/__fixtures__/versioned-site/versioned_docs/version-1.0.0/hello.md +0 -1
  171. package/src/__tests__/__fixtures__/versioned-site/versioned_docs/version-1.0.1/foo/bar.md +0 -1
  172. package/src/__tests__/__fixtures__/versioned-site/versioned_docs/version-1.0.1/hello.md +0 -1
  173. package/src/__tests__/__fixtures__/versioned-site/versioned_docs/version-withSlugs/rootAbsoluteSlug.md +0 -5
  174. package/src/__tests__/__fixtures__/versioned-site/versioned_docs/version-withSlugs/rootRelativeSlug.md +0 -5
  175. package/src/__tests__/__fixtures__/versioned-site/versioned_docs/version-withSlugs/rootResolvedSlug.md +0 -5
  176. package/src/__tests__/__fixtures__/versioned-site/versioned_docs/version-withSlugs/rootTryToEscapeSlug.md +0 -5
  177. package/src/__tests__/__fixtures__/versioned-site/versioned_docs/version-withSlugs/slugs/absoluteSlug.md +0 -5
  178. package/src/__tests__/__fixtures__/versioned-site/versioned_docs/version-withSlugs/slugs/relativeSlug.md +0 -5
  179. package/src/__tests__/__fixtures__/versioned-site/versioned_docs/version-withSlugs/slugs/resolvedSlug.md +0 -5
  180. package/src/__tests__/__fixtures__/versioned-site/versioned_docs/version-withSlugs/slugs/tryToEscapeSlug.md +0 -5
  181. package/src/__tests__/__fixtures__/versioned-site/versioned_sidebars/version-1.0.0-sidebars.json +0 -11
  182. package/src/__tests__/__fixtures__/versioned-site/versioned_sidebars/version-1.0.1-sidebars.json +0 -10
  183. package/src/__tests__/__fixtures__/versioned-site/versioned_sidebars/version-withSlugs-sidebars.json +0 -5
  184. package/src/__tests__/__fixtures__/versioned-site/versions.json +0 -5
  185. package/src/__tests__/__snapshots__/cli.test.ts.snap +0 -90
  186. package/src/__tests__/__snapshots__/index.test.ts.snap +0 -1907
  187. package/src/__tests__/__snapshots__/sidebars.test.ts.snap +0 -218
  188. package/src/__tests__/__snapshots__/translations.test.ts.snap +0 -487
  189. package/src/__tests__/cli.test.ts +0 -333
  190. package/src/__tests__/docFrontMatter.test.ts +0 -204
  191. package/src/__tests__/docs.test.ts +0 -875
  192. package/src/__tests__/index.test.ts +0 -1831
  193. package/src/__tests__/lastUpdate.test.ts +0 -68
  194. package/src/__tests__/numberPrefix.test.ts +0 -199
  195. package/src/__tests__/options.test.ts +0 -232
  196. package/src/__tests__/sidebarItemsGenerator.test.ts +0 -336
  197. package/src/__tests__/sidebars.test.ts +0 -638
  198. package/src/__tests__/slug.test.ts +0 -109
  199. package/src/__tests__/translations.test.ts +0 -159
  200. package/src/__tests__/versions.test.ts +0 -718
  201. package/src/client/__tests__/docsClientUtils.test.ts +0 -372
  202. package/src/markdown/__tests__/__fixtures__/docs/doc-localized.md +0 -1
  203. package/src/markdown/__tests__/__fixtures__/docs/doc1.md +0 -13
  204. package/src/markdown/__tests__/__fixtures__/docs/doc2.md +0 -12
  205. package/src/markdown/__tests__/__fixtures__/docs/doc4.md +0 -19
  206. package/src/markdown/__tests__/__fixtures__/docs/doc5.md +0 -6
  207. package/src/markdown/__tests__/__fixtures__/docs/subdir/doc3.md +0 -3
  208. package/src/markdown/__tests__/__fixtures__/versioned_docs/version-1.0.0/doc2.md +0 -7
  209. package/src/markdown/__tests__/__fixtures__/versioned_docs/version-1.0.0/subdir/doc1.md +0 -3
  210. package/src/markdown/__tests__/__snapshots__/linkify.test.ts.snap +0 -82
  211. package/src/markdown/__tests__/linkify.test.ts +0 -190
  212. package/src/sidebarItemsGenerator.ts +0 -307
  213. package/src/sidebars.ts +0 -489
  214. package/tsconfig.json +0 -9
package/lib/options.js CHANGED
@@ -1,21 +1,32 @@
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
9
  exports.validateOptions = exports.OptionsSchema = exports.DEFAULT_OPTIONS = void 0;
4
10
  const tslib_1 = require("tslib");
5
11
  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");
12
+ const utils_1 = require("@docusaurus/utils");
13
+ const logger_1 = (0, tslib_1.__importDefault)(require("@docusaurus/logger"));
14
+ const remark_admonitions_1 = (0, tslib_1.__importDefault)(require("remark-admonitions"));
15
+ const generator_1 = require("./sidebars/generator");
9
16
  const numberPrefix_1 = require("./numberPrefix");
10
17
  exports.DEFAULT_OPTIONS = {
11
18
  path: 'docs',
12
19
  routeBasePath: 'docs',
13
- homePageId: undefined,
20
+ tagsBasePath: 'tags',
14
21
  include: ['**/*.{md,mdx}'],
15
- sidebarItemsGenerator: sidebarItemsGenerator_1.DefaultSidebarItemsGenerator,
22
+ exclude: utils_1.GlobExcludeDefault,
23
+ sidebarItemsGenerator: generator_1.DefaultSidebarItemsGenerator,
16
24
  numberPrefixParser: numberPrefix_1.DefaultNumberPrefixParser,
17
25
  docLayoutComponent: '@theme/DocPage',
18
26
  docItemComponent: '@theme/DocItem',
27
+ docTagDocListComponent: '@theme/DocTagDocListPage',
28
+ docTagsListComponent: '@theme/DocTagsListPage',
29
+ docCategoryGeneratedIndexComponent: '@theme/DocCategoryGeneratedIndexPage',
19
30
  remarkPlugins: [],
20
31
  rehypePlugins: [],
21
32
  beforeDefaultRemarkPlugins: [],
@@ -23,17 +34,22 @@ exports.DEFAULT_OPTIONS = {
23
34
  showLastUpdateTime: false,
24
35
  showLastUpdateAuthor: false,
25
36
  admonitions: {},
26
- excludeNextVersionDocs: false,
27
37
  includeCurrentVersion: true,
28
38
  disableVersioning: false,
29
39
  lastVersion: undefined,
30
40
  versions: {},
31
41
  editCurrentVersion: false,
32
42
  editLocalizedFiles: false,
43
+ sidebarCollapsible: true,
44
+ sidebarCollapsed: true,
45
+ breadcrumbs: true,
33
46
  };
34
47
  const VersionOptionsSchema = utils_validation_1.Joi.object({
35
48
  path: utils_validation_1.Joi.string().allow('').optional(),
36
49
  label: utils_validation_1.Joi.string().optional(),
50
+ banner: utils_validation_1.Joi.string().equal('none', 'unreleased', 'unmaintained').optional(),
51
+ badge: utils_validation_1.Joi.boolean().optional(),
52
+ className: utils_validation_1.Joi.string().optional(),
37
53
  });
38
54
  const VersionsOptionsSchema = utils_validation_1.Joi.object()
39
55
  .pattern(utils_validation_1.Joi.string().required(), VersionOptionsSchema)
@@ -47,10 +63,16 @@ exports.OptionsSchema = utils_validation_1.Joi.object({
47
63
  // '' not allowed, see https://github.com/facebook/docusaurus/issues/3374
48
64
  // .allow('') ""
49
65
  .default(exports.DEFAULT_OPTIONS.routeBasePath),
50
- homePageId: utils_validation_1.Joi.string().optional(),
66
+ tagsBasePath: utils_validation_1.Joi.string().default(exports.DEFAULT_OPTIONS.tagsBasePath),
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,6 +82,9 @@ 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),
@@ -69,22 +94,32 @@ exports.OptionsSchema = utils_validation_1.Joi.object({
69
94
  .default(exports.DEFAULT_OPTIONS.admonitions),
70
95
  showLastUpdateTime: utils_validation_1.Joi.bool().default(exports.DEFAULT_OPTIONS.showLastUpdateTime),
71
96
  showLastUpdateAuthor: utils_validation_1.Joi.bool().default(exports.DEFAULT_OPTIONS.showLastUpdateAuthor),
72
- excludeNextVersionDocs: utils_validation_1.Joi.bool().default(exports.DEFAULT_OPTIONS.excludeNextVersionDocs),
73
97
  includeCurrentVersion: utils_validation_1.Joi.bool().default(exports.DEFAULT_OPTIONS.includeCurrentVersion),
74
98
  onlyIncludeVersions: utils_validation_1.Joi.array().items(utils_validation_1.Joi.string().required()).optional(),
75
99
  disableVersioning: utils_validation_1.Joi.bool().default(exports.DEFAULT_OPTIONS.disableVersioning),
76
100
  lastVersion: utils_validation_1.Joi.string().optional(),
77
101
  versions: VersionsOptionsSchema,
102
+ breadcrumbs: utils_validation_1.Joi.bool().default(exports.DEFAULT_OPTIONS.breadcrumbs),
78
103
  });
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;
104
+ function validateOptions({ validate, options: userOptions, }) {
105
+ let options = userOptions;
106
+ if (options.sidebarCollapsible === false) {
107
+ // When sidebarCollapsible=false and sidebarCollapsed=undefined, we don't
108
+ // want to have the inconsistency warning. We let options.sidebarCollapsible
109
+ // become the default value for options.sidebarCollapsed
110
+ if (typeof options.sidebarCollapsed === 'undefined') {
111
+ options = {
112
+ ...options,
113
+ sidebarCollapsed: false,
114
+ };
115
+ }
116
+ if (options.sidebarCollapsed) {
117
+ 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.`;
118
+ options = {
119
+ ...options,
120
+ sidebarCollapsed: false,
121
+ };
122
+ }
88
123
  }
89
124
  const normalizedOptions = validate(exports.OptionsSchema, options);
90
125
  if (normalizedOptions.admonitions) {
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 { LoadedVersion, VersionTag, DocMetadata } from './types';
8
+ import type { PropSidebars, PropVersionMetadata, PropTagDocList } 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: Pick<DocMetadata, 'id' | 'title' | 'description' | 'permalink'>[];
15
+ }): PropTagDocList;
package/lib/props.js CHANGED
@@ -6,30 +6,53 @@
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 = (0, 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
+ var _a;
26
+ const docMetadata = getDocById(item.id);
27
+ const { title, permalink, frontMatter: { sidebar_label: sidebarLabel }, } = docMetadata;
22
28
  return {
23
29
  type: 'link',
24
30
  label: sidebarLabel || item.label || title,
25
31
  href: permalink,
26
- customProps: item.customProps,
32
+ className: item.className,
33
+ customProps: (_a = item.customProps) !== null && _a !== void 0 ? _a : docMetadata.frontMatter.sidebar_custom_props,
34
+ docId: docMetadata.unversionedId,
27
35
  };
28
36
  };
29
- const normalizeItem = (item) => {
37
+ function getCategoryLinkHref(link) {
38
+ switch (link === null || link === void 0 ? void 0 : link.type) {
39
+ case 'doc':
40
+ return getDocById(link.id).permalink;
41
+ case 'generated-index':
42
+ return link.permalink;
43
+ default:
44
+ return undefined;
45
+ }
46
+ }
47
+ function convertCategory(item) {
48
+ const { link, ...rest } = item;
49
+ const href = getCategoryLinkHref(link);
50
+ return { ...rest, items: item.items.map(normalizeItem), ...(href && { href }) };
51
+ }
52
+ function normalizeItem(item) {
30
53
  switch (item.type) {
31
54
  case 'category':
32
- return { ...item, items: item.items.map(normalizeItem) };
55
+ return convertCategory(item);
33
56
  case 'ref':
34
57
  case 'doc':
35
58
  return convertDocLink(item);
@@ -37,21 +60,55 @@ Available document ids=
37
60
  default:
38
61
  return item;
39
62
  }
40
- };
63
+ }
41
64
  // Transform the sidebar so that all sidebar item will be in the
42
65
  // form of 'link' or 'category' only.
43
66
  // This is what will be passed as props to the UI component.
44
- return lodash_1.mapValues(loadedVersion.sidebars, (items) => items.map(normalizeItem));
67
+ return lodash_1.default.mapValues(loadedVersion.sidebars, (items) => items.map(normalizeItem));
45
68
  }
46
69
  exports.toSidebarsProp = toSidebarsProp;
70
+ function toVersionDocsProp(loadedVersion) {
71
+ return Object.fromEntries(loadedVersion.docs.map((doc) => [
72
+ doc.unversionedId,
73
+ {
74
+ id: doc.unversionedId,
75
+ title: doc.title,
76
+ description: doc.description,
77
+ sidebar: doc.sidebar,
78
+ },
79
+ ]));
80
+ }
47
81
  function toVersionMetadataProp(pluginId, loadedVersion) {
48
82
  return {
49
83
  pluginId,
50
84
  version: loadedVersion.versionName,
51
85
  label: loadedVersion.versionLabel,
86
+ banner: loadedVersion.versionBanner,
87
+ badge: loadedVersion.versionBadge,
88
+ className: loadedVersion.versionClassName,
52
89
  isLast: loadedVersion.isLast,
53
90
  docsSidebars: toSidebarsProp(loadedVersion),
54
- permalinkToSidebar: loadedVersion.permalinkToSidebar,
91
+ docs: toVersionDocsProp(loadedVersion),
55
92
  };
56
93
  }
57
94
  exports.toVersionMetadataProp = toVersionMetadataProp;
95
+ function toTagDocListProp({ allTagsPath, tag, docs, }) {
96
+ function toDocListProp() {
97
+ const list = lodash_1.default.compact(tag.docIds.map((id) => docs.find((doc) => doc.id === id)));
98
+ // Sort docs by title
99
+ list.sort((doc1, doc2) => doc1.title.localeCompare(doc2.title));
100
+ return list.map((doc) => ({
101
+ id: doc.id,
102
+ title: doc.title,
103
+ description: doc.description,
104
+ permalink: doc.permalink,
105
+ }));
106
+ }
107
+ return {
108
+ name: tag.name,
109
+ permalink: tag.permalink,
110
+ docs: toDocListProp(),
111
+ allTagsPath,
112
+ };
113
+ }
114
+ exports.toTagDocListProp = toTagDocListProp;
@@ -0,0 +1,28 @@
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 { DocMetadata, LoadedVersion } from './types';
9
+ export declare function createCategoryGeneratedIndexRoutes({ version, actions, docCategoryGeneratedIndexComponent, aliasedSource, }: {
10
+ version: LoadedVersion;
11
+ actions: PluginContentLoadedActions;
12
+ docCategoryGeneratedIndexComponent: string;
13
+ aliasedSource: (str: string) => string;
14
+ }): Promise<RouteConfig[]>;
15
+ export declare function createDocRoutes({ docs, actions, docItemComponent, }: {
16
+ docs: DocMetadata[];
17
+ actions: PluginContentLoadedActions;
18
+ docItemComponent: string;
19
+ }): Promise<RouteConfig[]>;
20
+ export declare function createVersionRoutes({ loadedVersion, actions, docItemComponent, docLayoutComponent, docCategoryGeneratedIndexComponent, pluginId, aliasedSource, }: {
21
+ loadedVersion: LoadedVersion;
22
+ actions: PluginContentLoadedActions;
23
+ docLayoutComponent: string;
24
+ docItemComponent: string;
25
+ docCategoryGeneratedIndexComponent: string;
26
+ pluginId: string;
27
+ aliasedSource: (str: string) => string;
28
+ }): Promise<void>;
package/lib/routes.js ADDED
@@ -0,0 +1,110 @@
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 utils_1 = require("@docusaurus/utils");
12
+ const props_1 = require("./props");
13
+ const logger_1 = (0, tslib_1.__importDefault)(require("@docusaurus/logger"));
14
+ async function createCategoryGeneratedIndexRoutes({ version, actions, docCategoryGeneratedIndexComponent, aliasedSource, }) {
15
+ const slugs = (0, utils_1.createSlugger)();
16
+ async function createCategoryGeneratedIndexRoute(categoryGeneratedIndex) {
17
+ const { sidebar, title, description, slug, permalink, previous, next, image, keywords, } = categoryGeneratedIndex;
18
+ const propFileName = slugs.slug(`${version.versionPath}-${categoryGeneratedIndex.sidebar}-category-${categoryGeneratedIndex.title}`);
19
+ const prop = {
20
+ title,
21
+ description,
22
+ slug,
23
+ permalink,
24
+ image,
25
+ keywords,
26
+ navigation: {
27
+ previous,
28
+ next,
29
+ },
30
+ };
31
+ const propData = await actions.createData(`${(0, utils_1.docuHash)(`category/${propFileName}`)}.json`, JSON.stringify(prop, null, 2));
32
+ return {
33
+ path: permalink,
34
+ component: docCategoryGeneratedIndexComponent,
35
+ exact: true,
36
+ modules: {
37
+ categoryGeneratedIndex: aliasedSource(propData),
38
+ },
39
+ // Same as doc, this sidebar route attribute permits to associate this
40
+ // subpage to the given sidebar
41
+ ...(sidebar && { sidebar }),
42
+ };
43
+ }
44
+ return Promise.all(version.categoryGeneratedIndices.map(createCategoryGeneratedIndexRoute));
45
+ }
46
+ exports.createCategoryGeneratedIndexRoutes = createCategoryGeneratedIndexRoutes;
47
+ async function createDocRoutes({ docs, actions, docItemComponent, }) {
48
+ return Promise.all(docs.map(async (metadataItem) => {
49
+ await actions.createData(
50
+ // Note that this created data path must be in sync with
51
+ // metadataPath provided to mdx-loader.
52
+ `${(0, utils_1.docuHash)(metadataItem.source)}.json`, JSON.stringify(metadataItem, null, 2));
53
+ const docRoute = {
54
+ path: metadataItem.permalink,
55
+ component: docItemComponent,
56
+ exact: true,
57
+ modules: {
58
+ content: metadataItem.source,
59
+ },
60
+ // Because the parent (DocPage) comp need to access it easily
61
+ // This permits to render the sidebar once without unmount/remount when
62
+ // navigating (and preserve sidebar state)
63
+ ...(metadataItem.sidebar && {
64
+ sidebar: metadataItem.sidebar,
65
+ }),
66
+ };
67
+ return docRoute;
68
+ }));
69
+ }
70
+ exports.createDocRoutes = createDocRoutes;
71
+ async function createVersionRoutes({ loadedVersion, actions, docItemComponent, docLayoutComponent, docCategoryGeneratedIndexComponent, pluginId, aliasedSource, }) {
72
+ async function doCreateVersionRoutes(version) {
73
+ const versionMetadata = (0, props_1.toVersionMetadataProp)(pluginId, version);
74
+ const versionMetadataPropPath = await actions.createData(`${(0, utils_1.docuHash)(`version-${version.versionName}-metadata-prop`)}.json`, JSON.stringify(versionMetadata, null, 2));
75
+ async function createVersionSubRoutes() {
76
+ const [docRoutes, sidebarsRoutes] = await Promise.all([
77
+ createDocRoutes({ docs: version.docs, actions, docItemComponent }),
78
+ createCategoryGeneratedIndexRoutes({
79
+ version,
80
+ actions,
81
+ docCategoryGeneratedIndexComponent,
82
+ aliasedSource,
83
+ }),
84
+ ]);
85
+ const routes = [...docRoutes, ...sidebarsRoutes];
86
+ return routes.sort((a, b) => a.path.localeCompare(b.path));
87
+ }
88
+ actions.addRoute({
89
+ path: version.versionPath,
90
+ // allow matching /docs/* as well
91
+ exact: false,
92
+ // main docs component (DocPage)
93
+ component: docLayoutComponent,
94
+ // sub-routes for each doc
95
+ routes: await createVersionSubRoutes(),
96
+ modules: {
97
+ versionMetadata: aliasedSource(versionMetadataPropPath),
98
+ },
99
+ priority: version.routePriority,
100
+ });
101
+ }
102
+ try {
103
+ return await doCreateVersionRoutes(loadedVersion);
104
+ }
105
+ catch (err) {
106
+ logger_1.default.error `Can't create version routes for version name=${loadedVersion.versionName}`;
107
+ throw err;
108
+ }
109
+ }
110
+ exports.createVersionRoutes = createVersionRoutes;
@@ -0,0 +1,8 @@
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, getVersionsFilePath, readVersionsFile, readVersionNames, } from './versions';
@@ -0,0 +1,23 @@
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.readVersionsFile = exports.getVersionsFilePath = 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
+ var constants_1 = require("./constants");
12
+ Object.defineProperty(exports, "CURRENT_VERSION_NAME", { enumerable: true, get: function () { return constants_1.CURRENT_VERSION_NAME; } });
13
+ Object.defineProperty(exports, "VERSIONED_DOCS_DIR", { enumerable: true, get: function () { return constants_1.VERSIONED_DOCS_DIR; } });
14
+ Object.defineProperty(exports, "VERSIONED_SIDEBARS_DIR", { enumerable: true, get: function () { return constants_1.VERSIONED_SIDEBARS_DIR; } });
15
+ Object.defineProperty(exports, "VERSIONS_JSON_FILE", { enumerable: true, get: function () { return constants_1.VERSIONS_JSON_FILE; } });
16
+ var versions_1 = require("./versions");
17
+ Object.defineProperty(exports, "filterVersions", { enumerable: true, get: function () { return versions_1.filterVersions; } });
18
+ Object.defineProperty(exports, "getDefaultVersionBanner", { enumerable: true, get: function () { return versions_1.getDefaultVersionBanner; } });
19
+ Object.defineProperty(exports, "getVersionBadge", { enumerable: true, get: function () { return versions_1.getVersionBadge; } });
20
+ Object.defineProperty(exports, "getVersionBanner", { enumerable: true, get: function () { return versions_1.getVersionBanner; } });
21
+ Object.defineProperty(exports, "getVersionsFilePath", { enumerable: true, get: function () { return versions_1.getVersionsFilePath; } });
22
+ Object.defineProperty(exports, "readVersionsFile", { enumerable: true, get: function () { return versions_1.readVersionsFile; } });
23
+ Object.defineProperty(exports, "readVersionNames", { enumerable: true, get: function () { return versions_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;
@@ -0,0 +1,190 @@
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.DefaultSidebarItemsGenerator = exports.CategoryMetadataFilenamePattern = exports.CategoryMetadataFilenameBase = void 0;
10
+ const tslib_1 = require("tslib");
11
+ const lodash_1 = (0, tslib_1.__importDefault)(require("lodash"));
12
+ const utils_1 = require("@docusaurus/utils");
13
+ const logger_1 = (0, tslib_1.__importDefault)(require("@docusaurus/logger"));
14
+ const path_1 = (0, tslib_1.__importDefault)(require("path"));
15
+ const docs_1 = require("../docs");
16
+ const BreadcrumbSeparator = '/';
17
+ // To avoid possible name clashes with a folder of the same name as the ID
18
+ const docIdPrefix = '$doc$/';
19
+ // Just an alias to the make code more explicit
20
+ function getLocalDocId(docId) {
21
+ return lodash_1.default.last(docId.split('/'));
22
+ }
23
+ exports.CategoryMetadataFilenameBase = '_category_';
24
+ exports.CategoryMetadataFilenamePattern = '_category_.{json,yml,yaml}';
25
+ // Comment for this feature: https://github.com/facebook/docusaurus/issues/3464#issuecomment-818670449
26
+ const DefaultSidebarItemsGenerator = async ({ numberPrefixParser, isCategoryIndex, docs: allDocs, item: { dirName: autogenDir }, categoriesMetadata, }) => {
27
+ const docsById = (0, docs_1.createDocsByIdIndex)(allDocs);
28
+ const findDoc = (docId) => docsById[docId];
29
+ const getDoc = (docId) => {
30
+ const doc = findDoc(docId);
31
+ if (!doc) {
32
+ throw new Error(`Can't find any doc with id=${docId}.\nAvailable doc ids:\n- ${Object.keys(docsById).join('\n- ')}`);
33
+ }
34
+ return doc;
35
+ };
36
+ /**
37
+ * Step 1. Extract the docs that are in the autogen dir.
38
+ */
39
+ function getAutogenDocs() {
40
+ function isInAutogeneratedDir(doc) {
41
+ return (
42
+ // Doc at the root of the autogenerated sidebar dir
43
+ doc.sourceDirName === autogenDir ||
44
+ // autogen dir is . and doc is in subfolder
45
+ autogenDir === '.' ||
46
+ // autogen dir is not . and doc is in subfolder
47
+ // "api/myDoc" startsWith "api/" (note "api2/myDoc" is not included)
48
+ doc.sourceDirName.startsWith((0, utils_1.addTrailingSlash)(autogenDir)));
49
+ }
50
+ const docs = allDocs.filter(isInAutogeneratedDir);
51
+ if (docs.length === 0) {
52
+ logger_1.default.warn `No docs found in path=${autogenDir}: can't auto-generate a sidebar.`;
53
+ }
54
+ return docs;
55
+ }
56
+ /**
57
+ * Step 2. Turn the linear file list into a tree structure.
58
+ */
59
+ function treeify(docs) {
60
+ // Get the category breadcrumb of a doc (relative to the dir of the
61
+ // autogenerated sidebar item)
62
+ // autogenDir=a/b and docDir=a/b/c/d => returns [c, d]
63
+ // autogenDir=a/b and docDir=a/b => returns []
64
+ // TODO: try to use path.relative()
65
+ function getRelativeBreadcrumb(doc) {
66
+ return autogenDir === doc.sourceDirName
67
+ ? []
68
+ : doc.sourceDirName
69
+ .replace((0, utils_1.addTrailingSlash)(autogenDir), '')
70
+ .split(BreadcrumbSeparator);
71
+ }
72
+ const treeRoot = {};
73
+ docs.forEach((doc) => {
74
+ const breadcrumb = getRelativeBreadcrumb(doc);
75
+ let currentDir = treeRoot; // We walk down the file's path to generate the fs structure
76
+ breadcrumb.forEach((dir) => {
77
+ if (typeof currentDir[dir] === 'undefined') {
78
+ currentDir[dir] = {}; // Create new folder.
79
+ }
80
+ currentDir = currentDir[dir]; // Go into the subdirectory.
81
+ });
82
+ currentDir[`${docIdPrefix}${doc.id}`] = null; // We've walked through the file path. Register the file in this directory.
83
+ });
84
+ return treeRoot;
85
+ }
86
+ /**
87
+ * Step 3. Recursively transform the tree-like structure to sidebar items.
88
+ * (From a record to an array of items, akin to normalizing shorthand)
89
+ */
90
+ function generateSidebar(fsModel) {
91
+ function createDocItem(id) {
92
+ const { sidebarPosition: position, frontMatter: { sidebar_label: label, sidebar_class_name: className }, } = getDoc(id);
93
+ return {
94
+ type: 'doc',
95
+ id,
96
+ position,
97
+ // We don't want these fields to magically appear in the generated
98
+ // sidebar
99
+ ...(label !== undefined && { label }),
100
+ ...(className !== undefined && { className }),
101
+ };
102
+ }
103
+ async function createCategoryItem(dir, fullPath, folderName) {
104
+ var _a, _b;
105
+ const categoryMetadata = categoriesMetadata[(0, utils_1.posixPath)(path_1.default.join(autogenDir, fullPath))];
106
+ const className = categoryMetadata === null || categoryMetadata === void 0 ? void 0 : categoryMetadata.className;
107
+ const { filename, numberPrefix } = numberPrefixParser(folderName);
108
+ const allItems = await Promise.all(Object.entries(dir).map(([key, content]) => dirToItem(content, key, `${fullPath}/${key}`)));
109
+ // Try to match a doc inside the category folder,
110
+ // using the "local id" (myDoc) or "qualified id" (dirName/myDoc)
111
+ function findDocByLocalId(localId) {
112
+ return allItems.find((item) => item.type === 'doc' && getLocalDocId(item.id) === localId);
113
+ }
114
+ function findConventionalCategoryDocLink() {
115
+ return allItems.find((item) => {
116
+ if (item.type !== 'doc') {
117
+ return false;
118
+ }
119
+ const doc = getDoc(item.id);
120
+ return isCategoryIndex((0, docs_1.toCategoryIndexMatcherParam)(doc));
121
+ });
122
+ }
123
+ function getCategoryLinkedDocId() {
124
+ var _a, _b;
125
+ const link = categoryMetadata === null || categoryMetadata === void 0 ? void 0 : categoryMetadata.link;
126
+ if (link !== undefined) {
127
+ if (link && link.type === 'doc') {
128
+ return ((_a = findDocByLocalId(link.id)) === null || _a === void 0 ? void 0 : _a.id) || getDoc(link.id).id;
129
+ }
130
+ // If a link is explicitly specified, we won't apply conventions
131
+ return undefined;
132
+ }
133
+ // Apply default convention to pick index.md, README.md or
134
+ // <categoryName>.md as the category doc
135
+ return (_b = findConventionalCategoryDocLink()) === null || _b === void 0 ? void 0 : _b.id;
136
+ }
137
+ const categoryLinkedDocId = getCategoryLinkedDocId();
138
+ const link = categoryLinkedDocId
139
+ ? {
140
+ type: 'doc',
141
+ id: categoryLinkedDocId, // We "remap" a potentially "local id" to a "qualified id"
142
+ }
143
+ : categoryMetadata === null || categoryMetadata === void 0 ? void 0 : categoryMetadata.link;
144
+ // If a doc is linked, remove it from the category subItems
145
+ const items = allItems.filter((item) => !(item.type === 'doc' && item.id === categoryLinkedDocId));
146
+ return {
147
+ type: 'category',
148
+ label: (_a = categoryMetadata === null || categoryMetadata === void 0 ? void 0 : categoryMetadata.label) !== null && _a !== void 0 ? _a : filename,
149
+ collapsible: categoryMetadata === null || categoryMetadata === void 0 ? void 0 : categoryMetadata.collapsible,
150
+ collapsed: categoryMetadata === null || categoryMetadata === void 0 ? void 0 : categoryMetadata.collapsed,
151
+ position: (_b = categoryMetadata === null || categoryMetadata === void 0 ? void 0 : categoryMetadata.position) !== null && _b !== void 0 ? _b : numberPrefix,
152
+ ...(className !== undefined && { className }),
153
+ items,
154
+ ...(link && { link }),
155
+ };
156
+ }
157
+ async function dirToItem(dir, // The directory item to be transformed.
158
+ itemKey, // For docs, it's the doc ID; for categories, it's used to generate the next `relativePath`.
159
+ fullPath) {
160
+ return dir
161
+ ? createCategoryItem(dir, fullPath, itemKey)
162
+ : createDocItem(itemKey.substring(docIdPrefix.length));
163
+ }
164
+ return Promise.all(Object.entries(fsModel).map(([key, content]) => dirToItem(content, key, key)));
165
+ }
166
+ /**
167
+ * Step 4. Recursively sort the categories/docs + remove the "position"
168
+ * attribute from final output. Note: the "position" is only used to sort
169
+ * "inside" a sidebar slice. It is not used to sort across multiple
170
+ * consecutive sidebar slices (i.e. a whole category composed of multiple
171
+ * autogenerated items)
172
+ */
173
+ function sortItems(sidebarItems) {
174
+ const processedSidebarItems = sidebarItems.map((item) => {
175
+ if (item.type === 'category') {
176
+ return { ...item, items: sortItems(item.items) };
177
+ }
178
+ return item;
179
+ });
180
+ const sortedSidebarItems = lodash_1.default.sortBy(processedSidebarItems, (item) => item.position);
181
+ return sortedSidebarItems.map(({ position, ...item }) => item);
182
+ }
183
+ // TODO: the whole code is designed for pipeline operator
184
+ const docs = getAutogenDocs();
185
+ const fsModel = treeify(docs);
186
+ const sidebarWithPosition = await generateSidebar(fsModel);
187
+ const sortedSidebar = sortItems(sidebarWithPosition);
188
+ return sortedSidebar;
189
+ };
190
+ exports.DefaultSidebarItemsGenerator = DefaultSidebarItemsGenerator;