Can delete expense
This commit is contained in:
@ -49,6 +49,22 @@ class ScanDetailScreen extends HookConsumerWidget {
|
||||
}
|
||||
}
|
||||
|
||||
handleDelete() async {
|
||||
try {
|
||||
await expenses.deleteExpense(expense.requireValue!.$1);
|
||||
if (context.mounted) {
|
||||
context.pop();
|
||||
}
|
||||
|
||||
ref.invalidate(expensesProvider);
|
||||
} catch (e, s) {
|
||||
Logger.root.warning("Failed to delete expense! $e$s");
|
||||
if (context.mounted) {
|
||||
context.showTextSnackBar("Failed to delete expense! $e");
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
return switch (expense) {
|
||||
AsyncData(:final value) when value == null => FullScreenError(
|
||||
message: "Expense does not exists!",
|
||||
@ -56,8 +72,9 @@ class ScanDetailScreen extends HookConsumerWidget {
|
||||
),
|
||||
AsyncData(:final value) => ExpenseEditor(
|
||||
file: value!.$2,
|
||||
onFinished: handleUpdate,
|
||||
initialData: value.$1.baseExpense,
|
||||
onFinished: handleUpdate,
|
||||
onDelete: handleDelete,
|
||||
),
|
||||
AsyncError(:final error) => FullScreenError(
|
||||
message: "Failed to load expense information!",
|
||||
|
@ -10,7 +10,6 @@ import 'package:path_provider/path_provider.dart';
|
||||
import 'package:riverpod_annotation/riverpod_annotation.dart';
|
||||
|
||||
part 'expenses.freezed.dart';
|
||||
|
||||
part 'expenses.g.dart';
|
||||
|
||||
typedef ExpensesList = List<Expense>;
|
||||
@ -157,11 +156,28 @@ class ExpensesManager {
|
||||
Future<void> updateExpense(Expense expense, BaseExpenseInfo newInfo) async {
|
||||
final list = await getList();
|
||||
final entry = list.indexWhere((e) => e.id == expense.id);
|
||||
list[entry] = Expense(id: expense.id,
|
||||
label: newInfo.label,
|
||||
cost: newInfo.cost,
|
||||
time: newInfo.timeAsSeconds,
|
||||
mimeType: expense.mimeType);
|
||||
list[entry] = Expense(
|
||||
id: expense.id,
|
||||
label: newInfo.label,
|
||||
cost: newInfo.cost,
|
||||
time: newInfo.timeAsSeconds,
|
||||
mimeType: expense.mimeType,
|
||||
);
|
||||
saveList(list);
|
||||
}
|
||||
}
|
||||
|
||||
/// Delete an expense
|
||||
Future<void> deleteExpense(Expense expense) async {
|
||||
// Remove expense from the list
|
||||
final list = await getList();
|
||||
await saveList(list.where((e) => e.id != expense.id).toList());
|
||||
|
||||
// Delete associated file, if any
|
||||
final filePath = File(
|
||||
p.join(filesStoragePath.absolute.path, expense.localFileName),
|
||||
);
|
||||
if (await filePath.exists()) {
|
||||
await filePath.delete();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
Reference in New Issue
Block a user