UNPKG

react-native-turbo-preferences

Version:

Modern TurboModule wrapper for iOS NSUserDefaults and Android SharedPreferences.

76 lines (73 loc) 2.25 kB
"use strict"; import { useState, useCallback, useEffect } from 'react'; import TurboPreferences from "../NativeTurboPreferences.js"; /** * React hook for managing a number preference * * @param key - The preference key * @returns [value, setValue, contains, clear] * * @example * ```tsx * function Counter() { * const [count, setCount, hasCount, clearCount] = usePreferenceNumber('count'); * * return ( * <View> * <Text>Count: {count ?? 0}</Text> * <Button title="+1" onPress={() => setCount((count ?? 0) + 1)} /> * <Button title="Clear" onPress={clearCount} /> * </View> * ); * } * ``` */ export function usePreferenceNumber(key) { const [value, setValue] = useState(null); const [contains, setContains] = useState(false); const setPreferenceValue = useCallback(async newValue => { if (!key) return; try { // Convert number to string for storage await TurboPreferences.set(key, String(newValue)); setValue(newValue); setContains(true); } catch (error) { console.warn('usePreferenceNumber setValue error:', error); throw error; } }, [key]); const clearPreferenceValue = useCallback(async () => { if (!key) return; try { await TurboPreferences.clear(key); setValue(null); setContains(false); } catch (error) { console.warn('usePreferenceNumber clear error:', error); throw error; } }, [key]); // Load initial value on mount and key change useEffect(() => { if (!key) return; const loadInitialValue = async () => { try { const [currentValue, exists] = await Promise.all([TurboPreferences.get(key), TurboPreferences.contains(key)]); if (currentValue !== null) { const numValue = Number(currentValue); // Check if it's a valid number setValue(isNaN(numValue) ? null : numValue); } else { setValue(null); } setContains(exists); } catch (error) { console.warn('usePreferenceNumber load error:', error); } }; loadInitialValue(); }, [key]); return [value, setPreferenceValue, contains, clearPreferenceValue]; } //# sourceMappingURL=usePreferenceNumber.js.map