X-Git-Url: https://git.ktnx.net/?a=blobdiff_plain;f=app%2Fsrc%2Fmain%2Fjava%2Fnet%2Fktnx%2Fmobileledger%2Fmodel%2FLedgerTransaction.java;h=fd2a8407dfca79910216bc3191ed692d3661f956;hb=7af4595e73742f8a3f07af1daa8402d3c408200b;hp=8e6f2bf6b1eb91735aaab24865eced5ed0a97c36;hpb=e12bae55fb75c0c30055dd34ded195e75feb3844;p=mobile-ledger.git
diff --git a/app/src/main/java/net/ktnx/mobileledger/model/LedgerTransaction.java b/app/src/main/java/net/ktnx/mobileledger/model/LedgerTransaction.java
index 8e6f2bf6..fd2a8407 100644
--- a/app/src/main/java/net/ktnx/mobileledger/model/LedgerTransaction.java
+++ b/app/src/main/java/net/ktnx/mobileledger/model/LedgerTransaction.java
@@ -1,18 +1,18 @@
/*
* Copyright © 2019 Damyan Ivanov.
- * This file is part of Mobile-Ledger.
- * Mobile-Ledger is free software: you can distribute it and/or modify it
+ * This file is part of MoLe.
+ * MoLe is free software: you can distribute it and/or modify it
* under the term of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your opinion), any later version.
*
- * Mobile-Ledger is distributed in the hope that it will be useful,
+ * MoLe is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License terms for details.
*
* You should have received a copy of the GNU General Public License
- * along with Mobile-Ledger. If not, see .
+ * along with MoLe. If not, see .
*/
package net.ktnx.mobileledger.model;
@@ -26,6 +26,7 @@ import net.ktnx.mobileledger.utils.Globals;
import java.nio.charset.Charset;
import java.security.NoSuchAlgorithmException;
+import java.text.ParseException;
import java.util.ArrayList;
import java.util.Comparator;
import java.util.Date;
@@ -50,7 +51,8 @@ public class LedgerTransaction {
private ArrayList accounts;
private String dataHash;
private boolean dataLoaded;
- public LedgerTransaction(Integer id, String dateString, String description) {
+ public LedgerTransaction(Integer id, String dateString, String description)
+ throws ParseException {
this(id, Globals.parseLedgerDate(dateString), description);
}
public LedgerTransaction(Integer id, Date date, String description) {
@@ -68,6 +70,15 @@ public class LedgerTransaction {
public LedgerTransaction(int id) {
this(id, (Date) null, null);
}
+ public LedgerTransaction(int id, String profileUUID) {
+ this.profile = profileUUID;
+ this.id = id;
+ this.date = null;
+ this.description = null;
+ this.accounts = new ArrayList<>();
+ this.dataHash = null;
+ this.dataLoaded = false;
+ }
public ArrayList getAccounts() {
return accounts;
}
@@ -102,6 +113,8 @@ public class LedgerTransaction {
data.append('\0');
data.append(getDescription());
data.append('\0');
+ data.append(Globals.formatLedgerDate(getDate()));
+ data.append('\0');
for (LedgerTransactionAccount item : accounts) {
data.append(item.getAccountName());
data.append('\0');
@@ -137,7 +150,15 @@ public class LedgerTransaction {
{
if (cTr.moveToFirst()) {
String dateString = cTr.getString(0);
- date = Globals.parseLedgerDate(dateString);
+ try {
+ date = Globals.parseLedgerDate(dateString);
+ }
+ catch (ParseException e) {
+ e.printStackTrace();
+ throw new RuntimeException(
+ String.format("Error parsing date '%s' from " + "transacion %d",
+ dateString, id));
+ }
description = cTr.getString(1);
try (Cursor cAcc = db.rawQuery("SELECT account_name, amount, currency FROM " +