X-Git-Url: https://git.ktnx.net/?p=mobile-ledger.git;a=blobdiff_plain;f=app%2Fsrc%2Fmain%2Fjava%2Fnet%2Fktnx%2Fmobileledger%2Fasync%2FUpdateTransactionsTask.java;h=5093d50c952287846284c1390e07da2259453b23;hp=dc02fe9f339d42204c772ae038efd65c9ddee765;hb=90383a155ec16a9f13b1e6ac94a118033e09b3aa;hpb=ea17ca9e3b03ca0090be03fdc0abbbbfd954be89 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 dc02fe9f..5093d50c 100644 --- a/app/src/main/java/net/ktnx/mobileledger/async/UpdateTransactionsTask.java +++ b/app/src/main/java/net/ktnx/mobileledger/async/UpdateTransactionsTask.java @@ -1,18 +1,18 @@ /* * Copyright © 2019 Damyan Ivanov. - * This file is part of Mobile-Ledger. - * Mobile-Ledger is free software: you can distribute it and/or modify it + * 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; @@ -20,22 +20,27 @@ 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.App; import net.ktnx.mobileledger.model.Data; import net.ktnx.mobileledger.model.LedgerTransaction; +import net.ktnx.mobileledger.model.MobileLedgerProfile; import net.ktnx.mobileledger.model.TransactionListItem; import net.ktnx.mobileledger.utils.Globals; -import net.ktnx.mobileledger.utils.MLDB; import java.text.ParseException; import java.util.ArrayList; import java.util.Date; +import static net.ktnx.mobileledger.utils.Logger.debug; + public class UpdateTransactionsTask extends AsyncTask { protected String doInBackground(String[] filterAccName) { - Data.backgroundTaskCount.incrementAndGet(); - String profile_uuid = Data.profile.get().getUuid(); + final MobileLedgerProfile profile = Data.profile.getValue(); + if (profile == null) return "Profile not configured"; + + String profile_uuid = profile.getUuid(); + Data.backgroundTaskStarted(); try { ArrayList newList = new ArrayList<>(); @@ -57,9 +62,10 @@ public class UpdateTransactionsTask extends AsyncTask { params = new String[]{profile_uuid, filterAccName[0]}; } - Log.d("UTT", sql); - SQLiteDatabase db = MLDB.getReadableDatabase(); - Date lastDate = null; + debug("UTT", sql); + SQLiteDatabase db = App.getDatabase(); + String lastDateString = Globals.formatLedgerDate(new Date()); + Date lastDate = Globals.parseLedgerDate(lastDateString); boolean odd = true; try (Cursor cursor = db.rawQuery(sql, params)) { while (cursor.moveToNext()) { @@ -69,23 +75,21 @@ public class UpdateTransactionsTask extends AsyncTask { String dateString = cursor.getString(1); Date date = Globals.parseLedgerDate(dateString); - if ((lastDate == null) || !lastDate.equals(date)) { - boolean showMonth = (lastDate == null) || (date != null) && - (date.getMonth() != - lastDate.getMonth() || - date.getYear() != - lastDate.getYear()); + if (!lastDateString.equals(dateString)) { + boolean showMonth = (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)); +// debug("UTT", String.format("got transaction %d", transaction_id)); lastDate = date; + lastDateString = dateString; odd = !odd; } - Data.transactions.set(newList); - Log.d("UTT", "transaction list value updated"); + Data.transactions.setList(newList); + debug("UTT", "transaction list value updated"); } return null; @@ -94,7 +98,7 @@ public class UpdateTransactionsTask extends AsyncTask { return String.format("Error parsing stored date '%s'", e.getMessage()); } finally { - Data.backgroundTaskCount.decrementAndGet(); + Data.backgroundTaskFinished(); } } }