ultisuite-client/lib/demo/demo-drive-context.tsx
R3D347HR4Y ad1370ea7e
Some checks are pending
E2E / Playwright e2e (push) Waiting to run
feat: enhance configuration and add new demo layouts
- Introduced turbopack alias for canvas in next.config.mjs.
- Updated package.json scripts for development and branding tasks.
- Added new dependencies for Tiptap extensions.
- Implemented new demo layouts for agenda, contacts, drive, and mail applications.
- Enhanced globals.css for improved theming and splash screen animations.
- Added OAuth callback handling for drive mounts.
- Updated layout components to integrate new demo shells and improve structure.
2026-06-12 19:10:24 +02:00

64 lines
1.3 KiB
TypeScript

"use client"
import {
createContext,
useCallback,
useContext,
useMemo,
type ReactNode,
} from "react"
import { toast } from "sonner"
export const DEMO_DRIVE_ROUTE_ROOT = "demo/drive"
export const DEFAULT_DRIVE_ROUTE_ROOT = "drive"
type DemoDriveContextValue = {
enabled: true
routeRoot: typeof DEMO_DRIVE_ROUTE_ROOT
reset: () => void
notify: (message: string) => void
}
const DemoDriveContext = createContext<DemoDriveContextValue | null>(null)
export function DemoDriveProvider({
children,
onReset,
}: {
children: ReactNode
onReset: () => void
}) {
const notify = useCallback((message: string) => {
toast.message(message, {
description: "Mode démo : rien n'est envoyé ni conservé.",
})
}, [])
const reset = useCallback(() => {
onReset()
notify("Démo réinitialisée")
}, [notify, onReset])
const value = useMemo<DemoDriveContextValue>(
() => ({
enabled: true,
routeRoot: DEMO_DRIVE_ROUTE_ROOT,
reset,
notify,
}),
[reset, notify]
)
return (
<DemoDriveContext.Provider value={value}>{children}</DemoDriveContext.Provider>
)
}
export function useDemoDrive(): DemoDriveContextValue | null {
return useContext(DemoDriveContext)
}
export function useIsDemoDrive(): boolean {
return useDemoDrive()?.enabled ?? false
}