fluffychat/lib/widgets/connection_status_header.dart

96 lines
2.8 KiB
Dart
Raw Normal View History

2020-07-04 10:22:51 +02:00
import 'dart:async';
2021-10-26 18:50:34 +02:00
2020-07-04 10:22:51 +02:00
import 'package:flutter/material.dart';
2021-10-26 18:50:34 +02:00
import 'package:flutter_gen/gen_l10n/l10n.dart';
2021-10-26 18:50:34 +02:00
import 'package:matrix/matrix.dart';
2020-07-04 10:22:51 +02:00
2021-10-26 18:50:34 +02:00
import '../utils/localized_exception_extension.dart';
2020-07-04 10:22:51 +02:00
import 'matrix.dart';
class ConnectionStatusHeader extends StatefulWidget {
2021-10-14 18:09:30 +02:00
const ConnectionStatusHeader({Key key}) : super(key: key);
2020-07-04 10:22:51 +02:00
@override
_ConnectionStatusHeaderState createState() => _ConnectionStatusHeaderState();
}
class _ConnectionStatusHeaderState extends State<ConnectionStatusHeader> {
StreamSubscription _onSyncSub;
StreamSubscription _onSyncErrorSub;
bool get _connected =>
DateTime.now().millisecondsSinceEpoch -
_lastSyncReceived.millisecondsSinceEpoch <
(Matrix.of(context).client.sendMessageTimeoutSeconds + 2) * 1000;
static DateTime _lastSyncReceived = DateTime(0);
2021-10-14 18:09:30 +02:00
SyncStatusUpdate _status =
const SyncStatusUpdate(SyncStatus.waitingForResponse);
2020-07-04 10:22:51 +02:00
@override
void dispose() {
_onSyncSub?.cancel();
_onSyncErrorSub?.cancel();
super.dispose();
}
@override
Widget build(BuildContext context) {
_onSyncSub ??= Matrix.of(context).client.onSyncStatus.stream.listen(
(status) => setState(
() {
if ((status.status == SyncStatus.processing &&
Matrix.of(context).client.prevBatch != null) ||
status.status == SyncStatus.finished) {
_lastSyncReceived = DateTime.now();
}
_status = status;
},
),
2020-07-04 10:22:51 +02:00
);
return AnimatedContainer(
2021-10-14 18:09:30 +02:00
duration: const Duration(milliseconds: 200),
2021-06-20 12:57:46 +02:00
curve: Curves.bounceInOut,
height: _connected ? 0 : 36,
clipBehavior: Clip.hardEdge,
2021-06-20 12:57:46 +02:00
decoration: BoxDecoration(color: Theme.of(context).secondaryHeaderColor),
2021-10-14 18:09:30 +02:00
padding: const EdgeInsets.symmetric(horizontal: 12),
child: Row(
mainAxisAlignment: MainAxisAlignment.center,
children: [
SizedBox(
width: 24,
height: 24,
2021-10-10 13:38:06 +02:00
child: CircularProgressIndicator.adaptive(
strokeWidth: 2,
value: _connected ? 1.0 : _status.progress,
),
),
2021-10-14 18:09:30 +02:00
const SizedBox(width: 12),
Text(
_status.toLocalizedString(context),
maxLines: 1,
overflow: TextOverflow.ellipsis,
),
],
),
2020-07-04 10:22:51 +02:00
);
}
}
extension on SyncStatusUpdate {
String toLocalizedString(BuildContext context) {
switch (status) {
case SyncStatus.waitingForResponse:
return L10n.of(context).loadingPleaseWait;
case SyncStatus.error:
return (error.exception as Object).toLocalizedString(context);
case SyncStatus.processing:
case SyncStatus.cleaningUp:
case SyncStatus.finished:
default:
return L10n.of(context).synchronizingPleaseWait;
}
}
}