|
@@ -1,40 +1,41 @@
|
|
import 'package:app_flowy/workspace/application/app/app_bloc.dart';
|
|
import 'package:app_flowy/workspace/application/app/app_bloc.dart';
|
|
import 'package:app_flowy/workspace/application/doc/doc_bloc.dart';
|
|
import 'package:app_flowy/workspace/application/doc/doc_bloc.dart';
|
|
import 'package:app_flowy/workspace/application/doc/share_bloc.dart';
|
|
import 'package:app_flowy/workspace/application/doc/share_bloc.dart';
|
|
|
|
+import 'package:app_flowy/workspace/application/home/home_listen_bloc.dart';
|
|
import 'package:app_flowy/workspace/application/menu/menu_bloc.dart';
|
|
import 'package:app_flowy/workspace/application/menu/menu_bloc.dart';
|
|
import 'package:app_flowy/workspace/application/menu/menu_user_bloc.dart';
|
|
import 'package:app_flowy/workspace/application/menu/menu_user_bloc.dart';
|
|
import 'package:app_flowy/workspace/application/trash/trash_bloc.dart';
|
|
import 'package:app_flowy/workspace/application/trash/trash_bloc.dart';
|
|
import 'package:app_flowy/workspace/application/view/view_bloc.dart';
|
|
import 'package:app_flowy/workspace/application/view/view_bloc.dart';
|
|
import 'package:app_flowy/workspace/application/workspace/welcome_bloc.dart';
|
|
import 'package:app_flowy/workspace/application/workspace/welcome_bloc.dart';
|
|
-import 'package:app_flowy/workspace/domain/i_doc.dart';
|
|
|
|
-import 'package:app_flowy/workspace/domain/i_share.dart';
|
|
|
|
-import 'package:app_flowy/workspace/domain/i_trash.dart';
|
|
|
|
-import 'package:app_flowy/workspace/domain/i_view.dart';
|
|
|
|
import 'package:app_flowy/workspace/domain/page_stack/page_stack.dart';
|
|
import 'package:app_flowy/workspace/domain/page_stack/page_stack.dart';
|
|
-import 'package:app_flowy/workspace/infrastructure/i_doc_impl.dart';
|
|
|
|
-import 'package:app_flowy/workspace/infrastructure/i_trash_impl.dart';
|
|
|
|
import 'package:app_flowy/workspace/infrastructure/repos/app_repo.dart';
|
|
import 'package:app_flowy/workspace/infrastructure/repos/app_repo.dart';
|
|
import 'package:app_flowy/workspace/infrastructure/repos/doc_repo.dart';
|
|
import 'package:app_flowy/workspace/infrastructure/repos/doc_repo.dart';
|
|
import 'package:app_flowy/workspace/infrastructure/repos/trash_repo.dart';
|
|
import 'package:app_flowy/workspace/infrastructure/repos/trash_repo.dart';
|
|
|
|
+import 'package:app_flowy/workspace/infrastructure/repos/user_repo.dart';
|
|
import 'package:app_flowy/workspace/infrastructure/repos/view_repo.dart';
|
|
import 'package:app_flowy/workspace/infrastructure/repos/view_repo.dart';
|
|
import 'package:app_flowy/workspace/infrastructure/repos/workspace_repo.dart';
|
|
import 'package:app_flowy/workspace/infrastructure/repos/workspace_repo.dart';
|
|
import 'package:flowy_sdk/protobuf/flowy-folder-data-model/app.pb.dart';
|
|
import 'package:flowy_sdk/protobuf/flowy-folder-data-model/app.pb.dart';
|
|
import 'package:flowy_sdk/protobuf/flowy-folder-data-model/view.pb.dart';
|
|
import 'package:flowy_sdk/protobuf/flowy-folder-data-model/view.pb.dart';
|
|
|
|
+import 'package:flowy_sdk/protobuf/flowy-user-data-model/user_profile.pb.dart';
|
|
import 'package:get_it/get_it.dart';
|
|
import 'package:get_it/get_it.dart';
|
|
-
|
|
|
|
-import 'i_share_impl.dart';
|
|
|
|
-import 'i_user_impl.dart';
|
|
|
|
-import 'i_view_impl.dart';
|
|
|
|
import 'repos/share_repo.dart';
|
|
import 'repos/share_repo.dart';
|
|
|
|
|
|
class HomeDepsResolver {
|
|
class HomeDepsResolver {
|
|
static Future<void> resolve(GetIt getIt) async {
|
|
static Future<void> resolve(GetIt getIt) async {
|
|
|
|
+ getIt.registerFactoryParam<UserListener, UserProfile, void>(
|
|
|
|
+ (user, _) => UserListener(user: user),
|
|
|
|
+ );
|
|
|
|
+
|
|
|
|
+ getIt.registerFactoryParam<HomeListenBloc, UserProfile, void>(
|
|
|
|
+ (user, _) => HomeListenBloc(getIt<UserListener>(param1: user)),
|
|
|
|
+ );
|
|
|
|
+
|
|
//
|
|
//
|
|
getIt.registerLazySingleton<HomeStackManager>(() => HomeStackManager());
|
|
getIt.registerLazySingleton<HomeStackManager>(() => HomeStackManager());
|
|
getIt.registerFactoryParam<WelcomeBloc, UserProfile, void>(
|
|
getIt.registerFactoryParam<WelcomeBloc, UserProfile, void>(
|
|
(user, _) => WelcomeBloc(
|
|
(user, _) => WelcomeBloc(
|
|
repo: UserRepo(user: user),
|
|
repo: UserRepo(user: user),
|
|
- listener: getIt<IUserListener>(param1: user),
|
|
|
|
|
|
+ listener: getIt<UserListener>(param1: user),
|
|
),
|
|
),
|
|
);
|
|
);
|
|
|
|
|
|
@@ -43,23 +44,17 @@ class HomeDepsResolver {
|
|
(user, workspaceId) => WorkspaceListener(repo: WorkspaceListenerRepo(user: user, workspaceId: workspaceId)));
|
|
(user, workspaceId) => WorkspaceListener(repo: WorkspaceListenerRepo(user: user, workspaceId: workspaceId)));
|
|
|
|
|
|
// View
|
|
// View
|
|
- getIt.registerFactoryParam<IView, View, void>((view, _) => IViewImpl(repo: ViewRepository(view: view)));
|
|
|
|
- getIt.registerFactoryParam<IViewListener, View, void>(
|
|
|
|
- (view, _) => IViewListenerImpl(repo: ViewListenerRepository(view: view)));
|
|
|
|
|
|
+ getIt.registerFactoryParam<ViewListener, View, void>(
|
|
|
|
+ (view, _) => ViewListener(view: view),
|
|
|
|
+ );
|
|
|
|
+
|
|
getIt.registerFactoryParam<ViewBloc, View, void>(
|
|
getIt.registerFactoryParam<ViewBloc, View, void>(
|
|
(view, _) => ViewBloc(
|
|
(view, _) => ViewBloc(
|
|
- viewManager: getIt<IView>(param1: view),
|
|
|
|
- listener: getIt<IViewListener>(param1: view),
|
|
|
|
|
|
+ repo: ViewRepository(view: view),
|
|
|
|
+ listener: getIt<ViewListener>(param1: view),
|
|
),
|
|
),
|
|
);
|
|
);
|
|
|
|
|
|
- // Doc
|
|
|
|
- getIt.registerFactoryParam<IDoc, String, void>((docId, _) => IDocImpl(repo: DocRepository(docId: docId)));
|
|
|
|
-
|
|
|
|
- // User
|
|
|
|
- getIt.registerFactoryParam<IUser, UserProfile, void>((user, _) => IUserImpl(repo: UserRepo(user: user)));
|
|
|
|
- getIt.registerFactoryParam<IUserListener, UserProfile, void>((user, _) => IUserListenerImpl(user: user));
|
|
|
|
-
|
|
|
|
//Menu Bloc
|
|
//Menu Bloc
|
|
getIt.registerFactoryParam<MenuBloc, UserProfile, String>(
|
|
getIt.registerFactoryParam<MenuBloc, UserProfile, String>(
|
|
(user, workspaceId) => MenuBloc(
|
|
(user, workspaceId) => MenuBloc(
|
|
@@ -69,14 +64,18 @@ class HomeDepsResolver {
|
|
);
|
|
);
|
|
|
|
|
|
getIt.registerFactoryParam<MenuUserBloc, UserProfile, void>(
|
|
getIt.registerFactoryParam<MenuUserBloc, UserProfile, void>(
|
|
- (user, _) => MenuUserBloc(getIt<IUser>(param1: user), getIt<IUserListener>(param1: user)));
|
|
|
|
|
|
+ (user, _) => MenuUserBloc(
|
|
|
|
+ UserRepo(user: user),
|
|
|
|
+ getIt<UserListener>(param1: user),
|
|
|
|
+ ),
|
|
|
|
+ );
|
|
|
|
|
|
// App
|
|
// App
|
|
getIt.registerFactoryParam<AppBloc, App, void>(
|
|
getIt.registerFactoryParam<AppBloc, App, void>(
|
|
(app, _) => AppBloc(
|
|
(app, _) => AppBloc(
|
|
app: app,
|
|
app: app,
|
|
repo: AppRepository(appId: app.id),
|
|
repo: AppRepository(appId: app.id),
|
|
- listener: AppListenerRepository(appId: app.id),
|
|
|
|
|
|
+ listener: AppListener(appId: app.id),
|
|
),
|
|
),
|
|
);
|
|
);
|
|
|
|
|
|
@@ -84,23 +83,25 @@ class HomeDepsResolver {
|
|
getIt.registerFactoryParam<DocBloc, View, void>(
|
|
getIt.registerFactoryParam<DocBloc, View, void>(
|
|
(view, _) => DocBloc(
|
|
(view, _) => DocBloc(
|
|
view: view,
|
|
view: view,
|
|
- docManager: getIt<IDoc>(param1: view.id),
|
|
|
|
- listener: getIt<IViewListener>(param1: view),
|
|
|
|
- trasnManager: getIt<ITrash>(),
|
|
|
|
|
|
+ repo: DocRepository(docId: view.id),
|
|
|
|
+ listener: getIt<ViewListener>(param1: view),
|
|
|
|
+ trashRepo: getIt<TrashRepo>(),
|
|
),
|
|
),
|
|
);
|
|
);
|
|
|
|
|
|
// trash
|
|
// trash
|
|
getIt.registerLazySingleton<TrashRepo>(() => TrashRepo());
|
|
getIt.registerLazySingleton<TrashRepo>(() => TrashRepo());
|
|
- getIt.registerLazySingleton<TrashListenerRepo>(() => TrashListenerRepo());
|
|
|
|
- getIt.registerFactory<ITrash>(() => ITrashImpl(repo: getIt<TrashRepo>()));
|
|
|
|
- getIt.registerFactory<ITrashListener>(() => ITrashListenerImpl(repo: getIt<TrashListenerRepo>()));
|
|
|
|
- getIt.registerFactory<TrashBloc>(() => TrashBloc(trasnManager: getIt<ITrash>(), listener: getIt<ITrashListener>()));
|
|
|
|
|
|
+ getIt.registerLazySingleton<TrashListener>(() => TrashListener());
|
|
|
|
+ getIt.registerFactory<TrashBloc>(
|
|
|
|
+ () => TrashBloc(
|
|
|
|
+ repo: getIt<TrashRepo>(),
|
|
|
|
+ listener: getIt<TrashListener>(),
|
|
|
|
+ ),
|
|
|
|
+ );
|
|
|
|
|
|
// share
|
|
// share
|
|
getIt.registerLazySingleton<ShareRepo>(() => ShareRepo());
|
|
getIt.registerLazySingleton<ShareRepo>(() => ShareRepo());
|
|
- getIt.registerFactory<IShare>(() => IShareImpl(repo: getIt<ShareRepo>()));
|
|
|
|
getIt.registerFactoryParam<DocShareBloc, View, void>(
|
|
getIt.registerFactoryParam<DocShareBloc, View, void>(
|
|
- (view, _) => DocShareBloc(view: view, shareManager: getIt<IShare>()));
|
|
|
|
|
|
+ (view, _) => DocShareBloc(view: view, repo: getIt<ShareRepo>()));
|
|
}
|
|
}
|
|
}
|
|
}
|