124 lines
3.5 KiB
Dart
124 lines
3.5 KiB
Dart
import 'dart:async';
|
|
|
|
import 'package:connectivity_plus/connectivity_plus.dart';
|
|
import 'package:device_info_plus/device_info_plus.dart';
|
|
import 'package:firebase_core/firebase_core.dart';
|
|
import 'package:flutter/material.dart';
|
|
import 'package:flutter/services.dart';
|
|
import 'package:flutter_screenutil/flutter_screenutil.dart';
|
|
import 'package:get/get.dart';
|
|
import 'package:permission_handler/permission_handler.dart';
|
|
import 'package:regroup/Utils/dialogs.dart';
|
|
import 'package:regroup/Utils/Common/NoInternet.dart';
|
|
import 'package:regroup/firebase_options.dart';
|
|
import 'package:regroup/resources/routes/route_name.dart';
|
|
import 'package:regroup/resources/routes/routes.dart';
|
|
|
|
Future<void> main() async {
|
|
WidgetsFlutterBinding.ensureInitialized();
|
|
await Firebase.initializeApp(options: DefaultFirebaseOptions.currentPlatform);
|
|
|
|
SystemChrome.setPreferredOrientations([
|
|
DeviceOrientation.portraitUp,
|
|
]).then((value) =>
|
|
// runApp(MyApp())
|
|
runApp(const MyApp())
|
|
|
|
// StatsFl(
|
|
// align: Alignment.center,
|
|
// width: 200,
|
|
// height: 100,
|
|
// child: const MyApp())),
|
|
);
|
|
}
|
|
|
|
final streamController = StreamController.broadcast();
|
|
|
|
class MyApp extends StatefulWidget {
|
|
const MyApp({super.key});
|
|
|
|
@override
|
|
State<MyApp> createState() => _MyAppState();
|
|
}
|
|
|
|
class _MyAppState extends State<MyApp> with WidgetsBindingObserver {
|
|
var _connectionStatus = ConnectivityResult.values.toString();
|
|
final Connectivity _connectivity = Connectivity();
|
|
late StreamSubscription<ConnectivityResult> _connectivitySubscription;
|
|
Future<void> checkInternet() async {
|
|
final connectivityResult = await (Connectivity().checkConnectivity());
|
|
|
|
if (connectivityResult == ConnectivityResult.wifi ||
|
|
connectivityResult == ConnectivityResult.mobile) {
|
|
setState(() {
|
|
_connectionStatus = connectivityResult.toString();
|
|
print("has internet");
|
|
});
|
|
} else {
|
|
setState(() {
|
|
_connectionStatus = connectivityResult.toString();
|
|
print("no internet");
|
|
});
|
|
}
|
|
}
|
|
|
|
Future<void> initConnectivity() async {
|
|
late List<ConnectivityResult> result;
|
|
// Platform messages may fail, so we use a try/catch PlatformException.
|
|
try {
|
|
result = await _connectivity.checkConnectivity();
|
|
print("initconnectivitity");
|
|
} on PlatformException catch (e) {
|
|
print("errrror");
|
|
print(e);
|
|
return;
|
|
}
|
|
if (!mounted) {
|
|
return Future.value(null);
|
|
}
|
|
|
|
return _updateConnectionStatus(result);
|
|
}
|
|
|
|
Future<void> _updateConnectionStatus(List<ConnectivityResult> result) async {
|
|
setState(() {
|
|
_connectionStatus = result.toString();
|
|
});
|
|
|
|
// ignore: avoid_print
|
|
print('Connectivity changed: $_connectionStatus');
|
|
}
|
|
|
|
@override
|
|
void initState() {
|
|
initConnectivity();
|
|
WidgetsBinding.instance.addObserver(this);
|
|
// _connectivitySubscription =
|
|
// _connectivity.onConnectivityChanged.listen(_updateConnectionStatus);
|
|
super.initState();
|
|
}
|
|
|
|
@override
|
|
void dispose() {
|
|
_connectivitySubscription.cancel();
|
|
super.dispose();
|
|
}
|
|
|
|
@override
|
|
Widget build(BuildContext context) {
|
|
return ScreenUtilInit(
|
|
builder: (BuildContext context, Widget? child) => GetMaterialApp(
|
|
title: 'Regroup',
|
|
theme: ThemeData(
|
|
primarySwatch: Colors.grey,
|
|
fontFamily: 'Cambria',
|
|
),
|
|
debugShowCheckedModeBanner: false,
|
|
initialRoute: RouteName.splashScreen,
|
|
getPages: AppRoutes.appRoutes(),
|
|
),
|
|
designSize: const Size(390, 844),
|
|
);
|
|
}
|
|
}
|