-
Notifications
You must be signed in to change notification settings - Fork 0
/
docusaurus.config.js
150 lines (141 loc) · 4.16 KB
/
docusaurus.config.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
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
// @ts-check
// `@type` JSDoc annotations allow editor autocompletion and type checking
// (when paired with `@ts-check`).
// There are various equivalent ways to declare your Docusaurus config.
// See: https://docusaurus.io/docs/api/docusaurus-config
import { themes as prismThemes } from "prism-react-renderer";
/** @type {import('@docusaurus/types').Config} */
// Read the OpenAPI spec from a local file
const config = {
title: "Mconf",
tagline: "API Documentation",
favicon: "img/favicon.ico",
// Set the production url of your site here
url: "https://api.h.elos.dev",
// Set the /<baseUrl>/ pathname under which your site is served
// For GitHub pages deployment, it is often '/<projectName>/'
baseUrl: "/docs/",
onBrokenLinks: "throw",
onBrokenMarkdownLinks: "warn",
// Even if you don't use internationalization, you can use this field to set
// useful metadata like html lang. For example, if your site is Chinese, you
// may want to replace "en" with "zh-Hans".
i18n: {
defaultLocale: "en",
locales: ["en"],
},
presets: [
[
"classic",
/** @type {import('@docusaurus/preset-classic').Options} */
({
docs: {
sidebarPath: "./sidebars.js",
path: "pages",
routeBasePath: "pages",
},
blog: {
showReadingTime: true,
feedOptions: {
type: ["rss", "atom"],
xslt: true,
},
// Useful options to enforce blogging best practices
onInlineTags: "warn",
onInlineAuthors: "warn",
onUntruncatedBlogPosts: "warn",
},
theme: {
customCss: "./src/css/custom.css",
},
}),
],
[
"redocusaurus",
{
// Plugin Options for loading OpenAPI files
specs: [
// Pass it a path to a local OpenAPI YAML file
{
// Redocusaurus will automatically bundle your spec into a single file during the build
spec: "/opt/docusaurus/static/proxy/openapi.yaml",
route: "/api/conference/",
},
{
spec: "/opt/docusaurus/static/data/openapi.yaml",
route: "/api/data/",
},
{
spec: "/opt/docusaurus/static/administrative/openapi.yaml",
route: "/api/administrative/",
},
],
theme: {
// Change with your site colors
primaryColor: "#1890ff",
},
},
],
],
themeConfig:
/** @type {import('@docusaurus/preset-classic').ThemeConfig} */
({
// Replace with your project's social card
image: "img/docusaurus-social-card.jpg",
navbar: {
title: "Mconf",
logo: {
alt: "Mconf Logo",
src: "img/logo.svg",
},
items: [
{ to: "/blog", label: "What's new", position: "left" },
{ to: "/pages/guide", label: "Guide", position: "left" },
{ to: "/api/conference", label: "Conference API", position: "right" },
{ to: "/api/data", label: "Data API", position: "right" },
{
to: "/api/administrative",
label: "Administrative API",
position: "right",
},
],
},
footer: {
style: "dark",
links: [
{
title: "Links",
items: [
{
label: "LinkedIn",
href: "https://www.linkedin.com/company/mconf",
},
{
label: "X",
href: "https://x.com/mconfoficial",
},
{
label: "Facebook",
href: "https://www.facebook.com/mconfoficial/",
},
],
},
{
title: "More",
items: [
{
label: "GitHub",
href: "https://github.com/mconf",
},
],
},
],
copyright: `Copyright © ${new Date().getFullYear()} Mconf, Inc. Built with Docusaurus.`,
},
prism: {
theme: prismThemes.github,
darkTheme: prismThemes.dracula,
},
}),
};
export default config;