refactor(apps): 主题系统迁移至 ColorScheme + 扩展架构并支持 Dark Mode

This commit is contained in:
qzl
2026-03-27 19:07:39 +08:00
parent ecc1ec6ce4
commit ae29a8209b
146 changed files with 4301 additions and 3200 deletions
+38 -21
View File
@@ -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(