forked from mixpanel/docs
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy paththeme.config.tsx
93 lines (89 loc) · 2.86 KB
/
theme.config.tsx
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
import { FC, ReactNode } from "react";
import { useRouter } from "next/router";
import { DocsThemeConfig, useConfig } from "nextra-theme-docs";
import Search from "./components/Search/Search";
import MixpanelLogoWordmark from "./components/svg/MixpanelLogoWordmark";
import MainContent from "./components/MainContent/MainContent";
import SignUpButton from "./components/SignUpButton/SignUpButton";
import ChangelogPostHeader from "./components/ChangelogPostHeader/ChangelogPostHeader";
import { VideoButtonWithModal } from "./components/VideoButtonWithModal";
function renderComponent<T>(ComponentOrNode: FC<T> | ReactNode, props?: T) {
if (!ComponentOrNode) return null;
if (typeof ComponentOrNode !== "function") return ComponentOrNode;
return <ComponentOrNode {...props} />;
}
const config: DocsThemeConfig = {
darkMode: true,
nextThemes: {
defaultTheme: `system`,
},
docsRepositoryBase: "https://github.com/mixpanel/docs/tree/main",
head() {
const { asPath } = useRouter();
const { title } = useConfig();
const url = `https://docs.mixpanel.com${asPath}`;
return (
<>
<title>{`${title} - Mixpanel Docs`}</title>
<meta property="og:url" content={url} />
<meta property="og:title" content={`${title} - Mixpanel Docs`} />
<meta
property="og:description"
content={`Read more about Mixpanel documentation`}
/>
<link
rel="apple-touch-icon"
sizes="180x180"
href={`https://cdn.mxpnl.com/marketing-site/static/favicons/apple-touch-icon.png`}
/>
<link
rel="icon"
sizes="16x16"
href="https://cdn.mxpnl.com/marketing-site/static/favicons/favicon-16x16.png"
type="image/png"
/>
<link
rel="icon"
sizes="32x32"
href="https://cdn.mxpnl.com/marketing-site/static/favicons/favicon-32x32.png"
type="image/png"
/>
<link
rel="mask-icon"
href={`https://cdn.mxpnl.com/marketing-site/static/favicons/safari-pinned-tab.svg`}
color="#7856ff"
/>
<meta name="msapplication-TileColor" content="#ffffff" />
<meta name="theme-color" content="#ffffff" />
</>
);
},
feedback: {
content: "Question? Contact our Support Team",
useLink: () => "https://mixpanel.com/get-support",
},
footer: {
content: "© Mixpanel 2024",
},
logo: <MixpanelLogoWordmark width={125} />,
logoLink: "https://mixpanel.com/home/",
main: MainContent,
components: {
ChangelogPostHeader: ChangelogPostHeader,
VideoButtonWithModal: VideoButtonWithModal,
},
search: {
component: Search,
},
project: {
link: "https://github.com/mixpanel/docs",
},
navbar: {
extraContent: SignUpButton,
},
sidebar: {
defaultMenuCollapseLevel: 1,
toggleButton: true,
},
};
export default config;