refactor(apps): 主题系统迁移至 ColorScheme + 扩展架构并支持 Dark Mode
This commit is contained in:
@@ -2,35 +2,43 @@ import 'package:dio/dio.dart';
|
||||
import 'package:flutter_secure_storage/flutter_secure_storage.dart';
|
||||
import 'package:get_it/get_it.dart';
|
||||
import 'package:shared_preferences/shared_preferences.dart';
|
||||
import '../../core/cache/cache_invalidator.dart';
|
||||
import '../../core/cache/hybrid_cache_store.dart';
|
||||
import '../../core/cache/memory_cache_store.dart';
|
||||
import '../../core/cache/persistent_cache_store.dart';
|
||||
import '../../data/cache/cache_invalidator.dart';
|
||||
import '../../data/cache/hybrid_cache_store.dart';
|
||||
import '../../data/cache/memory_cache_store.dart';
|
||||
import '../../data/cache/persistent_cache_store.dart';
|
||||
import '../../data/repositories/calendar_event_repository.dart';
|
||||
import '../../data/repositories/calendar_repository.dart';
|
||||
import '../../data/repositories/friend_repository.dart';
|
||||
import '../../data/repositories/inbox_repository.dart';
|
||||
import '../../data/repositories/user_repository.dart';
|
||||
import '../../core/auth/session_controller.dart';
|
||||
import '../../core/network/api_client.dart';
|
||||
import '../../core/network/i_api_client.dart';
|
||||
import '../../core/storage/app_preferences.dart';
|
||||
import '../../core/storage/token_storage.dart';
|
||||
import '../../core/config/env.dart';
|
||||
import '../../features/notification/data/services/local_notification_service.dart';
|
||||
import '../../data/services/local_notification_service.dart';
|
||||
import '../../features/auth/data/auth_api.dart';
|
||||
import '../../features/auth/data/auth_repository.dart';
|
||||
import '../../features/auth/data/auth_repository_impl.dart';
|
||||
import '../../features/auth/presentation/bloc/auth_bloc.dart';
|
||||
import '../../features/auth/presentation/bloc/auth_event.dart';
|
||||
import '../../features/chat/presentation/bloc/chat_bloc.dart';
|
||||
import '../../features/calendar/data/calendar_api.dart';
|
||||
import '../../features/calendar/data/services/calendar_repository.dart';
|
||||
import '../../features/calendar/data/services/calendar_service.dart';
|
||||
import '../../data/services/calendar_service.dart';
|
||||
import '../../features/notification/domain/services/reminder_action_executor.dart';
|
||||
import '../../features/calendar/presentation/calendar_state_manager.dart';
|
||||
import '../../shared/state/calendar_state_manager.dart';
|
||||
import '../../features/contacts/data/friends_api.dart';
|
||||
import '../../features/messages/data/inbox_api.dart';
|
||||
import '../../features/settings/data/settings_api.dart';
|
||||
import '../../features/settings/data/services/automation_jobs_api.dart';
|
||||
import '../../features/settings/data/services/settings_user_cache.dart';
|
||||
import '../../features/settings/data/services/user_profile_cache_repository.dart';
|
||||
import '../../features/settings/data/services/user_profile_service.dart';
|
||||
import '../../features/settings/data/services/memory_service.dart';
|
||||
import '../../features/contacts/data/users/users_api.dart';
|
||||
import '../../features/todo/data/todo_api.dart';
|
||||
import '../../features/todo/data/todo_repository.dart';
|
||||
import '../services/auth_session_controller.dart';
|
||||
|
||||
final sl = GetIt.instance;
|
||||
|
||||
@@ -63,6 +71,7 @@ Future<void> configureDependencies() async {
|
||||
|
||||
final sharedPreferences = await SharedPreferences.getInstance();
|
||||
sl.registerSingleton<SharedPreferences>(sharedPreferences);
|
||||
sl.registerSingleton<AppPreferences>(AppPreferences(sharedPreferences));
|
||||
|
||||
final memoryCacheStore = MemoryCacheStore();
|
||||
final persistentCacheStore = PersistentCacheStore();
|
||||
@@ -79,23 +88,31 @@ Future<void> configureDependencies() async {
|
||||
|
||||
final usersApi = UsersApi(apiClient);
|
||||
sl.registerSingleton<UsersApi>(usersApi);
|
||||
sl.registerSingleton<UserRepository>(UserRepositoryImpl(apiClient));
|
||||
final userProfileService = UserProfileService(apiClient);
|
||||
sl.registerSingleton<UserProfileService>(userProfileService);
|
||||
|
||||
final userProfileCacheRepository = UserProfileCacheRepository(
|
||||
store: hybridCacheStore,
|
||||
remoteLoader: usersApi.getMe,
|
||||
remoteLoader: userProfileService.getMe,
|
||||
);
|
||||
sl.registerSingleton<UserProfileCacheRepository>(userProfileCacheRepository);
|
||||
|
||||
final calendarApi = CalendarApi(apiClient);
|
||||
sl.registerSingleton<CalendarApi>(calendarApi);
|
||||
sl.registerSingleton<CalendarEventRepository>(
|
||||
CalendarEventRepositoryImpl(apiClient),
|
||||
);
|
||||
|
||||
final calendarService = CalendarService(apiClient: apiClient);
|
||||
final calendarService = CalendarService(
|
||||
apiClient: apiClient,
|
||||
invalidator: sl<CacheInvalidator>(),
|
||||
);
|
||||
sl.registerSingleton<CalendarService>(calendarService);
|
||||
|
||||
final calendarRepository = CalendarRepository(
|
||||
store: hybridCacheStore,
|
||||
loadDayFromRemote: calendarService.getEventsForDay,
|
||||
loadMonthFromRemote: calendarService.getEventsForRange,
|
||||
apiClient: apiClient,
|
||||
);
|
||||
sl.registerSingleton<CalendarRepository>(calendarRepository);
|
||||
|
||||
@@ -109,6 +126,7 @@ Future<void> configureDependencies() async {
|
||||
|
||||
final friendsApi = FriendsApi(apiClient);
|
||||
sl.registerSingleton<FriendsApi>(friendsApi);
|
||||
sl.registerSingleton<FriendRepository>(FriendRepositoryImpl(apiClient));
|
||||
|
||||
final settingsApi = SettingsApi(apiClient);
|
||||
sl.registerSingleton<SettingsApi>(settingsApi);
|
||||
@@ -119,12 +137,9 @@ Future<void> configureDependencies() async {
|
||||
final memoryService = MemoryService(apiClient);
|
||||
sl.registerSingleton<MemoryService>(memoryService);
|
||||
|
||||
sl.registerSingleton<SettingsUserCache>(
|
||||
SettingsUserCache(userProfileCacheRepository),
|
||||
);
|
||||
|
||||
final inboxApi = InboxApi(apiClient);
|
||||
sl.registerSingleton<InboxApi>(inboxApi);
|
||||
sl.registerSingleton<InboxRepository>(InboxRepositoryImpl(apiClient));
|
||||
|
||||
final todoApi = TodoApi(apiClient);
|
||||
sl.registerSingleton<TodoApi>(todoApi);
|
||||
@@ -141,8 +156,8 @@ Future<void> configureDependencies() async {
|
||||
tokenStorage: tokenStorage,
|
||||
onLogout: () async {
|
||||
apiClient.resetInterceptor();
|
||||
if (sl.isRegistered<SettingsUserCache>()) {
|
||||
sl<SettingsUserCache>().invalidate();
|
||||
if (sl.isRegistered<UserProfileCacheRepository>()) {
|
||||
await sl<UserProfileCacheRepository>().invalidate();
|
||||
}
|
||||
},
|
||||
);
|
||||
@@ -150,6 +165,8 @@ Future<void> configureDependencies() async {
|
||||
|
||||
final authBloc = AuthBloc(authRepository);
|
||||
sl.registerSingleton<AuthBloc>(authBloc);
|
||||
sl.registerSingleton<SessionController>(AuthSessionController(authBloc));
|
||||
sl.registerSingleton<ChatBloc>(ChatBloc(apiClient: apiClient));
|
||||
|
||||
apiClient.setRefreshCallback((token) async {
|
||||
try {
|
||||
@@ -161,8 +178,8 @@ Future<void> configureDependencies() async {
|
||||
});
|
||||
|
||||
apiClient.setAuthFailureCallback(() async {
|
||||
if (sl.isRegistered<SettingsUserCache>()) {
|
||||
sl<SettingsUserCache>().invalidate();
|
||||
if (sl.isRegistered<UserProfileCacheRepository>()) {
|
||||
await sl<UserProfileCacheRepository>().invalidate();
|
||||
}
|
||||
authBloc.add(
|
||||
const AuthSessionInvalidated(
|
||||
|
||||
Reference in New Issue
Block a user