Split banks search result in supported and unsupported banks
This commit is contained in:
parent
047f0e075f
commit
c231081798
|
@ -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 */,
|
||||||
|
|
|
@ -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.";
|
||||||
|
|
||||||
|
|
|
@ -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.";
|
||||||
|
|
||||||
|
|
|
@ -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)
|
||||||
}
|
}
|
||||||
|
|
|
@ -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."))
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue