application_widget.dart 3.7 KB

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