diff --git a/lib/pages/send_view/send_view.dart b/lib/pages/send_view/send_view.dart index e850e07d8..5c602d8d1 100644 --- a/lib/pages/send_view/send_view.dart +++ b/lib/pages/send_view/send_view.dart @@ -591,7 +591,7 @@ class _SendViewState extends ConsumerState { _address = _address!.substring(0, _address!.indexOf("\n")); } - sendToController.text = httpXOREpicBox(_address!); + sendToController.text = formatAddress(_address!); } }); } @@ -923,9 +923,8 @@ class _SendViewState extends ConsumerState { if (coin == Coin.epicCash) { // strip http:// and https:// if content contains @ - content = - httpXOREpicBox( - content); + content = formatAddress( + content); } sendToController.text = content; @@ -1778,13 +1777,21 @@ class _SendViewState extends ConsumerState { } } -// strip http:// and https:// if epicAddress contains @ -String httpXOREpicBox(String epicAddress) { +String formatAddress(String epicAddress) { + // strip http:// or https:// prefixes if the address contains an @ symbol (and is thus an epicbox address) if ((epicAddress.startsWith("http://") || epicAddress.startsWith("https://")) && epicAddress.contains("@")) { epicAddress = epicAddress.replaceAll("http://", ""); epicAddress = epicAddress.replaceAll("https://", ""); } + // strip mailto: prefix + if (epicAddress.startsWith("mailto:")) { + epicAddress = epicAddress.replaceAll("mailto:", ""); + } + // strip / suffix if the address contains an @ symbol (and is thus an epicbox address) + if (epicAddress.endsWith("/") && epicAddress.contains("@")) { + epicAddress = epicAddress.substring(0, epicAddress.length - 1); + } return epicAddress; } diff --git a/lib/pages_desktop_specific/my_stack_view/wallet_view/sub_widgets/desktop_send.dart b/lib/pages_desktop_specific/my_stack_view/wallet_view/sub_widgets/desktop_send.dart index c349eeb9d..1fc322062 100644 --- a/lib/pages_desktop_specific/my_stack_view/wallet_view/sub_widgets/desktop_send.dart +++ b/lib/pages_desktop_specific/my_stack_view/wallet_view/sub_widgets/desktop_send.dart @@ -580,7 +580,7 @@ class _DesktopSendState extends ConsumerState { if (coin == Coin.epicCash) { // strip http:// and https:// if content contains @ - content = httpXOREpicBox(content); + content = formatAddress(content); } sendToController.text = content; @@ -758,7 +758,7 @@ class _DesktopSendState extends ConsumerState { _address = _address!.substring(0, _address!.indexOf("\n")); } - sendToController.text = httpXOREpicBox(_address!); + sendToController.text = formatAddress(_address!); } }); } @@ -1345,13 +1345,21 @@ class _DesktopSendState extends ConsumerState { } } -// strip http:// and https:// if epicAddress contains @ -String httpXOREpicBox(String epicAddress) { +String formatAddress(String epicAddress) { + // strip http:// or https:// prefixes if the address contains an @ symbol (and is thus an epicbox address) if ((epicAddress.startsWith("http://") || epicAddress.startsWith("https://")) && epicAddress.contains("@")) { epicAddress = epicAddress.replaceAll("http://", ""); epicAddress = epicAddress.replaceAll("https://", ""); } + // strip mailto: prefix + if (epicAddress.startsWith("mailto:")) { + epicAddress = epicAddress.replaceAll("mailto:", ""); + } + // strip / suffix if the address contains an @ symbol (and is thus an epicbox address) + if (epicAddress.endsWith("/") && epicAddress.contains("@")) { + epicAddress = epicAddress.substring(0, epicAddress.length - 1); + } return epicAddress; }