From be8d9c96d2c7c3a8727cf95eb4aabb813e1cd58e Mon Sep 17 00:00:00 2001 From: dankito Date: Sat, 11 Jul 2020 20:59:52 +0200 Subject: [PATCH] Implemented searching for banks with imported BankFinder --- .../ui/views/AddAccountDialog.swift | 28 ++++++++++++++++--- 1 file changed, 24 insertions(+), 4 deletions(-) diff --git a/ui/BankingiOSApp/BankingiOSApp/ui/views/AddAccountDialog.swift b/ui/BankingiOSApp/BankingiOSApp/ui/views/AddAccountDialog.swift index df8791c4..619079d9 100644 --- a/ui/BankingiOSApp/BankingiOSApp/ui/views/AddAccountDialog.swift +++ b/ui/BankingiOSApp/BankingiOSApp/ui/views/AddAccountDialog.swift @@ -1,17 +1,32 @@ import SwiftUI +import fints4k +import BankFinder struct AddAccountDialog: View { - @State private var bankCode = "" + @State private var enteredBank = "" @State private var customerId = "" @State private var password = "" + @State private var bank: BankInfo? = nil + + + private let bankFinder = InMemoryBankFinder() + + var body: some View { - NavigationView { + let textValueBinding = Binding(get: { + self.enteredBank + }, set: { + self.enteredBank = $0 + self.findBank() + }) + + return NavigationView { Form { Section { - TextField("Bank code", text: $bankCode) + TextField("Bank code", text: textValueBinding) } Section { @@ -34,8 +49,13 @@ struct AddAccountDialog: View { } } + + func findBank() { + self.bank = bankFinder.findBankByNameBankCodeOrCity(query: enteredBank).first + } + func isRequiredDataEntered() -> Bool { - return bankCode.isEmpty == false + return bank != nil && customerId.isEmpty == false && password.isEmpty == false }