From c23108179881e7aa106094ee3d9f497bf9802fb8 Mon Sep 17 00:00:00 2001 From: dankito Date: Sat, 5 Sep 2020 03:29:54 +0200 Subject: [PATCH] Split banks search result in supported and unsupported banks --- .../BankingiOSApp.xcodeproj/project.pbxproj | 8 +-- .../Base.lproj/Localizable.strings | 3 + .../de.lproj/Localizable.strings | 3 + ...tionHeaderWithRightAlignedEditButton.swift | 2 +- .../ui/views/SelectBankDialog.swift | 60 +++++++++++++------ 5 files changed, 53 insertions(+), 23 deletions(-) diff --git a/ui/BankingiOSApp/BankingiOSApp.xcodeproj/project.pbxproj b/ui/BankingiOSApp/BankingiOSApp.xcodeproj/project.pbxproj index 14aa2f98..1d9de3b4 100644 --- a/ui/BankingiOSApp/BankingiOSApp.xcodeproj/project.pbxproj +++ b/ui/BankingiOSApp/BankingiOSApp.xcodeproj/project.pbxproj @@ -25,7 +25,7 @@ 3642F01625018DA1005186FE /* InterceptTabClickViewController.swift in Sources */ = {isa = PBXBuildFile; fileRef = 3642F01525018DA1005186FE /* InterceptTabClickViewController.swift */; }; 3642F0182502723A005186FE /* UIKitButton.swift in Sources */ = {isa = PBXBuildFile; fileRef = 3642F0172502723A005186FE /* UIKitButton.swift */; }; 3642F01A2502931F005186FE /* InstantPaymentInfoView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 3642F0192502931F005186FE /* InstantPaymentInfoView.swift */; }; - 366744E224FC4E96002B235A /* SectionWithRightAlignedEditButton.swift in Sources */ = {isa = PBXBuildFile; fileRef = 366744E124FC4E96002B235A /* SectionWithRightAlignedEditButton.swift */; }; + 3642F04B25031157005186FE /* SectionHeaderWithRightAlignedEditButton.swift in Sources */ = {isa = PBXBuildFile; fileRef = 3642F04A25031157005186FE /* SectionHeaderWithRightAlignedEditButton.swift */; }; 366FA4DA24C472A90094F009 /* Extensions.swift in Sources */ = {isa = PBXBuildFile; fileRef = 366FA4D924C472A90094F009 /* Extensions.swift */; }; 366FA4DC24C479120094F009 /* BankInfoListItem.swift in Sources */ = {isa = PBXBuildFile; fileRef = 366FA4DB24C479120094F009 /* BankInfoListItem.swift */; }; 366FA4E024C4924A0094F009 /* RemitteeListItem.swift in Sources */ = {isa = PBXBuildFile; fileRef = 366FA4DF24C4924A0094F009 /* RemitteeListItem.swift */; }; @@ -161,7 +161,7 @@ 3642F01525018DA1005186FE /* InterceptTabClickViewController.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = InterceptTabClickViewController.swift; sourceTree = ""; }; 3642F0172502723A005186FE /* UIKitButton.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = UIKitButton.swift; sourceTree = ""; }; 3642F0192502931F005186FE /* InstantPaymentInfoView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = InstantPaymentInfoView.swift; sourceTree = ""; }; - 366744E124FC4E96002B235A /* SectionWithRightAlignedEditButton.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SectionWithRightAlignedEditButton.swift; sourceTree = ""; }; + 3642F04A25031157005186FE /* SectionHeaderWithRightAlignedEditButton.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SectionHeaderWithRightAlignedEditButton.swift; sourceTree = ""; }; 366FA4D924C472A90094F009 /* Extensions.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = Extensions.swift; sourceTree = ""; }; 366FA4DB24C479120094F009 /* BankInfoListItem.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = BankInfoListItem.swift; sourceTree = ""; }; 366FA4DF24C4924A0094F009 /* RemitteeListItem.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = RemitteeListItem.swift; sourceTree = ""; }; @@ -482,7 +482,7 @@ 36E21EDE24DCCC2700649DC8 /* CheckmarkListItem.swift */, 3608D6C124FBA9C6006C93A8 /* TrianglePointingDown.swift */, 3608D6C524FBAB41006C93A8 /* TanGeneratorPositionMarker.swift */, - 366744E124FC4E96002B235A /* SectionWithRightAlignedEditButton.swift */, + 3642F04A25031157005186FE /* SectionHeaderWithRightAlignedEditButton.swift */, 3642F0092500F5AE005186FE /* Divider.swift */, 3642F00B25010021005186FE /* UIKitActivityIndicator.swift */, 3642F0172502723A005186FE /* UIKitButton.swift */, @@ -661,7 +661,6 @@ 3642F00C25010021005186FE /* UIKitActivityIndicator.swift in Sources */, 36E21ECB24D88DF000649DC8 /* UIKitExtensions.swift in Sources */, 360782C524E541970098FEFE /* ScaleImageView.swift in Sources */, - 366744E224FC4E96002B235A /* SectionWithRightAlignedEditButton.swift in Sources */, 366FA4E224C4ED6C0094F009 /* EnterTanDialog.swift in Sources */, 36FC92DC24B3A4A0002B12E9 /* AccountsTab.swift in Sources */, 36BCF86E24BA691B005BEC29 /* DependencyInjector.swift in Sources */, @@ -706,6 +705,7 @@ 36BE06C424D0801A00CBBB68 /* Size.swift in Sources */, 366FA4E624C6EBF40094F009 /* EnterTanState.swift in Sources */, 360782CF24F3D6610098FEFE /* InfoLabel.swift in Sources */, + 3642F04B25031157005186FE /* SectionHeaderWithRightAlignedEditButton.swift in Sources */, 36C4009B24D2F9E4005227AD /* IconedTitleView.swift in Sources */, 36BE065724C9E04800CBBB68 /* UIKitImageView.swift in Sources */, 3642F01625018DA1005186FE /* InterceptTabClickViewController.swift in Sources */, diff --git a/ui/BankingiOSApp/BankingiOSApp/Base.lproj/Localizable.strings b/ui/BankingiOSApp/BankingiOSApp/Base.lproj/Localizable.strings index 948fb9df..97caefb1 100644 --- a/ui/BankingiOSApp/BankingiOSApp/Base.lproj/Localizable.strings +++ b/ui/BankingiOSApp/BankingiOSApp/Base.lproj/Localizable.strings @@ -33,6 +33,9 @@ "Bank code, bank name or city" = "Bank code, bank name or city"; "Search by bank code, bank name or city" = "Search by bank code, bank name or city, e.g. Sparkasse Berlin"; +"No supported banks found" = "No supported banks found"; +"Unsupported banks" = "Unsupported banks"; + "%@ does not support FinTS 3.0" = "%@ does not support FinTS 3.0"; "Only banks supporting FinTS 3.0 can be used in this app." = "In this app only banks supporting the German banking standard FinTS 3.0 can be used."; diff --git a/ui/BankingiOSApp/BankingiOSApp/de.lproj/Localizable.strings b/ui/BankingiOSApp/BankingiOSApp/de.lproj/Localizable.strings index 58f5de6f..941e9a85 100644 --- a/ui/BankingiOSApp/BankingiOSApp/de.lproj/Localizable.strings +++ b/ui/BankingiOSApp/BankingiOSApp/de.lproj/Localizable.strings @@ -33,6 +33,9 @@ "Bank code, bank name or city" = "BLZ, Bankname oder Ort"; "Search by bank code, bank name or city" = "Suche mittels Bankleitzahl, Bankname oder Ort, z. B. Sparkasse Berlin"; +"No supported banks found" = "Keine unterstützten Banken gefunden"; +"Unsupported banks" = "Nicht unterstützte Banken"; + "%@ does not support FinTS 3.0" = "%@ wird von App nicht unterstützt"; "Only banks supporting FinTS 3.0 can be used in this app." = "In dieser App können nur Banken verwendet werden, die den deutschen Online-Banking Standard FinTS 3.0 unterstützen."; diff --git a/ui/BankingiOSApp/BankingiOSApp/ui/views/SectionHeaderWithRightAlignedEditButton.swift b/ui/BankingiOSApp/BankingiOSApp/ui/views/SectionHeaderWithRightAlignedEditButton.swift index 4e926ae3..1d873248 100644 --- a/ui/BankingiOSApp/BankingiOSApp/ui/views/SectionHeaderWithRightAlignedEditButton.swift +++ b/ui/BankingiOSApp/BankingiOSApp/ui/views/SectionHeaderWithRightAlignedEditButton.swift @@ -17,7 +17,7 @@ struct SectionHeaderWithRightAlignedEditButton: View { var body: some View { EditButton() - .frame(maxWidth: .infinity, alignment: .trailing) + .alignVertically(.trailing) .disabled( !isEditButtonEnabled) .overlay(Text(sectionTitle), alignment: .leading) } diff --git a/ui/BankingiOSApp/BankingiOSApp/ui/views/SelectBankDialog.swift b/ui/BankingiOSApp/BankingiOSApp/ui/views/SelectBankDialog.swift index 8d0880c0..db3585f8 100644 --- a/ui/BankingiOSApp/BankingiOSApp/ui/views/SelectBankDialog.swift +++ b/ui/BankingiOSApp/BankingiOSApp/ui/views/SelectBankDialog.swift @@ -22,7 +22,9 @@ struct SelectBankDialog: View { }) } - @State private var searchResult: [BankInfo] + @State private var supportedBanksSearchResults: [BankInfo] + + @State private var unsupportedBanksSearchResults: [BankInfo] @State private var errorMessage: Message? = nil @@ -33,7 +35,9 @@ struct SelectBankDialog: View { bankFinder.preloadBankList() - _searchResult = State(initialValue: bankFinder.getBankList()) + let allBanks = bankFinder.getBankList() + _supportedBanksSearchResults = State(initialValue:allBanks.filter { $0.supportsFinTs3_0 }) + _unsupportedBanksSearchResults = State(initialValue:allBanks.filter { $0.supportsFinTs3_0 == false }) } @@ -54,11 +58,29 @@ struct SelectBankDialog: View { } } - Section { - // TODO: showing only the first 100 items is a workaround as SwiftUI tries to compare the two lists (to be able to animate them!) which takes extremely long for the full data set - List(searchResult.prefix(100), id: \.self) { bank in - BankInfoListItem(bank) { - self.handleSelectedBank(bank) + if supportedBanksSearchResults.isEmpty { + Text("No supported banks found") + .detailForegroundColor() + .alignVertically(.center) + } + else { + Section { + // TODO: showing only the first 100 items is a workaround as SwiftUI tries to compare the two lists (to be able to animate them!) which takes extremely long for the full data set + List(supportedBanksSearchResults.prefix(100), id: \.self) { bank in + BankInfoListItem(bank) { + self.bankHasBeenSelected(bank) + } + } + } + } + + if unsupportedBanksSearchResults.isNotEmpty { + Section(header: Text("Unsupported banks")) { + // TODO: showing only the first 100 items is a workaround as SwiftUI tries to compare the two lists (to be able to animate them!) which takes extremely long for the full data set + List(unsupportedBanksSearchResults.prefix(100), id: \.self) { bank in + BankInfoListItem(bank) { + self.showBankIsNotSupportedMessage(bank) + } } } } @@ -72,20 +94,22 @@ struct SelectBankDialog: View { private func findBanks(_ query: String) { - self.searchResult = self.bankFinder.findBankByNameBankCodeOrCity(query: query) + let searchResult = self.bankFinder.findBankByNameBankCodeOrCity(query: query) + + supportedBanksSearchResults = searchResult.filter { $0.supportsFinTs3_0 } + unsupportedBanksSearchResults = searchResult.filter { $0.supportsFinTs3_0 == false } } - private func handleSelectedBank(_ bank: BankInfo) { - if bank.supportsFinTs3_0 { - self.selectedBank = bank + private func bankHasBeenSelected(_ bank: BankInfo) { + self.selectedBank = bank - presentation.wrappedValue.dismiss() - } - else { - self.selectedBank = nil - - self.errorMessage = Message(title: Text("\(bank.name) does not support FinTS 3.0"), message: Text("Only banks supporting FinTS 3.0 can be used in this app.")) - } + presentation.wrappedValue.dismiss() + } + + private func showBankIsNotSupportedMessage(_ bank: BankInfo) { + self.selectedBank = nil + + self.errorMessage = Message(title: Text("\(bank.name) does not support FinTS 3.0"), message: Text("Only banks supporting FinTS 3.0 can be used in this app.")) } }