38 lines
1.1 KiB
TypeScript
38 lines
1.1 KiB
TypeScript
|
import React from 'react'
|
||
|
|
||
|
import * as Dialog from '#/components/Dialog'
|
||
|
import {DialogControlProps} from '#/components/Dialog'
|
||
|
import {VerifyEmailIntentDialog} from '#/components/intents/VerifyEmailIntentDialog'
|
||
|
|
||
|
interface Context {
|
||
|
verifyEmailDialogControl: DialogControlProps
|
||
|
verifyEmailState: {code: string} | undefined
|
||
|
setVerifyEmailState: (state: {code: string} | undefined) => void
|
||
|
}
|
||
|
|
||
|
const Context = React.createContext({} as Context)
|
||
|
export const useIntentDialogs = () => React.useContext(Context)
|
||
|
|
||
|
export function Provider({children}: {children: React.ReactNode}) {
|
||
|
const verifyEmailDialogControl = Dialog.useDialogControl()
|
||
|
const [verifyEmailState, setVerifyEmailState] = React.useState<
|
||
|
{code: string} | undefined
|
||
|
>()
|
||
|
|
||
|
const value = React.useMemo(
|
||
|
() => ({
|
||
|
verifyEmailDialogControl,
|
||
|
verifyEmailState,
|
||
|
setVerifyEmailState,
|
||
|
}),
|
||
|
[verifyEmailDialogControl, verifyEmailState, setVerifyEmailState],
|
||
|
)
|
||
|
|
||
|
return (
|
||
|
<Context.Provider value={value}>
|
||
|
{children}
|
||
|
<VerifyEmailIntentDialog />
|
||
|
</Context.Provider>
|
||
|
)
|
||
|
}
|