+/*
+ * Copyright © 2018 Damyan Ivanov.
+ * This file is part of Mobile-Ledger.
+ * Mobile-Ledger 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,
+ * 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 <https://www.gnu.org/licenses/>.
+ */
+
package net.ktnx.mobileledger;
+import android.database.sqlite.SQLiteDatabase;
+
import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;
class LedgerTransaction {
+ private String id;
private String date;
private String description;
private List<LedgerTransactionItem> items;
- LedgerTransaction(String date, String description) {
+ LedgerTransaction(String id, String date, String description) {
+ this.id = id;
this.date = date;
this.description = description;
this.items = new ArrayList<>();
}
-
+ LedgerTransaction(String date, String description) {
+ this(null, date, description);
+ }
void add_item(LedgerTransactionItem item) {
items.add(item);
}
}
};
}
+ public String getId() {
+ return id;
+ }
+
+ void insertInto(SQLiteDatabase db) {
+ db.execSQL("INSERT INTO transactions(id, date, " + "description) values(?, ?, ?)",
+ new String[]{id, date, description});
+
+ for(LedgerTransactionItem item : items) {
+ db.execSQL("INSERT INTO transaction_accounts(transaction_id, account_name, amount, "
+ + "currency) values(?, ?, ?, ?)", new Object[]{id, item.getAccountName(),
+ item.getAmount(), item.getCurrency()});
+ }
+ }
}