signals-dart

star 783

Advanced reactive state primitives, collections, mixins, and utilities of signals_core.

rodydavis By rodydavis schedule Updated 5/25/2026

name: signals-dart description: Advanced reactive state primitives, collections, mixins, and utilities of signals_core.

Signals Core Advanced Primitives

This skill details advanced state management primitives, reactive collections, async features, and value options semantics in signals_core.

Related Documentation & Items

Core Primitives

Related File Description
signal.md Standard writeable reactive state primitive containing value accessors, mutation mechanics, and basic custom options.
computed.md Lazy, memoized read-only derived state signal tracking reactive dependencies dynamically.
effect.md Synchronous observer managing active subscription loops, dynamic dependency updates, and lifecycle teardown.
readonly.md Read-only signal views ensuring unidirectional data access flows.
batch.md Transactional state mutation blocks optimizing reactive computations and preventing rendering/recompute churn.

Asynchronous Operations

Related File Description
future_signal.md Single-evaluation asynchronous future state representation resolving the double-evaluation issue.
stream_signal.md Dynamic, lifecycle-safe, self-disposing stream listener mapping to async loading/data/error states.
async_signal.md Unifying async state container mapping loading, success data, and failure error states cleanly.
computed_async.md Composable asynchronous operations built over reactive signals with active race condition protection.
computed_from.md State aggregator signal merging multiple async signals into a single unified result.

Reactive Collections

Related File Description
list_signal.md Optimized list wrapper proxying standard operations to support element-level reactivity.
set_signal.md Custom set wrapper ignoring duplicates and notifying on unique mutations.
map_signal.md Granular map wrapper supporting isolated dictionary element lookup triggers.
iterable_signal.md Iterable wrapper mapping custom lazy traversals to dynamic subscription layers.
queue_signal.md Double-ended queue wrapper supporting optimized reactive pipeline structures.

Utility Primitives

Related File Description
linked_signal.md Writable computed signals supporting manual override resets and custom equivalence checks.
tracked_signal.md State history wrapper enabling clean out-of-the-box undo/redo mechanisms.
timer_signal.md Periodically emitting stopwatch signal with built-in pause, resume, and reset.
connect.md Dynamic event connector feeding multiple external data pipelines into single targets.

Core Primitives Quick Start Guide

The signals library exposes five core functions which are the building blocks to model any reactive business logic.

1. signal(initialValue)

Creates a new mutable signal container. You read a signal's value or subscribe to updates by accessing .value.

final counter = signal(0);
print(counter.value); // 0
counter.value = 1; // Mutates value and schedules dependent updates

.peek()

Reads a signal's current value without subscribing to its mutations.

final counter = signal(0);
final logCount = signal(0);

effect(() {
  print(counter.value);
  // Read using peek to avoid subscribing/triggering loop
  logCount.value = logCount.peek() + 1;
});

2. untracked(fn)

Executes a callback that reads signals without subscribing to any of them.

final counter = signal(0);
final count = signal(0);

effect(() {
  print(counter.value);
  count.value = untracked(() => count.value + 1);
});

3. computed(fn)

Combines the values of multiple signals into a lazy, memoized derived signal.

final first = signal('John');
final last = signal('Doe');
final fullName = computed(() => '${first.value} ${last.value}');
print(fullName.value); // John Doe

4. effect(fn)

Orchestrates immediate synchronous side effects by running a callback and subscribing to any signals read within it.

final name = signal('Jane');
final dispose = effect(() => print('Hello $name'));
dispose(); // Clean up subscription

5. batch(fn)

Groups multiple signal writes into a single transaction, executing all dependent computed evaluations and effects exactly once at the end.

final a = signal(0);
final b = signal(0);

batch(() {
  a.value = 1;
  b.value = 2;
});

1. Writable Computed Signal (linkedSignal)

A writable computed signal (LinkedSignal) provides a derived default value that can be overridden manually, resetting back to the derived default whenever its upstream dependencies mutate.

Usage

// Basic reset shorthand:
final size = signal('M');
final selection = linkedSignal(() => size.value);

// Advanced structural comparison:
final user = signal((id: 1, name: 'Alice'));
final name = linkedSignal<String, ({int id, String name})>(
  () => user.value,
  options: LinkedSignalOptions(
    computation: (u, prev) {
      if (prev != null && prev.source.id == u.id) {
        return prev.value; // Retain manual override
      }
      return u.name; // Reset on ID changes
    },
  ),
);

2. Collections and Async Primitives

A. Collections

Always use specialized collections (listSignal, setSignal, mapSignal, etc.) to wrap collections to ensure optimized mutations (only triggering updates when elements actually change).

final list = listSignal([1, 2], options: ListSignalOptions(autoDispose: true));
list.add(3); // Reacts to changes

B. Optimized FutureSignal

FutureSignal inherits directly from AsyncSignal to bypass Stream subscription overhead and tracks its dependencies manually via computed execution, executing future computations exactly once (avoiding double-evaluation loops).

final search = signal('');
final results = futureSignal(() => fetchResults(search.value));

3. Options Classes Value Semantics

All signal option objects support full value semantics (copyWith, custom equality, and hashCode overrides) for flexible copying and accurate comparisons:

  • SignalOptions
  • ComputedOptions
  • AsyncSignalOptions
  • LinkedSignalOptions
  • ListSignalOptions / SetSignalOptions / MapSignalOptions
Install via CLI
npx skills add https://github.com/rodydavis/signals.dart --skill signals-dart
Repository Details
star Stars 783
call_split Forks 82
navigation Branch main
article Path SKILL.md
More from Creator