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;
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);
}
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);
if (tvDate.getText().toString().isEmpty()) tvDate.requestFocus();
}
public void saveTransaction() {
- if (mSave != null) mSave.setVisible(false);
+ if (fab != null) fab.setEnabled(false);
toggleAllEditing(false);
progress.setVisibility(View.VISIBLE);
try {
progress.setVisibility(View.GONE);
toggleAllEditing(true);
- if (mSave != null) mSave.setVisible(true);
+ if (fab != null) fab.setEnabled(true);
}
catch (Exception e) {
Log.d("new-transaction", "Unknown error", e);
progress.setVisibility(View.GONE);
toggleAllEditing(true);
- if (mSave != null) mSave.setVisible(true);
+ if (fab != null) fab.setEnabled(true);
}
}
private void toggleAllEditing(boolean enabled) {
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();
(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",
}
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();
}
}