ultisuite-client/lib/demo/demo-contacts-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_CONTACTS_ROUTE_ROOT = "demo/contacts"
type DemoContactsContextValue = {
enabled: true
routeRoot: typeof DEMO_CONTACTS_ROUTE_ROOT
reset: () => void
notify: (message: string) => void
}
const DemoContactsContext = createContext<DemoContactsContextValue | null>(null)
export function DemoContactsProvider({
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<DemoContactsContextValue>(
() => ({
enabled: true,
routeRoot: DEMO_CONTACTS_ROUTE_ROOT,
reset,
notify,
}),
[reset, notify]
)
return (
<DemoContactsContext.Provider value={value}>{children}</DemoContactsContext.Provider>
)
}
export function useDemoContacts(): DemoContactsContextValue | null {
return useContext(DemoContactsContext)
}
export function useIsDemoContacts(): boolean {
return useDemoContacts()?.enabled ?? false
}