forked from canada-ca/tracker
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathUserState.js
More file actions
47 lines (38 loc) · 1.06 KB
/
UserState.js
File metadata and controls
47 lines (38 loc) · 1.06 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
import React, { useContext } from 'react'
import { makeVar, useApolloClient, useReactiveVar } from '@apollo/client'
import { node, func } from 'prop-types'
const UserVarContext = React.createContext({})
const { Provider } = UserVarContext
export function UserVarProvider({
userVar = makeVar({ jwt: null, tfaSendMethod: null, userName: null }),
children,
}) {
const client = useApolloClient()
const currentUser = useReactiveVar(userVar)
const isLoggedIn = () => {
return !!(
currentUser?.jwt ||
currentUser?.userName ||
currentUser?.tfaSendMethod
)
}
const login = (newUserState) => {
userVar(newUserState)
}
const logout = async () => {
userVar({ jwt: null, userName: null, tfaSendMethod: null })
await client.resetStore()
}
const userState = {
currentUser,
isLoggedIn,
login,
logout,
}
return <Provider value={userState}>{children}</Provider>
}
UserVarProvider.propTypes = {
userVar: func.isRequired,
children: node.isRequired,
}
export const useUserVar = () => useContext(UserVarContext)