ente/lib/ui/sync_indicator.dart

229 lines
6.9 KiB
Dart
Raw Normal View History

import 'dart:async';
import 'package:flutter/material.dart';
2020-11-12 16:32:10 +00:00
import 'package:photos/core/configuration.dart';
2021-02-26 09:21:47 +00:00
import 'package:photos/core/errors.dart';
import 'package:photos/core/event_bus.dart';
2020-11-16 16:35:16 +00:00
import 'package:photos/events/sync_status_update_event.dart';
2020-10-03 17:58:26 +00:00
import 'package:photos/services/sync_service.dart';
import 'package:photos/ui/common_elements.dart';
import 'package:photos/ui/subscription_page.dart';
class SyncIndicator extends StatefulWidget {
2020-11-12 16:32:10 +00:00
const SyncIndicator({Key key}) : super(key: key);
@override
_SyncIndicatorState createState() => _SyncIndicatorState();
}
class _SyncIndicatorState extends State<SyncIndicator> {
2020-11-12 16:32:10 +00:00
SyncStatusUpdate _event;
2020-11-16 16:35:16 +00:00
double _containerHeight = 48;
2020-11-12 16:32:10 +00:00
StreamSubscription<SyncStatusUpdate> _subscription;
@override
void initState() {
2020-11-12 16:32:10 +00:00
_subscription = Bus.instance.on<SyncStatusUpdate>().listen((event) {
setState(() {
_event = event;
});
});
2020-11-16 16:35:16 +00:00
_event = SyncService.instance.getLastSyncStatusEvent();
super.initState();
}
@override
void dispose() {
_subscription.cancel();
super.dispose();
}
@override
Widget build(BuildContext context) {
2021-03-21 06:27:23 +00:00
if (Configuration.instance.hasConfiguredAccount() && _event != null) {
2020-11-16 16:35:16 +00:00
if (_event.status == SyncStatus.completed) {
2020-11-19 14:49:01 +00:00
Future.delayed(Duration(milliseconds: 3000), () {
2020-12-08 19:29:51 +00:00
if (mounted) {
setState(() {
_containerHeight = 0;
});
}
2020-11-16 16:35:16 +00:00
});
} else {
_containerHeight = 48;
}
2021-02-26 09:56:17 +00:00
if (_event.status == SyncStatus.error) {
return _getErrorWidget();
} else {
var icon;
if (_event.status == SyncStatus.completed) {
icon = Icon(
Icons.cloud_done_outlined,
color: Theme.of(context).accentColor,
);
} else {
icon = CircularProgressIndicator(strokeWidth: 2);
}
return AnimatedContainer(
duration: Duration(milliseconds: 300),
height: _containerHeight,
width: double.infinity,
padding: EdgeInsets.all(8),
alignment: Alignment.center,
child: SingleChildScrollView(
physics: NeverScrollableScrollPhysics(),
child: Column(
mainAxisAlignment: MainAxisAlignment.center,
crossAxisAlignment: CrossAxisAlignment.center,
children: [
Row(
mainAxisAlignment: MainAxisAlignment.center,
crossAxisAlignment: CrossAxisAlignment.center,
children: [
Container(
2021-02-06 20:18:33 +00:00
padding: EdgeInsets.all(2),
width: 22,
height: 22,
child: icon,
),
Padding(
padding: const EdgeInsets.fromLTRB(12, 4, 0, 0),
child: Text(_getRefreshingText()),
),
],
),
Padding(padding: EdgeInsets.all(4)),
Divider(),
],
),
),
2020-11-16 16:35:16 +00:00
);
}
}
return Container();
}
Widget _getErrorWidget() {
if (_event.error is NoActiveSubscriptionError) {
return Container(
2021-02-05 16:07:14 +00:00
margin: EdgeInsets.only(top: 8),
child: Column(
children: [
Row(
mainAxisAlignment: MainAxisAlignment.center,
crossAxisAlignment: CrossAxisAlignment.center,
children: [
Icon(
Icons.error_outline,
color: Theme.of(context).accentColor,
),
Padding(padding: EdgeInsets.all(4)),
Text("your subscription has expired"),
],
),
Padding(padding: EdgeInsets.all(6)),
Container(
width: double.infinity,
height: 64,
padding: const EdgeInsets.fromLTRB(80, 0, 80, 0),
child: button("subscribe", onPressed: () {
Navigator.of(context).push(
MaterialPageRoute(
builder: (BuildContext context) {
return SubscriptionPage();
},
2020-11-12 16:32:10 +00:00
),
);
}),
),
Padding(padding: EdgeInsets.all(8)),
],
2020-11-16 16:35:16 +00:00
),
);
2021-02-02 19:01:32 +00:00
} else if (_event.error is StorageLimitExceededError) {
return Container(
2021-02-05 16:07:14 +00:00
margin: EdgeInsets.only(top: 8),
2021-02-02 19:01:32 +00:00
child: Column(
children: [
Row(
mainAxisAlignment: MainAxisAlignment.center,
crossAxisAlignment: CrossAxisAlignment.center,
children: [
Icon(
Icons.error_outline,
color: Theme.of(context).accentColor,
),
Padding(padding: EdgeInsets.all(4)),
2021-02-25 16:43:29 +00:00
Text("storage limit exceeded"),
2021-02-02 19:01:32 +00:00
],
),
Padding(padding: EdgeInsets.all(6)),
Container(
width: double.infinity,
height: 64,
padding: const EdgeInsets.fromLTRB(80, 0, 80, 0),
child: button("upgrade", onPressed: () {
Navigator.of(context).push(
MaterialPageRoute(
builder: (BuildContext context) {
return SubscriptionPage();
},
),
);
}),
),
Padding(padding: EdgeInsets.all(8)),
],
),
);
} else {
2021-02-02 16:59:06 +00:00
return Container(
child: Column(
children: [
Row(
mainAxisAlignment: MainAxisAlignment.center,
crossAxisAlignment: CrossAxisAlignment.center,
children: [
Icon(
Icons.error_outline,
color: Theme.of(context).accentColor,
),
Padding(padding: EdgeInsets.all(4)),
Text(_event.reason ?? "upload failed"),
],
),
Padding(padding: EdgeInsets.all(8)),
],
),
);
2020-11-12 16:32:10 +00:00
}
}
String _getRefreshingText() {
2021-03-20 11:32:33 +00:00
if (_event.status == SyncStatus.applying_remote_diff) {
2021-01-13 08:28:56 +00:00
return "syncing...";
}
if (_event.status == SyncStatus.preparing_for_upload) {
2021-01-13 08:28:56 +00:00
return "encrypting backup...";
}
if (_event.status == SyncStatus.in_progress) {
return _event.completed.toString() +
"/" +
_event.total.toString() +
2021-01-13 08:28:56 +00:00
" memories preserved";
}
if (_event.status == SyncStatus.paused) {
return _event.reason;
}
if (_event.status == SyncStatus.completed) {
if (_event.wasStopped) {
2021-01-13 08:28:56 +00:00
return "sync stopped";
} else {
2021-01-13 08:28:56 +00:00
return "all memories preserved";
}
}
// _event.status == SyncStatus.error
2021-02-02 16:35:38 +00:00
return _event.reason ?? "upload failed";
}
}