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';
|
2020-04-20 09:02:54 +02:00
|
|
|
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
|
|
|
|
2020-04-20 09:02:54 +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
|
|
|
}
|
|
|
|
|
2020-04-20 08:52:01 +02:00
|
|
|
@override
|
|
|
|
void dispose() {
|
|
|
|
super.dispose();
|
|
|
|
WebSocketHelper.close();
|
|
|
|
}
|
|
|
|
|
2020-04-20 09:02:54 +02:00
|
|
|
/// 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);
|
|
|
|
|
2020-05-01 09:17:08 +02:00
|
|
|
// 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-05-01 09:17:08 +02:00
|
|
|
|
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")),
|
|
|
|
),
|
|
|
|
],
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|