-
Notifications
You must be signed in to change notification settings - Fork 51
/
sidebars.js
87 lines (74 loc) · 2.48 KB
/
sidebars.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
/**
* Creating a sidebar enables you to:
- create an ordered group of docs
- render a sidebar for each doc of that group
- provide next/previous navigation
The sidebars can be generated from the filesystem, or explicitly defined here.
Create as many sidebars as you want.
*/
// @ts-check
const swap = (allItems, linkItems, descriptions) => {
const result = allItems.flatMap((item) => {
const header = item.customProps?.header ? [{
type: 'html',
value: item.customProps.header,
defaultStyle: true,
className: 'header',
}] : []
const className = [
item.className || '',
(item.customProps?.hidden ? 'hidden' : ''),
...(item.customProps?.offerings || [])
].join(' ')
if (item.type === 'category') {
// a workaround for category pages not picking up the description in index.md
// see https://docusaurus.io/feature-requests/p/allow-customizing-category-description-in-generated-index-cards
const customProps = descriptions[item.link?.id] ?
{...item.customProps, description: descriptions[item.link.id]} :
item.customProps
if (item.items.length > 0) return [...header, {
...item,
className,
customProps,
items: swap(item.items, linkItems, descriptions),
}]
// a workaround for empty category pages not respecting className
// see https://discord.com/channels/398180168688074762/867060369087922187/1068508121091293264
return [...header, {
type: 'doc',
id: item.link.id,
label: item.label,
className,
customProps,
}]
}
if (linkItems[item.id]) {
return [
{
type: 'link',
label: linkItems[item.id].sidebar_label ?? linkItems[item.id].title,
href: linkItems[item.id].href,
className,
customProps: linkItems[item.id].sidebar_custom_props,
},
]
}
return [{...item, className}]
})
return result
}
// Switch out doc items for external links where required
const swapDocItemsToLinkItems = (generatedDocs, originalDocs) => {
const linkItems = {}
const descriptions = {}
for (const docItem of originalDocs) {
if (docItem.frontMatter.description) {
descriptions[docItem.id] = docItem.frontMatter.description
}
if (docItem.frontMatter.type === 'link') {
linkItems[docItem.id] = docItem.frontMatter
}
}
return swap(generatedDocs, linkItems, descriptions)
}
module.exports = { swapDocItemsToLinkItems }