ultisuite-client/lib/demo/demo-agenda-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

63 lines
1.3 KiB
TypeScript

"use client"
import {
createContext,
useCallback,
useContext,
useMemo,
type ReactNode,
} from "react"
import { toast } from "sonner"
export const DEMO_AGENDA_ROUTE_ROOT = "demo/agenda"
type DemoAgendaContextValue = {
enabled: true
routeRoot: typeof DEMO_AGENDA_ROUTE_ROOT
reset: () => void
notify: (message: string) => void
}
const DemoAgendaContext = createContext<DemoAgendaContextValue | null>(null)
export function DemoAgendaProvider({
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<DemoAgendaContextValue>(
() => ({
enabled: true,
routeRoot: DEMO_AGENDA_ROUTE_ROOT,
reset,
notify,
}),
[reset, notify]
)
return (
<DemoAgendaContext.Provider value={value}>{children}</DemoAgendaContext.Provider>
)
}
export function useDemoAgenda(): DemoAgendaContextValue | null {
return useContext(DemoAgendaContext)
}
export function useIsDemoAgenda(): boolean {
return useDemoAgenda()?.enabled ?? false
}