From ad7a4f94232a714a8edde8dff1c300e59be95a46 Mon Sep 17 00:00:00 2001 From: Damyan Ivanov Date: Thu, 6 Dec 2018 21:29:31 +0000 Subject: [PATCH 01/16] table for storing account balance --- app/src/main/java/net/ktnx/mobileledger/MobileLedgerDB.java | 3 +++ 1 file changed, 3 insertions(+) diff --git a/app/src/main/java/net/ktnx/mobileledger/MobileLedgerDB.java b/app/src/main/java/net/ktnx/mobileledger/MobileLedgerDB.java index 1f5801a7..7c2a8e2d 100644 --- a/app/src/main/java/net/ktnx/mobileledger/MobileLedgerDB.java +++ b/app/src/main/java/net/ktnx/mobileledger/MobileLedgerDB.java @@ -29,6 +29,9 @@ class MobileLedgerDB { db.execSQL("create index if not exists idx_accounts_name on accounts(name);"); db.execSQL("create table if not exists options(name varchar, value varchar);"); db.execSQL("create unique index if not exists idx_options_name on options(name);"); + db.execSQL("create table if not exists account_values(account varchar not null, currency varchar not null, value decimal(18,2) not null);"); + db.execSQL("create index if not exists idx_account_values_account on account_values(account);"); + db.execSQL("create unique index if not exists un_account_values on account_values(account,currency);"); } static void applyRevisions(Resources rm) { -- 2.39.2 From 977ec47877ac3bd6f1b61b3edea8ad63cee7b982 Mon Sep 17 00:00:00 2001 From: Damyan Ivanov Date: Thu, 6 Dec 2018 21:29:36 +0000 Subject: [PATCH 02/16] fill account balance while storing account data --- .../mobileledger/RetrieveAccountsTask.java | 19 +++++++++++++++++++ 1 file changed, 19 insertions(+) diff --git a/app/src/main/java/net/ktnx/mobileledger/RetrieveAccountsTask.java b/app/src/main/java/net/ktnx/mobileledger/RetrieveAccountsTask.java index 3c48f2ed..a2590300 100644 --- a/app/src/main/java/net/ktnx/mobileledger/RetrieveAccountsTask.java +++ b/app/src/main/java/net/ktnx/mobileledger/RetrieveAccountsTask.java @@ -40,15 +40,19 @@ abstract public class RetrieveAccountsTask extends android.os.AsyncTask Date: Fri, 7 Dec 2018 05:29:20 +0000 Subject: [PATCH 03/16] account amounts parser improvements allow spaces before numbers, allow sign detect row end -- avoids parsing the total balance as part of last account's data --- .../net/ktnx/mobileledger/RetrieveAccountsTask.java | 13 +++++++++++-- 1 file changed, 11 insertions(+), 2 deletions(-) diff --git a/app/src/main/java/net/ktnx/mobileledger/RetrieveAccountsTask.java b/app/src/main/java/net/ktnx/mobileledger/RetrieveAccountsTask.java index a2590300..8f6b32d7 100644 --- a/app/src/main/java/net/ktnx/mobileledger/RetrieveAccountsTask.java +++ b/app/src/main/java/net/ktnx/mobileledger/RetrieveAccountsTask.java @@ -49,12 +49,13 @@ abstract public class RetrieveAccountsTask extends android.os.AsyncTask Date: Fri, 7 Dec 2018 05:56:44 +0000 Subject: [PATCH 13/16] use the global reference instead of passing it to execute() --- .../main/java/net/ktnx/mobileledger/AccountSummary.java | 3 +-- .../java/net/ktnx/mobileledger/RetrieveAccountsTask.java | 8 ++++---- 2 files changed, 5 insertions(+), 6 deletions(-) diff --git a/app/src/main/java/net/ktnx/mobileledger/AccountSummary.java b/app/src/main/java/net/ktnx/mobileledger/AccountSummary.java index 882403ec..ec122cd4 100644 --- a/app/src/main/java/net/ktnx/mobileledger/AccountSummary.java +++ b/app/src/main/java/net/ktnx/mobileledger/AccountSummary.java @@ -22,7 +22,6 @@ import android.widget.TextView; import java.util.Date; import static android.view.View.GONE; -import static net.ktnx.mobileledger.MobileLedgerDB.db; import static net.ktnx.mobileledger.MobileLedgerDB.set_option_value; public class AccountSummary extends AppCompatActivity { @@ -171,7 +170,7 @@ public class AccountSummary extends AppCompatActivity { }; task.setPref(PreferenceManager.getDefaultSharedPreferences(this)); - task.execute(db); + task.execute(); } } diff --git a/app/src/main/java/net/ktnx/mobileledger/RetrieveAccountsTask.java b/app/src/main/java/net/ktnx/mobileledger/RetrieveAccountsTask.java index 670b1493..0956f638 100644 --- a/app/src/main/java/net/ktnx/mobileledger/RetrieveAccountsTask.java +++ b/app/src/main/java/net/ktnx/mobileledger/RetrieveAccountsTask.java @@ -1,7 +1,6 @@ package net.ktnx.mobileledger; import android.content.SharedPreferences; -import android.database.sqlite.SQLiteDatabase; import android.util.Log; import java.io.BufferedReader; @@ -14,7 +13,9 @@ import java.net.URLDecoder; import java.util.regex.Matcher; import java.util.regex.Pattern; -abstract public class RetrieveAccountsTask extends android.os.AsyncTask { +import static net.ktnx.mobileledger.MobileLedgerDB.db; + +abstract public class RetrieveAccountsTask extends android.os.AsyncTask { int error; private SharedPreferences pref; @@ -25,8 +26,7 @@ abstract public class RetrieveAccountsTask extends android.os.AsyncTask Date: Fri, 7 Dec 2018 18:37:52 +0000 Subject: [PATCH 14/16] update accounts table visual upon refreshilg the account data from the backend --- .../net/ktnx/mobileledger/AccountSummary.java | 66 ++++++++++++++++++- .../res/layout/content_account_summary.xml | 44 ++++++------- app/src/main/res/values/colors.xml | 1 + app/src/main/res/values/styles.xml | 21 ++++++ 4 files changed, 108 insertions(+), 24 deletions(-) diff --git a/app/src/main/java/net/ktnx/mobileledger/AccountSummary.java b/app/src/main/java/net/ktnx/mobileledger/AccountSummary.java index ec122cd4..e19b8add 100644 --- a/app/src/main/java/net/ktnx/mobileledger/AccountSummary.java +++ b/app/src/main/java/net/ktnx/mobileledger/AccountSummary.java @@ -1,8 +1,10 @@ package net.ktnx.mobileledger; +import android.annotation.SuppressLint; import android.content.Intent; import android.content.pm.PackageInfo; import android.content.res.Resources; +import android.database.Cursor; import android.os.Build; import android.os.Bundle; import android.preference.PreferenceManager; @@ -13,15 +15,22 @@ import android.support.v7.app.ActionBarDrawerToggle; import android.support.v7.app.AppCompatActivity; import android.support.v7.widget.Toolbar; import android.util.Log; +import android.util.TypedValue; import android.view.Menu; import android.view.MenuItem; import android.view.View; +import android.view.ViewGroup; +import android.widget.EditText; +import android.widget.LinearLayout; import android.widget.ProgressBar; +import android.widget.TableLayout; +import android.widget.TableRow; import android.widget.TextView; import java.util.Date; import static android.view.View.GONE; +import static net.ktnx.mobileledger.MobileLedgerDB.db; import static net.ktnx.mobileledger.MobileLedgerDB.set_option_value; public class AccountSummary extends AppCompatActivity { @@ -89,7 +98,7 @@ public class AccountSummary extends AppCompatActivity { public boolean onCreateOptionsMenu(Menu menu) { // Inflate the menu; this adds items to the action bar if it is present. getMenuInflater().inflate(R.menu.account_summary, menu); - mRefresh = (MenuItem) menu.findItem(R.id.menu_acc_summary_refresh); + mRefresh = menu.findItem(R.id.menu_acc_summary_refresh); assert mRefresh != null; return true; } @@ -164,8 +173,11 @@ public class AccountSummary extends AppCompatActivity { String err_text = rm.getString(this.error); Log.d("visual", String.format("showing snackbar: %s", err_text)); Snackbar.make(drawer, err_text, Snackbar.LENGTH_LONG ).show(); - } else + } + else { set_option_value("last_refresh", new Date().getTime() ); + update_account_table(); + } } }; @@ -173,4 +185,54 @@ public class AccountSummary extends AppCompatActivity { task.execute(); } + + public int dp2px(float dp) { + return Math.round(TypedValue.applyDimension(TypedValue.COMPLEX_UNIT_DIP, dp, getResources().getDisplayMetrics())); + } + + @SuppressLint("DefaultLocale") + private void update_account_table() { + LinearLayout root = findViewById(R.id.account_root); + root.removeAllViewsInLayout(); + + try (Cursor cursor = db.rawQuery("SELECT name FROM accounts ORDER BY name;", null)) { + boolean even = false; + while (cursor.moveToNext()) { + String acc_name = cursor.getString(0); + + TableLayout t = new TableLayout(this); + TableRow r = new TableRow(this); + r.setLayoutParams(new TableRow.LayoutParams(ViewGroup.LayoutParams.MATCH_PARENT, ViewGroup.LayoutParams.MATCH_PARENT)); + if (even) + r.setBackgroundColor(getResources().getColor(R.color.table_row_even_bg, getTheme())); + even = !even; + + TextView acc_tv = new TextView(this, null, R.style.account_summary_account_name); + acc_tv.setLayoutParams(new TableRow.LayoutParams(ViewGroup.LayoutParams.MATCH_PARENT, ViewGroup.LayoutParams.WRAP_CONTENT, 9f)); + acc_tv.setText(acc_name); + r.addView(acc_tv); + + TextView amt_tv = new TextView(this, null, R.style.account_summary_amounts); + amt_tv.setLayoutParams(new TableRow.LayoutParams(ViewGroup.LayoutParams.MATCH_PARENT, ViewGroup.LayoutParams.WRAP_CONTENT, 1f)); + amt_tv.setTextAlignment(EditText.TEXT_ALIGNMENT_VIEW_END); + amt_tv.setMinWidth(dp2px(40f)); + StringBuilder amt_text = new StringBuilder(); + try (Cursor cAmounts = db.rawQuery("SELECT currency, value FROM account_values WHERE account = ?", new String[]{acc_name})) { + while (cAmounts.moveToNext()) { + String curr = cAmounts.getString(0); + Float amt = cAmounts.getFloat(1); + if (amt_text.length() != 0) amt_text.append('\n'); + amt_text.append(String.format("%s %1.2f", curr, amt)); + } + } + amt_tv.setText(amt_text.toString()); + + r.addView(amt_tv); + + t.addView(r); + + root.addView(t); + } + } + } } diff --git a/app/src/main/res/layout/content_account_summary.xml b/app/src/main/res/layout/content_account_summary.xml index dfda28d1..89114417 100644 --- a/app/src/main/res/layout/content_account_summary.xml +++ b/app/src/main/res/layout/content_account_summary.xml @@ -2,6 +2,7 @@ + app:layout_constraintStart_toStartOf="parent" + tools:ignore="HardcodedText" /> - + - + android:layout_height="match_parent" + android:background="@color/table_row_even_bg"> - + - - - - + + + diff --git a/app/src/main/res/values/colors.xml b/app/src/main/res/values/colors.xml index c9f43903..0b00bf98 100644 --- a/app/src/main/res/values/colors.xml +++ b/app/src/main/res/values/colors.xml @@ -3,4 +3,5 @@ #9c27b0 #4a148c #4db6ac + #289d29b1 diff --git a/app/src/main/res/values/styles.xml b/app/src/main/res/values/styles.xml index 2ed9b110..e08c79c2 100644 --- a/app/src/main/res/values/styles.xml +++ b/app/src/main/res/values/styles.xml @@ -27,4 +27,25 @@ @style/TextAppearance.AppCompat.Body1 + + + + + + -- 2.39.2 From ab77ad93534a325f1135f0fae72ea7a15265142a Mon Sep 17 00:00:00 2001 From: Damyan Ivanov Date: Fri, 7 Dec 2018 18:37:58 +0000 Subject: [PATCH 15/16] update accounts table upon start --- app/src/main/java/net/ktnx/mobileledger/AccountSummary.java | 1 + 1 file changed, 1 insertion(+) diff --git a/app/src/main/java/net/ktnx/mobileledger/AccountSummary.java b/app/src/main/java/net/ktnx/mobileledger/AccountSummary.java index e19b8add..9620a69a 100644 --- a/app/src/main/java/net/ktnx/mobileledger/AccountSummary.java +++ b/app/src/main/java/net/ktnx/mobileledger/AccountSummary.java @@ -66,6 +66,7 @@ public class AccountSummary extends AppCompatActivity { } prepare_db(); + update_account_table(); update_accounts(false); } -- 2.39.2 From 7e41ae1d0d50379d8f96f5687a2633a62e34ae8b Mon Sep 17 00:00:00 2001 From: Damyan Ivanov Date: Fri, 7 Dec 2018 18:39:49 +0000 Subject: [PATCH 16/16] rename to better reflect purpose --- .../net/ktnx/mobileledger/AccountSummary.java | 2 +- .../mobileledger/NewTransactionActivity.java | 2 +- .../res/layout/activity_account_summary.xml | 49 +++++++------------ .../layout/activity_latest_transactions.xml | 29 ----------- .../res/layout/activity_new_transaction.xml | 41 ++++++++++++++++ ...ctions.xml => app_bar_account_summary.xml} | 0 .../res/layout/content_account_summary.xml | 2 +- .../res/layout/content_new_transaction.xml | 2 +- 8 files changed, 63 insertions(+), 64 deletions(-) delete mode 100644 app/src/main/res/layout/activity_latest_transactions.xml create mode 100644 app/src/main/res/layout/activity_new_transaction.xml rename app/src/main/res/layout/{app_bar_latest_transactions.xml => app_bar_account_summary.xml} (100%) diff --git a/app/src/main/java/net/ktnx/mobileledger/AccountSummary.java b/app/src/main/java/net/ktnx/mobileledger/AccountSummary.java index 9620a69a..a516722f 100644 --- a/app/src/main/java/net/ktnx/mobileledger/AccountSummary.java +++ b/app/src/main/java/net/ktnx/mobileledger/AccountSummary.java @@ -46,7 +46,7 @@ public class AccountSummary extends AppCompatActivity { @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); - setContentView(R.layout.activity_latest_transactions); + setContentView(R.layout.activity_account_summary); Toolbar toolbar = findViewById(R.id.toolbar); setSupportActionBar(toolbar); diff --git a/app/src/main/java/net/ktnx/mobileledger/NewTransactionActivity.java b/app/src/main/java/net/ktnx/mobileledger/NewTransactionActivity.java index a9d6097a..dca8d463 100644 --- a/app/src/main/java/net/ktnx/mobileledger/NewTransactionActivity.java +++ b/app/src/main/java/net/ktnx/mobileledger/NewTransactionActivity.java @@ -60,7 +60,7 @@ public class NewTransactionActivity extends AppCompatActivity implements TaskCal @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); - setContentView(R.layout.activity_account_summary); + setContentView(R.layout.activity_new_transaction); Toolbar toolbar = findViewById(R.id.toolbar); setSupportActionBar(toolbar); diff --git a/app/src/main/res/layout/activity_account_summary.xml b/app/src/main/res/layout/activity_account_summary.xml index d5f20877..6154fd61 100644 --- a/app/src/main/res/layout/activity_account_summary.xml +++ b/app/src/main/res/layout/activity_account_summary.xml @@ -1,42 +1,29 @@ - + android:fitsSystemWindows="true" + tools:openDrawer="start"> - + android:layout_height="match_parent" /> - - - - - - - + android:layout_gravity="start" + android:fitsSystemWindows="true"> - + - + - \ No newline at end of file + diff --git a/app/src/main/res/layout/activity_latest_transactions.xml b/app/src/main/res/layout/activity_latest_transactions.xml deleted file mode 100644 index 1c82d931..00000000 --- a/app/src/main/res/layout/activity_latest_transactions.xml +++ /dev/null @@ -1,29 +0,0 @@ - - - - - - - - - - - - diff --git a/app/src/main/res/layout/activity_new_transaction.xml b/app/src/main/res/layout/activity_new_transaction.xml new file mode 100644 index 00000000..ba67cc34 --- /dev/null +++ b/app/src/main/res/layout/activity_new_transaction.xml @@ -0,0 +1,41 @@ + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/app/src/main/res/layout/app_bar_latest_transactions.xml b/app/src/main/res/layout/app_bar_account_summary.xml similarity index 100% rename from app/src/main/res/layout/app_bar_latest_transactions.xml rename to app/src/main/res/layout/app_bar_account_summary.xml diff --git a/app/src/main/res/layout/content_account_summary.xml b/app/src/main/res/layout/content_account_summary.xml index 89114417..cde4d6a5 100644 --- a/app/src/main/res/layout/content_account_summary.xml +++ b/app/src/main/res/layout/content_account_summary.xml @@ -7,7 +7,7 @@ android:layout_height="match_parent" app:layout_behavior="@string/appbar_scrolling_view_behavior" tools:context=".AccountSummary" - tools:showIn="@layout/app_bar_latest_transactions"> + tools:showIn="@layout/app_bar_account_summary"> + tools:showIn="@layout/activity_new_transaction">