diff --git a/src/main/java/com/sparrowwallet/sparrow/wallet/PaymentController.java b/src/main/java/com/sparrowwallet/sparrow/wallet/PaymentController.java index ca0729ba..424556fd 100644 --- a/src/main/java/com/sparrowwallet/sparrow/wallet/PaymentController.java +++ b/src/main/java/com/sparrowwallet/sparrow/wallet/PaymentController.java @@ -177,7 +177,7 @@ public class PaymentController extends WalletFormController implements Initializ List
existingAddresses = getOtherAddresses(); WalletNode freshNode = newValue.getFreshNode(KeyPurpose.RECEIVE); Address freshAddress = freshNode.getAddress(); - while(existingAddresses.contains(freshAddress)) { + while(existingAddresses.contains(freshAddress) || (freshNode.getLabel() != null && !freshNode.getLabel().isEmpty())) { freshNode = newValue.getFreshNode(KeyPurpose.RECEIVE, freshNode); freshAddress = freshNode.getAddress(); } diff --git a/src/main/java/com/sparrowwallet/sparrow/wallet/ReceiveController.java b/src/main/java/com/sparrowwallet/sparrow/wallet/ReceiveController.java index 5cf9e38d..6003d1f1 100644 --- a/src/main/java/com/sparrowwallet/sparrow/wallet/ReceiveController.java +++ b/src/main/java/com/sparrowwallet/sparrow/wallet/ReceiveController.java @@ -199,6 +199,9 @@ public class ReceiveController extends WalletFormController implements Initializ public void refreshAddress() { NodeEntry freshEntry = getWalletForm().getFreshNodeEntry(KeyPurpose.RECEIVE, currentEntry); + while(freshEntry.getLabel() != null && !freshEntry.getLabel().isEmpty()) { + freshEntry = getWalletForm().getFreshNodeEntry(KeyPurpose.RECEIVE, freshEntry); + } setNodeEntry(freshEntry); if(addressQrDialog != null) { addressQrDialog.close();