corrected folder structure

This commit is contained in:
2026-06-09 11:55:07 +02:00
parent b2b5ae9e29
commit b4eb757537
4 changed files with 64 additions and 4 deletions
+8 -2
View File
@@ -1,6 +1,8 @@
import 'package:flutter/material.dart'; import 'package:flutter/material.dart';
import 'model/pages/task_overview_page.dart'; import 'pages/task_create_page.dart';
import 'pages/task_edit_page.dart';
import 'pages/task_overview_page.dart';
void main() { void main() {
runApp(const MainApp()); runApp(const MainApp());
@@ -12,7 +14,11 @@ class MainApp extends StatelessWidget {
@override @override
Widget build(BuildContext context) { Widget build(BuildContext context) {
return MaterialApp( return MaterialApp(
routes: {TaskOverviewPage.routeName: (context) => TaskOverviewPage()}, routes: {
TaskCreatePage.routeName: (context) => TaskCreatePage(),
TaskOverviewPage.routeName: (context) => TaskOverviewPage(),
TaskEditPage.routeName: (context) => TaskEditPage(),
},
initialRoute: TaskOverviewPage.routeName, initialRoute: TaskOverviewPage.routeName,
); );
} }
+11
View File
@@ -0,0 +1,11 @@
import 'package:flutter/material.dart';
class TaskCreatePage extends StatelessWidget {
static const routeName = '/create';
const TaskCreatePage({super.key});
@override
Widget build(BuildContext context) {
return const Placeholder();
}
}
+18
View File
@@ -0,0 +1,18 @@
import 'package:flutter/material.dart';
import '../model/task.dart';
class TaskEditPage extends StatelessWidget {
static const routeName = '/edit';
const TaskEditPage({super.key});
@override
Widget build(BuildContext context) {
final task = ModalRoute.of(context)!.settings.arguments as Task;
return Scaffold(
appBar: AppBar(title: Text(task.title)),
body: Form(child: Column()),
);
}
}
@@ -1,7 +1,9 @@
import 'package:flutter/material.dart'; import 'package:flutter/material.dart';
import '../../example_data.dart'; import '../example_data.dart';
import '../task.dart'; import '../model/task.dart';
import 'task_create_page.dart';
import 'task_edit_page.dart';
class TaskOverviewPage extends StatefulWidget { class TaskOverviewPage extends StatefulWidget {
static const String routeName = '/'; static const String routeName = '/';
@@ -23,6 +25,10 @@ class _TaskOverviewPageState extends State<TaskOverviewPage> {
onReorderItem: (oldIndex, newIndex) => onReorderItem: (oldIndex, newIndex) =>
reorderList(tasks, oldIndex, newIndex), reorderList(tasks, oldIndex, newIndex),
), ),
floatingActionButton: FloatingActionButton(
onPressed: onCreateTaskTapped,
child: Icon(Icons.add),
),
); );
} }
@@ -33,9 +39,17 @@ class _TaskOverviewPageState extends State<TaskOverviewPage> {
key: Key(task.id), key: Key(task.id),
title: Text(task.title), title: Text(task.title),
subtitle: Text(task.description), subtitle: Text(task.description),
onTap: () => onTaskTapped(task),
); );
} }
Future<Task?> onTaskTapped(Task task) async {
final result = await Navigator.of(
context,
).pushNamed(TaskEditPage.routeName, arguments: task);
return result as Task?;
}
List<Task> reorderList(List<Task> tasks, oldIndex, newIndex) { List<Task> reorderList(List<Task> tasks, oldIndex, newIndex) {
final item = tasks.removeAt(oldIndex); final item = tasks.removeAt(oldIndex);
tasks.insert(newIndex, item); tasks.insert(newIndex, item);
@@ -48,4 +62,15 @@ class _TaskOverviewPageState extends State<TaskOverviewPage> {
return reordered; return reordered;
} }
void onCreateTaskTapped() async {
//TODO: example data call
final result =
await Navigator.of(context).pushNamed(TaskCreatePage.routeName)
as Task?;
if (result != null) {
tasks.add(result);
}
}
} }