From 7bff7b2c3ea7fe8fcc2febb96d8a432286173c85 Mon Sep 17 00:00:00 2001 From: Damyan Ivanov Date: Thu, 17 Sep 2020 07:37:28 +0000 Subject: [PATCH 1/1] store new currencies upon account amounts storage fixes a crash when a previous transaction is selected in the new transaction screen that uses currencies not added via the currency dialog --- .../model/MobileLedgerProfile.java | 19 +++++++++++++++++++ 1 file changed, 19 insertions(+) diff --git a/app/src/main/java/net/ktnx/mobileledger/model/MobileLedgerProfile.java b/app/src/main/java/net/ktnx/mobileledger/model/MobileLedgerProfile.java index 4ac99fe1..62ab8f4b 100644 --- a/app/src/main/java/net/ktnx/mobileledger/model/MobileLedgerProfile.java +++ b/app/src/main/java/net/ktnx/mobileledger/model/MobileLedgerProfile.java @@ -20,6 +20,7 @@ package net.ktnx.mobileledger.model; import android.content.res.Resources; import android.database.Cursor; import android.database.sqlite.SQLiteDatabase; +import android.text.TextUtils; import android.util.SparseArray; import androidx.annotation.Nullable; @@ -332,6 +333,24 @@ public final class MobileLedgerProfile { } public void storeAccountValue(SQLiteDatabase db, int generation, String name, String currency, Float amount) { + if (!TextUtils.isEmpty(currency)) { + boolean exists; + try (Cursor c = db.rawQuery("select 1 from currencies where name=?", + new String[]{currency})) + { + exists = c.moveToFirst(); + } + if (!exists) { + db.execSQL( + "insert into currencies(id, name, position, has_gap) values((select max" + + "(id) from currencies)+1, ?, ?, ?)", new Object[]{currency, + Objects.requireNonNull( + Data.currencySymbolPosition.getValue()).toString(), + Data.currencyGap.getValue() + }); + } + } + db.execSQL("replace into account_values(profile, account, " + "currency, value, generation) values(?, ?, ?, ?, ?);", new Object[]{uuid, name, Misc.emptyIsNull(currency), amount, generation}); -- 2.39.5