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:
@@ -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 [];
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
@@ -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;
|
||||
|
||||
|
||||
@@ -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() => [];
|
||||
|
||||
|
||||
Reference in New Issue
Block a user