feat: add AdminContext for managing upload state in admin dashboard

This commit is contained in:
Ardeman 2025-03-09 20:22:48 +08:00
parent 0f414f6963
commit c7583413bb
3 changed files with 56 additions and 3 deletions

47
app/contexts/admin.tsx Normal file
View File

@ -0,0 +1,47 @@
import {
createContext,
useState,
useContext,
type PropsWithChildren,
type Dispatch,
type SetStateAction,
} from 'react'
type TUpload =
| 'featured_image'
| 'ads'
| 'content'
| 'profile_picture'
| undefined
type AdminContextProperties = {
isUploadOpen: TUpload
setIsUploadOpen: Dispatch<SetStateAction<TUpload>>
}
const AdminContext = createContext<AdminContextProperties | undefined>(
undefined,
)
export const AdminProvider = ({ children }: PropsWithChildren) => {
const [isUploadOpen, setIsUploadOpen] = useState<TUpload>()
return (
<AdminContext.Provider
value={{
isUploadOpen,
setIsUploadOpen,
}}
>
{children}
</AdminContext.Provider>
)
}
export const useAdminContext = (): AdminContextProperties => {
const context = useContext(AdminContext)
if (!context) {
throw new Error('useAdminContext must be used within a AdminProvider')
}
return context
}

View File

@ -1,10 +1,13 @@
import type { PropsWithChildren } from 'react' import type { PropsWithChildren } from 'react'
import { useAdminContext } from '~/contexts/admin'
import { Navbar } from './navbar' import { Navbar } from './navbar'
import { Sidebar } from './sidebar' import { Sidebar } from './sidebar'
export const AdminDashboardLayout = (properties: PropsWithChildren) => { export const AdminDashboardLayout = (properties: PropsWithChildren) => {
const { children } = properties const { children } = properties
const {} = useAdminContext()
return ( return (
<div className="flex flex-col"> <div className="flex flex-col">
<Navbar /> <Navbar />

View File

@ -2,6 +2,7 @@ import { Outlet } from 'react-router'
import { getCategories } from '~/apis/common/get-categories' import { getCategories } from '~/apis/common/get-categories'
import { getTags } from '~/apis/common/get-tags' import { getTags } from '~/apis/common/get-tags'
import { AdminProvider } from '~/contexts/admin'
import { AdminDashboardLayout } from '~/layouts/admin/dashboard' import { AdminDashboardLayout } from '~/layouts/admin/dashboard'
import type { Route } from './+types/_admin.lg-admin._dashboard' import type { Route } from './+types/_admin.lg-admin._dashboard'
@ -18,9 +19,11 @@ export const loader = async ({}: Route.LoaderArgs) => {
const DashboardLayout = () => { const DashboardLayout = () => {
return ( return (
<AdminDashboardLayout> <AdminProvider>
<Outlet /> <AdminDashboardLayout>
</AdminDashboardLayout> <Outlet />
</AdminDashboardLayout>
</AdminProvider>
) )
} }
export default DashboardLayout export default DashboardLayout