X-Git-Url: https://git.ktnx.net/?p=mobile-ledger.git;a=blobdiff_plain;f=app%2Fsrc%2Fmain%2Fjava%2Fnet%2Fktnx%2Fmobileledger%2Fui%2Factivity%2FNewTransactionActivity.java;h=93d9ea6b953e3b8a61da6127561b4985f7abdaa7;hp=0856bb543b0b199df26d498d832aab841d784de9;hb=8fc197f9b27472b3113e850feae2221dcaab0aaf;hpb=bde37d0aa472d31606b53491240c79af3374f09b diff --git a/app/src/main/java/net/ktnx/mobileledger/ui/activity/NewTransactionActivity.java b/app/src/main/java/net/ktnx/mobileledger/ui/activity/NewTransactionActivity.java index 0856bb54..93d9ea6b 100644 --- a/app/src/main/java/net/ktnx/mobileledger/ui/activity/NewTransactionActivity.java +++ b/app/src/main/java/net/ktnx/mobileledger/ui/activity/NewTransactionActivity.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.ui.activity; @@ -20,6 +20,7 @@ package net.ktnx.mobileledger.ui.activity; import android.annotation.SuppressLint; import android.os.Bundle; import android.support.design.widget.BaseTransientBottomBar; +import android.support.design.widget.FloatingActionButton; import android.support.design.widget.Snackbar; import android.support.v4.app.DialogFragment; import android.support.v7.app.AppCompatActivity; @@ -41,16 +42,20 @@ import android.widget.ProgressBar; import android.widget.TableLayout; import android.widget.TableRow; import android.widget.TextView; +import android.widget.Toast; import net.ktnx.mobileledger.R; import net.ktnx.mobileledger.async.SaveTransactionTask; import net.ktnx.mobileledger.async.TaskCallback; +import net.ktnx.mobileledger.model.Data; import net.ktnx.mobileledger.model.LedgerTransaction; import net.ktnx.mobileledger.model.LedgerTransactionAccount; import net.ktnx.mobileledger.ui.DatePickerFragment; import net.ktnx.mobileledger.ui.OnSwipeTouchListener; +import net.ktnx.mobileledger.utils.Globals; import net.ktnx.mobileledger.utils.MLDB; +import java.text.ParseException; import java.util.Date; import java.util.Objects; @@ -59,7 +64,6 @@ import java.util.Objects; * TODO: reports * TODO: get rid of the custom session/cookie and auth code? * (the last problem with the POST was the missing content-length header) - * TODO: app icon * TODO: nicer swiping removal with visual feedback * TODO: setup wizard * TODO: update accounts/check settings upon change of backend settings @@ -69,9 +73,9 @@ public class NewTransactionActivity extends AppCompatActivity implements TaskCal private static SaveTransactionTask saver; private TableLayout table; private ProgressBar progress; + private FloatingActionButton fab; private TextView tvDate; private AutoCompleteTextView tvDescription; - private MenuItem mSave; private static boolean isZero(float f) { return (f < 0.005) && (f > -0.005); } @@ -81,6 +85,7 @@ public class NewTransactionActivity extends AppCompatActivity implements TaskCal setContentView(R.layout.activity_new_transaction); Toolbar toolbar = findViewById(R.id.toolbar); setSupportActionBar(toolbar); + toolbar.setSubtitle(Data.profile.get().getName()); tvDate = findViewById(R.id.new_transaction_date); tvDate.setOnFocusChangeListener((v, hasFocus) -> { @@ -92,6 +97,8 @@ public class NewTransactionActivity extends AppCompatActivity implements TaskCal hookTextChangeListener(tvDescription); progress = findViewById(R.id.save_transaction_progress); + fab = findViewById(R.id.fab); + fab.setOnClickListener(v -> saveTransaction()); Objects.requireNonNull(getSupportActionBar()).setDisplayHomeAsUpEnabled(true); table = findViewById(R.id.new_transaction_accounts_table); @@ -129,28 +136,49 @@ public class NewTransactionActivity extends AppCompatActivity implements TaskCal if (tvDescription.getText().toString().isEmpty()) tvDescription.requestFocus(); } public void saveTransaction() { - if (mSave != null) mSave.setVisible(false); + if (fab != null) fab.setEnabled(false); toggleAllEditing(false); progress.setVisibility(View.VISIBLE); + try { - saver = new SaveTransactionTask(this); + saver = new SaveTransactionTask(this); - String date = tvDate.getText().toString(); - if (date.isEmpty()) date = String.valueOf(new Date().getDate()); - LedgerTransaction tr = new LedgerTransaction(date, tvDescription.getText().toString()); + String dateString = tvDate.getText().toString(); + Date date; + if (dateString.isEmpty()) date = new Date(); + else date = Globals.parseLedgerDate(dateString); + LedgerTransaction tr = new LedgerTransaction(date, tvDescription.getText().toString()); - TableLayout table = findViewById(R.id.new_transaction_accounts_table); - for (int i = 0; i < table.getChildCount(); i++) { - TableRow row = (TableRow) table.getChildAt(i); - String acc = ((TextView) row.getChildAt(0)).getText().toString(); - String amt = ((TextView) row.getChildAt(1)).getText().toString(); - LedgerTransactionAccount item = - amt.length() > 0 ? new LedgerTransactionAccount(acc, Float.parseFloat(amt)) - : new LedgerTransactionAccount(acc); + TableLayout table = findViewById(R.id.new_transaction_accounts_table); + for (int i = 0; i < table.getChildCount(); i++) { + TableRow row = (TableRow) table.getChildAt(i); + String acc = ((TextView) row.getChildAt(0)).getText().toString(); + String amt = ((TextView) row.getChildAt(1)).getText().toString(); + LedgerTransactionAccount item = + amt.length() > 0 ? new LedgerTransactionAccount(acc, Float.parseFloat(amt)) + : new LedgerTransactionAccount(acc); - tr.addAccount(item); + tr.addAccount(item); + } + saver.execute(tr); + } + catch (ParseException e) { + Log.d("new-transaction", "Parse error", e); + Toast.makeText(this, getResources().getString(R.string.error_invalid_date), + Toast.LENGTH_LONG).show(); + tvDate.requestFocus(); + + progress.setVisibility(View.GONE); + toggleAllEditing(true); + if (fab != null) fab.setEnabled(true); + } + catch (Exception e) { + Log.d("new-transaction", "Unknown error", e); + + progress.setVisibility(View.GONE); + toggleAllEditing(true); + if (fab != null) fab.setEnabled(true); } - saver.execute(tr); } private void toggleAllEditing(boolean enabled) { tvDate.setEnabled(enabled); @@ -213,8 +241,6 @@ public class NewTransactionActivity extends AppCompatActivity implements TaskCal public boolean onCreateOptionsMenu(Menu menu) { // Inflate the menu; this adds items to the action bar if it is present. getMenuInflater().inflate(R.menu.new_transaction, menu); - mSave = menu.findItem(R.id.action_submit_transaction); - if (mSave == null) throw new AssertionError(); check_transaction_submittable(); @@ -378,9 +404,14 @@ public class NewTransactionActivity extends AppCompatActivity implements TaskCal (amounts_with_accounts == amounts) && (single_empty_amount && single_empty_amount_has_account || isZero(running_total))) { - if (mSave != null) mSave.setVisible(true); + if (fab != null) { + fab.show(); + fab.setEnabled(true); + } + } + else { + if (fab != null) fab.hide(); } - else if (mSave != null) mSave.setVisible(false); if (single_empty_amount) { empty_amount.setHint(String.format("%1.2f", @@ -389,11 +420,11 @@ public class NewTransactionActivity extends AppCompatActivity implements TaskCal } catch (NumberFormatException e) { - if (mSave != null) mSave.setVisible(false); + if (fab != null) fab.hide(); } catch (Exception e) { e.printStackTrace(); - if (mSave != null) mSave.setVisible(false); + if (fab != null) fab.hide(); } }