1
0
mirror of https://gitlab.com/comunic/comunicmobile synced 2025-01-28 12:43:00 +00:00
comunicmobile/lib/ui/widgets/init_widget.dart

142 lines
3.6 KiB
Dart
Raw Normal View History

2020-04-18 13:48:21 +02:00
import 'package:comunic/helpers/events_helper.dart';
2020-04-17 15:25:26 +02:00
import 'package:comunic/helpers/websocket_helper.dart';
import 'package:comunic/ui/routes/login_route.dart';
2020-05-09 14:07:14 +02:00
import 'package:comunic/ui/routes/main_route/main_route.dart';
2020-05-05 13:21:37 +02:00
import 'package:comunic/ui/routes/main_route/smartphone_route.dart';
2020-05-05 13:31:03 +02:00
import 'package:comunic/ui/routes/main_route/tablet_route.dart';
2020-04-18 13:48:21 +02:00
import 'package:comunic/ui/widgets/safe_state.dart';
2020-04-17 15:25:26 +02:00
import 'package:comunic/utils/intl_utils.dart';
2020-05-05 13:31:03 +02:00
import 'package:comunic/utils/ui_utils.dart';
2020-04-17 15:25:26 +02:00
import 'package:flutter/material.dart';
/// Comunic account initialization widget
///
/// Application screens should only appears as children of this widget
///
/// This widget ensures that the application is correctly initialized before
/// starting it
///
/// @author Pierre Hubert
class InitializeWidget extends StatefulWidget {
@override
_InitializeWidgetState createState() => _InitializeWidgetState();
}
2020-04-18 13:48:21 +02:00
class _InitializeWidgetState extends SafeState<InitializeWidget> {
2020-04-17 15:25:26 +02:00
bool _error = false;
@override
void initState() {
_tryConnect();
super.initState();
2020-04-18 13:48:21 +02:00
// Check if login token are considered as invalid
super.listen<InvalidLoginTokensEvent>((ev) => _openLoginPage());
2020-04-18 13:48:21 +02:00
// Listen to WebSocket close event
super.listen<WSClosedEvent>((e) => _tryConnect());
2020-04-17 15:25:26 +02:00
}
@override
void dispose() {
super.dispose();
WebSocketHelper.close();
}
/// Open login page
_openLoginPage() {
Navigator.of(context)
.pushReplacement(MaterialPageRoute(builder: (c) => LoginRoute()));
}
2020-04-17 15:25:26 +02:00
/// Try to connect to server
void _tryConnect() async {
try {
setState(() {
_error = false;
});
await WebSocketHelper.connect();
setState(() {});
} catch (e, stack) {
print("Could not connect to server! $e");
print(stack);
// Pop until we reach main route
2020-05-01 11:00:30 +02:00
Navigator.of(context).popUntil((settings) =>
ModalRoute.of(context).isCurrent || !ModalRoute.of(context).isActive);
2020-04-17 15:25:26 +02:00
setState(() {
_error = true;
});
}
}
@override
Widget build(BuildContext context) {
2020-04-17 16:04:47 +02:00
return !_error && WebSocketHelper.isConnected()
2020-05-09 14:07:14 +02:00
? (isTablet(context)
? TabletRoute(key: mainControllerKey)
: SmartphoneMainRoute(key: mainControllerKey))
2020-04-17 16:04:47 +02:00
: _buildNonReadyWidget();
2020-04-17 15:25:26 +02:00
}
/// Build loading widget
Widget _buildNonReadyWidget() {
return Scaffold(
backgroundColor: Colors.indigo.shade900,
body: Center(
2020-05-03 21:13:20 +02:00
child: Material(
color: Colors.transparent,
textStyle: TextStyle(color: Colors.white),
child: Column(
mainAxisAlignment: MainAxisAlignment.center,
crossAxisAlignment: CrossAxisAlignment.center,
children: <Widget>[
Spacer(
flex: 4,
),
Text(
tr("Comunic"),
style: TextStyle(fontSize: 50),
),
Spacer(
flex: 2,
),
_error ? _buildErrorWidget() : _buildConnectingWidget(),
Spacer(
flex: 2,
),
],
),
2020-04-17 15:25:26 +02:00
),
),
);
}
Widget _buildConnectingWidget() {
return CircularProgressIndicator();
}
Widget _buildErrorWidget() {
return Column(
children: <Widget>[
2020-05-03 21:13:20 +02:00
Icon(Icons.error, color: Colors.white),
2020-04-17 15:25:26 +02:00
SizedBox(height: 30),
Text(tr("Could not connect to server!")),
SizedBox(
height: 30,
),
RaisedButton(
color: Colors.indigo,
onPressed: () => _tryConnect(),
child: Text(tr("Try again")),
),
],
);
}
}