feat: add AdminContext for managing upload state in admin dashboard
This commit is contained in:
parent
0f414f6963
commit
c7583413bb
47
app/contexts/admin.tsx
Normal file
47
app/contexts/admin.tsx
Normal 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
|
||||||
|
}
|
||||||
@ -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 />
|
||||||
|
|||||||
@ -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 (
|
||||||
|
<AdminProvider>
|
||||||
<AdminDashboardLayout>
|
<AdminDashboardLayout>
|
||||||
<Outlet />
|
<Outlet />
|
||||||
</AdminDashboardLayout>
|
</AdminDashboardLayout>
|
||||||
|
</AdminProvider>
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
export default DashboardLayout
|
export default DashboardLayout
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user