X-Git-Url: https://git.ktnx.net/?p=mobile-ledger.git;a=blobdiff_plain;f=app%2Fsrc%2Fmain%2Fjava%2Fnet%2Fktnx%2Fmobileledger%2Fui%2Ftransaction_list%2FTransactionListViewModel.java;h=480c0de271b9d4d71d0f2215c84102a04e482c07;hp=0ce37f2c0184776fc60e30ff631aad1976c495e8;hb=a5971dd3588704cc5c8dd9077d4d74860c5a06a9;hpb=6c58c1072c9af6ea0d0f52baeae7f95ba7f7ee2f diff --git a/app/src/main/java/net/ktnx/mobileledger/ui/transaction_list/TransactionListViewModel.java b/app/src/main/java/net/ktnx/mobileledger/ui/transaction_list/TransactionListViewModel.java index 0ce37f2c..480c0de2 100644 --- a/app/src/main/java/net/ktnx/mobileledger/ui/transaction_list/TransactionListViewModel.java +++ b/app/src/main/java/net/ktnx/mobileledger/ui/transaction_list/TransactionListViewModel.java @@ -21,36 +21,39 @@ import android.arch.lifecycle.ViewModel; import android.content.Context; import android.database.Cursor; import android.database.sqlite.SQLiteDatabase; +import android.util.Log; import net.ktnx.mobileledger.model.LedgerTransaction; import net.ktnx.mobileledger.utils.MLDB; import java.util.ArrayList; -import java.util.List; public class TransactionListViewModel extends ViewModel { - private List transactions; + private ArrayList transactions; - public List getTransactions(Context context) { - if (transactions == null) { - transactions = new ArrayList<>(); - reloadTransactions(context); - } + public void reloadTransactions(Context context) { + ArrayList newList = new ArrayList<>(); - return transactions; - } - private void reloadTransactions(Context context) { - transactions.clear(); String sql = "SELECT id FROM transactions ORDER BY date desc, id desc"; try (SQLiteDatabase db = MLDB.getReadableDatabase(context)) { try (Cursor cursor = db.rawQuery(sql, null)) { while (cursor.moveToNext()) { - transactions.add(new LedgerTransaction(cursor.getInt(0))); + newList.add(new LedgerTransaction(cursor.getInt(0))); } + transactions = newList; + Log.d("transactions", "transaction list updated"); } } } + public LedgerTransaction getTransaction(int position) { + if (position >= transactions.size()) return null; + return transactions.get(position); + } + public int getTransactionCount() { + if (transactions == null) return 0; + return transactions.size(); + } }