У меня есть файл модели API, который содержит вызов API, и я получаю разные ответы на вызов API, а затем анализирую вызов, сравниваю ключи анализа в коде и показываю предупреждение. Я не хочу отображать оповещения в классе модели API, я хочу показывать оповещения в другом классе LoginVC, который содержит IBAction для Loginpressed.
Смотрите следующий код:
//API.swift
func loginApiCall(email : String,password : String, completion:@escaping (Bool) -> ()){
let urlString = "\(ApiServiceProvider.BASE_URL + ApiServiceProvider.LOGIN_ENDPOINT)"
let parameters = [
"user_email": "\(email)",
"user_password": "\(password)"
]
Alamofire.request(urlString, method:.post, parameters: parameters, encoding: URLEncoding.default).validate().responseJSON {
response in
switch response.result {
case .failure(let error):
print(error)
completion(false)
case .success(let responseObject):
print("response is success: \(responseObject)")
if let JSON = response.result.value {
let result = JSON as! [String:AnyObject]
let msg = result["status"] as! String
print(msg)
let message = result["message"] as! String
let fullNameArr = message.components(separatedBy: " ")
print(fullNameArr)
if msg == "error" {
// show alert in Login VC during api call
print("Validation error")
} else {
if msg == "NotVerified" {
} else {
print("Success login")
completion(true)
}
if let data = result["data"] {
print(data)
let user = data["user_id"]
let userdefault = UserDefaults.standard
userdefault.set(user!, forKey: KeyValues.userIdkey)
}
}
print("json: \(msg)")
}
}
}
}
// LoginVC
@IBAction func LoginPressed(_ sender: LoginButton) {
guard let email = emailField.text else {
// improper
return
}
guard let password = passField.text else {
return
}
if email == "" || password == "" {
let otherAlert = UIAlertController(title: "Fields Error!", message: "\(KeyValues.multiFieldsError)", preferredStyle: UIAlertControllerStyle.alert)
let dismiss = UIAlertAction(title: "OK", style: UIAlertActionStyle.cancel, handler: nil)
otherAlert.addAction(dismiss)
present(otherAlert, animated: true, completion: nil)
} else {
if Connectivity.isConnectedToInternet {
showActivityIndicator(uiView: self.view)
mainView.isHidden = false
let apiCall = ApiServiceProvider()
apiCall.loginApiCall(email: email, password: password) { success in
if success {
// show alert here which is highlighted in api class
print("successful")
self.hideActivityIndicator(uiView: self.view)
self.mainView.isHidden = true
self.networkView.isHidden = true
self.performSegue(withIdentifier: "LogToWorkSpace", sender: nil)
} else {
let otherAlert = UIAlertController(title: "Error!", message: "Login failed!", preferredStyle: UIAlertControllerStyle.alert)
let dismiss = UIAlertAction(title: "OK", style: UIAlertActionStyle.cancel, handler: nil)
otherAlert.addAction(dismiss)
self.present(otherAlert, animated: true, completion: nil)
print("not successful")
}
}
}else{
networkView.isHidden = false
//print("No internet connection.")
}
}
}
Подробнее здесь: https://stackoverflow.com/questions/510 ... -api-class
Показывать оповещение, связанное с Alamofire, вне класса API ⇐ IOS
-
- Похожие темы
- Ответы
- Просмотры
- Последнее сообщение
-
-
Показывать оповещение Bootstrap при нажатии кнопки через Javascript/jQuery
Anonymous » » в форуме Jquery - 0 Ответы
- 22 Просмотры
-
Последнее сообщение Anonymous
-
-
-
Автоматическое (не связанное с рефакторингом) извлечение интерфейса из класса
Anonymous » » в форуме C# - 0 Ответы
- 10 Просмотры
-
Последнее сообщение Anonymous
-