Compare commits
8 Commits
023610804d
..
v0.1.2
| Author | SHA1 | Date | |
|---|---|---|---|
| 392ec22dcd | |||
| 064c014f8b | |||
| 410a7eb843 | |||
| 20b017b066 | |||
| a3258b84fe | |||
| f088b84c54 | |||
| 5a39148577 | |||
| 2b718b5bd8 |
+11
-3
@@ -4,7 +4,9 @@ import 'model/repositories/local_repository.dart';
|
|||||||
import 'pages/task_edit_page.dart';
|
import 'pages/task_edit_page.dart';
|
||||||
import 'pages/task_overview_page.dart';
|
import 'pages/task_overview_page.dart';
|
||||||
import 'service/controller_scope.dart';
|
import 'service/controller_scope.dart';
|
||||||
import 'service/task_controller.dart';
|
import 'service/controllers/alarm_controller.dart';
|
||||||
|
import 'service/controllers/location_controller.dart';
|
||||||
|
import 'service/controllers/task_controller.dart';
|
||||||
|
|
||||||
void main() async {
|
void main() async {
|
||||||
final repository = LocalRepository();
|
final repository = LocalRepository();
|
||||||
@@ -13,8 +15,14 @@ void main() async {
|
|||||||
|
|
||||||
runApp(
|
runApp(
|
||||||
ControllerScope(
|
ControllerScope(
|
||||||
controller: TaskController(repository),
|
controller: LocationController(repository),
|
||||||
child: const MainApp(),
|
child: ControllerScope(
|
||||||
|
controller: AlarmController(repository),
|
||||||
|
child: ControllerScope(
|
||||||
|
controller: TaskController(repository),
|
||||||
|
child: const MainApp(),
|
||||||
|
),
|
||||||
|
),
|
||||||
),
|
),
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,4 +1,3 @@
|
|||||||
import '../location.dart';
|
|
||||||
import '../task.dart';
|
import '../task.dart';
|
||||||
|
|
||||||
class CreateTaskRequest {
|
class CreateTaskRequest {
|
||||||
|
|||||||
@@ -22,7 +22,12 @@ class LocalRepository
|
|||||||
if (_prefs == null) {
|
if (_prefs == null) {
|
||||||
await SharedPreferencesWithCache.create(
|
await SharedPreferencesWithCache.create(
|
||||||
cacheOptions: const SharedPreferencesWithCacheOptions(
|
cacheOptions: const SharedPreferencesWithCacheOptions(
|
||||||
allowList: <String>{_tasksKey, _taskOrderKey},
|
allowList: <String>{
|
||||||
|
_tasksKey,
|
||||||
|
_taskOrderKey,
|
||||||
|
_alarmsKey,
|
||||||
|
_locationsKey,
|
||||||
|
},
|
||||||
),
|
),
|
||||||
).then((value) => _prefs = value);
|
).then((value) => _prefs = value);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -3,7 +3,7 @@ import 'package:flutter/material.dart';
|
|||||||
import '../model/callback_models/create_task_request.dart';
|
import '../model/callback_models/create_task_request.dart';
|
||||||
import '../model/extensions/controller_context.dart';
|
import '../model/extensions/controller_context.dart';
|
||||||
import '../model/task.dart';
|
import '../model/task.dart';
|
||||||
import '../service/task_controller.dart';
|
import '../service/controllers/task_controller.dart';
|
||||||
import '../service/tools.dart';
|
import '../service/tools.dart';
|
||||||
import '../widgets/time_selector.dart';
|
import '../widgets/time_selector.dart';
|
||||||
|
|
||||||
|
|||||||
@@ -3,8 +3,9 @@ import 'package:flutter/material.dart';
|
|||||||
import '../model/callback_models/create_task_request.dart';
|
import '../model/callback_models/create_task_request.dart';
|
||||||
import '../model/extensions/controller_context.dart';
|
import '../model/extensions/controller_context.dart';
|
||||||
import '../model/task.dart';
|
import '../model/task.dart';
|
||||||
import '../service/task_controller.dart';
|
import '../service/controllers/task_controller.dart';
|
||||||
import '../service/tools.dart';
|
import '../service/tools.dart';
|
||||||
|
import '../widgets/task_dismissible.dart';
|
||||||
import 'task_edit_page.dart';
|
import 'task_edit_page.dart';
|
||||||
|
|
||||||
class TaskOverviewPage extends StatefulWidget {
|
class TaskOverviewPage extends StatefulWidget {
|
||||||
@@ -37,24 +38,28 @@ class _TaskOverviewPageState extends State<TaskOverviewPage> {
|
|||||||
Widget itemBuilder(BuildContext context, int index) {
|
Widget itemBuilder(BuildContext context, int index) {
|
||||||
final task = tasks.elementAt(index);
|
final task = tasks.elementAt(index);
|
||||||
|
|
||||||
return ListTile(
|
return TaskDismissible(
|
||||||
key: Key(task.id),
|
key: Key(task.id),
|
||||||
title: Text(task.title),
|
onDismissedRight: () =>
|
||||||
subtitle: task.description.isNotEmpty ? Text(task.description) : null,
|
context.controller<TaskController>().deleteTask(task),
|
||||||
trailing: Checkbox(
|
child: ListTile(
|
||||||
value: task.isCompleted,
|
title: Text(task.title),
|
||||||
onChanged: (isCompleted) => context
|
subtitle: task.description.isNotEmpty ? Text(task.description) : null,
|
||||||
.controller<TaskController>()
|
trailing: Checkbox(
|
||||||
.saveTask(task.copyWith(isCompleted: isCompleted)),
|
value: task.isCompleted,
|
||||||
|
onChanged: (isCompleted) => context
|
||||||
|
.controller<TaskController>()
|
||||||
|
.saveTask(task.copyWith(isCompleted: isCompleted)),
|
||||||
|
),
|
||||||
|
onTap: () async {
|
||||||
|
final result = await onTaskTapped(task);
|
||||||
|
if (result != null && context.mounted) {
|
||||||
|
context.controller<TaskController>().saveTask(
|
||||||
|
result.toTask(id: task.id),
|
||||||
|
);
|
||||||
|
}
|
||||||
|
},
|
||||||
),
|
),
|
||||||
onTap: () async {
|
|
||||||
final result = await onTaskTapped(task);
|
|
||||||
if (result != null && context.mounted) {
|
|
||||||
context.controller<TaskController>().saveTask(
|
|
||||||
result.toTask(id: task.id),
|
|
||||||
);
|
|
||||||
}
|
|
||||||
},
|
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -1,7 +1,7 @@
|
|||||||
import 'package:flutter/material.dart';
|
import 'package:flutter/material.dart';
|
||||||
|
|
||||||
import '../model/alarm.dart';
|
import '../../model/alarm.dart';
|
||||||
import '../model/repositories/interfaces/alarm_repository.dart';
|
import '../../model/repositories/interfaces/alarm_repository.dart';
|
||||||
|
|
||||||
class AlarmController extends ChangeNotifier {
|
class AlarmController extends ChangeNotifier {
|
||||||
AlarmController(AlarmRepository repository) : _repository = repository {
|
AlarmController(AlarmRepository repository) : _repository = repository {
|
||||||
@@ -0,0 +1,33 @@
|
|||||||
|
import 'package:flutter/material.dart';
|
||||||
|
|
||||||
|
import '../../model/location.dart';
|
||||||
|
import '../../model/repositories/interfaces/location_repository.dart';
|
||||||
|
|
||||||
|
class LocationController extends ChangeNotifier {
|
||||||
|
LocationController(LocationRepository repository) : _repository = repository {
|
||||||
|
_loadLocations();
|
||||||
|
}
|
||||||
|
|
||||||
|
final LocationRepository _repository;
|
||||||
|
|
||||||
|
final List<Location> _locations = [];
|
||||||
|
|
||||||
|
Future<void> addLocation(Location location) {
|
||||||
|
_locations.add(location);
|
||||||
|
notifyListeners();
|
||||||
|
return _repository.createLocation(location);
|
||||||
|
}
|
||||||
|
|
||||||
|
Future<void> deleteLocation(Location location) {
|
||||||
|
_locations.remove(location);
|
||||||
|
notifyListeners();
|
||||||
|
return _repository.deleteLocation(location);
|
||||||
|
}
|
||||||
|
|
||||||
|
Future<void> _loadLocations() {
|
||||||
|
_locations.clear();
|
||||||
|
return _repository.loadLocations().then(
|
||||||
|
(value) => _locations.addAll(value),
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -1,7 +1,7 @@
|
|||||||
import 'package:flutter/material.dart' show ChangeNotifier;
|
import 'package:flutter/material.dart' show ChangeNotifier;
|
||||||
|
|
||||||
import '../model/repositories/interfaces/task_repository.dart';
|
import '../../model/repositories/interfaces/task_repository.dart';
|
||||||
import '../model/task.dart';
|
import '../../model/task.dart';
|
||||||
|
|
||||||
class TaskController extends ChangeNotifier {
|
class TaskController extends ChangeNotifier {
|
||||||
TaskController(TaskRepository repository) : _repository = repository {
|
TaskController(TaskRepository repository) : _repository = repository {
|
||||||
@@ -0,0 +1,41 @@
|
|||||||
|
import 'package:flutter/material.dart';
|
||||||
|
|
||||||
|
class TaskDismissible extends StatelessWidget {
|
||||||
|
const TaskDismissible({
|
||||||
|
required super.key,
|
||||||
|
this.onDismissedRight,
|
||||||
|
required this.child,
|
||||||
|
});
|
||||||
|
|
||||||
|
final VoidCallback? onDismissedRight;
|
||||||
|
final Widget child;
|
||||||
|
|
||||||
|
@override
|
||||||
|
Widget build(BuildContext context) {
|
||||||
|
return Dismissible(
|
||||||
|
key: key!,
|
||||||
|
direction: DismissDirection.startToEnd,
|
||||||
|
background: Container(
|
||||||
|
color: Theme.of(context).colorScheme.error,
|
||||||
|
child: Align(
|
||||||
|
alignment: AlignmentGeometry.centerLeft,
|
||||||
|
child: Padding(
|
||||||
|
padding: const EdgeInsets.symmetric(horizontal: 12),
|
||||||
|
child: Icon(
|
||||||
|
Icons.delete,
|
||||||
|
color: Theme.of(context).colorScheme.onError,
|
||||||
|
),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
onDismissed: onDismissed,
|
||||||
|
child: child,
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
void onDismissed(DismissDirection direction) {
|
||||||
|
if (direction == DismissDirection.startToEnd && onDismissedRight != null) {
|
||||||
|
onDismissedRight!();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
Reference in New Issue
Block a user