add adaptive_scaffold
This commit is contained in:
@@ -1,13 +1,19 @@
|
||||
import 'package:get_it/get_it.dart';
|
||||
import 'package:immich_mobile/domain/interfaces/log.interface.dart';
|
||||
import 'package:immich_mobile/domain/interfaces/store.interface.dart';
|
||||
import 'package:immich_mobile/domain/repositories/database.repository.dart';
|
||||
import 'package:immich_mobile/domain/repositories/log.repository.dart';
|
||||
import 'package:immich_mobile/domain/repositories/store.repository.dart';
|
||||
import 'package:immich_mobile/domain/services/app_setting.service.dart';
|
||||
import 'package:immich_mobile/domain/services/login.service.dart';
|
||||
import 'package:immich_mobile/domain/services/server_info.service.dart';
|
||||
import 'package:immich_mobile/domain/store_manager.dart';
|
||||
import 'package:immich_mobile/presentation/modules/common/states/server_info/server_feature_config.state.dart';
|
||||
import 'package:immich_mobile/presentation/modules/theme/states/app_theme.state.dart';
|
||||
import 'package:immich_mobile/presentation/router/router.dart';
|
||||
import 'package:immich_mobile/presentation/theme/states/app_theme.state.dart';
|
||||
import 'package:watch_it/watch_it.dart';
|
||||
import 'package:openapi/openapi.dart';
|
||||
|
||||
final di = GetIt.I;
|
||||
|
||||
class ServiceLocator {
|
||||
const ServiceLocator._internal();
|
||||
@@ -15,26 +21,50 @@ class ServiceLocator {
|
||||
static void configureServices() {
|
||||
// Register DB
|
||||
di.registerSingleton<DriftDatabaseRepository>(DriftDatabaseRepository());
|
||||
_registerDomainServices();
|
||||
_registerPresentationService();
|
||||
_registerPreValidationServices();
|
||||
}
|
||||
|
||||
static void _registerDomainServices() {
|
||||
static void _registerPreValidationServices() {
|
||||
// ====== DOMAIN
|
||||
|
||||
// Init store
|
||||
di.registerFactory<IStoreRepository>(() => StoreDriftRepository(di()));
|
||||
di.registerSingleton<StoreManager>(StoreManager(di()));
|
||||
// StoreManager populates its cache with a async gap, manually signalReady once the cache is populated.
|
||||
di.registerSingleton<StoreManager>(StoreManager(di()), signalsReady: true);
|
||||
// Logs
|
||||
di.registerFactory<ILogRepository>(() => LogDriftRepository(di()));
|
||||
// App Settings
|
||||
di.registerFactory<AppSettingsService>(() => AppSettingsService(di()));
|
||||
}
|
||||
di.registerFactory<AppSettingService>(() => AppSettingService(di()));
|
||||
// Login Service
|
||||
di.registerFactory<LoginService>(() => const LoginService());
|
||||
|
||||
// ====== PRESENTATION
|
||||
|
||||
static void _registerPresentationService() {
|
||||
// App router
|
||||
di.registerSingleton<AppRouter>(AppRouter());
|
||||
// Global states
|
||||
di.registerLazySingleton<AppThemeState>(
|
||||
() => AppThemeState(appSettings: di())..init(),
|
||||
di.registerLazySingleton<AppThemeCubit>(() => AppThemeCubit(di()));
|
||||
}
|
||||
|
||||
static void registerPostValidationServices(String endpoint) {
|
||||
if (di.isRegistered<Openapi>()) {
|
||||
return;
|
||||
}
|
||||
|
||||
// ====== DOMAIN
|
||||
|
||||
di.registerSingleton<Openapi>(
|
||||
Openapi(
|
||||
basePathOverride: endpoint,
|
||||
interceptors: [BearerAuthInterceptor()],
|
||||
),
|
||||
);
|
||||
di.registerFactory<ServerInfoService>(() => ServerInfoService(di()));
|
||||
|
||||
// ====== PRESENTATION
|
||||
|
||||
di.registerLazySingleton<ServerFeatureConfigCubit>(
|
||||
() => ServerFeatureConfigCubit(di()),
|
||||
);
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user