Files
tasks/lib/pages/task_overview_page.dart
T
2026-06-09 17:44:35 +02:00

86 lines
2.3 KiB
Dart

import 'package:flutter/material.dart';
import '../example_data.dart';
import '../model/callback_models/create_task_request.dart';
import '../model/task.dart';
import '../service/tools.dart';
import 'task_edit_page.dart';
class TaskOverviewPage extends StatefulWidget {
static const String routeName = '/';
const TaskOverviewPage({super.key});
@override
State<TaskOverviewPage> createState() => _TaskOverviewPageState();
}
class _TaskOverviewPageState extends State<TaskOverviewPage> {
//TODO: Replace example data call
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(),
body: ReorderableListView.builder(
itemBuilder: itemBuilder,
itemCount: tasks.length,
onReorderItem: (oldIndex, newIndex) =>
reorderList(tasks, oldIndex, newIndex),
),
floatingActionButton: FloatingActionButton(
onPressed: onCreateTaskTapped,
child: Icon(Icons.add),
),
);
}
Widget itemBuilder(BuildContext context, int index) {
final task = tasks.elementAt(index);
return ListTile(
key: Key(task.id),
title: Text(task.title),
subtitle: Text(task.description),
onTap: () async {
final result = await onTaskTapped(task);
if (result != null) {
tasks.remove(task);
tasks.add(result.toTask(id: task.id, position: task.position));
setState(() {});
}
},
);
}
Future<CreateTaskRequest?> onTaskTapped(Task task) async {
final result = await Navigator.of(
context,
).pushNamed(TaskEditPage.routeName, arguments: task);
return result as CreateTaskRequest?;
}
List<Task> reorderList(List<Task> tasks, oldIndex, newIndex) {
final item = tasks.removeAt(oldIndex);
tasks.insert(newIndex, item);
final List<Task> reordered = [];
for (int i = 0; i < tasks.length; i++) {
reordered.add(tasks.elementAt(i).copyWith(position: i));
}
return reordered;
}
void onCreateTaskTapped() async {
//TODO: example data call
final result =
await Navigator.of(context).pushNamed(TaskEditPage.routeName)
as CreateTaskRequest?;
if (result != null) {
tasks.add(result.toTask(id: generateId(), position: tasks.length));
setState(() {});
}
}
}