2024-04-18 03:05:48 +02:00
|
|
|
import { useEffect, useCallback } from 'react';
|
2024-02-22 03:08:20 +01:00
|
|
|
// @ts-ignore: react-native-obscure is not in the type definition
|
|
|
|
import Obscure from 'react-native-obscure';
|
2024-04-18 03:05:48 +02:00
|
|
|
import { useSettings } from '../components/Context/SettingsContext';
|
2024-02-22 03:08:20 +01:00
|
|
|
|
|
|
|
export const usePrivacy = () => {
|
2024-04-18 03:05:48 +02:00
|
|
|
const { isPrivacyBlurEnabled } = useSettings();
|
2024-02-22 03:08:20 +01:00
|
|
|
|
|
|
|
const enableBlur = useCallback(() => {
|
|
|
|
if (!isPrivacyBlurEnabled) return;
|
|
|
|
Obscure.activateObscure();
|
|
|
|
}, [isPrivacyBlurEnabled]);
|
|
|
|
|
|
|
|
const disableBlur = useCallback(() => {
|
|
|
|
Obscure.deactivateObscure();
|
|
|
|
}, []); // This doesn't depend on the isPrivacyBlurEnabled value
|
|
|
|
|
|
|
|
useEffect(() => {
|
|
|
|
// Automatically activate or deactivate on mount and when isPrivacyBlurEnabled changes
|
|
|
|
if (isPrivacyBlurEnabled) {
|
|
|
|
enableBlur();
|
|
|
|
} else {
|
|
|
|
disableBlur();
|
|
|
|
}
|
|
|
|
|
|
|
|
// Cleanup function to deactivate obscure when the component unmounts
|
|
|
|
return () => {
|
|
|
|
disableBlur();
|
|
|
|
};
|
|
|
|
}, [isPrivacyBlurEnabled, enableBlur, disableBlur]);
|
|
|
|
|
|
|
|
return { enableBlur, disableBlur };
|
|
|
|
};
|
|
|
|
|
|
|
|
export default usePrivacy;
|