onSnapshots method

Stream<List<SdbRecordSnapshot<K, V>>> onSnapshots(
  1. SdbDatabase db, {
  2. SdbFindOptions<K>? options,
})

Reads the data and set a listener to redo the query on changes, including changes made in other browser tabs.

Implementation

Stream<List<SdbRecordSnapshot<K, V>>> onSnapshots(
  SdbDatabase db, {
  SdbFindOptions<K>? options,
}) {
  late StreamController<List<SdbRecordSnapshot<K, V>>> controller;
  StreamSubscription<List<String>>? externalSub;
  void addSnapshots() {
    findRecords(db, options: options).then((snapshots) {
      if (!controller.isClosed) {
        controller.add(snapshots);
      }
    });
  }

  FutureOr<void> onChange(
    SdbTransaction transaction,
    List<SdbRecordChange<K, V>> changes,
  ) {
    addSnapshots();
  }

  controller = StreamController<List<SdbRecordSnapshot<K, V>>>(
    onListen: () {
      addSnapshots();
      addOnChangesListener(db, onChange);
      externalSub = db.impl.externalStoreChanges
          .where((storeNames) => storeNames.contains(name))
          .listen((_) => addSnapshots());
      controller.onCancel = () {
        externalSub?.cancel();
        externalSub = null;
        removeOnChangesListener(db, onChange);
      };
    },
  );
  return controller.stream;
}