fix: Update contact list

This commit is contained in:
Christian Pauly 2021-02-07 09:55:24 +01:00
parent fe13778eb6
commit d870ec3029

View File

@ -23,6 +23,7 @@ class _ContactListState extends State<ContactList> {
String _searchQuery = ''; String _searchQuery = '';
final ScrollController _scrollController = ScrollController(); final ScrollController _scrollController = ScrollController();
StreamSubscription _onAppBarButtonTapSub; StreamSubscription _onAppBarButtonTapSub;
StreamSubscription _onSync;
final GlobalKey<DefaultAppBarSearchFieldState> _searchField = GlobalKey(); final GlobalKey<DefaultAppBarSearchFieldState> _searchField = GlobalKey();
@override @override
@ -43,12 +44,31 @@ class _ContactListState extends State<ContactList> {
@override @override
void dispose() { void dispose() {
_onSync?.cancel();
_onAppBarButtonTapSub?.cancel(); _onAppBarButtonTapSub?.cancel();
super.dispose(); super.dispose();
} }
DateTime _lastSetState = DateTime.now();
Timer _coolDown;
void _updateView() {
_lastSetState = DateTime.now();
setState(() => null);
}
@override @override
Widget build(BuildContext context) { Widget build(BuildContext context) {
_onSync ??= Matrix.of(context).client.onSync.stream.listen((_) {
if (DateTime.now().millisecondsSinceEpoch -
_lastSetState.millisecondsSinceEpoch <
1000) {
_coolDown?.cancel();
_coolDown = Timer(Duration(seconds: 1), _updateView);
} else {
_updateView();
}
});
return ListView( return ListView(
controller: _scrollController, controller: _scrollController,
children: [ children: [
@ -74,15 +94,12 @@ class _ContactListState extends State<ContactList> {
AdaptivePageLayout.of(context).pushNamed('/newprivatechat'), AdaptivePageLayout.of(context).pushNamed('/newprivatechat'),
), ),
Divider(height: 1), Divider(height: 1),
StreamBuilder<Object>( Builder(builder: (context) {
stream: Matrix.of(context).client.onSync.stream,
builder: (context, snapshot) {
final contactList = Matrix.of(context) final contactList = Matrix.of(context)
.client .client
.contactList .contactList
.where((p) => p.senderId .where((p) =>
.toLowerCase() p.senderId.toLowerCase().contains(_searchQuery.toLowerCase()))
.contains(_searchQuery.toLowerCase()))
.toList(); .toList();
if (contactList.isEmpty) { if (contactList.isEmpty) {
return Column( return Column(
@ -97,8 +114,7 @@ class _ContactListState extends State<ContactList> {
elevation: 7, elevation: 7,
color: Theme.of(context).primaryColor, color: Theme.of(context).primaryColor,
shape: RoundedRectangleBorder( shape: RoundedRectangleBorder(
borderRadius: borderRadius: BorderRadius.circular(AppConfig.borderRadius),
BorderRadius.circular(AppConfig.borderRadius),
), ),
child: Row( child: Row(
mainAxisSize: MainAxisSize.min, mainAxisSize: MainAxisSize.min,