This commit is contained in:
Alessandro Autiero
2022-12-16 21:08:57 +01:00
parent ef7f34e0e3
commit 966b4b33fd
91 changed files with 388682 additions and 1005 deletions

View File

@@ -1,4 +1,3 @@
import 'dart:io';
import 'package:fluent_ui/fluent_ui.dart';
import 'package:flutter/foundation.dart';
@@ -6,13 +5,12 @@ import 'package:get/get.dart';
import 'package:get_storage/get_storage.dart';
import 'package:reboot_launcher/src/controller/build_controller.dart';
import 'package:reboot_launcher/src/controller/game_controller.dart';
import 'package:reboot_launcher/src/util/os.dart';
import 'package:reboot_launcher/src/dialog/dialog.dart';
import 'package:reboot_launcher/src/widget/home/game_type_selector.dart';
import 'package:reboot_launcher/src/widget/home/launch_button.dart';
import 'package:reboot_launcher/src/widget/home/username_box.dart';
import 'package:reboot_launcher/src/widget/home/version_selector.dart';
import '../controller/settings_controller.dart';
import '../util/reboot.dart';
class LauncherPage extends StatefulWidget {
@@ -27,7 +25,6 @@ class LauncherPage extends StatefulWidget {
class _LauncherPageState extends State<LauncherPage> {
final GameController _gameController = Get.find<GameController>();
final BuildController _buildController = Get.find<BuildController>();
final SettingsController _settingsController = Get.find<SettingsController>();
@override
void initState() {
@@ -43,12 +40,12 @@ class _LauncherPageState extends State<LauncherPage> {
int? get _updateTime {
var storage = GetStorage("update");
return storage.read("last_update");
return storage.read("last_update_v2");
}
set _updateTime(int? updateTime) {
var storage = GetStorage("update");
storage.write("last_update", updateTime);
storage.write("last_update_v2", updateTime);
}
void _onCancelWarning() {
@@ -65,51 +62,63 @@ class _LauncherPageState extends State<LauncherPage> {
@override
Widget build(BuildContext context) {
return Padding(
padding: const EdgeInsets.all(12.0),
child: FutureBuilder(
future: _gameController.updater ?? Future.value(true),
builder: (context, snapshot) {
if (!snapshot.hasData && !snapshot.hasError) {
return Row(
mainAxisAlignment: MainAxisAlignment.center,
children: [
Column(
mainAxisAlignment: MainAxisAlignment.center,
children: const [
ProgressRing(),
SizedBox(height: 16.0),
Text("Updating Reboot DLL...")
],
),
],
);
}
return Column(
mainAxisAlignment: MainAxisAlignment.spaceBetween,
crossAxisAlignment: CrossAxisAlignment.start,
return FutureBuilder(
future: _gameController.updater ?? Future.value(true),
builder: (context, snapshot) {
if (!snapshot.hasData && !snapshot.hasError) {
return Row(
mainAxisAlignment: MainAxisAlignment.center,
children: [
if(snapshot.hasError)
_createUpdateError(snapshot),
UsernameBox(),
const VersionSelector(),
GameTypeSelector(),
const LaunchButton()
Column(
mainAxisAlignment: MainAxisAlignment.center,
children: const [
ProgressRing(),
SizedBox(height: 16.0),
Text("Updating Reboot DLL...")
],
),
],
);
}
),
);
}
return Column(
mainAxisAlignment: MainAxisAlignment.spaceBetween,
crossAxisAlignment: CrossAxisAlignment.start,
children: [
if(snapshot.hasError)
_createUpdateError(snapshot),
UsernameBox(),
const VersionSelector(),
GameTypeSelector(),
const LaunchButton()
],
);
}
);
}
Widget _createUpdateError(AsyncSnapshot<Object?> snapshot) {
return const SizedBox(
width: double.infinity,
child: InfoBar(
title: Text("Cannot update dll"),
severity: InfoBarSeverity.warning
return MouseRegion(
cursor: SystemMouseCursors.click,
child: GestureDetector(
onTap: () {
showDialog(
context: context,
builder: (context) => ErrorDialog(
exception: snapshot.error!,
stackTrace: snapshot.stackTrace!,
errorMessageBuilder: (exception) => "Cannot update Reboot dll: ${snapshot.error}"
)
);
},
child: const SizedBox(
width: double.infinity,
child: InfoBar(
title: Text("Cannot update dll"),
severity: InfoBarSeverity.info
),
)
),
);
}
}
}