fluffychat/lib/widgets/connection_status_header.dart

92 lines
2.5 KiB
Dart
Raw Normal View History

2020-07-04 08:22:51 +00:00
import 'dart:async';
2021-10-26 16:50:34 +00:00
2020-07-04 08:22:51 +00:00
import 'package:flutter/material.dart';
2021-10-26 16:50:34 +00:00
import 'package:flutter_gen/gen_l10n/l10n.dart';
2021-10-26 16:50:34 +00:00
import 'package:matrix/matrix.dart';
2020-07-04 08:22:51 +00:00
import '../config/themes.dart';
2021-10-26 16:50:34 +00:00
import '../utils/localized_exception_extension.dart';
2020-07-04 08:22:51 +00:00
import 'matrix.dart';
class ConnectionStatusHeader extends StatefulWidget {
const ConnectionStatusHeader({super.key});
2021-10-14 16:09:30 +00:00
2020-07-04 08:22:51 +00:00
@override
2022-08-14 14:59:21 +00:00
ConnectionStatusHeaderState createState() => ConnectionStatusHeaderState();
2020-07-04 08:22:51 +00:00
}
2022-08-14 14:59:21 +00:00
class ConnectionStatusHeaderState extends State<ConnectionStatusHeader> {
2022-07-09 08:18:53 +00:00
late final StreamSubscription _onSyncSub;
2021-11-23 18:34:55 +00:00
2022-07-09 08:18:53 +00:00
@override
void initState() {
_onSyncSub = Matrix.of(context).client.onSyncStatus.stream.listen(
(_) => setState(() {}),
);
super.initState();
}
2020-07-04 08:22:51 +00:00
@override
void dispose() {
2022-07-09 08:18:53 +00:00
_onSyncSub.cancel();
2020-07-04 08:22:51 +00:00
super.dispose();
}
@override
Widget build(BuildContext context) {
final client = Matrix.of(context).client;
final status = client.onSyncStatus.value ??
2022-07-09 08:18:53 +00:00
const SyncStatusUpdate(SyncStatus.waitingForResponse);
final hide = client.onSync.value != null &&
2022-07-09 08:18:53 +00:00
status.status != SyncStatus.error &&
client.prevBatch != null;
2021-11-23 18:34:55 +00:00
2020-07-04 08:22:51 +00:00
return AnimatedContainer(
duration: FluffyThemes.animationDuration,
curve: FluffyThemes.animationCurve,
2021-11-23 18:34:55 +00:00
height: hide ? 0 : 36,
clipBehavior: Clip.hardEdge,
2024-03-28 10:16:38 +00:00
decoration: const BoxDecoration(color: Colors.transparent),
2021-10-14 16:09:30 +00:00
padding: const EdgeInsets.symmetric(horizontal: 12),
child: Row(
mainAxisAlignment: MainAxisAlignment.center,
children: [
SizedBox(
width: 24,
height: 24,
2021-10-10 11:38:06 +00:00
child: CircularProgressIndicator.adaptive(
strokeWidth: 2,
2022-07-09 08:18:53 +00:00
value: hide ? 1.0 : status.progress,
),
),
2021-10-14 16:09:30 +00:00
const SizedBox(width: 12),
Text(
2022-07-09 08:18:53 +00:00
status.toLocalizedString(context),
maxLines: 1,
overflow: TextOverflow.ellipsis,
2022-06-04 18:06:57 +00:00
style: TextStyle(color: Theme.of(context).colorScheme.onSurface),
),
],
),
2020-07-04 08:22:51 +00:00
);
}
}
extension on SyncStatusUpdate {
String toLocalizedString(BuildContext context) {
switch (status) {
case SyncStatus.waitingForResponse:
2021-11-19 19:38:16 +00:00
return L10n.of(context)!.loadingPleaseWait;
case SyncStatus.error:
2021-11-19 19:38:16 +00:00
return ((error?.exception ?? Object()) as Object)
.toLocalizedString(context);
case SyncStatus.processing:
case SyncStatus.cleaningUp:
case SyncStatus.finished:
default:
2021-11-19 19:38:16 +00:00
return L10n.of(context)!.synchronizingPleaseWait;
}
}
}