PersistSignalImpl<T> class
Implementation of PersistSignal that persists its value to external storage.
This is the concrete implementation of the PersistSignal interface. PersistSignal automatically saves its value to external storage whenever it changes and loads the initial value from storage when created. It supports both synchronous and asynchronous read/write operations.
See PersistSignal for the public interface and usage examples.
Example:
final theme = PersistSignal(
initialValue: () => 'light',
read: () => SharedPreferences.getInstance()
.then((prefs) => prefs.getString('theme') ?? 'light'),
write: (value) => SharedPreferences.getInstance()
.then((prefs) => prefs.setString('theme', value)),
);
theme.value = 'dark'; // Automatically saved to storage
- Inheritance
-
- Object
- ReactiveNode
- SignalReactiveNode<
T> - SignalImpl<
T> - PersistSignalImpl
- Implemented types
- Available extensions
Constructors
-
PersistSignalImpl({required FutureOr<
T> read(), required FutureOr<void> write(T value), T initialValue()?, bool lazy = false, Duration writeDelay = Duration.zero, JoltDebugFn? onDebug}) - Creates a persistent signal with the given configuration.
Properties
- cachedValue ↔ T?
-
getter/setter pairinherited
- deps ↔ Link?
-
First dependency link in the chain.
getter/setter pairinherited
- depsTail ↔ Link?
-
Last dependency link in the chain.
getter/setter pairinherited
- flags ↔ int
-
Reactive flags for this node.
getter/setter pairinherited
- hashCode → int
-
The hash code for this object.
no setterinherited
- hasInitialized ↔ bool
-
Whether the signal has been initialized from storage.
getter/setter pairoverride-getter
- isDisposed → bool
-
Whether this node has been disposed.
no setterinherited
-
listenable
→ JoltValueListenable<
T> -
Available on Readonly<
Converts this Jolt value to a Flutter ValueListenable.T> , provided by the JoltValueListenableExtension extensionno setter -
notifier
→ JoltValueNotifier<
T> -
Available on Readonly<
Converts this Jolt value to a Flutter ValueNotifier.T> , provided by the JoltValueNotifierExtension extensionno setter - peek → T
-
Returns the current value without establishing a reactive dependency.
no setterinherited
- pendingValue ↔ T?
-
getter/setter pairinherited
-
read
→ FutureOr<
T> Function() -
Function to read the value from storage.
final
- runtimeType → Type
-
A representation of the runtime type of the object.
no setterinherited
-
stream
→ Stream<
T> -
Available on ReadonlyNode<
Converts this reactive value to a broadcast stream.T> , provided by the JoltReadonlyExtension extensionno setter - subs ↔ Link?
-
First subscriber link in the chain.
getter/setter pairinherited
- subsTail ↔ Link?
-
Last subscriber link in the chain.
getter/setter pairinherited
- value ↔ T
-
Returns the current value and establishes a reactive dependency.
getter/setter pairinherited
-
write
→ FutureOr<
void> Function(T value) -
Function to write the value to storage.
final
- writeDelay → Duration
-
Delay before writing to storage (for debouncing).
final
Methods
-
dispose(
) → void -
Disposes this node and cleans up resources.
inherited
-
ensure(
FutureOr< void> fn()?) → Future<void> -
Ensures the signal is initialized and runs the given function.
override
-
get(
) → T -
Returns the current value and establishes a reactive dependency.
override
-
getEnsured(
) → Future< T> -
Gets the value and ensures it's loaded from storage.
override
-
listen(
void onData(T event)?, {Function? onError, void onDone()?, bool? cancelOnError, bool immediately = false}) → StreamSubscription< T> -
Available on ReadonlyNode<
Creates a stream subscription that listens to changes in this reactive value.T> , provided by the JoltReadonlyExtension extension -
noSuchMethod(
Invocation invocation) → dynamic -
Invoked when a nonexistent method or property is accessed.
inherited
-
notify(
) → void -
Manually notifies all subscribers that this signal has changed.
inherited
-
onDispose(
) → void -
Disposes the signal and cleans up resources.
inherited
-
readonly(
) → ReadonlySignal< T> -
Available on Signal<
Returns a read-only view of this signal.T> , provided by the JoltSignalExtension extension -
set(
T value) → T -
Sets a new value for the signal and notifies subscribers when it changes.
override
-
setEnsured(
T value, {bool optimistic = false}) → Future< bool> -
Sets a value and ensures it's written to storage before completing.
override
-
toString(
) → String -
A string representation of this object.
inherited
-
until(
bool predicate(T value)) → Future< T> -
Available on ReadonlyNode<
Waits until the reactive value satisfies a predicate condition.T> , provided by the JoltReadonlyExtension extension -
update(
T updater(T value)) → T -
Available on WritableNode<
Updates the value using an updater function based on the current value.T> , provided by the JoltWritableExtension extension
Operators
-
operator ==(
Object other) → bool -
The equality operator.
inherited