mirror of
https://codeberg.org/r4v3r23/mysu.git
synced 2024-11-22 22:02:25 +00:00
Disable send button when balance is 0
This commit is contained in:
parent
59a5dc0794
commit
e87ff399d1
1 changed files with 39 additions and 25 deletions
|
@ -19,6 +19,7 @@ import androidx.annotation.NonNull;
|
||||||
import androidx.annotation.Nullable;
|
import androidx.annotation.Nullable;
|
||||||
import androidx.lifecycle.LiveData;
|
import androidx.lifecycle.LiveData;
|
||||||
import androidx.lifecycle.MutableLiveData;
|
import androidx.lifecycle.MutableLiveData;
|
||||||
|
import androidx.lifecycle.Observer;
|
||||||
|
|
||||||
import com.google.android.material.bottomsheet.BottomSheetDialogFragment;
|
import com.google.android.material.bottomsheet.BottomSheetDialogFragment;
|
||||||
import com.google.zxing.client.android.Intents;
|
import com.google.zxing.client.android.Intents;
|
||||||
|
@ -93,6 +94,44 @@ public class SendBottomSheetDialog extends BottomSheetDialogFragment {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bindObservers();
|
||||||
|
bindListeners();
|
||||||
|
}
|
||||||
|
|
||||||
|
private void bindObservers() {
|
||||||
|
|
||||||
|
BalanceService.getInstance().balance.observe(getViewLifecycleOwner(), balance -> {
|
||||||
|
createButton.setEnabled(balance != 0);
|
||||||
|
sendMaxButton.setEnabled(balance != 0);
|
||||||
|
});
|
||||||
|
|
||||||
|
sendingMax.observe(getViewLifecycleOwner(), sendingMax -> {
|
||||||
|
if (pendingTransaction.getValue() == null) {
|
||||||
|
if (sendingMax) {
|
||||||
|
amountEditText.setVisibility(View.INVISIBLE);
|
||||||
|
sendAllTextView.setVisibility(View.VISIBLE);
|
||||||
|
sendMaxButton.setText(getText(R.string.undo));
|
||||||
|
} else {
|
||||||
|
amountEditText.setVisibility(View.VISIBLE);
|
||||||
|
sendAllTextView.setVisibility(View.GONE);
|
||||||
|
sendMaxButton.setText(getText(R.string.send_max));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
pendingTransaction.observe(getViewLifecycleOwner(), pendingTx -> {
|
||||||
|
showConfirmationLayout(pendingTx != null);
|
||||||
|
|
||||||
|
if (pendingTx != null) {
|
||||||
|
String address = addressEditText.getText().toString();
|
||||||
|
addressTextView.setText(getString(R.string.tx_address_text, address));
|
||||||
|
amountTextView.setText(getString(R.string.tx_amount_text, Helper.getDisplayAmount(pendingTx.getAmount())));
|
||||||
|
feeTextView.setText(getString(R.string.tx_fee_text, Helper.getDisplayAmount(pendingTx.getFee())));
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
private void bindListeners() {
|
||||||
pasteAddressImageButton.setOnClickListener(view1 -> {
|
pasteAddressImageButton.setOnClickListener(view1 -> {
|
||||||
Context ctx = getContext();
|
Context ctx = getContext();
|
||||||
if (ctx != null) {
|
if (ctx != null) {
|
||||||
|
@ -142,31 +181,6 @@ public class SendBottomSheetDialog extends BottomSheetDialogFragment {
|
||||||
sendTx(pendingTx);
|
sendTx(pendingTx);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
sendingMax.observe(getViewLifecycleOwner(), sendingMax -> {
|
|
||||||
if (pendingTransaction.getValue() == null) {
|
|
||||||
if (sendingMax) {
|
|
||||||
amountEditText.setVisibility(View.INVISIBLE);
|
|
||||||
sendAllTextView.setVisibility(View.VISIBLE);
|
|
||||||
sendMaxButton.setText(getText(R.string.undo));
|
|
||||||
} else {
|
|
||||||
amountEditText.setVisibility(View.VISIBLE);
|
|
||||||
sendAllTextView.setVisibility(View.GONE);
|
|
||||||
sendMaxButton.setText(getText(R.string.send_max));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
pendingTransaction.observe(getViewLifecycleOwner(), pendingTx -> {
|
|
||||||
showConfirmationLayout(pendingTx != null);
|
|
||||||
|
|
||||||
if (pendingTx != null) {
|
|
||||||
String address = addressEditText.getText().toString();
|
|
||||||
addressTextView.setText(getString(R.string.tx_address_text, address));
|
|
||||||
amountTextView.setText(getString(R.string.tx_amount_text, Helper.getDisplayAmount(pendingTx.getAmount())));
|
|
||||||
feeTextView.setText(getString(R.string.tx_fee_text, Helper.getDisplayAmount(pendingTx.getFee())));
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private void onScan() {
|
private void onScan() {
|
||||||
|
|
Loading…
Reference in a new issue