application_widget.dart 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107
  1. import 'package:app_flowy/startup/startup.dart';
  2. import 'package:app_flowy/user/infrastructure/repos/user_setting_repo.dart';
  3. import 'package:app_flowy/workspace/application/appearance.dart';
  4. import 'package:easy_localization/easy_localization.dart';
  5. import 'package:flowy_infra/theme.dart';
  6. import 'package:flowy_infra_ui/flowy_infra_ui.dart';
  7. import 'package:flutter/material.dart';
  8. import 'package:provider/provider.dart';
  9. import 'package:window_size/window_size.dart';
  10. import 'package:app_flowy/startup/launcher.dart';
  11. import 'package:bloc/bloc.dart';
  12. import 'package:flowy_log/flowy_log.dart';
  13. class AppWidgetTask extends LaunchTask {
  14. @override
  15. LaunchTaskType get type => LaunchTaskType.appLauncher;
  16. @override
  17. Future<void> initialize(LaunchContext context) async {
  18. final widget = context.getIt<EntryPoint>().create();
  19. final setting = await UserSettingReppsitory().getAppearanceSettings();
  20. final settingModel = AppearanceSettingModel(setting);
  21. final app = ApplicationWidget(
  22. child: widget,
  23. settingModel: settingModel,
  24. );
  25. BlocOverrides.runZoned(
  26. () {
  27. runApp(
  28. EasyLocalization(
  29. supportedLocales: const [Locale('en'), Locale('zh', 'CN'), Locale('it', 'IT'), Locale('fr', 'CA')],
  30. path: 'assets/translations',
  31. fallbackLocale: const Locale('en'),
  32. child: app),
  33. );
  34. },
  35. blocObserver: ApplicationBlocObserver(),
  36. );
  37. return Future(() => {});
  38. }
  39. }
  40. class ApplicationWidget extends StatelessWidget {
  41. final Widget child;
  42. final AppearanceSettingModel settingModel;
  43. const ApplicationWidget({
  44. Key? key,
  45. required this.child,
  46. required this.settingModel,
  47. }) : super(key: key);
  48. @override
  49. Widget build(BuildContext context) => ChangeNotifierProvider.value(
  50. value: settingModel,
  51. builder: (context, _) {
  52. const ratio = 1.73;
  53. const minWidth = 800.0;
  54. setWindowMinSize(const Size(minWidth, minWidth / ratio));
  55. AppTheme theme = context.select<AppearanceSettingModel, AppTheme>(
  56. (value) => value.theme,
  57. );
  58. return Provider.value(
  59. value: theme,
  60. child: MaterialApp(
  61. builder: overlayManagerBuilder(),
  62. debugShowCheckedModeBanner: false,
  63. theme: theme.themeData,
  64. localizationsDelegates: context.localizationDelegates,
  65. supportedLocales: context.supportedLocales,
  66. locale: context.locale,
  67. navigatorKey: AppGlobals.rootNavKey,
  68. home: child,
  69. ),
  70. );
  71. },
  72. );
  73. }
  74. class AppGlobals {
  75. static GlobalKey<NavigatorState> rootNavKey = GlobalKey();
  76. static NavigatorState get nav => rootNavKey.currentState!;
  77. }
  78. class ApplicationBlocObserver extends BlocObserver {
  79. @override
  80. // ignore: unnecessary_overrides
  81. void onTransition(Bloc bloc, Transition transition) {
  82. // Log.debug("[current]: ${transition.currentState} \n\n[next]: ${transition.nextState}");
  83. //Log.debug("${transition.nextState}");
  84. super.onTransition(bloc, transition);
  85. }
  86. @override
  87. void onError(BlocBase bloc, Object error, StackTrace stackTrace) {
  88. Log.debug(error);
  89. super.onError(bloc, error, stackTrace);
  90. }
  91. @override
  92. void onEvent(Bloc bloc, Object? event) {
  93. Log.debug("$event");
  94. super.onEvent(bloc, event);
  95. }
  96. }