@docusaurus/plugin-content-docs 2.0.0-beta.1ec2c95e3 → 2.0.0-beta.21

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 (229) 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 +58 -72
  5. package/lib/client/docsClientUtils.d.ts +9 -28
  6. package/lib/client/docsClientUtils.js +34 -43
  7. package/lib/client/index.d.ts +22 -0
  8. package/lib/client/index.js +59 -0
  9. package/lib/constants.d.ts +4 -0
  10. package/lib/constants.js +4 -1
  11. package/lib/docs.d.ts +32 -3
  12. package/lib/docs.js +164 -63
  13. package/{src/__tests__/__fixtures__/site-with-autogenerated-sidebar/docusaurus.config.js → lib/frontMatter.d.ts} +4 -8
  14. package/lib/{docFrontMatter.js → frontMatter.js} +12 -3
  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 +123 -149
  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 +6 -3
  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 +54 -13
  29. package/lib/props.d.ts +7 -2
  30. package/lib/props.js +70 -14
  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 +22 -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 +55 -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 +178 -0
  46. package/lib/{docFrontMatter.d.ts → sidebars/types.js} +2 -2
  47. package/lib/sidebars/utils.d.ts +54 -0
  48. package/lib/sidebars/utils.js +255 -0
  49. package/lib/sidebars/validation.d.ts +11 -0
  50. package/lib/sidebars/validation.js +142 -0
  51. package/lib/slug.d.ts +5 -4
  52. package/lib/slug.js +28 -18
  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 +83 -93
  57. package/lib/types.d.ts +13 -184
  58. package/lib/versions/files.d.ts +51 -0
  59. package/lib/versions/files.js +143 -0
  60. package/lib/versions/index.d.ts +36 -0
  61. package/lib/versions/index.js +155 -0
  62. package/lib/versions/validation.d.ts +17 -0
  63. package/lib/versions/validation.js +71 -0
  64. package/package.json +34 -29
  65. package/src/categoryGeneratedIndex.ts +60 -0
  66. package/src/cli.ts +85 -114
  67. package/src/client/docsClientUtils.ts +44 -71
  68. package/src/client/index.ts +106 -0
  69. package/src/constants.ts +4 -2
  70. package/{types.d.ts → src/deps.d.ts} +1 -1
  71. package/src/docs.ts +228 -65
  72. package/src/{docFrontMatter.ts → frontMatter.ts} +20 -10
  73. package/src/globalData.ts +57 -7
  74. package/src/index.ts +179 -216
  75. package/src/lastUpdate.ts +26 -37
  76. package/src/markdown/index.ts +10 -16
  77. package/src/markdown/linkify.ts +7 -4
  78. package/src/numberPrefix.ts +19 -26
  79. package/src/options.ts +59 -18
  80. package/src/plugin-content-docs.d.ts +642 -89
  81. package/src/props.ts +103 -21
  82. package/src/routes.ts +159 -0
  83. package/src/server-export.ts +22 -0
  84. package/src/sidebars/README.md +10 -0
  85. package/src/sidebars/generator.ts +292 -0
  86. package/src/sidebars/index.ts +118 -0
  87. package/src/sidebars/normalization.ts +85 -0
  88. package/src/sidebars/postProcessor.ts +112 -0
  89. package/src/sidebars/processor.ts +123 -0
  90. package/src/sidebars/types.ts +275 -0
  91. package/src/sidebars/utils.ts +390 -0
  92. package/src/sidebars/validation.ts +178 -0
  93. package/src/slug.ts +41 -22
  94. package/src/tags.ts +20 -0
  95. package/src/translations.ts +129 -123
  96. package/src/types.ts +18 -249
  97. package/src/versions/files.ts +220 -0
  98. package/src/versions/index.ts +247 -0
  99. package/src/versions/validation.ts +115 -0
  100. package/lib/.tsbuildinfo +0 -1
  101. package/lib/sidebarItemsGenerator.js +0 -211
  102. package/lib/sidebars.d.ts +0 -43
  103. package/lib/sidebars.js +0 -320
  104. package/lib/theme/hooks/useDocs.d.ts +0 -20
  105. package/lib/theme/hooks/useDocs.js +0 -75
  106. package/lib/versions.d.ts +0 -16
  107. package/lib/versions.js +0 -319
  108. package/src/__tests__/__fixtures__/bad-id-site/docs/invalid-id.md +0 -5
  109. package/src/__tests__/__fixtures__/bad-slug-on-doc-home-site/docs/docWithSlug.md +0 -5
  110. package/src/__tests__/__fixtures__/empty-site/docusaurus.config.js +0 -16
  111. package/src/__tests__/__fixtures__/empty-site/sidebars.json +0 -1
  112. package/src/__tests__/__fixtures__/sidebars/sidebars-category-shorthand.js +0 -34
  113. package/src/__tests__/__fixtures__/sidebars/sidebars-category-wrong-items.json +0 -11
  114. package/src/__tests__/__fixtures__/sidebars/sidebars-category-wrong-label.json +0 -11
  115. package/src/__tests__/__fixtures__/sidebars/sidebars-category.js +0 -44
  116. package/src/__tests__/__fixtures__/sidebars/sidebars-collapsed-first-level.json +0 -20
  117. package/src/__tests__/__fixtures__/sidebars/sidebars-collapsed.json +0 -21
  118. package/src/__tests__/__fixtures__/sidebars/sidebars-doc-id-not-string.json +0 -10
  119. package/src/__tests__/__fixtures__/sidebars/sidebars-link-wrong-href.json +0 -11
  120. package/src/__tests__/__fixtures__/sidebars/sidebars-link-wrong-label.json +0 -11
  121. package/src/__tests__/__fixtures__/sidebars/sidebars-link.json +0 -11
  122. package/src/__tests__/__fixtures__/sidebars/sidebars-unknown-type.json +0 -14
  123. package/src/__tests__/__fixtures__/sidebars/sidebars-wrong-field.json +0 -20
  124. package/src/__tests__/__fixtures__/sidebars/sidebars.json +0 -20
  125. package/src/__tests__/__fixtures__/simple-site/docs/foo/bar.md +0 -69
  126. package/src/__tests__/__fixtures__/simple-site/docs/foo/baz.md +0 -70
  127. package/src/__tests__/__fixtures__/simple-site/docs/headingAsTitle.md +0 -1
  128. package/src/__tests__/__fixtures__/simple-site/docs/hello.md +0 -53
  129. package/src/__tests__/__fixtures__/simple-site/docs/ipsum.md +0 -5
  130. package/src/__tests__/__fixtures__/simple-site/docs/lorem.md +0 -6
  131. package/src/__tests__/__fixtures__/simple-site/docs/rootAbsoluteSlug.md +0 -5
  132. package/src/__tests__/__fixtures__/simple-site/docs/rootRelativeSlug.md +0 -5
  133. package/src/__tests__/__fixtures__/simple-site/docs/rootResolvedSlug.md +0 -5
  134. package/src/__tests__/__fixtures__/simple-site/docs/rootTryToEscapeSlug.md +0 -5
  135. package/src/__tests__/__fixtures__/simple-site/docs/slugs/absoluteSlug.md +0 -5
  136. package/src/__tests__/__fixtures__/simple-site/docs/slugs/relativeSlug.md +0 -5
  137. package/src/__tests__/__fixtures__/simple-site/docs/slugs/resolvedSlug.md +0 -5
  138. package/src/__tests__/__fixtures__/simple-site/docs/slugs/tryToEscapeSlug.md +0 -5
  139. package/src/__tests__/__fixtures__/simple-site/docusaurus.config.js +0 -14
  140. package/src/__tests__/__fixtures__/simple-site/sidebars.json +0 -23
  141. package/src/__tests__/__fixtures__/simple-site/wrong-sidebars.json +0 -7
  142. package/src/__tests__/__fixtures__/site-with-autogenerated-sidebar/docs/0-getting-started.md +0 -3
  143. package/src/__tests__/__fixtures__/site-with-autogenerated-sidebar/docs/1-installation.md +0 -3
  144. package/src/__tests__/__fixtures__/site-with-autogenerated-sidebar/docs/3-API/00_api-overview.md +0 -3
  145. package/src/__tests__/__fixtures__/site-with-autogenerated-sidebar/docs/3-API/01_Core APIs/0 --- Client API.md +0 -1
  146. package/src/__tests__/__fixtures__/site-with-autogenerated-sidebar/docs/3-API/01_Core APIs/1 --- Server API.md +0 -1
  147. package/src/__tests__/__fixtures__/site-with-autogenerated-sidebar/docs/3-API/02_Extension APIs/0. Plugin API.md +0 -1
  148. package/src/__tests__/__fixtures__/site-with-autogenerated-sidebar/docs/3-API/02_Extension APIs/1. Theme API.md +0 -1
  149. package/src/__tests__/__fixtures__/site-with-autogenerated-sidebar/docs/3-API/02_Extension APIs/_category_.yml +0 -1
  150. package/src/__tests__/__fixtures__/site-with-autogenerated-sidebar/docs/3-API/03_api-end.md +0 -3
  151. package/src/__tests__/__fixtures__/site-with-autogenerated-sidebar/docs/3-API/_category_.json +0 -3
  152. package/src/__tests__/__fixtures__/site-with-autogenerated-sidebar/docs/Guides/0-guide2.5.md +0 -8
  153. package/src/__tests__/__fixtures__/site-with-autogenerated-sidebar/docs/Guides/02-guide2.md +0 -7
  154. package/src/__tests__/__fixtures__/site-with-autogenerated-sidebar/docs/Guides/_category_.json +0 -3
  155. package/src/__tests__/__fixtures__/site-with-autogenerated-sidebar/docs/Guides/a-guide4.md +0 -7
  156. package/src/__tests__/__fixtures__/site-with-autogenerated-sidebar/docs/Guides/b-guide5.md +0 -7
  157. package/src/__tests__/__fixtures__/site-with-autogenerated-sidebar/docs/Guides/guide3.md +0 -8
  158. package/src/__tests__/__fixtures__/site-with-autogenerated-sidebar/docs/Guides/z-guide1.md +0 -8
  159. package/src/__tests__/__fixtures__/site-with-autogenerated-sidebar/partialAutogeneratedSidebars.js +0 -23
  160. package/src/__tests__/__fixtures__/site-with-autogenerated-sidebar/partialAutogeneratedSidebars2.js +0 -16
  161. package/src/__tests__/__fixtures__/site-with-doc-label/docs/hello-1.md +0 -7
  162. package/src/__tests__/__fixtures__/site-with-doc-label/docs/hello-2.md +0 -8
  163. package/src/__tests__/__fixtures__/site-with-doc-label/docusaurus.config.js +0 -14
  164. package/src/__tests__/__fixtures__/site-with-doc-label/sidebars.json +0 -14
  165. package/src/__tests__/__fixtures__/versioned-site/community/team.md +0 -1
  166. package/src/__tests__/__fixtures__/versioned-site/community_sidebars.json +0 -3
  167. package/src/__tests__/__fixtures__/versioned-site/community_versioned_docs/version-1.0.0/team.md +0 -1
  168. package/src/__tests__/__fixtures__/versioned-site/community_versioned_sidebars/version-1.0.0-sidebars.json +0 -3
  169. package/src/__tests__/__fixtures__/versioned-site/community_versions.json +0 -1
  170. package/src/__tests__/__fixtures__/versioned-site/docs/foo/bar.md +0 -4
  171. package/src/__tests__/__fixtures__/versioned-site/docs/hello.md +0 -1
  172. package/src/__tests__/__fixtures__/versioned-site/docs/slugs/absoluteSlug.md +0 -5
  173. package/src/__tests__/__fixtures__/versioned-site/docs/slugs/relativeSlug.md +0 -5
  174. package/src/__tests__/__fixtures__/versioned-site/docs/slugs/resolvedSlug.md +0 -5
  175. package/src/__tests__/__fixtures__/versioned-site/docs/slugs/tryToEscapeSlug.md +0 -5
  176. package/src/__tests__/__fixtures__/versioned-site/docusaurus.config.js +0 -18
  177. package/src/__tests__/__fixtures__/versioned-site/i18n/en/docusaurus-plugin-content-docs/version-1.0.0/hello.md +0 -1
  178. package/src/__tests__/__fixtures__/versioned-site/i18n/en/docusaurus-plugin-content-docs-community/current/team.md +0 -5
  179. package/src/__tests__/__fixtures__/versioned-site/i18n/fr/docusaurus-plugin-content-docs/version-1.0.0/hello.md +0 -1
  180. package/src/__tests__/__fixtures__/versioned-site/sidebars.json +0 -10
  181. package/src/__tests__/__fixtures__/versioned-site/versioned_docs/version-1.0.0/foo/bar.md +0 -4
  182. package/src/__tests__/__fixtures__/versioned-site/versioned_docs/version-1.0.0/foo/baz.md +0 -1
  183. package/src/__tests__/__fixtures__/versioned-site/versioned_docs/version-1.0.0/hello.md +0 -1
  184. package/src/__tests__/__fixtures__/versioned-site/versioned_docs/version-1.0.1/foo/bar.md +0 -1
  185. package/src/__tests__/__fixtures__/versioned-site/versioned_docs/version-1.0.1/hello.md +0 -1
  186. package/src/__tests__/__fixtures__/versioned-site/versioned_docs/version-withSlugs/rootAbsoluteSlug.md +0 -5
  187. package/src/__tests__/__fixtures__/versioned-site/versioned_docs/version-withSlugs/rootRelativeSlug.md +0 -5
  188. package/src/__tests__/__fixtures__/versioned-site/versioned_docs/version-withSlugs/rootResolvedSlug.md +0 -5
  189. package/src/__tests__/__fixtures__/versioned-site/versioned_docs/version-withSlugs/rootTryToEscapeSlug.md +0 -5
  190. package/src/__tests__/__fixtures__/versioned-site/versioned_docs/version-withSlugs/slugs/absoluteSlug.md +0 -5
  191. package/src/__tests__/__fixtures__/versioned-site/versioned_docs/version-withSlugs/slugs/relativeSlug.md +0 -5
  192. package/src/__tests__/__fixtures__/versioned-site/versioned_docs/version-withSlugs/slugs/resolvedSlug.md +0 -5
  193. package/src/__tests__/__fixtures__/versioned-site/versioned_docs/version-withSlugs/slugs/tryToEscapeSlug.md +0 -5
  194. package/src/__tests__/__fixtures__/versioned-site/versioned_sidebars/version-1.0.0-sidebars.json +0 -11
  195. package/src/__tests__/__fixtures__/versioned-site/versioned_sidebars/version-1.0.1-sidebars.json +0 -10
  196. package/src/__tests__/__fixtures__/versioned-site/versioned_sidebars/version-withSlugs-sidebars.json +0 -5
  197. package/src/__tests__/__fixtures__/versioned-site/versions.json +0 -5
  198. package/src/__tests__/__snapshots__/cli.test.ts.snap +0 -90
  199. package/src/__tests__/__snapshots__/index.test.ts.snap +0 -1916
  200. package/src/__tests__/__snapshots__/sidebars.test.ts.snap +0 -218
  201. package/src/__tests__/__snapshots__/translations.test.ts.snap +0 -487
  202. package/src/__tests__/cli.test.ts +0 -333
  203. package/src/__tests__/docFrontMatter.test.ts +0 -244
  204. package/src/__tests__/docs.test.ts +0 -878
  205. package/src/__tests__/index.test.ts +0 -1871
  206. package/src/__tests__/lastUpdate.test.ts +0 -69
  207. package/src/__tests__/numberPrefix.test.ts +0 -199
  208. package/src/__tests__/options.test.ts +0 -231
  209. package/src/__tests__/sidebarItemsGenerator.test.ts +0 -336
  210. package/src/__tests__/sidebars.test.ts +0 -639
  211. package/src/__tests__/slug.test.ts +0 -109
  212. package/src/__tests__/translations.test.ts +0 -159
  213. package/src/__tests__/versions.test.ts +0 -741
  214. package/src/client/__tests__/docsClientUtils.test.ts +0 -371
  215. package/src/markdown/__tests__/__fixtures__/docs/doc-localized.md +0 -1
  216. package/src/markdown/__tests__/__fixtures__/docs/doc1.md +0 -13
  217. package/src/markdown/__tests__/__fixtures__/docs/doc2.md +0 -12
  218. package/src/markdown/__tests__/__fixtures__/docs/doc4.md +0 -19
  219. package/src/markdown/__tests__/__fixtures__/docs/doc5.md +0 -6
  220. package/src/markdown/__tests__/__fixtures__/docs/subdir/doc3.md +0 -3
  221. package/src/markdown/__tests__/__fixtures__/versioned_docs/version-1.0.0/doc2.md +0 -7
  222. package/src/markdown/__tests__/__fixtures__/versioned_docs/version-1.0.0/subdir/doc1.md +0 -3
  223. package/src/markdown/__tests__/__snapshots__/linkify.test.ts.snap +0 -82
  224. package/src/markdown/__tests__/linkify.test.ts +0 -190
  225. package/src/sidebarItemsGenerator.ts +0 -307
  226. package/src/sidebars.ts +0 -522
  227. package/src/theme/hooks/useDocs.ts +0 -103
  228. package/src/versions.ts +0 -572
  229. package/tsconfig.json +0 -9
package/src/sidebars.ts DELETED
@@ -1,522 +0,0 @@
1
- /**
2
- * Copyright (c) Facebook, Inc. and its affiliates.
3
- *
4
- * This source code is licensed under the MIT license found in the
5
- * LICENSE file in the root directory of this source tree.
6
- */
7
-
8
- import fs from 'fs-extra';
9
- import importFresh from 'import-fresh';
10
- import {
11
- Sidebars,
12
- SidebarItem,
13
- SidebarItemBase,
14
- SidebarItemLink,
15
- SidebarItemDoc,
16
- Sidebar,
17
- SidebarItemCategory,
18
- SidebarItemType,
19
- UnprocessedSidebarItem,
20
- UnprocessedSidebars,
21
- UnprocessedSidebar,
22
- DocMetadataBase,
23
- VersionMetadata,
24
- SidebarItemsGeneratorDoc,
25
- SidebarItemsGeneratorVersion,
26
- NumberPrefixParser,
27
- SidebarItemsGeneratorOption,
28
- PluginOptions,
29
- } from './types';
30
- import {mapValues, flatten, flatMap, difference, pick, memoize} from 'lodash';
31
- import {getElementsAround, toMessageRelativeFilePath} from '@docusaurus/utils';
32
- import combinePromises from 'combine-promises';
33
- import {DefaultSidebarItemsGenerator} from './sidebarItemsGenerator';
34
- import path from 'path';
35
-
36
- type SidebarItemCategoryJSON = SidebarItemBase & {
37
- type: 'category';
38
- label: string;
39
- items: SidebarItemJSON[];
40
- collapsed?: boolean;
41
- };
42
-
43
- type SidebarItemAutogeneratedJSON = SidebarItemBase & {
44
- type: 'autogenerated';
45
- dirName: string;
46
- };
47
-
48
- type SidebarItemJSON =
49
- | string
50
- | SidebarCategoryShorthandJSON
51
- | SidebarItemDoc
52
- | SidebarItemLink
53
- | SidebarItemCategoryJSON
54
- | SidebarItemAutogeneratedJSON
55
- | {
56
- type: string;
57
- [key: string]: unknown;
58
- };
59
-
60
- type SidebarCategoryShorthandJSON = {
61
- [sidebarCategory: string]: SidebarItemJSON[];
62
- };
63
-
64
- type SidebarJSON = SidebarCategoryShorthandJSON | SidebarItemJSON[];
65
-
66
- // Sidebar given by user that is not normalized yet. e.g: sidebars.json
67
- type SidebarsJSON = {
68
- [sidebarId: string]: SidebarJSON;
69
- };
70
-
71
- function isCategoryShorthand(
72
- item: SidebarItemJSON,
73
- ): item is SidebarCategoryShorthandJSON {
74
- return typeof item !== 'string' && !item.type;
75
- }
76
-
77
- // categories are collapsed by default, unless user set collapsed = false
78
- export const DefaultCategoryCollapsedValue = true;
79
-
80
- /**
81
- * Convert {category1: [item1,item2]} shorthand syntax to long-form syntax
82
- */
83
- function normalizeCategoryShorthand(
84
- sidebar: SidebarCategoryShorthandJSON,
85
- ): SidebarItemCategoryJSON[] {
86
- return Object.entries(sidebar).map(([label, items]) => ({
87
- type: 'category',
88
- collapsed: DefaultCategoryCollapsedValue,
89
- label,
90
- items,
91
- }));
92
- }
93
-
94
- /**
95
- * Check that item contains only allowed keys.
96
- */
97
- function assertItem<K extends string>(
98
- item: Record<string, unknown>,
99
- keys: K[],
100
- ): asserts item is Record<K, unknown> {
101
- const unknownKeys = Object.keys(item).filter(
102
- // @ts-expect-error: key is always string
103
- (key) => !keys.includes(key as string) && key !== 'type',
104
- );
105
-
106
- if (unknownKeys.length) {
107
- throw new Error(
108
- `Unknown sidebar item keys: ${unknownKeys}. Item: ${JSON.stringify(
109
- item,
110
- )}`,
111
- );
112
- }
113
- }
114
-
115
- function assertIsCategory(
116
- item: Record<string, unknown>,
117
- ): asserts item is SidebarItemCategoryJSON {
118
- assertItem(item, ['items', 'label', 'collapsed', 'customProps']);
119
- if (typeof item.label !== 'string') {
120
- throw new Error(
121
- `Error loading ${JSON.stringify(item)}: "label" must be a string.`,
122
- );
123
- }
124
- if (!Array.isArray(item.items)) {
125
- throw new Error(
126
- `Error loading ${JSON.stringify(item)}: "items" must be an array.`,
127
- );
128
- }
129
- // "collapsed" is an optional property
130
- if (
131
- typeof item.collapsed !== 'undefined' &&
132
- typeof item.collapsed !== 'boolean'
133
- ) {
134
- throw new Error(
135
- `Error loading ${JSON.stringify(item)}: "collapsed" must be a boolean.`,
136
- );
137
- }
138
- }
139
-
140
- function assertIsAutogenerated(
141
- item: Record<string, unknown>,
142
- ): asserts item is SidebarItemAutogeneratedJSON {
143
- assertItem(item, ['dirName', 'customProps']);
144
- if (typeof item.dirName !== 'string') {
145
- throw new Error(
146
- `Error loading ${JSON.stringify(item)}: "dirName" must be a string.`,
147
- );
148
- }
149
- if (item.dirName.startsWith('/') || item.dirName.endsWith('/')) {
150
- throw new Error(
151
- `Error loading ${JSON.stringify(
152
- item,
153
- )}: "dirName" must be a dir path relative to the docs folder root, and should not start or end with slash`,
154
- );
155
- }
156
- }
157
-
158
- function assertIsDoc(
159
- item: Record<string, unknown>,
160
- ): asserts item is SidebarItemDoc {
161
- assertItem(item, ['id', 'label', 'customProps']);
162
- if (typeof item.id !== 'string') {
163
- throw new Error(
164
- `Error loading ${JSON.stringify(item)}: "id" must be a string.`,
165
- );
166
- }
167
-
168
- if (item.label && typeof item.label !== 'string') {
169
- throw new Error(
170
- `Error loading ${JSON.stringify(item)}: "label" must be a string.`,
171
- );
172
- }
173
- }
174
-
175
- function assertIsLink(
176
- item: Record<string, unknown>,
177
- ): asserts item is SidebarItemLink {
178
- assertItem(item, ['href', 'label', 'customProps']);
179
- if (typeof item.href !== 'string') {
180
- throw new Error(
181
- `Error loading ${JSON.stringify(item)}: "href" must be a string.`,
182
- );
183
- }
184
- if (typeof item.label !== 'string') {
185
- throw new Error(
186
- `Error loading ${JSON.stringify(item)}: "label" must be a string.`,
187
- );
188
- }
189
- }
190
-
191
- /**
192
- * Normalizes recursively item and all its children. Ensures that at the end
193
- * each item will be an object with the corresponding type.
194
- */
195
- function normalizeItem(item: SidebarItemJSON): UnprocessedSidebarItem[] {
196
- if (typeof item === 'string') {
197
- return [
198
- {
199
- type: 'doc',
200
- id: item,
201
- },
202
- ];
203
- }
204
- if (isCategoryShorthand(item)) {
205
- return flatMap(normalizeCategoryShorthand(item), normalizeItem);
206
- }
207
- switch (item.type) {
208
- case 'category':
209
- assertIsCategory(item);
210
- return [
211
- {
212
- collapsed: DefaultCategoryCollapsedValue,
213
- ...item,
214
- items: flatMap(item.items, normalizeItem),
215
- },
216
- ];
217
- case 'autogenerated':
218
- assertIsAutogenerated(item);
219
- return [item];
220
- case 'link':
221
- assertIsLink(item);
222
- return [item];
223
- case 'ref':
224
- case 'doc':
225
- assertIsDoc(item);
226
- return [item];
227
- default: {
228
- const extraMigrationError =
229
- item.type === 'subcategory'
230
- ? 'Docusaurus v2: "subcategory" has been renamed as "category".'
231
- : '';
232
- throw new Error(
233
- `Unknown sidebar item type "${
234
- item.type
235
- }". Sidebar item is ${JSON.stringify(item)}.\n${extraMigrationError}`,
236
- );
237
- }
238
- }
239
- }
240
-
241
- function normalizeSidebar(sidebar: SidebarJSON): UnprocessedSidebar {
242
- const normalizedSidebar: SidebarItemJSON[] = Array.isArray(sidebar)
243
- ? sidebar
244
- : normalizeCategoryShorthand(sidebar);
245
-
246
- return flatMap(normalizedSidebar, normalizeItem);
247
- }
248
-
249
- function normalizeSidebars(sidebars: SidebarsJSON): UnprocessedSidebars {
250
- return mapValues(sidebars, normalizeSidebar);
251
- }
252
-
253
- export const DefaultSidebars: UnprocessedSidebars = {
254
- defaultSidebar: [
255
- {
256
- type: 'autogenerated',
257
- dirName: '.',
258
- },
259
- ],
260
- };
261
-
262
- export const DisabledSidebars: UnprocessedSidebars = {};
263
-
264
- // If a path is provided, make it absolute
265
- // use this before loadSidebars()
266
- export function resolveSidebarPathOption(
267
- siteDir: string,
268
- sidebarPathOption: PluginOptions['sidebarPath'],
269
- ): PluginOptions['sidebarPath'] {
270
- return sidebarPathOption
271
- ? path.resolve(siteDir, sidebarPathOption)
272
- : sidebarPathOption;
273
- }
274
-
275
- // TODO refactor: make async
276
- // Note: sidebarFilePath must be absolute, use resolveSidebarPathOption
277
- export function loadSidebars(
278
- sidebarFilePath: string | false | undefined,
279
- ): UnprocessedSidebars {
280
- // false => no sidebars
281
- if (sidebarFilePath === false) {
282
- return DisabledSidebars;
283
- }
284
-
285
- // undefined => defaults to autogenerated sidebars
286
- if (typeof sidebarFilePath === 'undefined') {
287
- return DefaultSidebars;
288
- }
289
-
290
- // unexisting sidebars file: no sidebars
291
- // Note: this edge case can happen on versioned docs, not current version
292
- // We avoid creating empty versioned sidebars file with the CLI
293
- if (!fs.existsSync(sidebarFilePath)) {
294
- return DisabledSidebars;
295
- }
296
-
297
- // We don't want sidebars to be cached because of hot reloading.
298
- const sidebarJson = importFresh(sidebarFilePath) as SidebarsJSON;
299
-
300
- return normalizeSidebars(sidebarJson);
301
- }
302
-
303
- export function toSidebarItemsGeneratorDoc(
304
- doc: DocMetadataBase,
305
- ): SidebarItemsGeneratorDoc {
306
- return pick(doc, [
307
- 'id',
308
- 'frontMatter',
309
- 'source',
310
- 'sourceDirName',
311
- 'sidebarPosition',
312
- ]);
313
- }
314
- export function toSidebarItemsGeneratorVersion(
315
- version: VersionMetadata,
316
- ): SidebarItemsGeneratorVersion {
317
- return pick(version, ['versionName', 'contentPath']);
318
- }
319
-
320
- // Handle the generation of autogenerated sidebar items
321
- export async function processSidebar({
322
- sidebarItemsGenerator,
323
- numberPrefixParser,
324
- unprocessedSidebar,
325
- docs,
326
- version,
327
- }: {
328
- sidebarItemsGenerator: SidebarItemsGeneratorOption;
329
- numberPrefixParser: NumberPrefixParser;
330
- unprocessedSidebar: UnprocessedSidebar;
331
- docs: DocMetadataBase[];
332
- version: VersionMetadata;
333
- }): Promise<Sidebar> {
334
- // Just a minor lazy transformation optimization
335
- const getSidebarItemsGeneratorDocsAndVersion = memoize(() => ({
336
- docs: docs.map(toSidebarItemsGeneratorDoc),
337
- version: toSidebarItemsGeneratorVersion(version),
338
- }));
339
-
340
- async function processRecursive(
341
- item: UnprocessedSidebarItem,
342
- ): Promise<SidebarItem[]> {
343
- if (item.type === 'category') {
344
- return [
345
- {
346
- ...item,
347
- items: (await Promise.all(item.items.map(processRecursive))).flat(),
348
- },
349
- ];
350
- }
351
- if (item.type === 'autogenerated') {
352
- return sidebarItemsGenerator({
353
- item,
354
- numberPrefixParser,
355
- defaultSidebarItemsGenerator: DefaultSidebarItemsGenerator,
356
- ...getSidebarItemsGeneratorDocsAndVersion(),
357
- });
358
- }
359
- return [item];
360
- }
361
-
362
- return (await Promise.all(unprocessedSidebar.map(processRecursive))).flat();
363
- }
364
-
365
- export async function processSidebars({
366
- sidebarItemsGenerator,
367
- numberPrefixParser,
368
- unprocessedSidebars,
369
- docs,
370
- version,
371
- }: {
372
- sidebarItemsGenerator: SidebarItemsGeneratorOption;
373
- numberPrefixParser: NumberPrefixParser;
374
- unprocessedSidebars: UnprocessedSidebars;
375
- docs: DocMetadataBase[];
376
- version: VersionMetadata;
377
- }): Promise<Sidebars> {
378
- return combinePromises(
379
- mapValues(unprocessedSidebars, (unprocessedSidebar) =>
380
- processSidebar({
381
- sidebarItemsGenerator,
382
- numberPrefixParser,
383
- unprocessedSidebar,
384
- docs,
385
- version,
386
- }),
387
- ),
388
- );
389
- }
390
-
391
- function collectSidebarItemsOfType<
392
- Type extends SidebarItemType,
393
- Item extends SidebarItem & {type: SidebarItemType}
394
- >(type: Type, sidebar: Sidebar): Item[] {
395
- function collectRecursive(item: SidebarItem): Item[] {
396
- const currentItemsCollected: Item[] =
397
- item.type === type ? [item as Item] : [];
398
-
399
- const childItemsCollected: Item[] =
400
- item.type === 'category' ? flatten(item.items.map(collectRecursive)) : [];
401
-
402
- return [...currentItemsCollected, ...childItemsCollected];
403
- }
404
-
405
- return flatten(sidebar.map(collectRecursive));
406
- }
407
-
408
- export function collectSidebarDocItems(sidebar: Sidebar): SidebarItemDoc[] {
409
- return collectSidebarItemsOfType('doc', sidebar);
410
- }
411
- export function collectSidebarCategories(
412
- sidebar: Sidebar,
413
- ): SidebarItemCategory[] {
414
- return collectSidebarItemsOfType('category', sidebar);
415
- }
416
- export function collectSidebarLinks(sidebar: Sidebar): SidebarItemLink[] {
417
- return collectSidebarItemsOfType('link', sidebar);
418
- }
419
-
420
- export function transformSidebarItems(
421
- sidebar: Sidebar,
422
- updateFn: (item: SidebarItem) => SidebarItem,
423
- ): Sidebar {
424
- function transformRecursive(item: SidebarItem): SidebarItem {
425
- if (item.type === 'category') {
426
- return updateFn({
427
- ...item,
428
- items: item.items.map(transformRecursive),
429
- });
430
- }
431
- return updateFn(item);
432
- }
433
- return sidebar.map(transformRecursive);
434
- }
435
-
436
- export function collectSidebarsDocIds(
437
- sidebars: Sidebars,
438
- ): Record<string, string[]> {
439
- return mapValues(sidebars, (sidebar) => {
440
- return collectSidebarDocItems(sidebar).map((docItem) => docItem.id);
441
- });
442
- }
443
-
444
- export function createSidebarsUtils(
445
- sidebars: Sidebars,
446
- ): {
447
- getFirstDocIdOfFirstSidebar: () => string | undefined;
448
- getSidebarNameByDocId: (docId: string) => string | undefined;
449
- getDocNavigation: (
450
- docId: string,
451
- ) => {
452
- sidebarName: string | undefined;
453
- previousId: string | undefined;
454
- nextId: string | undefined;
455
- };
456
- checkSidebarsDocIds: (validDocIds: string[], sidebarFilePath: string) => void;
457
- } {
458
- const sidebarNameToDocIds = collectSidebarsDocIds(sidebars);
459
-
460
- function getFirstDocIdOfFirstSidebar(): string | undefined {
461
- return Object.values(sidebarNameToDocIds)[0]?.[0];
462
- }
463
-
464
- function getSidebarNameByDocId(docId: string): string | undefined {
465
- // TODO lookup speed can be optimized
466
- const entry = Object.entries(
467
- sidebarNameToDocIds,
468
- ).find(([_sidebarName, docIds]) => docIds.includes(docId));
469
-
470
- return entry?.[0];
471
- }
472
-
473
- function getDocNavigation(
474
- docId: string,
475
- ): {
476
- sidebarName: string | undefined;
477
- previousId: string | undefined;
478
- nextId: string | undefined;
479
- } {
480
- const sidebarName = getSidebarNameByDocId(docId);
481
- if (sidebarName) {
482
- const docIds = sidebarNameToDocIds[sidebarName];
483
- const currentIndex = docIds.indexOf(docId);
484
- const {previous, next} = getElementsAround(docIds, currentIndex);
485
- return {
486
- sidebarName,
487
- previousId: previous,
488
- nextId: next,
489
- };
490
- } else {
491
- return {
492
- sidebarName: undefined,
493
- previousId: undefined,
494
- nextId: undefined,
495
- };
496
- }
497
- }
498
-
499
- function checkSidebarsDocIds(validDocIds: string[], sidebarFilePath: string) {
500
- const allSidebarDocIds = flatten(Object.values(sidebarNameToDocIds));
501
- const invalidSidebarDocIds = difference(allSidebarDocIds, validDocIds);
502
- if (invalidSidebarDocIds.length > 0) {
503
- throw new Error(
504
- `Invalid sidebar file at "${toMessageRelativeFilePath(
505
- sidebarFilePath,
506
- )}".
507
- These sidebar document ids do not exist:
508
- - ${invalidSidebarDocIds.sort().join('\n- ')}
509
-
510
- Available document ids are:
511
- - ${validDocIds.sort().join('\n- ')}`,
512
- );
513
- }
514
- }
515
-
516
- return {
517
- getFirstDocIdOfFirstSidebar,
518
- getSidebarNameByDocId,
519
- getDocNavigation,
520
- checkSidebarsDocIds,
521
- };
522
- }
@@ -1,103 +0,0 @@
1
- /**
2
- * Copyright (c) Facebook, Inc. and its affiliates.
3
- *
4
- * This source code is licensed under the MIT license found in the
5
- * LICENSE file in the root directory of this source tree.
6
- */
7
-
8
- import {useLocation} from '@docusaurus/router';
9
- import useGlobalData, {
10
- // useAllPluginInstancesData,
11
- usePluginData,
12
- } from '@docusaurus/useGlobalData';
13
-
14
- import {GlobalPluginData, GlobalVersion} from '../../types';
15
- import {
16
- getActivePlugin,
17
- getLatestVersion,
18
- getActiveVersion,
19
- getActiveDocContext,
20
- getDocVersionSuggestions,
21
- ActivePlugin,
22
- ActiveDocContext,
23
- DocVersionSuggestions,
24
- GetActivePluginOptions,
25
- } from '../../client/docsClientUtils';
26
-
27
- // Important to use a constant object to avoid React useEffect executions etc...,
28
- // see https://github.com/facebook/docusaurus/issues/5089
29
- const StableEmptyObject = {};
30
-
31
- // Not using useAllPluginInstancesData() because in blog-only mode, docs hooks are still used by the theme
32
- // We need a fail-safe fallback when the docs plugin is not in use
33
- export const useAllDocsData = (): Record<string, GlobalPluginData> =>
34
- // useAllPluginInstancesData('docusaurus-plugin-content-docs');
35
- useGlobalData()['docusaurus-plugin-content-docs'] ?? StableEmptyObject;
36
-
37
- export const useDocsData = (pluginId: string | undefined): GlobalPluginData =>
38
- usePluginData('docusaurus-plugin-content-docs', pluginId) as GlobalPluginData;
39
-
40
- export const useActivePlugin = (
41
- options: GetActivePluginOptions = {},
42
- ): ActivePlugin | undefined => {
43
- const data = useAllDocsData();
44
- const {pathname} = useLocation();
45
- return getActivePlugin(data, pathname, options);
46
- };
47
-
48
- export const useActivePluginAndVersion = (
49
- options: GetActivePluginOptions = {},
50
- ):
51
- | undefined
52
- | {activePlugin: ActivePlugin; activeVersion: GlobalVersion | undefined} => {
53
- const activePlugin = useActivePlugin(options);
54
- const {pathname} = useLocation();
55
- if (activePlugin) {
56
- const activeVersion = getActiveVersion(activePlugin.pluginData, pathname);
57
- return {
58
- activePlugin,
59
- activeVersion,
60
- };
61
- }
62
- return undefined;
63
- };
64
-
65
- // versions are returned ordered (most recent first)
66
- export const useVersions = (pluginId: string | undefined): GlobalVersion[] => {
67
- const data = useDocsData(pluginId);
68
- return data.versions;
69
- };
70
-
71
- export const useLatestVersion = (
72
- pluginId: string | undefined,
73
- ): GlobalVersion => {
74
- const data = useDocsData(pluginId);
75
- return getLatestVersion(data);
76
- };
77
-
78
- // Note: return undefined on doc-unrelated pages,
79
- // because there's no version currently considered as active
80
- export const useActiveVersion = (
81
- pluginId: string | undefined,
82
- ): GlobalVersion | undefined => {
83
- const data = useDocsData(pluginId);
84
- const {pathname} = useLocation();
85
- return getActiveVersion(data, pathname);
86
- };
87
-
88
- export const useActiveDocContext = (
89
- pluginId: string | undefined,
90
- ): ActiveDocContext => {
91
- const data = useDocsData(pluginId);
92
- const {pathname} = useLocation();
93
- return getActiveDocContext(data, pathname);
94
- };
95
-
96
- // Useful to say "hey, you are not on the latest docs version, please switch"
97
- export const useDocVersionSuggestions = (
98
- pluginId: string | undefined,
99
- ): DocVersionSuggestions => {
100
- const data = useDocsData(pluginId);
101
- const {pathname} = useLocation();
102
- return getDocVersionSuggestions(data, pathname);
103
- };