import React from 'react' import * as persisted from '#/state/persisted' type StateContext = persisted.Schema['largeAltBadgeEnabled'] type SetContext = (v: persisted.Schema['largeAltBadgeEnabled']) => void const stateContext = React.createContext( persisted.defaults.largeAltBadgeEnabled, ) stateContext.displayName = 'LargeAltBadgeStateContext' const setContext = React.createContext( (_: persisted.Schema['largeAltBadgeEnabled']) => {}, ) setContext.displayName = 'LargeAltBadgeSetContext' export function Provider({children}: React.PropsWithChildren<{}>) { const [state, setState] = React.useState( persisted.get('largeAltBadgeEnabled'), ) const setStateWrapped = React.useCallback( (largeAltBadgeEnabled: persisted.Schema['largeAltBadgeEnabled']) => { setState(largeAltBadgeEnabled) persisted.write('largeAltBadgeEnabled', largeAltBadgeEnabled) }, [setState], ) React.useEffect(() => { return persisted.onUpdate( 'largeAltBadgeEnabled', nextLargeAltBadgeEnabled => { setState(nextLargeAltBadgeEnabled) }, ) }, [setStateWrapped]) return ( {children} ) } export function useLargeAltBadgeEnabled() { return React.useContext(stateContext) } export function useSetLargeAltBadgeEnabled() { return React.useContext(setContext) }