onSnapshots method

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

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

Implementation

Stream<List<SdbIndexRecordSnapshot<K, V, IK>>> onSnapshots(
  SdbDatabase db, {
  SdbFindOptions<IK>? options,
}) {
  late StreamController<List<SdbIndexRecordSnapshot<K, V, IK>>> 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<SdbIndexRecordSnapshot<K, V, IK>>>(
    onListen: () {
      addSnapshots();
      store.addOnChangesListener(db, onChange);
      externalSub = db.impl.externalStoreChanges
          .where((storeNames) => storeNames.contains(store.name))
          .listen((_) => addSnapshots());
      controller.onCancel = () {
        externalSub?.cancel();
        externalSub = null;
        store.removeOnChangesListener(db, onChange);
      };
    },
  );
  return controller.stream;
}