71 lines
1.9 KiB
TypeScript
71 lines
1.9 KiB
TypeScript
|
import React from 'react'
|
||
|
|
||
|
import {BackgroundNotificationHandlerPreferences} from './ExpoBackgroundNotificationHandler.types'
|
||
|
import {BackgroundNotificationHandler} from './ExpoBackgroundNotificationHandlerModule'
|
||
|
|
||
|
interface BackgroundNotificationPreferencesContext {
|
||
|
preferences: BackgroundNotificationHandlerPreferences
|
||
|
setPref: <Key extends keyof BackgroundNotificationHandlerPreferences>(
|
||
|
key: Key,
|
||
|
value: BackgroundNotificationHandlerPreferences[Key],
|
||
|
) => void
|
||
|
}
|
||
|
|
||
|
const Context = React.createContext<BackgroundNotificationPreferencesContext>(
|
||
|
{} as BackgroundNotificationPreferencesContext,
|
||
|
)
|
||
|
export const useBackgroundNotificationPreferences = () =>
|
||
|
React.useContext(Context)
|
||
|
|
||
|
export function BackgroundNotificationPreferencesProvider({
|
||
|
children,
|
||
|
}: {
|
||
|
children: React.ReactNode
|
||
|
}) {
|
||
|
const [preferences, setPreferences] =
|
||
|
React.useState<BackgroundNotificationHandlerPreferences>({
|
||
|
playSoundChat: true,
|
||
|
})
|
||
|
|
||
|
React.useEffect(() => {
|
||
|
;(async () => {
|
||
|
const prefs = await BackgroundNotificationHandler.getAllPrefsAsync()
|
||
|
setPreferences(prefs)
|
||
|
})()
|
||
|
}, [])
|
||
|
|
||
|
const value = React.useMemo(
|
||
|
() => ({
|
||
|
preferences,
|
||
|
setPref: async <
|
||
|
Key extends keyof BackgroundNotificationHandlerPreferences,
|
||
|
>(
|
||
|
k: Key,
|
||
|
v: BackgroundNotificationHandlerPreferences[Key],
|
||
|
) => {
|
||
|
switch (typeof v) {
|
||
|
case 'boolean': {
|
||
|
await BackgroundNotificationHandler.setBoolAsync(k, v)
|
||
|
break
|
||
|
}
|
||
|
case 'string': {
|
||
|
await BackgroundNotificationHandler.setStringAsync(k, v)
|
||
|
break
|
||
|
}
|
||
|
default: {
|
||
|
throw new Error(`Invalid type for value: ${typeof v}`)
|
||
|
}
|
||
|
}
|
||
|
|
||
|
setPreferences(prev => ({
|
||
|
...prev,
|
||
|
[k]: v,
|
||
|
}))
|
||
|
},
|
||
|
}),
|
||
|
[preferences],
|
||
|
)
|
||
|
|
||
|
return <Context.Provider value={value}>{children}</Context.Provider>
|
||
|
}
|