mirror of
https://github.com/DocNR/POWR.git
synced 2025-04-19 19:01:18 +00:00
33 lines
1.1 KiB
TypeScript
33 lines
1.1 KiB
TypeScript
![]() |
// lib/contexts/SettingsDrawerContext.tsx
|
||
|
import React, { createContext, useContext, useState, ReactNode } from 'react';
|
||
|
|
||
|
interface SettingsDrawerContextType {
|
||
|
isDrawerOpen: boolean;
|
||
|
openDrawer: () => void;
|
||
|
closeDrawer: () => void;
|
||
|
toggleDrawer: () => void;
|
||
|
}
|
||
|
|
||
|
const SettingsDrawerContext = createContext<SettingsDrawerContextType | undefined>(undefined);
|
||
|
|
||
|
export function SettingsDrawerProvider({ children }: { children: ReactNode }) {
|
||
|
const [isDrawerOpen, setIsDrawerOpen] = useState(false);
|
||
|
|
||
|
const openDrawer = () => setIsDrawerOpen(true);
|
||
|
const closeDrawer = () => setIsDrawerOpen(false);
|
||
|
const toggleDrawer = () => setIsDrawerOpen(prev => !prev);
|
||
|
|
||
|
return (
|
||
|
<SettingsDrawerContext.Provider value={{ isDrawerOpen, openDrawer, closeDrawer, toggleDrawer }}>
|
||
|
{children}
|
||
|
</SettingsDrawerContext.Provider>
|
||
|
);
|
||
|
}
|
||
|
|
||
|
export function useSettingsDrawer(): SettingsDrawerContextType {
|
||
|
const context = useContext(SettingsDrawerContext);
|
||
|
if (context === undefined) {
|
||
|
throw new Error('useSettingsDrawer must be used within a SettingsDrawerProvider');
|
||
|
}
|
||
|
return context;
|
||
|
}
|