Split banks search result in supported and unsupported banks

This commit is contained in:
dankito 2020-09-05 03:29:54 +02:00
parent 047f0e075f
commit c231081798
5 changed files with 53 additions and 23 deletions

View File

@ -25,7 +25,7 @@
3642F01625018DA1005186FE /* InterceptTabClickViewController.swift in Sources */ = {isa = PBXBuildFile; fileRef = 3642F01525018DA1005186FE /* InterceptTabClickViewController.swift */; }; 3642F01625018DA1005186FE /* InterceptTabClickViewController.swift in Sources */ = {isa = PBXBuildFile; fileRef = 3642F01525018DA1005186FE /* InterceptTabClickViewController.swift */; };
3642F0182502723A005186FE /* UIKitButton.swift in Sources */ = {isa = PBXBuildFile; fileRef = 3642F0172502723A005186FE /* UIKitButton.swift */; }; 3642F0182502723A005186FE /* UIKitButton.swift in Sources */ = {isa = PBXBuildFile; fileRef = 3642F0172502723A005186FE /* UIKitButton.swift */; };
3642F01A2502931F005186FE /* InstantPaymentInfoView.swift in Sources */ = {isa = PBXBuildFile; fileRef = 3642F0192502931F005186FE /* InstantPaymentInfoView.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 */; }; 366FA4DA24C472A90094F009 /* Extensions.swift in Sources */ = {isa = PBXBuildFile; fileRef = 366FA4D924C472A90094F009 /* Extensions.swift */; };
366FA4DC24C479120094F009 /* BankInfoListItem.swift in Sources */ = {isa = PBXBuildFile; fileRef = 366FA4DB24C479120094F009 /* BankInfoListItem.swift */; }; 366FA4DC24C479120094F009 /* BankInfoListItem.swift in Sources */ = {isa = PBXBuildFile; fileRef = 366FA4DB24C479120094F009 /* BankInfoListItem.swift */; };
366FA4E024C4924A0094F009 /* RemitteeListItem.swift in Sources */ = {isa = PBXBuildFile; fileRef = 366FA4DF24C4924A0094F009 /* RemitteeListItem.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 = "<group>"; }; 3642F01525018DA1005186FE /* InterceptTabClickViewController.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = InterceptTabClickViewController.swift; sourceTree = "<group>"; };
3642F0172502723A005186FE /* UIKitButton.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = UIKitButton.swift; sourceTree = "<group>"; }; 3642F0172502723A005186FE /* UIKitButton.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = UIKitButton.swift; sourceTree = "<group>"; };
3642F0192502931F005186FE /* InstantPaymentInfoView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = InstantPaymentInfoView.swift; sourceTree = "<group>"; }; 3642F0192502931F005186FE /* InstantPaymentInfoView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = InstantPaymentInfoView.swift; sourceTree = "<group>"; };
366744E124FC4E96002B235A /* SectionWithRightAlignedEditButton.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SectionWithRightAlignedEditButton.swift; sourceTree = "<group>"; }; 3642F04A25031157005186FE /* SectionHeaderWithRightAlignedEditButton.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = SectionHeaderWithRightAlignedEditButton.swift; sourceTree = "<group>"; };
366FA4D924C472A90094F009 /* Extensions.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = Extensions.swift; sourceTree = "<group>"; }; 366FA4D924C472A90094F009 /* Extensions.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = Extensions.swift; sourceTree = "<group>"; };
366FA4DB24C479120094F009 /* BankInfoListItem.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = BankInfoListItem.swift; sourceTree = "<group>"; }; 366FA4DB24C479120094F009 /* BankInfoListItem.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = BankInfoListItem.swift; sourceTree = "<group>"; };
366FA4DF24C4924A0094F009 /* RemitteeListItem.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = RemitteeListItem.swift; sourceTree = "<group>"; }; 366FA4DF24C4924A0094F009 /* RemitteeListItem.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = RemitteeListItem.swift; sourceTree = "<group>"; };
@ -482,7 +482,7 @@
36E21EDE24DCCC2700649DC8 /* CheckmarkListItem.swift */, 36E21EDE24DCCC2700649DC8 /* CheckmarkListItem.swift */,
3608D6C124FBA9C6006C93A8 /* TrianglePointingDown.swift */, 3608D6C124FBA9C6006C93A8 /* TrianglePointingDown.swift */,
3608D6C524FBAB41006C93A8 /* TanGeneratorPositionMarker.swift */, 3608D6C524FBAB41006C93A8 /* TanGeneratorPositionMarker.swift */,
366744E124FC4E96002B235A /* SectionWithRightAlignedEditButton.swift */, 3642F04A25031157005186FE /* SectionHeaderWithRightAlignedEditButton.swift */,
3642F0092500F5AE005186FE /* Divider.swift */, 3642F0092500F5AE005186FE /* Divider.swift */,
3642F00B25010021005186FE /* UIKitActivityIndicator.swift */, 3642F00B25010021005186FE /* UIKitActivityIndicator.swift */,
3642F0172502723A005186FE /* UIKitButton.swift */, 3642F0172502723A005186FE /* UIKitButton.swift */,
@ -661,7 +661,6 @@
3642F00C25010021005186FE /* UIKitActivityIndicator.swift in Sources */, 3642F00C25010021005186FE /* UIKitActivityIndicator.swift in Sources */,
36E21ECB24D88DF000649DC8 /* UIKitExtensions.swift in Sources */, 36E21ECB24D88DF000649DC8 /* UIKitExtensions.swift in Sources */,
360782C524E541970098FEFE /* ScaleImageView.swift in Sources */, 360782C524E541970098FEFE /* ScaleImageView.swift in Sources */,
366744E224FC4E96002B235A /* SectionWithRightAlignedEditButton.swift in Sources */,
366FA4E224C4ED6C0094F009 /* EnterTanDialog.swift in Sources */, 366FA4E224C4ED6C0094F009 /* EnterTanDialog.swift in Sources */,
36FC92DC24B3A4A0002B12E9 /* AccountsTab.swift in Sources */, 36FC92DC24B3A4A0002B12E9 /* AccountsTab.swift in Sources */,
36BCF86E24BA691B005BEC29 /* DependencyInjector.swift in Sources */, 36BCF86E24BA691B005BEC29 /* DependencyInjector.swift in Sources */,
@ -706,6 +705,7 @@
36BE06C424D0801A00CBBB68 /* Size.swift in Sources */, 36BE06C424D0801A00CBBB68 /* Size.swift in Sources */,
366FA4E624C6EBF40094F009 /* EnterTanState.swift in Sources */, 366FA4E624C6EBF40094F009 /* EnterTanState.swift in Sources */,
360782CF24F3D6610098FEFE /* InfoLabel.swift in Sources */, 360782CF24F3D6610098FEFE /* InfoLabel.swift in Sources */,
3642F04B25031157005186FE /* SectionHeaderWithRightAlignedEditButton.swift in Sources */,
36C4009B24D2F9E4005227AD /* IconedTitleView.swift in Sources */, 36C4009B24D2F9E4005227AD /* IconedTitleView.swift in Sources */,
36BE065724C9E04800CBBB68 /* UIKitImageView.swift in Sources */, 36BE065724C9E04800CBBB68 /* UIKitImageView.swift in Sources */,
3642F01625018DA1005186FE /* InterceptTabClickViewController.swift in Sources */, 3642F01625018DA1005186FE /* InterceptTabClickViewController.swift in Sources */,

View File

@ -33,6 +33,9 @@
"Bank code, bank name or city" = "Bank code, bank name or city"; "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"; "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"; "%@ 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."; "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.";

View File

@ -33,6 +33,9 @@
"Bank code, bank name or city" = "BLZ, Bankname oder Ort"; "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"; "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"; "%@ 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."; "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.";

View File

@ -17,7 +17,7 @@ struct SectionHeaderWithRightAlignedEditButton: View {
var body: some View { var body: some View {
EditButton() EditButton()
.frame(maxWidth: .infinity, alignment: .trailing) .alignVertically(.trailing)
.disabled( !isEditButtonEnabled) .disabled( !isEditButtonEnabled)
.overlay(Text(sectionTitle), alignment: .leading) .overlay(Text(sectionTitle), alignment: .leading)
} }

View File

@ -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 @State private var errorMessage: Message? = nil
@ -33,7 +35,9 @@ struct SelectBankDialog: View {
bankFinder.preloadBankList() 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 {
} }
} }
if supportedBanksSearchResults.isEmpty {
Text("No supported banks found")
.detailForegroundColor()
.alignVertically(.center)
}
else {
Section { 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 // 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 List(supportedBanksSearchResults.prefix(100), id: \.self) { bank in
BankInfoListItem(bank) { BankInfoListItem(bank) {
self.handleSelectedBank(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,21 +94,23 @@ struct SelectBankDialog: View {
private func findBanks(_ query: String) { 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) { private func bankHasBeenSelected(_ bank: BankInfo) {
if bank.supportsFinTs3_0 {
self.selectedBank = bank self.selectedBank = bank
presentation.wrappedValue.dismiss() presentation.wrappedValue.dismiss()
} }
else {
private func showBankIsNotSupportedMessage(_ bank: BankInfo) {
self.selectedBank = nil 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.")) 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."))
} }
}
} }