62 lines
1.8 KiB
TypeScript
62 lines
1.8 KiB
TypeScript
"use client"
|
|
|
|
import {
|
|
AnalyticsProvider,
|
|
ColorModeProvider,
|
|
helpButtonNotification,
|
|
HooksLoader,
|
|
LearningPathProvider,
|
|
MobileProvider,
|
|
ModalProvider,
|
|
NotificationProvider,
|
|
PaginationProvider,
|
|
ScrollControllerProvider,
|
|
SiteConfigProvider,
|
|
} from "docs-ui"
|
|
import SidebarProvider from "./sidebar"
|
|
import SearchProvider from "./search"
|
|
import { config } from "../config"
|
|
|
|
type ProvidersProps = {
|
|
children?: React.ReactNode
|
|
}
|
|
|
|
const Providers = ({ children }: ProvidersProps) => {
|
|
return (
|
|
<AnalyticsProvider writeKey={process.env.NEXT_PUBLIC_SEGMENT_API_KEY}>
|
|
<SiteConfigProvider config={config}>
|
|
<MobileProvider>
|
|
<ColorModeProvider>
|
|
<ModalProvider>
|
|
<LearningPathProvider
|
|
baseUrl={process.env.NEXT_PUBLIC_BASE_PATH || "/resources"}
|
|
>
|
|
<NotificationProvider initial={[helpButtonNotification]}>
|
|
<ScrollControllerProvider scrollableSelector="#main">
|
|
<SidebarProvider>
|
|
<PaginationProvider>
|
|
<SearchProvider>
|
|
<HooksLoader
|
|
options={{
|
|
pageScrollManager: true,
|
|
currentLearningPath: true,
|
|
}}
|
|
>
|
|
{children}
|
|
</HooksLoader>
|
|
</SearchProvider>
|
|
</PaginationProvider>
|
|
</SidebarProvider>
|
|
</ScrollControllerProvider>
|
|
</NotificationProvider>
|
|
</LearningPathProvider>
|
|
</ModalProvider>
|
|
</ColorModeProvider>
|
|
</MobileProvider>
|
|
</SiteConfigProvider>
|
|
</AnalyticsProvider>
|
|
)
|
|
}
|
|
|
|
export default Providers
|