mirror of
https://github.com/foss42/apidash.git
synced 2025-12-01 10:17:47 +08:00
feat: add task suggestions panel in chat screen
This commit is contained in:
@@ -1,3 +1,4 @@
|
|||||||
|
import 'package:apidash/dashbot/features/chat/view/widgets/dashbot_task_buttons.dart';
|
||||||
import 'package:apidash_design_system/apidash_design_system.dart';
|
import 'package:apidash_design_system/apidash_design_system.dart';
|
||||||
|
|
||||||
import '../../models/chat_models.dart';
|
import '../../models/chat_models.dart';
|
||||||
@@ -17,6 +18,7 @@ class ChatScreen extends ConsumerStatefulWidget {
|
|||||||
|
|
||||||
class _ChatScreenState extends ConsumerState<ChatScreen> {
|
class _ChatScreenState extends ConsumerState<ChatScreen> {
|
||||||
final TextEditingController _textController = TextEditingController();
|
final TextEditingController _textController = TextEditingController();
|
||||||
|
bool _showTaskSuggestions = false;
|
||||||
|
|
||||||
@override
|
@override
|
||||||
void initState() {
|
void initState() {
|
||||||
@@ -34,6 +36,12 @@ class _ChatScreenState extends ConsumerState<ChatScreen> {
|
|||||||
|
|
||||||
@override
|
@override
|
||||||
Widget build(BuildContext context) {
|
Widget build(BuildContext context) {
|
||||||
|
ref.listen(chatViewmodelProvider, (prev, next) {
|
||||||
|
if (next.isGenerating) {
|
||||||
|
_showTaskSuggestions = false;
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
return Scaffold(
|
return Scaffold(
|
||||||
body: Column(
|
body: Column(
|
||||||
children: [
|
children: [
|
||||||
@@ -72,10 +80,19 @@ class _ChatScreenState extends ConsumerState<ChatScreen> {
|
|||||||
height: 5,
|
height: 5,
|
||||||
thickness: 6,
|
thickness: 6,
|
||||||
),
|
),
|
||||||
|
if (_showTaskSuggestions) DashbotTaskButtons(),
|
||||||
Padding(
|
Padding(
|
||||||
padding: const EdgeInsets.all(8.0),
|
padding: const EdgeInsets.all(8.0),
|
||||||
child: Row(
|
child: Row(
|
||||||
children: [
|
children: [
|
||||||
|
ADIconButton(
|
||||||
|
icon: Icons.help_outline_rounded,
|
||||||
|
tooltip: 'Show tasks',
|
||||||
|
onPressed: ref.watch(chatViewmodelProvider).isGenerating
|
||||||
|
? null
|
||||||
|
: () => setState(
|
||||||
|
() => _showTaskSuggestions = !_showTaskSuggestions),
|
||||||
|
),
|
||||||
ADIconButton(
|
ADIconButton(
|
||||||
icon: Icons.clear_all_rounded,
|
icon: Icons.clear_all_rounded,
|
||||||
tooltip: 'Clear chat',
|
tooltip: 'Clear chat',
|
||||||
|
|||||||
146
lib/dashbot/features/chat/view/widgets/dashbot_task_buttons.dart
Normal file
146
lib/dashbot/features/chat/view/widgets/dashbot_task_buttons.dart
Normal file
@@ -0,0 +1,146 @@
|
|||||||
|
import 'package:apidash/dashbot/features/chat/viewmodel/chat_viewmodel.dart';
|
||||||
|
import 'package:apidash/providers/collection_providers.dart';
|
||||||
|
import 'package:apidash/screens/common_widgets/agentic_ui_features/ai_ui_designer/generate_ui_dialog.dart';
|
||||||
|
import 'package:apidash/screens/common_widgets/agentic_ui_features/tool_generation/generate_tool_dialog.dart';
|
||||||
|
|
||||||
|
import 'package:flutter/material.dart';
|
||||||
|
import 'package:flutter_riverpod/flutter_riverpod.dart';
|
||||||
|
|
||||||
|
import '../../models/chat_models.dart';
|
||||||
|
import '../../../home/view/widgets/home_screen_task_button.dart';
|
||||||
|
import '../../../../core/providers/dashbot_window_notifier.dart';
|
||||||
|
|
||||||
|
class DashbotTaskButtons extends ConsumerWidget {
|
||||||
|
const DashbotTaskButtons({super.key});
|
||||||
|
|
||||||
|
@override
|
||||||
|
Widget build(BuildContext context, WidgetRef ref) {
|
||||||
|
final vm = ref.read(chatViewmodelProvider.notifier);
|
||||||
|
return Padding(
|
||||||
|
padding: const EdgeInsets.fromLTRB(12, 8, 12, 8),
|
||||||
|
child: Column(
|
||||||
|
crossAxisAlignment: CrossAxisAlignment.center,
|
||||||
|
children: [
|
||||||
|
Text(
|
||||||
|
'Do you want assistance with any of these tasks?',
|
||||||
|
style: Theme.of(context).textTheme.titleMedium?.copyWith(
|
||||||
|
fontWeight: FontWeight.w700,
|
||||||
|
),
|
||||||
|
),
|
||||||
|
const SizedBox(height: 12),
|
||||||
|
Wrap(
|
||||||
|
alignment: WrapAlignment.center,
|
||||||
|
spacing: 8,
|
||||||
|
runSpacing: 8,
|
||||||
|
children: [
|
||||||
|
HomeScreenTaskButton(
|
||||||
|
label: '🔎 Explain me this response',
|
||||||
|
onPressed: () {
|
||||||
|
vm.sendMessage(
|
||||||
|
text: '',
|
||||||
|
type: ChatMessageType.explainResponse,
|
||||||
|
countAsUser: false,
|
||||||
|
);
|
||||||
|
},
|
||||||
|
),
|
||||||
|
HomeScreenTaskButton(
|
||||||
|
label: '🐞 Help me debug this error',
|
||||||
|
onPressed: () {
|
||||||
|
vm.sendMessage(
|
||||||
|
text: '',
|
||||||
|
type: ChatMessageType.debugError,
|
||||||
|
countAsUser: false,
|
||||||
|
);
|
||||||
|
},
|
||||||
|
),
|
||||||
|
HomeScreenTaskButton(
|
||||||
|
label: '📄 Generate documentation',
|
||||||
|
onPressed: () {
|
||||||
|
vm.sendMessage(
|
||||||
|
text: '',
|
||||||
|
type: ChatMessageType.generateDoc,
|
||||||
|
countAsUser: false,
|
||||||
|
);
|
||||||
|
},
|
||||||
|
),
|
||||||
|
HomeScreenTaskButton(
|
||||||
|
label: '📝 Generate Tests',
|
||||||
|
onPressed: () {
|
||||||
|
vm.sendMessage(
|
||||||
|
text: '',
|
||||||
|
type: ChatMessageType.generateTest,
|
||||||
|
countAsUser: false,
|
||||||
|
);
|
||||||
|
},
|
||||||
|
),
|
||||||
|
HomeScreenTaskButton(
|
||||||
|
label: '🧩 Generate Code',
|
||||||
|
onPressed: () {
|
||||||
|
vm.sendMessage(
|
||||||
|
text: '',
|
||||||
|
type: ChatMessageType.generateCode,
|
||||||
|
countAsUser: false,
|
||||||
|
);
|
||||||
|
},
|
||||||
|
),
|
||||||
|
HomeScreenTaskButton(
|
||||||
|
label: '📥 Import cURL',
|
||||||
|
onPressed: () {
|
||||||
|
vm.sendMessage(
|
||||||
|
text: '',
|
||||||
|
type: ChatMessageType.importCurl,
|
||||||
|
countAsUser: false,
|
||||||
|
);
|
||||||
|
},
|
||||||
|
),
|
||||||
|
HomeScreenTaskButton(
|
||||||
|
label: '📄 Import OpenAPI',
|
||||||
|
onPressed: () {
|
||||||
|
vm.sendMessage(
|
||||||
|
text: '',
|
||||||
|
type: ChatMessageType.importOpenApi,
|
||||||
|
countAsUser: false,
|
||||||
|
);
|
||||||
|
},
|
||||||
|
),
|
||||||
|
HomeScreenTaskButton(
|
||||||
|
label: '🛠️ Generate Tool',
|
||||||
|
onPressed: () async {
|
||||||
|
final notifier =
|
||||||
|
ref.read(dashbotWindowNotifierProvider.notifier);
|
||||||
|
notifier.hide();
|
||||||
|
await GenerateToolDialog.show(context, ref);
|
||||||
|
notifier.show();
|
||||||
|
},
|
||||||
|
),
|
||||||
|
HomeScreenTaskButton(
|
||||||
|
label: '📱 Generate UI',
|
||||||
|
onPressed: () async {
|
||||||
|
final notifier =
|
||||||
|
ref.read(dashbotWindowNotifierProvider.notifier);
|
||||||
|
notifier.hide();
|
||||||
|
final model = ref.watch(selectedRequestModelProvider
|
||||||
|
.select((value) => value?.httpResponseModel));
|
||||||
|
if (model != null) {
|
||||||
|
String data = '';
|
||||||
|
if (model.sseOutput != null) {
|
||||||
|
data = model.sseOutput!.join('');
|
||||||
|
} else {
|
||||||
|
data = model.formattedBody ?? '<>';
|
||||||
|
}
|
||||||
|
await showCustomDialog(
|
||||||
|
context,
|
||||||
|
GenerateUIDialog(content: data),
|
||||||
|
useRootNavigator: true,
|
||||||
|
);
|
||||||
|
}
|
||||||
|
notifier.show();
|
||||||
|
},
|
||||||
|
),
|
||||||
|
],
|
||||||
|
),
|
||||||
|
],
|
||||||
|
),
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
||||||
Reference in New Issue
Block a user