import android.database.sqlite.SQLiteDatabase;
import android.os.AsyncTask;
+import androidx.lifecycle.MutableLiveData;
+
+import net.ktnx.mobileledger.App;
import net.ktnx.mobileledger.async.RetrieveTransactionsTask;
import net.ktnx.mobileledger.ui.activity.MainActivity;
import net.ktnx.mobileledger.utils.LockHolder;
import net.ktnx.mobileledger.utils.Logger;
import net.ktnx.mobileledger.utils.MLDB;
import net.ktnx.mobileledger.utils.ObservableList;
-import net.ktnx.mobileledger.utils.ObservableValue;
import java.lang.ref.WeakReference;
+import java.text.NumberFormat;
import java.util.ArrayList;
import java.util.Date;
import java.util.List;
import java.util.Locale;
import java.util.concurrent.atomic.AtomicInteger;
-import androidx.lifecycle.MutableLiveData;
-
import static net.ktnx.mobileledger.utils.Logger.debug;
public final class Data {
public static MutableLiveData<Date> lastUpdateDate = new MutableLiveData<>();
public static MutableLiveData<MobileLedgerProfile> profile = new MutableLiveData<>();
public static MutableLiveData<ArrayList<MobileLedgerProfile>> profiles =
- new MutableLiveData<>(new ArrayList<>());
- public static ObservableValue<Boolean> optShowOnlyStarred = new ObservableValue<>();
+ new MutableLiveData<>(null);
public static MutableLiveData<String> accountFilter = new MutableLiveData<>();
+ public static MutableLiveData<Currency.Position> currencySymbolPosition =
+ new MutableLiveData<>();
private static AtomicInteger backgroundTaskCount = new AtomicInteger(0);
private static Locker profilesLocker = new Locker();
private static RetrieveTransactionsTask retrieveTransactionsTask;
backgroundTasksRunning.postValue(cnt > 0);
}
public static void setCurrentProfile(MobileLedgerProfile newProfile) {
- MLDB.setOption(MLDB.OPT_PROFILE_UUID, newProfile.getUuid());
+ MLDB.setOption(MLDB.OPT_PROFILE_UUID, (newProfile == null) ? null : newProfile.getUuid());
+ stopTransactionsRetrieval();
profile.postValue(newProfile);
}
public static int getProfileIndex(MobileLedgerProfile profile) {
try (LockHolder ignored = profilesLocker.lockForReading()) {
List<MobileLedgerProfile> prList = profiles.getValue();
- assert prList != null;
+ if (prList == null)
+ throw new AssertionError();
for (int i = 0; i < prList.size(); i++) {
MobileLedgerProfile p = prList.get(i);
- if (p.equals(profile)) return i;
+ if (p.equals(profile))
+ return i;
}
return -1;
public static int getProfileIndex(String profileUUID) {
try (LockHolder ignored = profilesLocker.lockForReading()) {
List<MobileLedgerProfile> prList = profiles.getValue();
- assert prList != null;
+ if (prList == null)
+ throw new AssertionError();
for (int i = 0; i < prList.size(); i++) {
MobileLedgerProfile p = prList.get(i);
- if (p.getUuid().equals(profileUUID)) return i;
+ if (p.getUuid()
+ .equals(profileUUID))
+ return i;
}
return -1;
}
public static int retrieveCurrentThemeIdFromDb() {
String profileUUID = MLDB.getOption(MLDB.OPT_PROFILE_UUID, null);
- if (profileUUID == null) return -1;
+ if (profileUUID == null)
+ return -1;
- SQLiteDatabase db = MLDB.getDatabase();
- try (Cursor c = db
- .rawQuery("SELECT theme from profiles where uuid=?", new String[]{profileUUID}))
+ SQLiteDatabase db = App.getDatabase();
+ try (Cursor c = db.rawQuery("SELECT theme from profiles where uuid=?",
+ new String[]{profileUUID}))
{
- if (c.moveToNext()) return c.getInt(0);
+ if (c.moveToNext())
+ return c.getInt(0);
}
return -1;
MobileLedgerProfile profile;
try (LockHolder readLock = profilesLocker.lockForReading()) {
List<MobileLedgerProfile> prList = profiles.getValue();
- assert prList != null;
- if (prList.isEmpty()) {
+ if ((prList == null) || prList.isEmpty()) {
readLock.close();
try (LockHolder ignored = profilesLocker.lockForWriting()) {
profile = MobileLedgerProfile.loadAllFromDB(profileUUID);
}
else {
int i = getProfileIndex(profileUUID);
- if (i == -1) i = 0;
+ if (i == -1)
+ i = 0;
profile = prList.get(i);
}
}
Logger.debug("db", "Ignoring request for transaction retrieval - already active");
return;
}
+ MobileLedgerProfile pr = profile.getValue();
+ if (pr == null)
+ throw new IllegalStateException("No current profile");
+
retrieveTransactionsTask =
new RetrieveTransactionsTask(new WeakReference<>(activity), profile.getValue());
Logger.debug("db", "Created a background transaction retrieval task");
retrieveTransactionsTask.executeOnExecutor(AsyncTask.THREAD_POOL_EXECUTOR);
}
public static synchronized void stopTransactionsRetrieval() {
- if (retrieveTransactionsTask != null) retrieveTransactionsTask.cancel(false);
+ if (retrieveTransactionsTask != null)
+ retrieveTransactionsTask.cancel(false);
}
public static void transactionRetrievalDone() {
retrieveTransactionsTask = null;
}
-}
+ public static void refreshCurrencyData(Locale locale) {
+ NumberFormat formatter = NumberFormat.getCurrencyInstance(locale);
+ java.util.Currency currency = formatter.getCurrency();
+ Logger.debug("locale",
+ String.format("Discovering currency symbol position for locale %s (currency is %s)",
+ locale.toString(), currency.toString()));
+ String formatted = formatter.format(1234.56f);
+ Logger.debug("locale", String.format("1234.56 formats as '%s'", formatted));
+ String symbol = currency.getSymbol();
+ if (formatted.startsWith(symbol))
+ currencySymbolPosition.setValue(Currency.Position.before);
+ else if (formatted.endsWith(symbol))
+ currencySymbolPosition.setValue(Currency.Position.after);
+ else
+ currencySymbolPosition.setValue(Currency.Position.none);
+ }
+
+}
\ No newline at end of file