//
//  SettingsFeedbinAccountView.swift
//  Multiplatform iOS
//
//  Created by Rizwan on 07/07/20.
//  Copyright © 2020 Ranchero Software. All rights reserved.
//

import SwiftUI
import Account
import Combine
import RSWeb
import Secrets

struct SettingsFeedbinAccountView: View {
	@Environment(\.presentationMode) var presentationMode
	@ObservedObject var settingsModel: SettingsFeedbinAccountModel

	init(account: Account? = nil) {
		if let account = account {
			self.settingsModel = SettingsFeedbinAccountModel(account: account)
		}
		else {
			self.settingsModel = SettingsFeedbinAccountModel()
		}
	}

	var body: some View {
		NavigationView {
			List {
				Section(header: AccountHeaderImageView(image: AppAssets.image(for: .feedbin)!)) {
					TextField("Email", text: $settingsModel.email).textContentType(.emailAddress)
					SecureField("Password", text: $settingsModel.password)
				}
				Section(footer: errorFooter) {
					HStack {
						Spacer()
						Button(action: { settingsModel.addAccount() }) {
							if settingsModel.isUpdate {
								Text("Update Account")
							} else {
								Text("Add Account")
							}
						}
						.disabled(!settingsModel.isValid)
						Spacer()
						if settingsModel.busy {
							ProgressView()
						}
					}
				}
			}
			.listStyle(InsetGroupedListStyle())
			.disabled(settingsModel.busy)
			.onReceive(settingsModel.$shouldDismiss, perform: { dismiss in
				if dismiss == true {
					presentationMode.wrappedValue.dismiss()
				}
			})
			.navigationBarTitle(Text(verbatim: "Feedbin"), displayMode: .inline)
			.navigationBarItems(leading:
									Button(action: { self.dismiss() }) { Text("Cancel") }
			)
		}
	}

	var errorFooter: some View {
		HStack {
			Spacer()
			if settingsModel.showError {
				Text(verbatim: settingsModel.feedbinAccountError!.localizedDescription).foregroundColor(.red)
			}
			Spacer()
		}
	}

	private func dismiss() {
		presentationMode.wrappedValue.dismiss()
	}
}

struct SettingsFeedbinAccountView_Previews: PreviewProvider {
	static var previews: some View {
		SettingsFeedbinAccountView()
	}
}