mirror of
https://github.com/lollipopkit/flutter_server_box.git
synced 2025-12-17 07:14:28 +01:00
150 lines
4.4 KiB
Dart
150 lines
4.4 KiB
Dart
// ignore_for_file: avoid_print
|
|
|
|
import 'dart:async';
|
|
|
|
import 'package:flutter/material.dart';
|
|
import 'package:flutter_displaymode/flutter_displaymode.dart';
|
|
import 'package:hive_flutter/hive_flutter.dart';
|
|
import 'package:logging/logging.dart';
|
|
import 'package:provider/provider.dart';
|
|
import 'package:shared_preferences/shared_preferences.dart';
|
|
import 'package:toolbox/core/channel/bg_run.dart';
|
|
import 'package:toolbox/core/utils/sync/icloud.dart';
|
|
import 'package:toolbox/core/utils/platform/base.dart';
|
|
import 'package:toolbox/core/utils/sync/webdav.dart';
|
|
import 'package:toolbox/data/res/logger.dart';
|
|
import 'package:toolbox/data/res/provider.dart';
|
|
import 'package:toolbox/data/res/store.dart';
|
|
import 'package:window_manager/window_manager.dart';
|
|
|
|
import 'app.dart';
|
|
import 'core/analysis.dart';
|
|
import 'core/utils/ui.dart';
|
|
import 'data/model/app/net_view.dart';
|
|
import 'data/model/server/private_key_info.dart';
|
|
import 'data/model/server/server_private_info.dart';
|
|
import 'data/model/server/snippet.dart';
|
|
import 'data/model/ssh/virtual_key.dart';
|
|
import 'data/provider/app.dart';
|
|
import 'data/provider/debug.dart';
|
|
import 'data/provider/docker.dart';
|
|
import 'data/provider/private_key.dart';
|
|
import 'data/provider/server.dart';
|
|
import 'data/provider/sftp.dart';
|
|
import 'data/provider/snippet.dart';
|
|
import 'data/res/color.dart';
|
|
import 'locator.dart';
|
|
import 'view/widget/appbar.dart';
|
|
|
|
Future<void> main() async {
|
|
_runInZone(() async {
|
|
await _initApp();
|
|
runApp(
|
|
MultiProvider(
|
|
providers: [
|
|
ChangeNotifierProvider(create: (_) => locator<AppProvider>()),
|
|
ChangeNotifierProvider(create: (_) => locator<DebugProvider>()),
|
|
ChangeNotifierProvider(create: (_) => locator<DockerProvider>()),
|
|
ChangeNotifierProvider(create: (_) => locator<ServerProvider>()),
|
|
ChangeNotifierProvider(create: (_) => locator<SnippetProvider>()),
|
|
ChangeNotifierProvider(create: (_) => locator<PrivateKeyProvider>()),
|
|
ChangeNotifierProvider(create: (_) => locator<SftpProvider>()),
|
|
],
|
|
child: const MyApp(),
|
|
),
|
|
);
|
|
});
|
|
}
|
|
|
|
void _runInZone(void Function() body) {
|
|
final zoneSpec = ZoneSpecification(
|
|
print: (Zone self, ZoneDelegate parent, Zone zone, String line) {
|
|
parent.print(zone, line);
|
|
},
|
|
);
|
|
|
|
runZonedGuarded(
|
|
body,
|
|
(obj, trace) {
|
|
Analysis.recordException(trace);
|
|
Loggers.root.warning(obj, null, trace);
|
|
},
|
|
zoneSpecification: zoneSpec,
|
|
);
|
|
}
|
|
|
|
Future<void> _initApp() async {
|
|
WidgetsFlutterBinding.ensureInitialized();
|
|
await _initDesktopWindow();
|
|
|
|
// Base of all data.
|
|
await _initDb();
|
|
await setupLocator();
|
|
_setupLogger();
|
|
_setupProviders();
|
|
|
|
// Load font
|
|
primaryColor = Color(Stores.setting.primaryColor.fetch());
|
|
loadFontFile(Stores.setting.fontPath.fetch());
|
|
|
|
if (isAndroid) {
|
|
// Only start service when [bgRun] is true.
|
|
if (Stores.setting.bgRun.fetch()) {
|
|
BgRunMC.startService();
|
|
}
|
|
// SharedPreferences is only used on Android for saving home widgets settings.
|
|
SharedPreferences.setPrefix('');
|
|
// try switch to highest refresh rate
|
|
await FlutterDisplayMode.setHighRefreshRate();
|
|
}
|
|
if (isIOS || isMacOS) {
|
|
if (Stores.setting.icloudSync.fetch()) ICloud.sync();
|
|
}
|
|
if (Stores.setting.webdavSync.fetch()) Webdav.sync();
|
|
}
|
|
|
|
void _setupProviders() {
|
|
Pros.snippet.load();
|
|
Pros.key.load();
|
|
}
|
|
|
|
Future<void> _initDb() async {
|
|
// await SecureStore.init();
|
|
await Hive.initFlutter();
|
|
// Ordered by typeId
|
|
Hive.registerAdapter(PrivateKeyInfoAdapter()); // 1
|
|
Hive.registerAdapter(SnippetAdapter()); // 2
|
|
Hive.registerAdapter(ServerPrivateInfoAdapter()); // 3
|
|
Hive.registerAdapter(VirtKeyAdapter()); // 4
|
|
Hive.registerAdapter(NetViewTypeAdapter()); // 5
|
|
}
|
|
|
|
void _setupLogger() {
|
|
Logger.root.level = Level.ALL;
|
|
Logger.root.onRecord.listen((record) {
|
|
Pros.debug.addLog(record);
|
|
print(record);
|
|
if (record.error != null) print(record.error);
|
|
if (record.stackTrace != null) print(record.stackTrace);
|
|
});
|
|
}
|
|
|
|
Future<void> _initDesktopWindow() async {
|
|
if (!isDesktop) return;
|
|
|
|
await windowManager.ensureInitialized();
|
|
await CustomAppBar.updateTitlebarHeight();
|
|
|
|
const windowOptions = WindowOptions(
|
|
size: Size(400, 777),
|
|
center: true,
|
|
backgroundColor: Colors.transparent,
|
|
skipTaskbar: false,
|
|
titleBarStyle: TitleBarStyle.hidden,
|
|
);
|
|
windowManager.waitUntilReadyToShow(windowOptions, () async {
|
|
await windowManager.show();
|
|
await windowManager.focus();
|
|
});
|
|
}
|