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=d391b6227b5674019a853609cad9802f72330204;hp=1680236bc9c96a12675be57dd39b6488ce93ed8f;hb=a6fdfa98f01366db77c1d2774575aee0b3b1b410;hpb=14873dbc3aa249dc5af735c8906be1a19b5f7dda 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 1680236b..d391b622 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 @@ -1,5 +1,5 @@ /* - * Copyright © 2018 Damyan Ivanov. + * Copyright © 2019 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 @@ -17,70 +17,48 @@ package net.ktnx.mobileledger.ui.transaction_list; +import android.app.Activity; import android.arch.lifecycle.ViewModel; -import android.content.Context; -import android.database.Cursor; -import android.database.sqlite.SQLiteDatabase; -import android.util.Log; +import android.os.AsyncTask; import android.view.View; import android.widget.AutoCompleteTextView; import net.ktnx.mobileledger.R; -import net.ktnx.mobileledger.TransactionListActivity; +import net.ktnx.mobileledger.async.UpdateTransactionsTask; +import net.ktnx.mobileledger.model.Data; import net.ktnx.mobileledger.model.LedgerTransaction; -import net.ktnx.mobileledger.utils.MLDB; +import net.ktnx.mobileledger.utils.ObservableValue; -import java.util.ArrayList; +import java.util.List; public class TransactionListViewModel extends ViewModel { + public static ObservableValue updating = new ObservableValue<>(); - private ArrayList transactions; - - public void reloadTransactions(Context context) { - ArrayList newList = new ArrayList<>(); - - TransactionListActivity act = (TransactionListActivity) context; - boolean hasFilter = - act.findViewById(R.id.transaction_list_account_name_filter).getVisibility() == - View.VISIBLE; - - String sql; - String[] params; - - sql = "SELECT id FROM transactions ORDER BY date desc, id desc"; - params = null; - - if (hasFilter) { - String filterAccName = String.valueOf( - ((AutoCompleteTextView) act.findViewById(R.id.transaction_filter_account_name)) - .getText()); - - if (!filterAccName.isEmpty()) { - sql = "SELECT distinct tr.id from transactions tr JOIN transaction_accounts ta " + - "ON ta.transaction_id=tr.id WHERE ta.account_name LIKE ?||'%' AND ta" + - ".amount <> 0 ORDER BY tr.date desc, tr.id desc"; - params = new String[]{filterAccName}; - } - } - - Log.d("tmp", sql); - try (SQLiteDatabase db = MLDB.getReadableDatabase(context)) { - try (Cursor cursor = db.rawQuery(sql, params)) { - while (cursor.moveToNext()) { - newList.add(new LedgerTransaction(cursor.getInt(0))); - } - transactions = newList; - Log.d("transactions", "transaction list updated"); - } - } - + public static void scheduleTransactionListReload(Activity act) { + View filter = act.findViewById(R.id.transaction_list_account_name_filter); + if (filter == null) return; + boolean hasFilter = filter.getVisibility() == View.VISIBLE; + String accFilter = hasFilter ? String.valueOf( + ((AutoCompleteTextView) act.findViewById(R.id.transaction_filter_account_name)) + .getText()) : null; + AsyncTask> task = new UTT(); + task.execute(accFilter); } - public LedgerTransaction getTransaction(int position) { + public static LedgerTransaction getTransaction(int position) { + List transactions = Data.transactions.get(); if (position >= transactions.size()) return null; return transactions.get(position); } - public int getTransactionCount() { + public static int getTransactionCount() { + List transactions = Data.transactions.get(); if (transactions == null) return 0; return transactions.size(); } + private static class UTT extends UpdateTransactionsTask { + @Override + protected void onPostExecute(List list) { + super.onPostExecute(list); + if (list != null) Data.transactions.set(list); + } + } }