X-Git-Url: https://git.ktnx.net/?a=blobdiff_plain;f=app%2Fsrc%2Fmain%2Fjava%2Fnet%2Fktnx%2Fmobileledger%2Fasync%2FUpdateTransactionsTask.java;h=38db6b17f8c7b30648a92d980f23626f4fbe222e;hb=63d4636c19652b688fb0a1e4f3081843c740bf78;hp=f58d3e5cae25f8f9a06ea4c8b941a3af40cd0af2;hpb=11c8dff16901782f69287854cb4788ddf8d932c2;p=mobile-ledger.git diff --git a/app/src/main/java/net/ktnx/mobileledger/async/UpdateTransactionsTask.java b/app/src/main/java/net/ktnx/mobileledger/async/UpdateTransactionsTask.java index f58d3e5c..38db6b17 100644 --- a/app/src/main/java/net/ktnx/mobileledger/async/UpdateTransactionsTask.java +++ b/app/src/main/java/net/ktnx/mobileledger/async/UpdateTransactionsTask.java @@ -1,97 +1,81 @@ /* - * Copyright © 2019 Damyan Ivanov. - * This file is part of Mobile-Ledger. - * Mobile-Ledger is free software: you can distribute it and/or modify it + * Copyright © 2021 Damyan Ivanov. + * 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.async; -import android.database.Cursor; -import android.database.sqlite.SQLiteDatabase; import android.os.AsyncTask; -import android.util.Log; +import net.ktnx.mobileledger.db.DB; +import net.ktnx.mobileledger.db.Profile; +import net.ktnx.mobileledger.db.TransactionWithAccounts; import net.ktnx.mobileledger.model.Data; import net.ktnx.mobileledger.model.LedgerTransaction; -import net.ktnx.mobileledger.model.TransactionListItem; -import net.ktnx.mobileledger.utils.Globals; -import net.ktnx.mobileledger.utils.MLDB; +import net.ktnx.mobileledger.ui.MainModel; +import net.ktnx.mobileledger.utils.Logger; import java.util.ArrayList; -import java.util.Date; import java.util.List; -public class UpdateTransactionsTask extends AsyncTask> { - protected List doInBackground(String[] filterAccName) { - Data.backgroundTaskCount.incrementAndGet(); - String profile_uuid = Data.profile.get().getUuid(); - try { - ArrayList newList = new ArrayList<>(); +import static net.ktnx.mobileledger.db.Profile.NO_PROFILE_ID; +import static net.ktnx.mobileledger.utils.Logger.debug; + +public class UpdateTransactionsTask extends AsyncTask { + protected String doInBackground(MainModel[] parentModel) { + final Profile profile = Data.getProfile(); - String sql; - String[] params; + long profileId = (profile == null) ? NO_PROFILE_ID : profile.getId(); + Data.backgroundTaskStarted(); + try { + Logger.debug("UTT", "Starting DB transaction list retrieval"); - if (filterAccName[0] == null) { - sql = "SELECT id, date FROM transactions WHERE profile=? ORDER BY date desc, id " + - "desc"; - params = new String[]{profile_uuid}; + final MainModel model = parentModel[0]; + final String accFilter = model.getAccountFilter() + .getValue(); + final List transactions; + if (profileId == NO_PROFILE_ID) + transactions = new ArrayList<>(); + else if (accFilter == null) { + transactions = DB.get() + .getTransactionDAO() + .getAllWithAccountsSync(profileId); } else { - sql = "SELECT distinct tr.id, tr.date from transactions tr JOIN " + - "transaction_accounts ta " + - "ON ta.transaction_id=tr.id AND ta.profile=tr.profile WHERE tr.profile=? " + - "and ta.account_name LIKE ?||'%' AND ta" + - ".amount <> 0 ORDER BY tr.date desc, tr.id desc"; - params = new String[]{profile_uuid, filterAccName[0]}; + transactions = DB.get() + .getTransactionDAO() + .getAllWithAccountsFilteredSync(profileId, accFilter); } - Log.d("UTT", sql); - SQLiteDatabase db = MLDB.getReadableDatabase(); - Date lastDate = null; - boolean odd = true; - try (Cursor cursor = db.rawQuery(sql, params)) { - while (cursor.moveToNext()) { - if (isCancelled()) return null; + TransactionAccumulator accumulator = new TransactionAccumulator(model); - int transaction_id = cursor.getInt(0); - String dateString = cursor.getString(1); - Date date = Globals.parseLedgerDate(dateString); + for (TransactionWithAccounts tr : transactions) { + if (isCancelled()) + return null; - if ((lastDate == null) || !lastDate.equals(date)) { - boolean showMonth = (lastDate == null) || (date != null) && - (date.getMonth() != - lastDate.getMonth() || - date.getYear() != - lastDate.getYear()); - newList.add(new TransactionListItem(date, showMonth)); - } - newList.add( - new TransactionListItem(new LedgerTransaction(transaction_id), odd)); -// Log.d("UTT", String.format("got transaction %d", transaction_id)); - - lastDate = date; - odd = !odd; - } - Data.transactions.set(newList); - Log.d("UTT", "transaction list value updated"); + accumulator.put(new LedgerTransaction(tr)); } - return newList; + accumulator.done(); + debug("UTT", "transaction list value updated"); + + return null; } finally { - Data.backgroundTaskCount.decrementAndGet(); + Data.backgroundTaskFinished(); } } }