You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
38 lines
1.0 KiB
Dart
38 lines
1.0 KiB
Dart
import 'package:flutter/material.dart';
|
|
|
|
import 'package:matrix/matrix.dart';
|
|
|
|
import 'package:fluffychat/widgets/matrix.dart';
|
|
|
|
class PresenceBuilder extends StatelessWidget {
|
|
final Widget Function(BuildContext context, CachedPresence? presence) builder;
|
|
final String? userId;
|
|
final Client? client;
|
|
|
|
const PresenceBuilder({
|
|
required this.builder,
|
|
this.userId,
|
|
this.client,
|
|
super.key,
|
|
});
|
|
|
|
@override
|
|
Widget build(BuildContext context) {
|
|
final userId = this.userId;
|
|
if (userId == null) return builder(context, null);
|
|
|
|
final client = this.client ?? Matrix.of(context).client;
|
|
return FutureBuilder<CachedPresence>(
|
|
future: client.fetchCurrentPresence(userId),
|
|
builder: (context, cachedPresenceSnapshot) => StreamBuilder(
|
|
stream: client.onPresenceChanged.stream
|
|
.where((cachedPresence) => cachedPresence.userid == userId),
|
|
builder: (context, snapshot) => builder(
|
|
context,
|
|
snapshot.data ?? cachedPresenceSnapshot.data,
|
|
),
|
|
),
|
|
);
|
|
}
|
|
}
|