PrfEnum<T extends Enum> class
A type-safe wrapper for storing and retrieving enum values in SharedPreferences.
This class automatically handles the conversion between enum values and their integer indices for storage in SharedPreferences.
Use this class for storing enumerated types like application states, user roles, theme modes, or any other enum-based selections.
Example:
enum ThemeMode { light, dark, system }
final themePreference = PrfEnum<ThemeMode>(
'theme_mode',
values: ThemeMode.values,
defaultValue: ThemeMode.system,
);
await themePreference.set(ThemeMode.dark);
final mode = await themePreference.get(); // ThemeMode.dark
- Inheritance
-
- Object
- PrfVariable<
T> - PrfEncoded<
T, int> - PrfEnum
Constructors
Properties
- defaultValue → T?
-
Default value to use when no value is stored yet.
finalinherited
- hashCode → int
-
The hash code for this object.
no setterinherited
- key → String
-
Unique key used to store this variable in SharedPreferences.
finalinherited
- runtimeType → Type
-
A representation of the runtime type of the object.
no setterinherited
Methods
-
getValue(
SharedPreferences prefs) → Future< T?> -
Retrieves the current value from cache or SharedPreferences.
inherited
-
isValueNull(
SharedPreferences prefs) → Future< bool> -
Checks if the current value is null.
inherited
-
noSuchMethod(
Invocation invocation) → dynamic -
Invoked when a nonexistent method or property is accessed.
inherited
-
removeValue(
SharedPreferences prefs) → Future< void> -
Removes the value from both the cache and SharedPreferences.
inherited
-
setValue(
SharedPreferences prefs, T value) → Future< bool> -
Saves a new value to SharedPreferences and updates the cache.
inherited
-
toString(
) → String -
A string representation of this object.
inherited
Operators
-
operator ==(
Object other) → bool -
The equality operator.
inherited