Show a loader while an open group is being joined

pull/236/head
nielsandriesse 5 years ago
parent 5d8ae82817
commit 11d4add8f9

@ -142,24 +142,27 @@ final class JoinPublicChatVC : BaseVC, UIPageViewControllerDataSource, UIPageVie
transaction.removeObject(forKey: "\(urlAsString).\(channelID)", inCollection: PublicChatAPI.lastMessageServerIDCollection) transaction.removeObject(forKey: "\(urlAsString).\(channelID)", inCollection: PublicChatAPI.lastMessageServerIDCollection)
transaction.removeObject(forKey: "\(urlAsString).\(channelID)", inCollection: PublicChatAPI.lastDeletionServerIDCollection) transaction.removeObject(forKey: "\(urlAsString).\(channelID)", inCollection: PublicChatAPI.lastDeletionServerIDCollection)
} }
PublicChatManager.shared.addChat(server: urlAsString, channel: channelID) ModalActivityIndicatorViewController.present(fromViewController: navigationController!, canCancel: false) { [weak self] _ in
.done(on: .main) { [weak self] _ in PublicChatManager.shared.addChat(server: urlAsString, channel: channelID)
let _ = PublicChatAPI.setDisplayName(to: displayName, on: urlAsString) .done(on: DispatchQueue.main) { [weak self] _ in
let _ = PublicChatAPI.setProfilePictureURL(to: profilePictureURL, using: profileKey, on: urlAsString) let _ = PublicChatAPI.setDisplayName(to: displayName, on: urlAsString)
let _ = PublicChatAPI.join(channelID, on: urlAsString) let _ = PublicChatAPI.setProfilePictureURL(to: profilePictureURL, using: profileKey, on: urlAsString)
let syncManager = SSKEnvironment.shared.syncManager let _ = PublicChatAPI.join(channelID, on: urlAsString)
let _ = syncManager.syncAllOpenGroups() let syncManager = SSKEnvironment.shared.syncManager
self?.presentingViewController!.dismiss(animated: true, completion: nil) let _ = syncManager.syncAllOpenGroups()
} self?.presentingViewController!.dismiss(animated: true, completion: nil)
.catch(on: .main) { [weak self] error in }
var title = NSLocalizedString("Couldn't Join", comment: "") .catch(on: DispatchQueue.main) { [weak self] error in
var message = "" self?.dismiss(animated: true, completion: nil) // Dismiss the loader
if case HTTP.Error.httpRequestFailed(let statusCode, _) = error, statusCode == 401 || statusCode == 403 { var title = NSLocalizedString("Couldn't Join", comment: "")
title = NSLocalizedString("Unauthorized", comment: "") var message = ""
message = NSLocalizedString("Please ask the open group operator to add you to the group.", comment: "") if case HTTP.Error.httpRequestFailed(let statusCode, _) = error, statusCode == 401 || statusCode == 403 {
title = NSLocalizedString("Unauthorized", comment: "")
message = NSLocalizedString("Please ask the open group operator to add you to the group.", comment: "")
}
self?.isJoining = false
self?.showError(title: title, message: message)
} }
self?.isJoining = false
self?.showError(title: title, message: message)
} }
} }

@ -189,7 +189,7 @@ final class NewClosedGroupVC : BaseVC, UITableViewDataSource, UITableViewDelegat
self?.presentingViewController?.dismiss(animated: true, completion: nil) self?.presentingViewController?.dismiss(animated: true, completion: nil)
SignalApp.shared().presentConversation(for: thread, action: .compose, animated: false) SignalApp.shared().presentConversation(for: thread, action: .compose, animated: false)
}.catch(on: DispatchQueue.main) { _ in }.catch(on: DispatchQueue.main) { _ in
self?.dismiss(animated: true, completion: nil) // Dismiss the modal self?.dismiss(animated: true, completion: nil) // Dismiss the loader
let title = NSLocalizedString("Couldn't Create Group", comment: "") let title = NSLocalizedString("Couldn't Create Group", comment: "")
let message = NSLocalizedString("Please check your internet connection and try again.", comment: "") let message = NSLocalizedString("Please check your internet connection and try again.", comment: "")
let alert = UIAlertController(title: title, message: message, preferredStyle: .alert) let alert = UIAlertController(title: title, message: message, preferredStyle: .alert)

Loading…
Cancel
Save