-
Notifications
You must be signed in to change notification settings - Fork 36
/
Copy pathuseFlag.ts
39 lines (31 loc) · 976 Bytes
/
useFlag.ts
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
import { useContext, useEffect, useState, useRef } from 'react';
import FlagContext from './FlagContext';
const useFlag = (featureName: string) => {
const { isEnabled, client } = useContext(FlagContext);
const [flag, setFlag] = useState(!!isEnabled(featureName));
const flagRef = useRef<typeof flag>();
flagRef.current = flag;
useEffect(() => {
if (!client) return;
const updateHandler = () => {
const enabled = isEnabled(featureName);
if (enabled !== flagRef.current) {
flagRef.current = enabled;
setFlag(!!enabled);
}
};
const readyHandler = () => {
const enabled = isEnabled(featureName);
flagRef.current = enabled;
setFlag(enabled);
};
client.on('update', updateHandler);
client.on('ready', readyHandler);
return () => {
client.off('update', updateHandler);
client.off('ready', readyHandler);
};
}, [client]);
return flag;
};
export default useFlag;