Withdraw tx runs in separate thread while displaying spinning wheel

This commit is contained in:
niyid 2024-04-07 12:37:54 +01:00 committed by GitHub
parent 60d82520c0
commit 9f2546543a
No known key found for this signature in database
GPG key ID: B5690EEEBB952194

View file

@ -48,38 +48,48 @@ import haveno.core.xmr.setup.WalletsSetup;
import haveno.core.xmr.wallet.XmrWalletService; import haveno.core.xmr.wallet.XmrWalletService;
import haveno.desktop.common.view.ActivatableView; import haveno.desktop.common.view.ActivatableView;
import haveno.desktop.common.view.FxmlView; import haveno.desktop.common.view.FxmlView;
import haveno.desktop.components.BusyAnimation;
import haveno.desktop.components.TitledGroupBg; import haveno.desktop.components.TitledGroupBg;
import haveno.desktop.main.overlays.popups.Popup; import haveno.desktop.main.overlays.popups.Popup;
import haveno.desktop.main.overlays.windows.TxDetails; import haveno.desktop.main.overlays.windows.TxDetails;
import haveno.desktop.main.overlays.windows.WalletPasswordWindow; import haveno.desktop.main.overlays.windows.WalletPasswordWindow;
import haveno.desktop.util.FormBuilder; import haveno.desktop.util.FormBuilder;
import static haveno.desktop.util.FormBuilder.addButton;
import static haveno.desktop.util.FormBuilder.addTitledGroupBg;
import static haveno.desktop.util.FormBuilder.addTopLabelInputTextField;
import haveno.desktop.util.GUIUtil; import haveno.desktop.util.GUIUtil;
import haveno.network.p2p.P2PService; import haveno.network.p2p.P2PService;
import javafx.application.Platform;
import javafx.beans.value.ChangeListener;
import javafx.fxml.FXML;
import javafx.scene.control.Label;
import javafx.scene.control.TextField;
import javafx.scene.control.RadioButton;
import javafx.scene.control.ToggleGroup;
import javafx.scene.control.Toggle;
import javafx.scene.control.Button;
import javafx.scene.layout.GridPane;
import javafx.scene.layout.StackPane;
import javafx.scene.layout.VBox;
import monero.wallet.model.MoneroTxConfig;
import monero.wallet.model.MoneroTxWallet;
import java.math.BigInteger; import java.math.BigInteger;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.Arrays; import java.util.Arrays;
import java.util.List; import java.util.List;
import javafx.beans.value.ChangeListener;
import javafx.fxml.FXML; import static haveno.desktop.util.FormBuilder.addTitledGroupBg;
import javafx.scene.control.Button; import static haveno.desktop.util.FormBuilder.addTopLabelInputTextField;
import javafx.scene.control.Label; import static haveno.desktop.util.FormBuilder.addButton;
import javafx.scene.control.RadioButton;
import javafx.scene.control.TextField;
import javafx.scene.control.Toggle;
import javafx.scene.control.ToggleGroup;
import javafx.scene.layout.GridPane;
import javafx.scene.layout.VBox;
import monero.wallet.model.MoneroTxConfig;
import monero.wallet.model.MoneroTxWallet;
@FxmlView @FxmlView
public class WithdrawalView extends ActivatableView<VBox, Void> { public class WithdrawalView extends ActivatableView<VBox, Void> {
@FXML @FXML
GridPane gridPane; private GridPane gridPane;
private BusyAnimation spinningWheel;
private StackPane overlayPane;
private Label amountLabel; private Label amountLabel;
private TextField amountTextField, withdrawToTextField, withdrawMemoTextField; private TextField amountTextField, withdrawToTextField, withdrawMemoTextField;
@ -118,6 +128,15 @@ public class WithdrawalView extends ActivatableView<VBox, Void> {
@Override @Override
public void initialize() { public void initialize() {
spinningWheel = new BusyAnimation();
overlayPane = new StackPane();
overlayPane.setStyle("-fx-background-color: transparent;"); // Adjust opacity as needed
overlayPane.setVisible(false);
overlayPane.getChildren().add(spinningWheel);
// Add overlay pane to root VBox
root.getChildren().add(overlayPane);
final TitledGroupBg titledGroupBg = addTitledGroupBg(gridPane, rowIndex, 4, Res.get("funds.deposit.withdrawFromWallet")); final TitledGroupBg titledGroupBg = addTitledGroupBg(gridPane, rowIndex, 4, Res.get("funds.deposit.withdrawFromWallet"));
titledGroupBg.getStyleClass().add("last"); titledGroupBg.getStyleClass().add("last");
@ -144,7 +163,19 @@ public class WithdrawalView extends ActivatableView<VBox, Void> {
final Button withdrawButton = addButton(gridPane, ++rowIndex, Res.get("funds.withdrawal.withdrawButton"), 15); final Button withdrawButton = addButton(gridPane, ++rowIndex, Res.get("funds.withdrawal.withdrawButton"), 15);
withdrawButton.setOnAction(event -> onWithdraw()); withdrawButton.setOnAction(event -> {
// Show the spinning wheel (progress indicator)
showLoadingIndicator();
// Execute onWithdraw() method on a separate thread
new Thread(() -> {
// Call the method that performs the withdrawal
onWithdraw();
// Hide the spinning wheel (progress indicator) after withdrawal is complete
Platform.runLater(() -> hideLoadingIndicator());
}).start();
});
balanceListener = new XmrBalanceListener() { balanceListener = new XmrBalanceListener() {
@Override @Override
@ -180,6 +211,19 @@ public class WithdrawalView extends ActivatableView<VBox, Void> {
}; };
} }
private void showLoadingIndicator() {
overlayPane.setVisible(true);
spinningWheel.play();
root.setDisable(true);
}
private void hideLoadingIndicator() {
overlayPane.setVisible(false);
spinningWheel.stop();
root.setDisable(false);
}
@Override @Override
protected void activate() { protected void activate() {
reset(); reset();
@ -196,6 +240,7 @@ public class WithdrawalView extends ActivatableView<VBox, Void> {
@Override @Override
protected void deactivate() { protected void deactivate() {
spinningWheel.stop();
xmrWalletService.removeBalanceListener(balanceListener); xmrWalletService.removeBalanceListener(balanceListener);
amountTextField.textProperty().removeListener(amountListener); amountTextField.textProperty().removeListener(amountListener);
amountTextField.focusedProperty().removeListener(amountFocusListener); amountTextField.focusedProperty().removeListener(amountFocusListener);