@docusaurus/plugin-content-docs 2.0.0-beta.15a2b59f9 → 2.0.0-beta.17

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 (213) hide show
  1. package/lib/categoryGeneratedIndex.d.ts +12 -0
  2. package/lib/categoryGeneratedIndex.js +38 -0
  3. package/lib/cli.d.ts +2 -2
  4. package/lib/cli.js +27 -44
  5. package/lib/client/docsClientUtils.d.ts +3 -25
  6. package/lib/client/docsClientUtils.js +25 -24
  7. package/lib/{theme/hooks/useDocs.d.ts → client/index.d.ts} +1 -2
  8. package/lib/{theme/hooks/useDocs.js → client/index.js} +26 -26
  9. package/lib/docFrontMatter.d.ts +1 -1
  10. package/lib/docFrontMatter.js +9 -3
  11. package/lib/docs.d.ts +39 -3
  12. package/lib/docs.js +157 -53
  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 +110 -144
  17. package/lib/lastUpdate.js +15 -28
  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 +2 -2
  22. package/lib/numberPrefix.d.ts +1 -1
  23. package/lib/numberPrefix.js +9 -9
  24. package/lib/options.d.ts +3 -3
  25. package/lib/options.js +50 -10
  26. package/lib/props.d.ts +7 -2
  27. package/lib/props.js +66 -11
  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 +193 -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 +70 -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 +259 -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 +28 -17
  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 +91 -49
  54. package/lib/types.d.ts +40 -126
  55. package/lib/versions.d.ts +29 -4
  56. package/lib/versions.js +92 -87
  57. package/package.json +30 -27
  58. package/src/categoryGeneratedIndex.ts +59 -0
  59. package/src/cli.ts +34 -54
  60. package/src/client/docsClientUtils.ts +32 -57
  61. package/src/{theme/hooks/useDocs.ts → client/index.ts} +11 -10
  62. package/{types.d.ts → src/deps.d.ts} +0 -0
  63. package/src/docFrontMatter.ts +12 -5
  64. package/src/docs.ts +213 -47
  65. package/src/globalData.ts +53 -2
  66. package/src/index.ts +151 -197
  67. package/src/lastUpdate.ts +14 -37
  68. package/src/markdown/index.ts +9 -13
  69. package/src/markdown/linkify.ts +1 -1
  70. package/src/numberPrefix.ts +11 -8
  71. package/src/options.ts +59 -15
  72. package/src/plugin-content-docs.d.ts +249 -54
  73. package/src/props.ts +97 -18
  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 +269 -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 +39 -21
  86. package/src/tags.ts +19 -0
  87. package/src/translations.ts +121 -62
  88. package/src/types.ts +46 -183
  89. package/src/versions.ts +136 -102
  90. package/lib/.tsbuildinfo +0 -1
  91. package/lib/sidebarItemsGenerator.js +0 -211
  92. package/lib/sidebars.d.ts +0 -43
  93. package/lib/sidebars.js +0 -320
  94. package/src/__tests__/__fixtures__/bad-id-site/docs/invalid-id.md +0 -5
  95. package/src/__tests__/__fixtures__/bad-slug-on-doc-home-site/docs/docWithSlug.md +0 -5
  96. package/src/__tests__/__fixtures__/empty-site/docusaurus.config.js +0 -16
  97. package/src/__tests__/__fixtures__/empty-site/sidebars.json +0 -1
  98. package/src/__tests__/__fixtures__/sidebars/sidebars-category-shorthand.js +0 -34
  99. package/src/__tests__/__fixtures__/sidebars/sidebars-category-wrong-items.json +0 -11
  100. package/src/__tests__/__fixtures__/sidebars/sidebars-category-wrong-label.json +0 -11
  101. package/src/__tests__/__fixtures__/sidebars/sidebars-category.js +0 -44
  102. package/src/__tests__/__fixtures__/sidebars/sidebars-collapsed-first-level.json +0 -20
  103. package/src/__tests__/__fixtures__/sidebars/sidebars-collapsed.json +0 -21
  104. package/src/__tests__/__fixtures__/sidebars/sidebars-doc-id-not-string.json +0 -10
  105. package/src/__tests__/__fixtures__/sidebars/sidebars-first-level-not-category.js +0 -20
  106. package/src/__tests__/__fixtures__/sidebars/sidebars-link-wrong-href.json +0 -11
  107. package/src/__tests__/__fixtures__/sidebars/sidebars-link-wrong-label.json +0 -11
  108. package/src/__tests__/__fixtures__/sidebars/sidebars-link.json +0 -11
  109. package/src/__tests__/__fixtures__/sidebars/sidebars-unknown-type.json +0 -14
  110. package/src/__tests__/__fixtures__/sidebars/sidebars-wrong-field.json +0 -20
  111. package/src/__tests__/__fixtures__/sidebars/sidebars.json +0 -20
  112. package/src/__tests__/__fixtures__/simple-site/docs/foo/bar.md +0 -69
  113. package/src/__tests__/__fixtures__/simple-site/docs/foo/baz.md +0 -70
  114. package/src/__tests__/__fixtures__/simple-site/docs/headingAsTitle.md +0 -1
  115. package/src/__tests__/__fixtures__/simple-site/docs/hello.md +0 -53
  116. package/src/__tests__/__fixtures__/simple-site/docs/ipsum.md +0 -5
  117. package/src/__tests__/__fixtures__/simple-site/docs/lorem.md +0 -6
  118. package/src/__tests__/__fixtures__/simple-site/docs/rootAbsoluteSlug.md +0 -5
  119. package/src/__tests__/__fixtures__/simple-site/docs/rootRelativeSlug.md +0 -5
  120. package/src/__tests__/__fixtures__/simple-site/docs/rootResolvedSlug.md +0 -5
  121. package/src/__tests__/__fixtures__/simple-site/docs/rootTryToEscapeSlug.md +0 -5
  122. package/src/__tests__/__fixtures__/simple-site/docs/slugs/absoluteSlug.md +0 -5
  123. package/src/__tests__/__fixtures__/simple-site/docs/slugs/relativeSlug.md +0 -5
  124. package/src/__tests__/__fixtures__/simple-site/docs/slugs/resolvedSlug.md +0 -5
  125. package/src/__tests__/__fixtures__/simple-site/docs/slugs/tryToEscapeSlug.md +0 -5
  126. package/src/__tests__/__fixtures__/simple-site/docusaurus.config.js +0 -14
  127. package/src/__tests__/__fixtures__/simple-site/sidebars.json +0 -23
  128. package/src/__tests__/__fixtures__/simple-site/wrong-sidebars.json +0 -7
  129. package/src/__tests__/__fixtures__/site-with-autogenerated-sidebar/docs/0-getting-started.md +0 -3
  130. package/src/__tests__/__fixtures__/site-with-autogenerated-sidebar/docs/1-installation.md +0 -3
  131. package/src/__tests__/__fixtures__/site-with-autogenerated-sidebar/docs/3-API/00_api-overview.md +0 -3
  132. package/src/__tests__/__fixtures__/site-with-autogenerated-sidebar/docs/3-API/01_Core APIs/0 --- Client API.md +0 -1
  133. package/src/__tests__/__fixtures__/site-with-autogenerated-sidebar/docs/3-API/01_Core APIs/1 --- Server API.md +0 -1
  134. package/src/__tests__/__fixtures__/site-with-autogenerated-sidebar/docs/3-API/02_Extension APIs/0. Plugin API.md +0 -1
  135. package/src/__tests__/__fixtures__/site-with-autogenerated-sidebar/docs/3-API/02_Extension APIs/1. Theme API.md +0 -1
  136. package/src/__tests__/__fixtures__/site-with-autogenerated-sidebar/docs/3-API/02_Extension APIs/_category_.yml +0 -1
  137. package/src/__tests__/__fixtures__/site-with-autogenerated-sidebar/docs/3-API/03_api-end.md +0 -3
  138. package/src/__tests__/__fixtures__/site-with-autogenerated-sidebar/docs/3-API/_category_.json +0 -3
  139. package/src/__tests__/__fixtures__/site-with-autogenerated-sidebar/docs/Guides/0-guide2.5.md +0 -8
  140. package/src/__tests__/__fixtures__/site-with-autogenerated-sidebar/docs/Guides/02-guide2.md +0 -7
  141. package/src/__tests__/__fixtures__/site-with-autogenerated-sidebar/docs/Guides/_category_.json +0 -3
  142. package/src/__tests__/__fixtures__/site-with-autogenerated-sidebar/docs/Guides/a-guide4.md +0 -7
  143. package/src/__tests__/__fixtures__/site-with-autogenerated-sidebar/docs/Guides/b-guide5.md +0 -7
  144. package/src/__tests__/__fixtures__/site-with-autogenerated-sidebar/docs/Guides/guide3.md +0 -8
  145. package/src/__tests__/__fixtures__/site-with-autogenerated-sidebar/docs/Guides/z-guide1.md +0 -8
  146. package/src/__tests__/__fixtures__/site-with-autogenerated-sidebar/docusaurus.config.js +0 -14
  147. package/src/__tests__/__fixtures__/site-with-autogenerated-sidebar/partialAutogeneratedSidebars.js +0 -23
  148. package/src/__tests__/__fixtures__/site-with-doc-label/docs/hello-1.md +0 -7
  149. package/src/__tests__/__fixtures__/site-with-doc-label/docs/hello-2.md +0 -8
  150. package/src/__tests__/__fixtures__/site-with-doc-label/sidebars.json +0 -14
  151. package/src/__tests__/__fixtures__/versioned-site/community/team.md +0 -1
  152. package/src/__tests__/__fixtures__/versioned-site/community_sidebars.json +0 -3
  153. package/src/__tests__/__fixtures__/versioned-site/community_versioned_docs/version-1.0.0/team.md +0 -1
  154. package/src/__tests__/__fixtures__/versioned-site/community_versioned_sidebars/version-1.0.0-sidebars.json +0 -3
  155. package/src/__tests__/__fixtures__/versioned-site/community_versions.json +0 -1
  156. package/src/__tests__/__fixtures__/versioned-site/docs/foo/bar.md +0 -4
  157. package/src/__tests__/__fixtures__/versioned-site/docs/hello.md +0 -1
  158. package/src/__tests__/__fixtures__/versioned-site/docs/slugs/absoluteSlug.md +0 -5
  159. package/src/__tests__/__fixtures__/versioned-site/docs/slugs/relativeSlug.md +0 -5
  160. package/src/__tests__/__fixtures__/versioned-site/docs/slugs/resolvedSlug.md +0 -5
  161. package/src/__tests__/__fixtures__/versioned-site/docs/slugs/tryToEscapeSlug.md +0 -5
  162. package/src/__tests__/__fixtures__/versioned-site/docusaurus.config.js +0 -18
  163. package/src/__tests__/__fixtures__/versioned-site/i18n/en/docusaurus-plugin-content-docs/version-1.0.0/hello.md +0 -1
  164. package/src/__tests__/__fixtures__/versioned-site/i18n/en/docusaurus-plugin-content-docs-community/current/team.md +0 -5
  165. package/src/__tests__/__fixtures__/versioned-site/i18n/fr/docusaurus-plugin-content-docs/version-1.0.0/hello.md +0 -1
  166. package/src/__tests__/__fixtures__/versioned-site/sidebars.json +0 -10
  167. package/src/__tests__/__fixtures__/versioned-site/versioned_docs/version-1.0.0/foo/bar.md +0 -4
  168. package/src/__tests__/__fixtures__/versioned-site/versioned_docs/version-1.0.0/foo/baz.md +0 -1
  169. package/src/__tests__/__fixtures__/versioned-site/versioned_docs/version-1.0.0/hello.md +0 -1
  170. package/src/__tests__/__fixtures__/versioned-site/versioned_docs/version-1.0.1/foo/bar.md +0 -1
  171. package/src/__tests__/__fixtures__/versioned-site/versioned_docs/version-1.0.1/hello.md +0 -1
  172. package/src/__tests__/__fixtures__/versioned-site/versioned_docs/version-withSlugs/rootAbsoluteSlug.md +0 -5
  173. package/src/__tests__/__fixtures__/versioned-site/versioned_docs/version-withSlugs/rootRelativeSlug.md +0 -5
  174. package/src/__tests__/__fixtures__/versioned-site/versioned_docs/version-withSlugs/rootResolvedSlug.md +0 -5
  175. package/src/__tests__/__fixtures__/versioned-site/versioned_docs/version-withSlugs/rootTryToEscapeSlug.md +0 -5
  176. package/src/__tests__/__fixtures__/versioned-site/versioned_docs/version-withSlugs/slugs/absoluteSlug.md +0 -5
  177. package/src/__tests__/__fixtures__/versioned-site/versioned_docs/version-withSlugs/slugs/relativeSlug.md +0 -5
  178. package/src/__tests__/__fixtures__/versioned-site/versioned_docs/version-withSlugs/slugs/resolvedSlug.md +0 -5
  179. package/src/__tests__/__fixtures__/versioned-site/versioned_docs/version-withSlugs/slugs/tryToEscapeSlug.md +0 -5
  180. package/src/__tests__/__fixtures__/versioned-site/versioned_sidebars/version-1.0.0-sidebars.json +0 -11
  181. package/src/__tests__/__fixtures__/versioned-site/versioned_sidebars/version-1.0.1-sidebars.json +0 -10
  182. package/src/__tests__/__fixtures__/versioned-site/versioned_sidebars/version-withSlugs-sidebars.json +0 -5
  183. package/src/__tests__/__fixtures__/versioned-site/versions.json +0 -5
  184. package/src/__tests__/__snapshots__/cli.test.ts.snap +0 -90
  185. package/src/__tests__/__snapshots__/index.test.ts.snap +0 -1916
  186. package/src/__tests__/__snapshots__/sidebars.test.ts.snap +0 -218
  187. package/src/__tests__/__snapshots__/translations.test.ts.snap +0 -487
  188. package/src/__tests__/cli.test.ts +0 -333
  189. package/src/__tests__/docFrontMatter.test.ts +0 -244
  190. package/src/__tests__/docs.test.ts +0 -878
  191. package/src/__tests__/index.test.ts +0 -1871
  192. package/src/__tests__/lastUpdate.test.ts +0 -69
  193. package/src/__tests__/numberPrefix.test.ts +0 -199
  194. package/src/__tests__/options.test.ts +0 -231
  195. package/src/__tests__/sidebarItemsGenerator.test.ts +0 -336
  196. package/src/__tests__/sidebars.test.ts +0 -639
  197. package/src/__tests__/slug.test.ts +0 -109
  198. package/src/__tests__/translations.test.ts +0 -159
  199. package/src/__tests__/versions.test.ts +0 -741
  200. package/src/client/__tests__/docsClientUtils.test.ts +0 -371
  201. package/src/markdown/__tests__/__fixtures__/docs/doc-localized.md +0 -1
  202. package/src/markdown/__tests__/__fixtures__/docs/doc1.md +0 -13
  203. package/src/markdown/__tests__/__fixtures__/docs/doc2.md +0 -12
  204. package/src/markdown/__tests__/__fixtures__/docs/doc4.md +0 -19
  205. package/src/markdown/__tests__/__fixtures__/docs/doc5.md +0 -6
  206. package/src/markdown/__tests__/__fixtures__/docs/subdir/doc3.md +0 -3
  207. package/src/markdown/__tests__/__fixtures__/versioned_docs/version-1.0.0/doc2.md +0 -7
  208. package/src/markdown/__tests__/__fixtures__/versioned_docs/version-1.0.0/subdir/doc1.md +0 -3
  209. package/src/markdown/__tests__/__snapshots__/linkify.test.ts.snap +0 -82
  210. package/src/markdown/__tests__/linkify.test.ts +0 -190
  211. package/src/sidebarItemsGenerator.ts +0 -307
  212. package/src/sidebars.ts +0 -522
  213. package/tsconfig.json +0 -9
@@ -0,0 +1,259 @@
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.toNavigationLink = exports.toDocNavigationLink = exports.createSidebarsUtils = exports.collectSidebarsNavigations = exports.collectSidebarsDocIds = exports.collectSidebarNavigation = exports.collectSidebarDocIds = exports.collectSidebarLinks = exports.collectSidebarCategories = exports.collectSidebarDocItems = exports.transformSidebarItems = exports.isCategoriesShorthand = void 0;
10
+ const tslib_1 = require("tslib");
11
+ const lodash_1 = tslib_1.__importDefault(require("lodash"));
12
+ const utils_1 = require("@docusaurus/utils");
13
+ function isCategoriesShorthand(item) {
14
+ return typeof item === 'object' && !item.type;
15
+ }
16
+ exports.isCategoriesShorthand = isCategoriesShorthand;
17
+ function transformSidebarItems(sidebar, updateFn) {
18
+ function transformRecursive(item) {
19
+ if (item.type === 'category') {
20
+ return updateFn({
21
+ ...item,
22
+ items: item.items.map(transformRecursive),
23
+ });
24
+ }
25
+ return updateFn(item);
26
+ }
27
+ return sidebar.map(transformRecursive);
28
+ }
29
+ exports.transformSidebarItems = transformSidebarItems;
30
+ /**
31
+ * Flatten sidebar items into a single flat array (containing categories/docs on
32
+ * the same level). Order matters (useful for next/prev nav), top categories
33
+ * appear before their child elements
34
+ */
35
+ function flattenSidebarItems(items) {
36
+ function flattenRecursive(item) {
37
+ return item.type === 'category'
38
+ ? [item, ...item.items.flatMap(flattenRecursive)]
39
+ : [item];
40
+ }
41
+ return items.flatMap(flattenRecursive);
42
+ }
43
+ function collectSidebarItemsOfType(type, sidebar) {
44
+ return flattenSidebarItems(sidebar).filter((item) => item.type === type);
45
+ }
46
+ function collectSidebarDocItems(sidebar) {
47
+ return collectSidebarItemsOfType('doc', sidebar);
48
+ }
49
+ exports.collectSidebarDocItems = collectSidebarDocItems;
50
+ function collectSidebarCategories(sidebar) {
51
+ return collectSidebarItemsOfType('category', sidebar);
52
+ }
53
+ exports.collectSidebarCategories = collectSidebarCategories;
54
+ function collectSidebarLinks(sidebar) {
55
+ return collectSidebarItemsOfType('link', sidebar);
56
+ }
57
+ exports.collectSidebarLinks = collectSidebarLinks;
58
+ // /!\ docId order matters for navigation!
59
+ function collectSidebarDocIds(sidebar) {
60
+ return flattenSidebarItems(sidebar).flatMap((item) => {
61
+ if (item.type === 'category') {
62
+ return item.link?.type === 'doc' ? [item.link.id] : [];
63
+ }
64
+ if (item.type === 'doc') {
65
+ return [item.id];
66
+ }
67
+ return [];
68
+ });
69
+ }
70
+ exports.collectSidebarDocIds = collectSidebarDocIds;
71
+ function collectSidebarNavigation(sidebar) {
72
+ return flattenSidebarItems(sidebar).flatMap((item) => {
73
+ if (item.type === 'category' && item.link) {
74
+ return [item];
75
+ }
76
+ if (item.type === 'doc') {
77
+ return [item];
78
+ }
79
+ return [];
80
+ });
81
+ }
82
+ exports.collectSidebarNavigation = collectSidebarNavigation;
83
+ function collectSidebarsDocIds(sidebars) {
84
+ return lodash_1.default.mapValues(sidebars, collectSidebarDocIds);
85
+ }
86
+ exports.collectSidebarsDocIds = collectSidebarsDocIds;
87
+ function collectSidebarsNavigations(sidebars) {
88
+ return lodash_1.default.mapValues(sidebars, collectSidebarNavigation);
89
+ }
90
+ exports.collectSidebarsNavigations = collectSidebarsNavigations;
91
+ function createSidebarsUtils(sidebars) {
92
+ const sidebarNameToDocIds = collectSidebarsDocIds(sidebars);
93
+ const sidebarNameToNavigationItems = collectSidebarsNavigations(sidebars);
94
+ // Reverse mapping
95
+ const docIdToSidebarName = Object.fromEntries(Object.entries(sidebarNameToDocIds).flatMap(([sidebarName, docIds]) => docIds.map((docId) => [docId, sidebarName])));
96
+ function getFirstDocIdOfFirstSidebar() {
97
+ return Object.values(sidebarNameToDocIds)[0]?.[0];
98
+ }
99
+ function getSidebarNameByDocId(docId) {
100
+ return docIdToSidebarName[docId];
101
+ }
102
+ function emptySidebarNavigation() {
103
+ return {
104
+ sidebarName: undefined,
105
+ previous: undefined,
106
+ next: undefined,
107
+ };
108
+ }
109
+ function getDocNavigation(unversionedId, versionedId, displayedSidebar) {
110
+ // TODO legacy id retro-compatibility!
111
+ let docId = unversionedId;
112
+ let sidebarName = displayedSidebar === undefined
113
+ ? getSidebarNameByDocId(docId)
114
+ : displayedSidebar;
115
+ if (sidebarName === undefined) {
116
+ docId = versionedId;
117
+ sidebarName = getSidebarNameByDocId(docId);
118
+ }
119
+ if (!sidebarName) {
120
+ return emptySidebarNavigation();
121
+ }
122
+ if (!sidebarNameToNavigationItems[sidebarName]) {
123
+ throw new Error(`Doc with ID ${docId} wants to display sidebar ${sidebarName} but a sidebar with this name doesn't exist`);
124
+ }
125
+ const navigationItems = sidebarNameToNavigationItems[sidebarName];
126
+ const currentItemIndex = navigationItems.findIndex((item) => {
127
+ if (item.type === 'doc') {
128
+ return item.id === docId;
129
+ }
130
+ if (item.type === 'category' && item.link.type === 'doc') {
131
+ return item.link.id === docId;
132
+ }
133
+ return false;
134
+ });
135
+ if (currentItemIndex === -1) {
136
+ return { sidebarName, next: undefined, previous: undefined };
137
+ }
138
+ const { previous, next } = (0, utils_1.getElementsAround)(navigationItems, currentItemIndex);
139
+ return { sidebarName, previous, next };
140
+ }
141
+ function getCategoryGeneratedIndexList() {
142
+ return Object.values(sidebarNameToNavigationItems)
143
+ .flat()
144
+ .flatMap((item) => {
145
+ if (item.type === 'category' && item.link.type === 'generated-index') {
146
+ return [item];
147
+ }
148
+ return [];
149
+ });
150
+ }
151
+ /**
152
+ * We identity the category generated index by its permalink (should be
153
+ * unique). More reliable than using object identity
154
+ */
155
+ function getCategoryGeneratedIndexNavigation(categoryGeneratedIndexPermalink) {
156
+ function isCurrentCategoryGeneratedIndexItem(item) {
157
+ return (item.type === 'category' &&
158
+ item.link?.type === 'generated-index' &&
159
+ item.link.permalink === categoryGeneratedIndexPermalink);
160
+ }
161
+ const sidebarName = Object.entries(sidebarNameToNavigationItems).find(([, navigationItems]) => navigationItems.find(isCurrentCategoryGeneratedIndexItem))?.[0];
162
+ if (!sidebarName) {
163
+ return emptySidebarNavigation();
164
+ }
165
+ const navigationItems = sidebarNameToNavigationItems[sidebarName];
166
+ const currentItemIndex = navigationItems.findIndex(isCurrentCategoryGeneratedIndexItem);
167
+ const { previous, next } = (0, utils_1.getElementsAround)(navigationItems, currentItemIndex);
168
+ return { sidebarName, previous, next };
169
+ }
170
+ function checkSidebarsDocIds(validDocIds, sidebarFilePath) {
171
+ const allSidebarDocIds = Object.values(sidebarNameToDocIds).flat();
172
+ const invalidSidebarDocIds = lodash_1.default.difference(allSidebarDocIds, validDocIds);
173
+ if (invalidSidebarDocIds.length > 0) {
174
+ throw new Error(`Invalid sidebar file at "${(0, utils_1.toMessageRelativeFilePath)(sidebarFilePath)}".
175
+ These sidebar document ids do not exist:
176
+ - ${invalidSidebarDocIds.sort().join('\n- ')}
177
+
178
+ Available document ids are:
179
+ - ${lodash_1.default.uniq(validDocIds).sort().join('\n- ')}`);
180
+ }
181
+ }
182
+ function getFirstLink(sidebar) {
183
+ for (const item of sidebar) {
184
+ if (item.type === 'doc') {
185
+ return {
186
+ type: 'doc',
187
+ id: item.id,
188
+ label: item.label ?? item.id,
189
+ };
190
+ }
191
+ else if (item.type === 'category') {
192
+ if (item.link?.type === 'doc') {
193
+ return {
194
+ type: 'doc',
195
+ id: item.link.id,
196
+ label: item.label,
197
+ };
198
+ }
199
+ else if (item.link?.type === 'generated-index') {
200
+ return {
201
+ type: 'generated-index',
202
+ slug: item.link.slug,
203
+ label: item.label,
204
+ };
205
+ }
206
+ const firstSubItem = getFirstLink(item.items);
207
+ if (firstSubItem) {
208
+ return firstSubItem;
209
+ }
210
+ }
211
+ }
212
+ return undefined;
213
+ }
214
+ return {
215
+ sidebars,
216
+ getFirstDocIdOfFirstSidebar,
217
+ getSidebarNameByDocId,
218
+ getDocNavigation,
219
+ getCategoryGeneratedIndexList,
220
+ getCategoryGeneratedIndexNavigation,
221
+ checkSidebarsDocIds,
222
+ getFirstLink: (id) => getFirstLink(sidebars[id]),
223
+ };
224
+ }
225
+ exports.createSidebarsUtils = createSidebarsUtils;
226
+ function toDocNavigationLink(doc) {
227
+ const { title, permalink, frontMatter: { pagination_label: paginationLabel, sidebar_label: sidebarLabel, }, } = doc;
228
+ return { title: paginationLabel ?? sidebarLabel ?? title, permalink };
229
+ }
230
+ exports.toDocNavigationLink = toDocNavigationLink;
231
+ function toNavigationLink(navigationItem, docsById) {
232
+ function getDocById(docId) {
233
+ const doc = docsById[docId];
234
+ if (!doc) {
235
+ throw new Error(`Can't create navigation link: no doc found with id=${docId}`);
236
+ }
237
+ return doc;
238
+ }
239
+ if (!navigationItem) {
240
+ return undefined;
241
+ }
242
+ if (navigationItem.type === 'doc') {
243
+ return toDocNavigationLink(getDocById(navigationItem.id));
244
+ }
245
+ else if (navigationItem.type === 'category') {
246
+ if (navigationItem.link.type === 'doc') {
247
+ return toDocNavigationLink(getDocById(navigationItem.link.id));
248
+ }
249
+ else if (navigationItem.link.type === 'generated-index') {
250
+ return {
251
+ title: navigationItem.label,
252
+ permalink: navigationItem.link.permalink,
253
+ };
254
+ }
255
+ throw new Error('unexpected category link type');
256
+ }
257
+ throw new Error('unexpected navigation item');
258
+ }
259
+ exports.toNavigationLink = toNavigationLink;
@@ -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
+ import type { NormalizedSidebars, CategoryMetadataFile } from './types';
8
+ export declare function validateSidebars(sidebars: Record<string, unknown>): asserts sidebars is NormalizedSidebars;
9
+ export declare function validateCategoryMetadataFile(unsafeContent: unknown): CategoryMetadataFile;
@@ -0,0 +1,137 @@
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.validateCategoryMetadataFile = exports.validateSidebars = void 0;
10
+ const utils_validation_1 = require("@docusaurus/utils-validation");
11
+ // NOTE: we don't add any default values during validation on purpose!
12
+ // Config types are exposed to users for typechecking and we use the same type
13
+ // in normalization
14
+ const sidebarItemBaseSchema = utils_validation_1.Joi.object({
15
+ className: utils_validation_1.Joi.string(),
16
+ customProps: utils_validation_1.Joi.object().unknown(),
17
+ });
18
+ const sidebarItemAutogeneratedSchema = sidebarItemBaseSchema.append({
19
+ type: 'autogenerated',
20
+ dirName: utils_validation_1.Joi.string()
21
+ .required()
22
+ .pattern(/^[^/](?:.*[^/])?$/)
23
+ .message('"dirName" must be a dir path relative to the docs folder root, and should not start or end with slash'),
24
+ });
25
+ const sidebarItemDocSchema = sidebarItemBaseSchema.append({
26
+ type: utils_validation_1.Joi.string().valid('doc', 'ref').required(),
27
+ id: utils_validation_1.Joi.string().required(),
28
+ label: utils_validation_1.Joi.string(),
29
+ });
30
+ const sidebarItemHtmlSchema = sidebarItemBaseSchema.append({
31
+ type: 'html',
32
+ value: utils_validation_1.Joi.string().required(),
33
+ defaultStyle: utils_validation_1.Joi.boolean(),
34
+ });
35
+ const sidebarItemLinkSchema = sidebarItemBaseSchema.append({
36
+ type: 'link',
37
+ href: utils_validation_1.URISchema.required(),
38
+ label: utils_validation_1.Joi.string()
39
+ .required()
40
+ .messages({ 'any.unknown': '"label" must be a string' }),
41
+ });
42
+ const sidebarItemCategoryLinkSchema = utils_validation_1.Joi.object()
43
+ .allow(null)
44
+ .when('.type', {
45
+ switch: [
46
+ {
47
+ is: 'doc',
48
+ then: utils_validation_1.Joi.object({
49
+ type: 'doc',
50
+ id: utils_validation_1.Joi.string().required(),
51
+ }),
52
+ },
53
+ {
54
+ is: 'generated-index',
55
+ then: utils_validation_1.Joi.object({
56
+ type: 'generated-index',
57
+ slug: utils_validation_1.Joi.string().optional(),
58
+ // This one is not in the user config, only in the normalized version
59
+ // permalink: Joi.string().optional(),
60
+ title: utils_validation_1.Joi.string().optional(),
61
+ description: utils_validation_1.Joi.string().optional(),
62
+ image: utils_validation_1.Joi.string().optional(),
63
+ keywords: [utils_validation_1.Joi.string(), utils_validation_1.Joi.array().items(utils_validation_1.Joi.string())],
64
+ }),
65
+ },
66
+ {
67
+ is: utils_validation_1.Joi.required(),
68
+ then: utils_validation_1.Joi.forbidden().messages({
69
+ 'any.unknown': 'Unknown sidebar category link type "{.type}".',
70
+ }),
71
+ },
72
+ ],
73
+ });
74
+ const sidebarItemCategorySchema = sidebarItemBaseSchema.append({
75
+ type: 'category',
76
+ label: utils_validation_1.Joi.string()
77
+ .required()
78
+ .messages({ 'any.unknown': '"label" must be a string' }),
79
+ items: utils_validation_1.Joi.array()
80
+ .required()
81
+ .messages({ 'any.unknown': '"items" must be an array' }),
82
+ // TODO: Joi doesn't allow mutual recursion. See https://github.com/sideway/joi/issues/2611
83
+ // .items(Joi.link('#sidebarItemSchema')),
84
+ link: sidebarItemCategoryLinkSchema,
85
+ collapsed: utils_validation_1.Joi.boolean().messages({
86
+ 'any.unknown': '"collapsed" must be a boolean',
87
+ }),
88
+ collapsible: utils_validation_1.Joi.boolean().messages({
89
+ 'any.unknown': '"collapsible" must be a boolean',
90
+ }),
91
+ });
92
+ const sidebarItemSchema = utils_validation_1.Joi.object().when('.type', {
93
+ switch: [
94
+ { is: 'link', then: sidebarItemLinkSchema },
95
+ {
96
+ is: utils_validation_1.Joi.string().valid('doc', 'ref').required(),
97
+ then: sidebarItemDocSchema,
98
+ },
99
+ { is: 'html', then: sidebarItemHtmlSchema },
100
+ { is: 'autogenerated', then: sidebarItemAutogeneratedSchema },
101
+ { is: 'category', then: sidebarItemCategorySchema },
102
+ {
103
+ is: utils_validation_1.Joi.any().required(),
104
+ then: utils_validation_1.Joi.forbidden().messages({
105
+ 'any.unknown': 'Unknown sidebar item type "{.type}".',
106
+ }),
107
+ },
108
+ ],
109
+ });
110
+ // .id('sidebarItemSchema');
111
+ function validateSidebarItem(item) {
112
+ // TODO: remove once with proper Joi support
113
+ // Because we can't use Joi to validate nested items (see above), we do it
114
+ // manually
115
+ utils_validation_1.Joi.assert(item, sidebarItemSchema);
116
+ if (item.type === 'category') {
117
+ item.items.forEach(validateSidebarItem);
118
+ }
119
+ }
120
+ function validateSidebars(sidebars) {
121
+ Object.values(sidebars).forEach((sidebar) => {
122
+ sidebar.forEach(validateSidebarItem);
123
+ });
124
+ }
125
+ exports.validateSidebars = validateSidebars;
126
+ const categoryMetadataFileSchema = utils_validation_1.Joi.object({
127
+ label: utils_validation_1.Joi.string(),
128
+ position: utils_validation_1.Joi.number(),
129
+ collapsed: utils_validation_1.Joi.boolean(),
130
+ collapsible: utils_validation_1.Joi.boolean(),
131
+ className: utils_validation_1.Joi.string(),
132
+ link: sidebarItemCategoryLinkSchema,
133
+ });
134
+ function validateCategoryMetadataFile(unsafeContent) {
135
+ return utils_validation_1.Joi.attempt(unsafeContent, categoryMetadataFileSchema);
136
+ }
137
+ exports.validateCategoryMetadataFile = validateCategoryMetadataFile;
package/lib/slug.d.ts CHANGED
@@ -4,11 +4,13 @@
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 { NumberPrefixParser } from './types';
8
- export default function getSlug({ baseID, frontmatterSlug, dirName, stripDirNumberPrefixes, numberPrefixParser, }: {
7
+ import type { DocMetadataBase } from './types';
8
+ import type { NumberPrefixParser } from '@docusaurus/plugin-content-docs';
9
+ export default function getSlug({ baseID, frontMatterSlug, source, sourceDirName, stripDirNumberPrefixes, numberPrefixParser, }: {
9
10
  baseID: string;
10
- frontmatterSlug?: string;
11
- dirName: string;
11
+ frontMatterSlug?: string;
12
+ source: DocMetadataBase['source'];
13
+ sourceDirName: DocMetadataBase['sourceDirName'];
12
14
  stripDirNumberPrefixes?: boolean;
13
15
  numberPrefixParser?: NumberPrefixParser;
14
16
  }): string;
package/lib/slug.js CHANGED
@@ -8,33 +8,44 @@
8
8
  Object.defineProperty(exports, "__esModule", { value: true });
9
9
  const utils_1 = require("@docusaurus/utils");
10
10
  const numberPrefix_1 = require("./numberPrefix");
11
- function getSlug({ baseID, frontmatterSlug, dirName, stripDirNumberPrefixes = true, numberPrefixParser = numberPrefix_1.DefaultNumberPrefixParser, }) {
12
- const baseSlug = frontmatterSlug || baseID;
13
- let slug;
14
- if (baseSlug.startsWith('/')) {
15
- slug = baseSlug;
16
- }
17
- else {
11
+ const docs_1 = require("./docs");
12
+ function getSlug({ baseID, frontMatterSlug, source, sourceDirName, stripDirNumberPrefixes = true, numberPrefixParser = numberPrefix_1.DefaultNumberPrefixParser, }) {
13
+ function getDirNameSlug() {
18
14
  const dirNameStripped = stripDirNumberPrefixes
19
- ? numberPrefix_1.stripPathNumberPrefixes(dirName, numberPrefixParser)
20
- : dirName;
21
- const resolveDirname = dirName === '.'
15
+ ? (0, numberPrefix_1.stripPathNumberPrefixes)(sourceDirName, numberPrefixParser)
16
+ : sourceDirName;
17
+ const resolveDirname = sourceDirName === '.'
22
18
  ? '/'
23
- : utils_1.addLeadingSlash(utils_1.addTrailingSlash(dirNameStripped));
24
- slug = utils_1.resolvePathname(baseSlug, resolveDirname);
19
+ : (0, utils_1.addLeadingSlash)((0, utils_1.addTrailingSlash)(dirNameStripped));
20
+ return resolveDirname;
21
+ }
22
+ function computeSlug() {
23
+ if (frontMatterSlug?.startsWith('/')) {
24
+ return frontMatterSlug;
25
+ }
26
+ const dirNameSlug = getDirNameSlug();
27
+ if (!frontMatterSlug &&
28
+ (0, docs_1.isCategoryIndex)((0, docs_1.toCategoryIndexMatcherParam)({ source, sourceDirName }))) {
29
+ return dirNameSlug;
30
+ }
31
+ const baseSlug = frontMatterSlug || baseID;
32
+ return (0, utils_1.resolvePathname)(baseSlug, getDirNameSlug());
25
33
  }
26
- if (!utils_1.isValidPathname(slug)) {
27
- throw new Error(`We couldn't compute a valid slug for document with id "${baseID}" in "${dirName}" directory.
34
+ function ensureValidSlug(slug) {
35
+ if (!(0, utils_1.isValidPathname)(slug)) {
36
+ throw new Error(`We couldn't compute a valid slug for document with id "${baseID}" in "${sourceDirName}" directory.
28
37
  The slug we computed looks invalid: ${slug}.
29
- Maybe your slug frontmatter is incorrect or you use weird chars in the file path?
30
- By using the slug frontmatter, you should be able to fix this error, by using the slug of your choice:
38
+ Maybe your slug front matter is incorrect or you use weird chars in the file path?
39
+ By using the slug front matter, you should be able to fix this error, by using the slug of your choice:
31
40
 
32
41
  Example =>
33
42
  ---
34
43
  slug: /my/customDocPath
35
44
  ---
36
45
  `);
46
+ }
47
+ return slug;
37
48
  }
38
- return slug;
49
+ return ensureValidSlug(computeSlug());
39
50
  }
40
51
  exports.default = getSlug;
@@ -4,11 +4,5 @@
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
-
8
- module.exports = {
9
- title: 'My Site',
10
- tagline: 'The tagline of my site',
11
- url: 'https://your-docusaurus-test-site.com',
12
- baseUrl: '/',
13
- favicon: 'img/favicon.ico',
14
- };
7
+ import type { VersionTags, DocMetadata } from './types';
8
+ export declare function getVersionTags(docs: DocMetadata[]): VersionTags;
package/lib/tags.js ADDED
@@ -0,0 +1,21 @@
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.getVersionTags = void 0;
10
+ const tslib_1 = require("tslib");
11
+ const utils_1 = require("@docusaurus/utils");
12
+ const lodash_1 = tslib_1.__importDefault(require("lodash"));
13
+ function getVersionTags(docs) {
14
+ const groups = (0, utils_1.groupTaggedItems)(docs, (doc) => doc.tags);
15
+ return lodash_1.default.mapValues(groups, (group) => ({
16
+ name: group.tag.label,
17
+ docIds: group.items.map((item) => item.id),
18
+ permalink: group.tag.permalink,
19
+ }));
20
+ }
21
+ exports.getVersionTags = getVersionTags;
@@ -4,7 +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 { LoadedContent } from './types';
8
- import { TranslationFile, TranslationFiles } from '@docusaurus/types';
7
+ import type { LoadedContent } from './types';
8
+ import type { TranslationFile, TranslationFiles } from '@docusaurus/types';
9
9
  export declare function getLoadedContentTranslationFiles(loadedContent: LoadedContent): TranslationFiles;
10
10
  export declare function translateLoadedContent(loadedContent: LoadedContent, translationFiles: TranslationFile[]): LoadedContent;