47 lines
1.2 KiB
TypeScript
Raw Normal View History

import React, {
createContext,
useState,
useContext,
type PropsWithChildren,
} from 'react'
type NewsContextProperties = {
isLoginOpen: boolean
setIsLoginOpen: React.Dispatch<React.SetStateAction<boolean>>
isRegisterOpen: boolean
setIsRegisterOpen: React.Dispatch<React.SetStateAction<boolean>>
2025-02-22 21:17:56 +07:00
isForgetOpen: boolean
setForgetOpen: React.Dispatch<React.SetStateAction<boolean>>
}
const NewsContext = createContext<NewsContextProperties | undefined>(undefined)
export const NewsProvider = ({ children }: PropsWithChildren) => {
const [isLoginOpen, setIsLoginOpen] = useState(false)
const [isRegisterOpen, setIsRegisterOpen] = useState(false)
2025-02-22 21:17:56 +07:00
const [isForgetOpen, setForgetOpen] = useState(false)
return (
<NewsContext.Provider
2025-02-22 21:17:56 +07:00
value={{
isLoginOpen,
setIsLoginOpen,
isRegisterOpen,
setIsRegisterOpen,
isForgetOpen,
setForgetOpen,
}}
>
{children}
</NewsContext.Provider>
)
}
export const useNewsContext = (): NewsContextProperties => {
const context = useContext(NewsContext)
if (!context) {
throw new Error('useNewsContext must be used within a NewsProvider')
}
return context
}