diff options
Diffstat (limited to 'src/state/shell')
-rw-r--r-- | src/state/shell/drawer-open.tsx | 24 | ||||
-rw-r--r-- | src/state/shell/drawer-swipe-disabled.tsx | 24 | ||||
-rw-r--r-- | src/state/shell/index.tsx | 21 | ||||
-rw-r--r-- | src/state/shell/minimal-mode.tsx | 24 |
4 files changed, 93 insertions, 0 deletions
diff --git a/src/state/shell/drawer-open.tsx b/src/state/shell/drawer-open.tsx new file mode 100644 index 000000000..a2322f680 --- /dev/null +++ b/src/state/shell/drawer-open.tsx @@ -0,0 +1,24 @@ +import React from 'react' + +type StateContext = boolean +type SetContext = (v: boolean) => void + +const stateContext = React.createContext<StateContext>(false) +const setContext = React.createContext<SetContext>((_: boolean) => {}) + +export function Provider({children}: React.PropsWithChildren<{}>) { + const [state, setState] = React.useState(false) + return ( + <stateContext.Provider value={state}> + <setContext.Provider value={setState}>{children}</setContext.Provider> + </stateContext.Provider> + ) +} + +export function useIsDrawerOpen() { + return React.useContext(stateContext) +} + +export function useSetDrawerOpen() { + return React.useContext(setContext) +} diff --git a/src/state/shell/drawer-swipe-disabled.tsx b/src/state/shell/drawer-swipe-disabled.tsx new file mode 100644 index 000000000..d3f09f2a8 --- /dev/null +++ b/src/state/shell/drawer-swipe-disabled.tsx @@ -0,0 +1,24 @@ +import React from 'react' + +type StateContext = boolean +type SetContext = (v: boolean) => void + +const stateContext = React.createContext<StateContext>(false) +const setContext = React.createContext<SetContext>((_: boolean) => {}) + +export function Provider({children}: React.PropsWithChildren<{}>) { + const [state, setState] = React.useState(false) + return ( + <stateContext.Provider value={state}> + <setContext.Provider value={setState}>{children}</setContext.Provider> + </stateContext.Provider> + ) +} + +export function useIsDrawerSwipeDisabled() { + return React.useContext(stateContext) +} + +export function useSetDrawerSwipeDisabled() { + return React.useContext(setContext) +} diff --git a/src/state/shell/index.tsx b/src/state/shell/index.tsx new file mode 100644 index 000000000..ac2f24b4a --- /dev/null +++ b/src/state/shell/index.tsx @@ -0,0 +1,21 @@ +import React from 'react' +import {Provider as DrawerOpenProvider} from './drawer-open' +import {Provider as DrawerSwipableProvider} from './drawer-swipe-disabled' +import {Provider as MinimalModeProvider} from './minimal-mode' + +export {useIsDrawerOpen, useSetDrawerOpen} from './drawer-open' +export { + useIsDrawerSwipeDisabled, + useSetDrawerSwipeDisabled, +} from './drawer-swipe-disabled' +export {useMinimalShellMode, useSetMinimalShellMode} from './minimal-mode' + +export function Provider({children}: React.PropsWithChildren<{}>) { + return ( + <DrawerOpenProvider> + <DrawerSwipableProvider> + <MinimalModeProvider>{children}</MinimalModeProvider> + </DrawerSwipableProvider> + </DrawerOpenProvider> + ) +} diff --git a/src/state/shell/minimal-mode.tsx b/src/state/shell/minimal-mode.tsx new file mode 100644 index 000000000..4909a9a65 --- /dev/null +++ b/src/state/shell/minimal-mode.tsx @@ -0,0 +1,24 @@ +import React from 'react' + +type StateContext = boolean +type SetContext = (v: boolean) => void + +const stateContext = React.createContext<StateContext>(false) +const setContext = React.createContext<SetContext>((_: boolean) => {}) + +export function Provider({children}: React.PropsWithChildren<{}>) { + const [state, setState] = React.useState(false) + return ( + <stateContext.Provider value={state}> + <setContext.Provider value={setState}>{children}</setContext.Provider> + </stateContext.Provider> + ) +} + +export function useMinimalShellMode() { + return React.useContext(stateContext) +} + +export function useSetMinimalShellMode() { + return React.useContext(setContext) +} |