refactor: migrate Phase 2 FutureProvider functions (5-15/15)

Migrated 11 more providers to @riverpod functions:
Core providers:
- userSettingsProvider → userSettings
- conversationSuggestionsProvider → conversationSuggestions
- userPermissionsProvider → userPermissions
- foldersProvider → folders
- userFilesProvider → userFiles
- knowledgeBasesProvider → knowledgeBases
- availableVoicesProvider → availableVoices
- imageModelsProvider → imageModels

Feature providers:
- promptsListProvider → promptsList
- toolsListProvider → toolsList

Bonus notifiers also migrated:
- activePromptCommandProvider → ActivePromptCommand
- selectedToolIdsProvider → SelectedToolIds

Phase 2 Complete! All 15 FutureProvider functions migrated.
All provider names unchanged, no breaking changes.
Analyzer passing, only pre-existing keepAlive warnings.
This commit is contained in:
cogwheel0
2025-09-30 14:39:22 +05:30
parent 083c65527d
commit dd96ddccb6
3 changed files with 41 additions and 40 deletions

View File

@@ -1438,7 +1438,8 @@ class ReviewerMode extends _$ReviewerMode {
}
// User Settings providers
final userSettingsProvider = FutureProvider<UserSettings>((ref) async {
@riverpod
Future<UserSettings> userSettings(Ref ref) async {
final api = ref.watch(apiServiceProvider);
if (api == null) {
// Return default settings if no API
@@ -1453,12 +1454,11 @@ final userSettingsProvider = FutureProvider<UserSettings>((ref) async {
// Return default settings on error
return const UserSettings();
}
});
}
// Conversation Suggestions provider
final conversationSuggestionsProvider = FutureProvider<List<String>>((
ref,
) async {
@riverpod
Future<List<String>> conversationSuggestions(Ref ref) async {
final api = ref.watch(apiServiceProvider);
if (api == null) return [];
@@ -1468,12 +1468,11 @@ final conversationSuggestionsProvider = FutureProvider<List<String>>((
DebugLogger.error('suggestions-failed', scope: 'suggestions', error: e);
return [];
}
});
}
// Server features and permissions
final userPermissionsProvider = FutureProvider<Map<String, dynamic>>((
ref,
) async {
@riverpod
Future<Map<String, dynamic>> userPermissions(Ref ref) async {
final api = ref.watch(apiServiceProvider);
if (api == null) return {};
@@ -1483,7 +1482,7 @@ final userPermissionsProvider = FutureProvider<Map<String, dynamic>>((
DebugLogger.error('permissions-failed', scope: 'permissions', error: e);
return {};
}
});
}
final imageGenerationAvailableProvider = Provider<bool>((ref) {
final perms = ref.watch(userPermissionsProvider);
@@ -1518,7 +1517,8 @@ final webSearchAvailableProvider = Provider<bool>((ref) {
});
// Folders provider
final foldersProvider = FutureProvider<List<Folder>>((ref) async {
@riverpod
Future<List<Folder>> folders(Ref ref) async {
// Protected: require authentication
if (!ref.read(isAuthenticatedProvider2)) {
DebugLogger.log('skip-unauthed', scope: 'folders');
@@ -1545,10 +1545,11 @@ final foldersProvider = FutureProvider<List<Folder>>((ref) async {
DebugLogger.error('fetch-failed', scope: 'folders', error: e);
return [];
}
});
}
// Files provider
final userFilesProvider = FutureProvider<List<FileInfo>>((ref) async {
@riverpod
Future<List<FileInfo>> userFiles(Ref ref) async {
// Protected: require authentication
if (!ref.read(isAuthenticatedProvider2)) {
DebugLogger.log('skip-unauthed', scope: 'files');
@@ -1564,7 +1565,7 @@ final userFilesProvider = FutureProvider<List<FileInfo>>((ref) async {
DebugLogger.error('files-failed', scope: 'files', error: e);
return [];
}
});
}
// File content provider
final fileContentProvider = FutureProvider.family<String, String>((
@@ -1593,7 +1594,8 @@ final fileContentProvider = FutureProvider.family<String, String>((
});
// Knowledge Base providers
final knowledgeBasesProvider = FutureProvider<List<KnowledgeBase>>((ref) async {
@riverpod
Future<List<KnowledgeBase>> knowledgeBases(Ref ref) async {
// Protected: require authentication
if (!ref.read(isAuthenticatedProvider2)) {
DebugLogger.log('skip-unauthed', scope: 'knowledge');
@@ -1609,7 +1611,7 @@ final knowledgeBasesProvider = FutureProvider<List<KnowledgeBase>>((ref) async {
DebugLogger.error('knowledge-bases-failed', scope: 'knowledge', error: e);
return [];
}
});
}
final knowledgeBaseItemsProvider =
FutureProvider.family<List<KnowledgeBaseItem>, String>((ref, kbId) async {
@@ -1637,7 +1639,8 @@ final knowledgeBaseItemsProvider =
});
// Audio providers
final availableVoicesProvider = FutureProvider<List<String>>((ref) async {
@riverpod
Future<List<String>> availableVoices(Ref ref) async {
// Protected: require authentication
if (!ref.read(isAuthenticatedProvider2)) {
DebugLogger.log('skip-unauthed', scope: 'voices');
@@ -1652,12 +1655,11 @@ final availableVoicesProvider = FutureProvider<List<String>>((ref) async {
DebugLogger.error('voices-failed', scope: 'voices', error: e);
return [];
}
});
}
// Image Generation providers
final imageModelsProvider = FutureProvider<List<Map<String, dynamic>>>((
ref,
) async {
@riverpod
Future<List<Map<String, dynamic>>> imageModels(Ref ref) async {
final api = ref.watch(apiServiceProvider);
if (api == null) return [];
@@ -1667,4 +1669,4 @@ final imageModelsProvider = FutureProvider<List<Map<String, dynamic>>>((
DebugLogger.error('image-models-failed', scope: 'image-models', error: e);
return [];
}
});
}

View File

@@ -1,20 +1,19 @@
import 'package:flutter_riverpod/flutter_riverpod.dart';
import 'package:riverpod_annotation/riverpod_annotation.dart';
import 'package:conduit/core/models/prompt.dart';
import 'package:conduit/core/services/prompts_service.dart';
final promptsListProvider = FutureProvider<List<Prompt>>((ref) async {
part 'prompts_providers.g.dart';
@riverpod
Future<List<Prompt>> promptsList(Ref ref) async {
final promptsService = ref.watch(promptsServiceProvider);
if (promptsService == null) return const <Prompt>[];
return promptsService.getPrompts();
});
}
final activePromptCommandProvider =
NotifierProvider<ActivePromptCommandNotifier, String?>(
ActivePromptCommandNotifier.new,
);
class ActivePromptCommandNotifier extends Notifier<String?> {
@riverpod
class ActivePromptCommand extends _$ActivePromptCommand {
@override
String? build() => null;

View File

@@ -1,19 +1,19 @@
import 'package:flutter_riverpod/flutter_riverpod.dart';
import 'package:riverpod_annotation/riverpod_annotation.dart';
import 'package:conduit/core/models/tool.dart';
import 'package:conduit/core/services/tools_service.dart';
final toolsListProvider = FutureProvider<List<Tool>>((ref) async {
part 'tools_providers.g.dart';
@riverpod
Future<List<Tool>> toolsList(Ref ref) async {
final toolsService = ref.watch(toolsServiceProvider);
if (toolsService == null) return [];
return await toolsService.getTools();
});
}
final selectedToolIdsProvider =
NotifierProvider<SelectedToolIdsNotifier, List<String>>(
SelectedToolIdsNotifier.new,
);
class SelectedToolIdsNotifier extends Notifier<List<String>> {
@riverpod
class SelectedToolIds extends _$SelectedToolIds {
@override
List<String> build() => [];