aboutsummaryrefslogtreecommitdiff
path: root/frontend/lib/views/task/test_suite_detail_view.dart
diff options
context:
space:
mode:
Diffstat (limited to 'frontend/lib/views/task/test_suite_detail_view.dart')
-rw-r--r--frontend/lib/views/task/test_suite_detail_view.dart79
1 files changed, 79 insertions, 0 deletions
diff --git a/frontend/lib/views/task/test_suite_detail_view.dart b/frontend/lib/views/task/test_suite_detail_view.dart
new file mode 100644
index 000000000..ff7d2833c
--- /dev/null
+++ b/frontend/lib/views/task/test_suite_detail_view.dart
@@ -0,0 +1,79 @@
+import 'package:auto_gpt_flutter_client/models/test_suite.dart';
+import 'package:auto_gpt_flutter_client/viewmodels/chat_viewmodel.dart';
+import 'package:auto_gpt_flutter_client/viewmodels/task_viewmodel.dart';
+import 'package:auto_gpt_flutter_client/views/task/task_list_tile.dart';
+import 'package:flutter/material.dart';
+import 'package:provider/provider.dart';
+
+// TODO: Do we want a view model for every view?
+class TestSuiteDetailView extends StatefulWidget {
+ final TaskViewModel viewModel;
+ final TestSuite testSuite;
+
+ const TestSuiteDetailView(
+ {Key? key, required this.testSuite, required this.viewModel})
+ : super(key: key);
+
+ @override
+ _TestSuiteDetailViewState createState() => _TestSuiteDetailViewState();
+}
+
+class _TestSuiteDetailViewState extends State<TestSuiteDetailView> {
+ @override
+ Widget build(BuildContext context) {
+ return Scaffold(
+ backgroundColor: Colors.white,
+ appBar: AppBar(
+ backgroundColor: Colors.grey,
+ foregroundColor: Colors.black,
+ title: Text("${widget.testSuite.timestamp}"),
+ leading: IconButton(
+ icon: Icon(Icons.arrow_back),
+ onPressed: () => widget.viewModel.deselectTestSuite(),
+ ),
+ ),
+ body: Column(
+ children: [
+ // Task List
+ Expanded(
+ child: ListView.builder(
+ itemCount:
+ widget.testSuite.tests.length, // Count of tasks passed in
+ itemBuilder: (context, index) {
+ final task = widget.testSuite.tests[index];
+ return TaskListTile(
+ task: task,
+ onTap: () {
+ // Select the task in TaskViewModel
+ widget.viewModel.selectTask(task.id);
+
+ // Update the current task ID in ChatViewModel
+ // TODO: Do we want to have a reference to chat view model in this class?
+ final chatViewModel =
+ Provider.of<ChatViewModel>(context, listen: false);
+ chatViewModel.setCurrentTaskId(task.id);
+
+ print('Task ${task.title} tapped');
+ },
+ onDelete: () {
+ // Delete the task in TaskViewModel
+ widget.viewModel.deleteTask(task.id);
+ // TODO: Do we want to have a reference to chat view model in this class?
+ final chatViewModel =
+ Provider.of<ChatViewModel>(context, listen: false);
+ if (chatViewModel.currentTaskId == task.id) {
+ chatViewModel.clearCurrentTaskAndChats();
+ }
+
+ print('Task ${task.title} delete button tapped');
+ },
+ selected: task.id == widget.viewModel.selectedTask?.id,
+ );
+ },
+ ),
+ ),
+ ],
+ ),
+ );
+ }
+}