-
Notifications
You must be signed in to change notification settings - Fork 16
/
Copy pathsidebars.ts
51 lines (39 loc) · 1.27 KB
/
sidebars.ts
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
/**
* 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
import { SidebarsConfig } from "@docusaurus/plugin-content-docs";
import openapiSidebar from "./docs/api/sidebar";
// This reorders the docs to be in the order of get, post, put, delete
function reorderSidebar(sidebar) {
const methodOrder = ["get", "post", "put", "delete"];
sidebar.forEach((category) => {
if (category.items) {
category.items.sort((a, b) => {
const methodA = a.className.split(" ")[1].toLowerCase();
const methodB = b.className.split(" ")[1].toLowerCase();
const indexA = methodOrder.indexOf(methodA);
const indexB = methodOrder.indexOf(methodB);
if (indexA === -1 && indexB === -1) return 0;
if (indexA === -1) return 1;
if (indexB === -1) return -1;
return indexA - indexB;
});
}
});
return sidebar;
}
const sidebars: SidebarsConfig = {
sidebar: [
{ type: "autogenerated", dirName: "." },
{
API: reorderSidebar(openapiSidebar),
},
],
};
export default sidebars;