Can disable dates extraction
This commit is contained in:
@@ -4,6 +4,7 @@ import 'package:flutter/material.dart';
|
|||||||
import 'package:hooks_riverpod/hooks_riverpod.dart';
|
import 'package:hooks_riverpod/hooks_riverpod.dart';
|
||||||
import 'package:logging/logging.dart';
|
import 'package:logging/logging.dart';
|
||||||
import 'package:moneymgr_mobile/services/storage/expenses.dart';
|
import 'package:moneymgr_mobile/services/storage/expenses.dart';
|
||||||
|
import 'package:moneymgr_mobile/services/storage/prefs.dart';
|
||||||
import 'package:moneymgr_mobile/utils/ocr_utils.dart';
|
import 'package:moneymgr_mobile/utils/ocr_utils.dart';
|
||||||
import 'package:moneymgr_mobile/utils/pdf_utils.dart';
|
import 'package:moneymgr_mobile/utils/pdf_utils.dart';
|
||||||
import 'package:moneymgr_mobile/widgets/expense_editor.dart';
|
import 'package:moneymgr_mobile/widgets/expense_editor.dart';
|
||||||
@@ -14,9 +15,14 @@ part 'scan_screen.g.dart';
|
|||||||
/// Scan a document & return generated PDF as byte file
|
/// Scan a document & return generated PDF as byte file
|
||||||
@riverpod
|
@riverpod
|
||||||
Future<(Uint8List?, BaseExpenseInfo?)> _scanDocument(Ref ref) async {
|
Future<(Uint8List?, BaseExpenseInfo?)> _scanDocument(Ref ref) async {
|
||||||
|
final prefs = ref.watch(prefsProvider).requireValue;
|
||||||
|
|
||||||
final pdf = await scanDocAsPDF();
|
final pdf = await scanDocAsPDF();
|
||||||
final img = await renderPdf(pdfBytes: pdf);
|
final img = await renderPdf(pdfBytes: pdf);
|
||||||
final amount = await extractInfoFromBill(img);
|
final amount = await extractInfoFromBill(
|
||||||
|
imgBuff: img,
|
||||||
|
extractDates: !prefs.disableExtractDates(),
|
||||||
|
);
|
||||||
return (pdf, amount);
|
return (pdf, amount);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@@ -22,6 +22,11 @@ class SettingsScreen extends ConsumerWidget {
|
|||||||
ref.invalidate(prefsProvider);
|
ref.invalidate(prefsProvider);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
handleToggleDisableExtractDate(v) async {
|
||||||
|
await prefs.setDisableExtractDates(v);
|
||||||
|
ref.invalidate(prefsProvider);
|
||||||
|
}
|
||||||
|
|
||||||
return Scaffold(
|
return Scaffold(
|
||||||
appBar: AppBar(title: const Text('Settings')),
|
appBar: AppBar(title: const Text('Settings')),
|
||||||
body: ListView(
|
body: ListView(
|
||||||
@@ -40,6 +45,14 @@ class SettingsScreen extends ConsumerWidget {
|
|||||||
"Do not start camera automatically on application startup",
|
"Do not start camera automatically on application startup",
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
|
SwitchListTile(
|
||||||
|
value: prefs.disableExtractDates(),
|
||||||
|
onChanged: handleToggleDisableExtractDate,
|
||||||
|
title: Text("Do not extract dates"),
|
||||||
|
subtitle: Text(
|
||||||
|
"Do not attempt to extract dates from scanned expenses",
|
||||||
|
),
|
||||||
|
),
|
||||||
const Divider(),
|
const Divider(),
|
||||||
ListTile(
|
ListTile(
|
||||||
leading: const Icon(Icons.info_outline),
|
leading: const Icon(Icons.info_outline),
|
||||||
|
@@ -23,6 +23,14 @@ extension MoneyMgrSharedPreferences on SharedPreferencesWithCache {
|
|||||||
await setBool("startOnScansListScreen", start);
|
await setBool("startOnScansListScreen", start);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool disableExtractDates() {
|
||||||
|
return getBool("disableExtractDates") ?? false;
|
||||||
|
}
|
||||||
|
|
||||||
|
Future<void> setDisableExtractDates(bool disable) async {
|
||||||
|
await setBool("disableExtractDates", disable);
|
||||||
|
}
|
||||||
|
|
||||||
ServerConfig? serverConfig() {
|
ServerConfig? serverConfig() {
|
||||||
final json = getString("serverConfig");
|
final json = getString("serverConfig");
|
||||||
if (json != null) return ServerConfig.fromJson(jsonDecode(json));
|
if (json != null) return ServerConfig.fromJson(jsonDecode(json));
|
||||||
|
@@ -8,7 +8,10 @@ import 'package:logging/logging.dart';
|
|||||||
import 'package:moneymgr_mobile/services/storage/expenses.dart';
|
import 'package:moneymgr_mobile/services/storage/expenses.dart';
|
||||||
|
|
||||||
/// Attempt to extract information from invoice image
|
/// Attempt to extract information from invoice image
|
||||||
Future<BaseExpenseInfo?> extractInfoFromBill(Uint8List imgBuff) async {
|
Future<BaseExpenseInfo?> extractInfoFromBill({
|
||||||
|
required Uint8List imgBuff,
|
||||||
|
required bool extractDates,
|
||||||
|
}) async {
|
||||||
final decodedImage = await decodeImageFromList(imgBuff);
|
final decodedImage = await decodeImageFromList(imgBuff);
|
||||||
|
|
||||||
final byteData = await decodedImage.toByteData(
|
final byteData = await decodedImage.toByteData(
|
||||||
@@ -74,6 +77,8 @@ Future<BaseExpenseInfo?> extractInfoFromBill(Uint8List imgBuff) async {
|
|||||||
return BaseExpenseInfo(
|
return BaseExpenseInfo(
|
||||||
label: null,
|
label: null,
|
||||||
cost: highestCost,
|
cost: highestCost,
|
||||||
time: newest?.isBefore(currDate) ?? false ? newest! : currDate,
|
time: extractDates && (newest?.isBefore(currDate) ?? false)
|
||||||
|
? newest!
|
||||||
|
: currDate,
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user