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

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 (140) hide show
  1. package/lib/.tsbuildinfo +1 -1
  2. package/lib/categoryGeneratedIndex.d.ts +12 -0
  3. package/lib/categoryGeneratedIndex.js +37 -0
  4. package/lib/cli.d.ts +2 -2
  5. package/lib/cli.js +12 -34
  6. package/lib/client/docsClientUtils.d.ts +1 -4
  7. package/lib/client/docsClientUtils.js +21 -31
  8. package/lib/docFrontMatter.d.ts +1 -1
  9. package/lib/docFrontMatter.js +10 -6
  10. package/lib/docs.d.ts +25 -3
  11. package/lib/docs.js +125 -38
  12. package/lib/globalData.d.ts +1 -1
  13. package/lib/index.d.ts +1 -1
  14. package/lib/index.js +104 -138
  15. package/lib/lastUpdate.js +9 -10
  16. package/lib/markdown/index.d.ts +3 -6
  17. package/lib/markdown/index.js +3 -3
  18. package/lib/markdown/linkify.js +2 -2
  19. package/lib/numberPrefix.d.ts +1 -1
  20. package/lib/options.d.ts +3 -3
  21. package/lib/options.js +49 -17
  22. package/lib/props.d.ts +7 -2
  23. package/lib/props.js +61 -9
  24. package/lib/routes.d.ts +27 -0
  25. package/lib/routes.js +105 -0
  26. package/lib/{sidebarItemsGenerator.d.ts → sidebars/generator.d.ts} +5 -2
  27. package/lib/sidebars/generator.js +216 -0
  28. package/lib/sidebars/index.d.ts +15 -0
  29. package/lib/sidebars/index.js +73 -0
  30. package/lib/sidebars/normalization.d.ts +14 -0
  31. package/lib/sidebars/normalization.js +77 -0
  32. package/lib/sidebars/processor.d.ts +18 -0
  33. package/lib/sidebars/processor.js +85 -0
  34. package/lib/sidebars/types.d.ts +127 -0
  35. package/lib/sidebars/types.js +8 -0
  36. package/lib/sidebars/utils.d.ts +35 -0
  37. package/lib/sidebars/utils.js +228 -0
  38. package/lib/sidebars/validation.d.ts +10 -0
  39. package/lib/sidebars/validation.js +138 -0
  40. package/lib/slug.d.ts +4 -3
  41. package/lib/slug.js +27 -15
  42. package/lib/tags.d.ts +8 -0
  43. package/lib/tags.js +20 -0
  44. package/lib/theme/hooks/useDocs.js +24 -21
  45. package/lib/translations.d.ts +2 -2
  46. package/lib/translations.js +71 -29
  47. package/lib/types.d.ts +52 -62
  48. package/lib/versions.d.ts +3 -3
  49. package/lib/versions.js +76 -24
  50. package/package.json +22 -20
  51. package/src/__tests__/__fixtures__/simple-site/docs/_partials/somePartial.md +3 -0
  52. package/src/__tests__/__fixtures__/simple-site/docs/_partials/subfolder/somePartial.md +3 -0
  53. package/src/__tests__/__fixtures__/simple-site/docs/_somePartial.md +3 -0
  54. package/src/__tests__/__fixtures__/simple-site/docs/foo/baz.md +5 -0
  55. package/src/__tests__/__fixtures__/simple-site/docs/hello.md +2 -0
  56. package/src/__tests__/__fixtures__/simple-site/docs/rootAbsoluteSlug.md +2 -0
  57. package/src/__tests__/__fixtures__/simple-site/docs/rootRelativeSlug.md +2 -0
  58. package/src/__tests__/__fixtures__/simple-site/docs/rootResolvedSlug.md +2 -0
  59. package/src/__tests__/__fixtures__/simple-site/docs/rootTryToEscapeSlug.md +2 -0
  60. package/src/__tests__/__fixtures__/simple-site/sidebars.json +15 -1
  61. package/src/__tests__/__fixtures__/site-with-doc-label/docs/hello-1.md +1 -0
  62. package/src/__tests__/__fixtures__/versioned-site/docs/foo/bar.md +6 -0
  63. package/src/__tests__/__fixtures__/versioned-site/docs/hello.md +3 -0
  64. package/src/__tests__/__fixtures__/versioned-site/i18n/en/docusaurus-plugin-content-docs/version-1.0.0/hello.md +3 -0
  65. package/src/__tests__/__fixtures__/versioned-site/i18n/fr/docusaurus-plugin-content-docs/version-1.0.0/hello.md +3 -0
  66. package/src/__tests__/__fixtures__/versioned-site/versioned_docs/version-1.0.0/hello.md +3 -0
  67. package/src/__tests__/__fixtures__/versioned-site/versioned_docs/version-1.0.1/_partials/somePartial.md +3 -0
  68. package/src/__tests__/__fixtures__/versioned-site/versioned_docs/version-1.0.1/_partials/subfolder/somePartial.md +3 -0
  69. package/src/__tests__/__fixtures__/versioned-site/versioned_docs/version-1.0.1/_somePartial.md +3 -0
  70. package/src/__tests__/__fixtures__/versioned-site/versioned_docs/version-1.0.1/hello.md +3 -0
  71. package/src/__tests__/__fixtures__/versioned-site/versioned_sidebars/version-1.0.1-sidebars.json +2 -2
  72. package/src/__tests__/__snapshots__/cli.test.ts.snap +48 -73
  73. package/src/__tests__/__snapshots__/docs.test.ts.snap +140 -0
  74. package/src/__tests__/__snapshots__/index.test.ts.snap +753 -112
  75. package/src/__tests__/__snapshots__/translations.test.ts.snap +45 -18
  76. package/src/__tests__/cli.test.ts +15 -11
  77. package/src/__tests__/docFrontMatter.test.ts +195 -40
  78. package/src/__tests__/docs.test.ts +311 -150
  79. package/src/__tests__/index.test.ts +112 -69
  80. package/src/__tests__/lastUpdate.test.ts +3 -2
  81. package/src/__tests__/options.test.ts +48 -4
  82. package/src/__tests__/props.test.ts +62 -0
  83. package/src/__tests__/slug.test.ts +127 -20
  84. package/src/__tests__/translations.test.ts +7 -2
  85. package/src/__tests__/versions.test.ts +93 -67
  86. package/src/categoryGeneratedIndex.ts +57 -0
  87. package/src/cli.ts +8 -41
  88. package/src/client/__tests__/docsClientUtils.test.ts +4 -5
  89. package/src/client/docsClientUtils.ts +19 -41
  90. package/{types.d.ts → src/deps.d.ts} +0 -0
  91. package/src/docFrontMatter.ts +13 -7
  92. package/src/docs.ts +158 -29
  93. package/src/globalData.ts +6 -1
  94. package/src/index.ts +134 -179
  95. package/src/lastUpdate.ts +10 -9
  96. package/src/markdown/index.ts +8 -12
  97. package/src/numberPrefix.ts +5 -3
  98. package/src/options.ts +59 -28
  99. package/src/plugin-content-docs.d.ts +179 -35
  100. package/src/props.ts +91 -16
  101. package/src/routes.ts +173 -0
  102. package/src/{__tests__ → sidebars/__tests__}/__fixtures__/sidebars/sidebars-category-shorthand.js +0 -0
  103. package/src/{__tests__ → sidebars/__tests__}/__fixtures__/sidebars/sidebars-category-wrong-items.json +0 -0
  104. package/src/{__tests__ → sidebars/__tests__}/__fixtures__/sidebars/sidebars-category-wrong-label.json +0 -0
  105. package/src/{__tests__ → sidebars/__tests__}/__fixtures__/sidebars/sidebars-category.js +0 -0
  106. package/src/{__tests__ → sidebars/__tests__}/__fixtures__/sidebars/sidebars-collapsed-first-level.json +0 -0
  107. package/src/{__tests__ → sidebars/__tests__}/__fixtures__/sidebars/sidebars-collapsed.json +0 -0
  108. package/src/{__tests__ → sidebars/__tests__}/__fixtures__/sidebars/sidebars-doc-id-not-string.json +0 -0
  109. package/src/{__tests__ → sidebars/__tests__}/__fixtures__/sidebars/sidebars-first-level-not-category.js +0 -0
  110. package/src/{__tests__ → sidebars/__tests__}/__fixtures__/sidebars/sidebars-link-wrong-href.json +0 -0
  111. package/src/{__tests__ → sidebars/__tests__}/__fixtures__/sidebars/sidebars-link-wrong-label.json +0 -0
  112. package/src/{__tests__ → sidebars/__tests__}/__fixtures__/sidebars/sidebars-link.json +0 -0
  113. package/src/{__tests__ → sidebars/__tests__}/__fixtures__/sidebars/sidebars-unknown-type.json +0 -0
  114. package/src/{__tests__ → sidebars/__tests__}/__fixtures__/sidebars/sidebars-wrong-field.json +0 -0
  115. package/src/{__tests__ → sidebars/__tests__}/__fixtures__/sidebars/sidebars.json +0 -0
  116. package/src/{__tests__/__snapshots__/sidebars.test.ts.snap → sidebars/__tests__/__snapshots__/index.test.ts.snap} +36 -6
  117. package/src/{__tests__/sidebarItemsGenerator.test.ts → sidebars/__tests__/generator.test.ts} +143 -18
  118. package/src/sidebars/__tests__/index.test.ts +204 -0
  119. package/src/sidebars/__tests__/processor.test.ts +237 -0
  120. package/src/sidebars/__tests__/utils.test.ts +695 -0
  121. package/src/sidebars/__tests__/validation.test.ts +105 -0
  122. package/src/sidebars/generator.ts +310 -0
  123. package/src/sidebars/index.ts +94 -0
  124. package/src/sidebars/normalization.ts +112 -0
  125. package/src/sidebars/processor.ts +154 -0
  126. package/src/sidebars/types.ts +211 -0
  127. package/src/sidebars/utils.ts +329 -0
  128. package/src/sidebars/validation.ts +168 -0
  129. package/src/slug.ts +32 -17
  130. package/src/tags.ts +19 -0
  131. package/src/theme/hooks/useDocs.ts +5 -1
  132. package/src/translations.ts +103 -47
  133. package/src/types.ts +67 -105
  134. package/src/versions.ts +117 -21
  135. package/lib/sidebarItemsGenerator.js +0 -211
  136. package/lib/sidebars.d.ts +0 -43
  137. package/lib/sidebars.js +0 -319
  138. package/src/__tests__/sidebars.test.ts +0 -639
  139. package/src/sidebarItemsGenerator.ts +0 -307
  140. package/src/sidebars.ts +0 -506
package/lib/sidebars.d.ts DELETED
@@ -1,43 +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
- import { Sidebars, SidebarItem, SidebarItemLink, SidebarItemDoc, Sidebar, SidebarItemCategory, UnprocessedSidebars, UnprocessedSidebar, DocMetadataBase, VersionMetadata, SidebarItemsGeneratorDoc, SidebarItemsGeneratorVersion, NumberPrefixParser, SidebarItemsGeneratorOption, PluginOptions } from './types';
8
- export declare const DefaultCategoryCollapsedValue = true;
9
- export declare const DefaultSidebars: UnprocessedSidebars;
10
- export declare const DisabledSidebars: UnprocessedSidebars;
11
- export declare function resolveSidebarPathOption(siteDir: string, sidebarPathOption: PluginOptions['sidebarPath']): PluginOptions['sidebarPath'];
12
- export declare function loadSidebars(sidebarFilePath: string | false | undefined): UnprocessedSidebars;
13
- export declare function toSidebarItemsGeneratorDoc(doc: DocMetadataBase): SidebarItemsGeneratorDoc;
14
- export declare function toSidebarItemsGeneratorVersion(version: VersionMetadata): SidebarItemsGeneratorVersion;
15
- export declare function processSidebar({ sidebarItemsGenerator, numberPrefixParser, unprocessedSidebar, docs, version, }: {
16
- sidebarItemsGenerator: SidebarItemsGeneratorOption;
17
- numberPrefixParser: NumberPrefixParser;
18
- unprocessedSidebar: UnprocessedSidebar;
19
- docs: DocMetadataBase[];
20
- version: VersionMetadata;
21
- }): Promise<Sidebar>;
22
- export declare function processSidebars({ sidebarItemsGenerator, numberPrefixParser, unprocessedSidebars, docs, version, }: {
23
- sidebarItemsGenerator: SidebarItemsGeneratorOption;
24
- numberPrefixParser: NumberPrefixParser;
25
- unprocessedSidebars: UnprocessedSidebars;
26
- docs: DocMetadataBase[];
27
- version: VersionMetadata;
28
- }): Promise<Sidebars>;
29
- export declare function collectSidebarDocItems(sidebar: Sidebar): SidebarItemDoc[];
30
- export declare function collectSidebarCategories(sidebar: Sidebar): SidebarItemCategory[];
31
- export declare function collectSidebarLinks(sidebar: Sidebar): SidebarItemLink[];
32
- export declare function transformSidebarItems(sidebar: Sidebar, updateFn: (item: SidebarItem) => SidebarItem): Sidebar;
33
- export declare function collectSidebarsDocIds(sidebars: Sidebars): Record<string, string[]>;
34
- export declare function createSidebarsUtils(sidebars: Sidebars): {
35
- getFirstDocIdOfFirstSidebar: () => string | undefined;
36
- getSidebarNameByDocId: (docId: string) => string | undefined;
37
- getDocNavigation: (docId: string) => {
38
- sidebarName: string | undefined;
39
- previousId: string | undefined;
40
- nextId: string | undefined;
41
- };
42
- checkSidebarsDocIds: (validDocIds: string[], sidebarFilePath: string) => void;
43
- };
package/lib/sidebars.js DELETED
@@ -1,319 +0,0 @@
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.createSidebarsUtils = exports.collectSidebarsDocIds = exports.transformSidebarItems = exports.collectSidebarLinks = exports.collectSidebarCategories = exports.collectSidebarDocItems = exports.processSidebars = exports.processSidebar = exports.toSidebarItemsGeneratorVersion = exports.toSidebarItemsGeneratorDoc = exports.loadSidebars = exports.resolveSidebarPathOption = exports.DisabledSidebars = exports.DefaultSidebars = exports.DefaultCategoryCollapsedValue = void 0;
10
- const tslib_1 = require("tslib");
11
- const fs_extra_1 = tslib_1.__importDefault(require("fs-extra"));
12
- const import_fresh_1 = tslib_1.__importDefault(require("import-fresh"));
13
- const lodash_1 = require("lodash");
14
- const utils_1 = require("@docusaurus/utils");
15
- const combine_promises_1 = tslib_1.__importDefault(require("combine-promises"));
16
- const sidebarItemsGenerator_1 = require("./sidebarItemsGenerator");
17
- const path_1 = tslib_1.__importDefault(require("path"));
18
- function isCategoryShorthand(item) {
19
- return typeof item !== 'string' && !item.type;
20
- }
21
- // categories are collapsed by default, unless user set collapsed = false
22
- exports.DefaultCategoryCollapsedValue = true;
23
- /**
24
- * Convert {category1: [item1,item2]} shorthand syntax to long-form syntax
25
- */
26
- function normalizeCategoryShorthand(sidebar) {
27
- return Object.entries(sidebar).map(([label, items]) => ({
28
- type: 'category',
29
- collapsed: exports.DefaultCategoryCollapsedValue,
30
- label,
31
- items,
32
- }));
33
- }
34
- /**
35
- * Check that item contains only allowed keys.
36
- */
37
- function assertItem(item, keys) {
38
- const unknownKeys = Object.keys(item).filter(
39
- // @ts-expect-error: key is always string
40
- (key) => !keys.includes(key) && key !== 'type');
41
- if (unknownKeys.length) {
42
- throw new Error(`Unknown sidebar item keys: ${unknownKeys}. Item: ${JSON.stringify(item)}`);
43
- }
44
- }
45
- function assertIsCategory(item) {
46
- assertItem(item, ['items', 'label', 'collapsed', 'customProps']);
47
- if (typeof item.label !== 'string') {
48
- throw new Error(`Error loading ${JSON.stringify(item)}: "label" must be a string.`);
49
- }
50
- if (!Array.isArray(item.items)) {
51
- throw new Error(`Error loading ${JSON.stringify(item)}: "items" must be an array.`);
52
- }
53
- // "collapsed" is an optional property
54
- if (item.hasOwnProperty('collapsed') && typeof item.collapsed !== 'boolean') {
55
- throw new Error(`Error loading ${JSON.stringify(item)}: "collapsed" must be a boolean.`);
56
- }
57
- }
58
- function assertIsAutogenerated(item) {
59
- assertItem(item, ['dirName', 'customProps']);
60
- if (typeof item.dirName !== 'string') {
61
- throw new Error(`Error loading ${JSON.stringify(item)}: "dirName" must be a string.`);
62
- }
63
- if (item.dirName.startsWith('/') || item.dirName.endsWith('/')) {
64
- throw new Error(`Error loading ${JSON.stringify(item)}: "dirName" must be a dir path relative to the docs folder root, and should not start or end with slash`);
65
- }
66
- }
67
- function assertIsDoc(item) {
68
- assertItem(item, ['id', 'label', 'customProps']);
69
- if (typeof item.id !== 'string') {
70
- throw new Error(`Error loading ${JSON.stringify(item)}: "id" must be a string.`);
71
- }
72
- if (item.label && typeof item.label !== 'string') {
73
- throw new Error(`Error loading ${JSON.stringify(item)}: "label" must be a string.`);
74
- }
75
- }
76
- function assertIsLink(item) {
77
- assertItem(item, ['href', 'label', 'customProps']);
78
- if (typeof item.href !== 'string') {
79
- throw new Error(`Error loading ${JSON.stringify(item)}: "href" must be a string.`);
80
- }
81
- if (typeof item.label !== 'string') {
82
- throw new Error(`Error loading ${JSON.stringify(item)}: "label" must be a string.`);
83
- }
84
- }
85
- /**
86
- * Normalizes recursively item and all its children. Ensures that at the end
87
- * each item will be an object with the corresponding type.
88
- */
89
- function normalizeItem(item) {
90
- if (typeof item === 'string') {
91
- return [
92
- {
93
- type: 'doc',
94
- id: item,
95
- },
96
- ];
97
- }
98
- if (isCategoryShorthand(item)) {
99
- return lodash_1.flatMap(normalizeCategoryShorthand(item), normalizeItem);
100
- }
101
- switch (item.type) {
102
- case 'category':
103
- assertIsCategory(item);
104
- return [
105
- {
106
- collapsed: exports.DefaultCategoryCollapsedValue,
107
- ...item,
108
- items: lodash_1.flatMap(item.items, normalizeItem),
109
- },
110
- ];
111
- case 'autogenerated':
112
- assertIsAutogenerated(item);
113
- return [item];
114
- case 'link':
115
- assertIsLink(item);
116
- return [item];
117
- case 'ref':
118
- case 'doc':
119
- assertIsDoc(item);
120
- return [item];
121
- default: {
122
- const extraMigrationError = item.type === 'subcategory'
123
- ? 'Docusaurus v2: "subcategory" has been renamed as "category".'
124
- : '';
125
- throw new Error(`Unknown sidebar item type "${item.type}". Sidebar item is ${JSON.stringify(item)}.\n${extraMigrationError}`);
126
- }
127
- }
128
- }
129
- function normalizeSidebar(sidebar) {
130
- const normalizedSidebar = Array.isArray(sidebar)
131
- ? sidebar
132
- : normalizeCategoryShorthand(sidebar);
133
- return lodash_1.flatMap(normalizedSidebar, normalizeItem);
134
- }
135
- function normalizeSidebars(sidebars) {
136
- return lodash_1.mapValues(sidebars, normalizeSidebar);
137
- }
138
- exports.DefaultSidebars = {
139
- defaultSidebar: [
140
- {
141
- type: 'autogenerated',
142
- dirName: '.',
143
- },
144
- ],
145
- };
146
- exports.DisabledSidebars = {};
147
- // If a path is provided, make it absolute
148
- // use this before loadSidebars()
149
- function resolveSidebarPathOption(siteDir, sidebarPathOption) {
150
- return sidebarPathOption
151
- ? path_1.default.resolve(siteDir, sidebarPathOption)
152
- : sidebarPathOption;
153
- }
154
- exports.resolveSidebarPathOption = resolveSidebarPathOption;
155
- // TODO refactor: make async
156
- // Note: sidebarFilePath must be absolute, use resolveSidebarPathOption
157
- function loadSidebars(sidebarFilePath) {
158
- // false => no sidebars
159
- if (sidebarFilePath === false) {
160
- return exports.DisabledSidebars;
161
- }
162
- // undefined => defaults to autogenerated sidebars
163
- if (typeof sidebarFilePath === 'undefined') {
164
- return exports.DefaultSidebars;
165
- }
166
- // unexisting sidebars file: no sidebars
167
- // Note: this edge case can happen on versioned docs, not current version
168
- // We avoid creating empty versioned sidebars file with the CLI
169
- if (!fs_extra_1.default.existsSync(sidebarFilePath)) {
170
- return exports.DisabledSidebars;
171
- }
172
- // We don't want sidebars to be cached because of hot reloading.
173
- const sidebarJson = import_fresh_1.default(sidebarFilePath);
174
- return normalizeSidebars(sidebarJson);
175
- }
176
- exports.loadSidebars = loadSidebars;
177
- function toSidebarItemsGeneratorDoc(doc) {
178
- return lodash_1.pick(doc, [
179
- 'id',
180
- 'frontMatter',
181
- 'source',
182
- 'sourceDirName',
183
- 'sidebarPosition',
184
- ]);
185
- }
186
- exports.toSidebarItemsGeneratorDoc = toSidebarItemsGeneratorDoc;
187
- function toSidebarItemsGeneratorVersion(version) {
188
- return lodash_1.pick(version, ['versionName', 'contentPath']);
189
- }
190
- exports.toSidebarItemsGeneratorVersion = toSidebarItemsGeneratorVersion;
191
- // Handle the generation of autogenerated sidebar items
192
- async function processSidebar({ sidebarItemsGenerator, numberPrefixParser, unprocessedSidebar, docs, version, }) {
193
- // Just a minor lazy transformation optimization
194
- const getSidebarItemsGeneratorDocsAndVersion = lodash_1.memoize(() => ({
195
- docs: docs.map(toSidebarItemsGeneratorDoc),
196
- version: toSidebarItemsGeneratorVersion(version),
197
- }));
198
- async function processRecursive(item) {
199
- if (item.type === 'category') {
200
- return [
201
- {
202
- ...item,
203
- items: (await Promise.all(item.items.map(processRecursive))).flat(),
204
- },
205
- ];
206
- }
207
- if (item.type === 'autogenerated') {
208
- return sidebarItemsGenerator({
209
- item,
210
- numberPrefixParser,
211
- defaultSidebarItemsGenerator: sidebarItemsGenerator_1.DefaultSidebarItemsGenerator,
212
- ...getSidebarItemsGeneratorDocsAndVersion(),
213
- });
214
- }
215
- return [item];
216
- }
217
- return (await Promise.all(unprocessedSidebar.map(processRecursive))).flat();
218
- }
219
- exports.processSidebar = processSidebar;
220
- async function processSidebars({ sidebarItemsGenerator, numberPrefixParser, unprocessedSidebars, docs, version, }) {
221
- return combine_promises_1.default(lodash_1.mapValues(unprocessedSidebars, (unprocessedSidebar) => processSidebar({
222
- sidebarItemsGenerator,
223
- numberPrefixParser,
224
- unprocessedSidebar,
225
- docs,
226
- version,
227
- })));
228
- }
229
- exports.processSidebars = processSidebars;
230
- function collectSidebarItemsOfType(type, sidebar) {
231
- function collectRecursive(item) {
232
- const currentItemsCollected = item.type === type ? [item] : [];
233
- const childItemsCollected = item.type === 'category' ? lodash_1.flatten(item.items.map(collectRecursive)) : [];
234
- return [...currentItemsCollected, ...childItemsCollected];
235
- }
236
- return lodash_1.flatten(sidebar.map(collectRecursive));
237
- }
238
- function collectSidebarDocItems(sidebar) {
239
- return collectSidebarItemsOfType('doc', sidebar);
240
- }
241
- exports.collectSidebarDocItems = collectSidebarDocItems;
242
- function collectSidebarCategories(sidebar) {
243
- return collectSidebarItemsOfType('category', sidebar);
244
- }
245
- exports.collectSidebarCategories = collectSidebarCategories;
246
- function collectSidebarLinks(sidebar) {
247
- return collectSidebarItemsOfType('link', sidebar);
248
- }
249
- exports.collectSidebarLinks = collectSidebarLinks;
250
- function transformSidebarItems(sidebar, updateFn) {
251
- function transformRecursive(item) {
252
- if (item.type === 'category') {
253
- return updateFn({
254
- ...item,
255
- items: item.items.map(transformRecursive),
256
- });
257
- }
258
- return updateFn(item);
259
- }
260
- return sidebar.map(transformRecursive);
261
- }
262
- exports.transformSidebarItems = transformSidebarItems;
263
- function collectSidebarsDocIds(sidebars) {
264
- return lodash_1.mapValues(sidebars, (sidebar) => {
265
- return collectSidebarDocItems(sidebar).map((docItem) => docItem.id);
266
- });
267
- }
268
- exports.collectSidebarsDocIds = collectSidebarsDocIds;
269
- function createSidebarsUtils(sidebars) {
270
- const sidebarNameToDocIds = collectSidebarsDocIds(sidebars);
271
- function getFirstDocIdOfFirstSidebar() {
272
- var _a;
273
- return (_a = Object.values(sidebarNameToDocIds)[0]) === null || _a === void 0 ? void 0 : _a[0];
274
- }
275
- function getSidebarNameByDocId(docId) {
276
- // TODO lookup speed can be optimized
277
- const entry = Object.entries(sidebarNameToDocIds).find(([_sidebarName, docIds]) => docIds.includes(docId));
278
- return entry === null || entry === void 0 ? void 0 : entry[0];
279
- }
280
- function getDocNavigation(docId) {
281
- const sidebarName = getSidebarNameByDocId(docId);
282
- if (sidebarName) {
283
- const docIds = sidebarNameToDocIds[sidebarName];
284
- const currentIndex = docIds.indexOf(docId);
285
- const { previous, next } = utils_1.getElementsAround(docIds, currentIndex);
286
- return {
287
- sidebarName,
288
- previousId: previous,
289
- nextId: next,
290
- };
291
- }
292
- else {
293
- return {
294
- sidebarName: undefined,
295
- previousId: undefined,
296
- nextId: undefined,
297
- };
298
- }
299
- }
300
- function checkSidebarsDocIds(validDocIds, sidebarFilePath) {
301
- const allSidebarDocIds = lodash_1.flatten(Object.values(sidebarNameToDocIds));
302
- const invalidSidebarDocIds = lodash_1.difference(allSidebarDocIds, validDocIds);
303
- if (invalidSidebarDocIds.length > 0) {
304
- throw new Error(`Invalid sidebar file at "${utils_1.toMessageRelativeFilePath(sidebarFilePath)}".
305
- These sidebar document ids do not exist:
306
- - ${invalidSidebarDocIds.sort().join('\n- ')}
307
-
308
- Available document ids are:
309
- - ${validDocIds.sort().join('\n- ')}`);
310
- }
311
- }
312
- return {
313
- getFirstDocIdOfFirstSidebar,
314
- getSidebarNameByDocId,
315
- getDocNavigation,
316
- checkSidebarsDocIds,
317
- };
318
- }
319
- exports.createSidebarsUtils = createSidebarsUtils;