]> git.ktnx.net Git - mobile-ledger.git/blobdiff - app/src/main/java/net/ktnx/mobileledger/ui/transaction_list/TransactionListViewModel.java
TransactionListViewModel: also load transaction accounts
[mobile-ledger.git] / app / src / main / java / net / ktnx / mobileledger / ui / transaction_list / TransactionListViewModel.java
index 10aa2e9bc62630949cf9df03607463bc12d306de..d0c979e6df9b06ea6325fa80c3e906f5f3a78e62 100644 (file)
 package net.ktnx.mobileledger.ui.transaction_list;
 
 import android.arch.lifecycle.ViewModel;
+import android.database.Cursor;
+import android.database.sqlite.SQLiteDatabase;
+
+import net.ktnx.mobileledger.model.LedgerTransaction;
+import net.ktnx.mobileledger.model.LedgerTransactionItem;
+import net.ktnx.mobileledger.utils.MobileLedgerDatabase;
+
+import java.util.ArrayList;
+import java.util.List;
 
 public class TransactionListViewModel extends ViewModel {
-    // TODO: Implement the ViewModel
+
+    private List<LedgerTransaction> transactions;
+
+    public List<LedgerTransaction> getTransactions(MobileLedgerDatabase dbh) {
+        if (transactions == null) {
+            transactions = new ArrayList<>();
+            reloadTransactions(dbh);
+        }
+
+        return transactions;
+    }
+    private void reloadTransactions(MobileLedgerDatabase dbh) {
+        transactions.clear();
+        String sql = "SELECT id, date, description FROM transactions";
+        sql += " ORDER BY date desc, id desc";
+
+        try (SQLiteDatabase db = dbh.getReadableDatabase()) {
+            try (Cursor cursor = db.rawQuery(sql, null)) {
+                while (cursor.moveToNext()) {
+                    LedgerTransaction tr =
+                            new LedgerTransaction(cursor.getString(0), cursor.getString(1),
+                                    cursor.getString(2));
+                    try (Cursor cAcc = db.rawQuery("SELECT account_name, amount, currency FROM " +
+                                                   "transaction_accounts WHERE transaction_id = ?",
+                            new String[]{tr.getId()}))
+                    {
+                        while (cAcc.moveToNext()) {
+                            tr.add_item(
+                                    new LedgerTransactionItem(cAcc.getString(0), cAcc.getFloat(1),
+                                            cAcc.getString(2)));
+                        }
+                    }
+                    transactions.add(tr);
+                }
+            }
+        }
+
+    }
 }