В Firebase я хотел бы получать данные асинхронно, а затем отображать их в TableView, но некоторые данные дублируются в TableView.Я думаю, это потому, что я использую замыкание в операторе For, но я не уверен, где мне следует его вместо этого вызывать.
Я пытался вызвать setDataToArray в Dispatchqueue.main.async, но это не работает.
Class PostTableViewController: UITableViewController {
let db = Firestore.firestore()
var postArray: [Post] = [Post]()
override func viewDidLoad() {
super.viewDidLoad()
SVProgressHUD.show()
configureTableview()
setDataToArray()
}
func setDataToArray() {
retrievePost() { (posts) in
print(posts!)
for post in posts! {
self.postArray.append(post)
}
print(self.postArray)
self.tableView.reloadData()
SVProgressHUD.dismiss()
}
}
func retrievePost(completion: @escaping ([Post]?) -> Void) {
var posts = [Post]()
let postsColRef = db.collection("posts").order(by: "createdAt")
postsColRef.getDocuments() { (querySnapshot, error) in
if let error = error {
print("Document data: \(error)")
} else {
for document in querySnapshot!.documents {
let data = document.data()
let userId = data["userId"] as? String
let postImage = data["postImageURL"] as? String
let postText = data["postText"] as? String
let createdAt = data["createdAt"] as? String
let numberOfLike = data["numberOfLike"] as? Int
let docRef = self.db.collection("users").document(userId!)
docRef.getDocument() { (document, error) in
if let document = document, document.exists {
let data = document.data()!
let userName = data["userName"] as? String
let userImage = data["userImageURL"] as? String
let post = Post(
userId: userId!,
userName: userName!,
userImageURL: userImage!,
postImageURL: postImage!,
postText: postText!,
createdAt: createdAt!,
numberOfLike: numberOfLike!)
print(post)
posts.append(post)
completion(posts)
}
}
}
}
}
}
@IBAction func cameraButtonPressed(_ sender: UIBarButtonItem) {
performSegue(withIdentifier: "homeToChooseImage", sender: nil)
}
}
extension PostTableViewController {
override func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
return postArray.count
}
override func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
let cell = tableView.dequeueReusableCell(withIdentifier: "postCell", for: indexPath) as! PostTableViewCell
let post = postArray[indexPath.row]
let postImageURL = URL(string: post.postImageURL)
do {
let data = try Data(contentsOf: postImageURL!)
cell.postImage.image = UIImage(data: data)
}catch let err {
print("Error : \(err.localizedDescription)")
}
let userImageURL = URL(string: post.userImageURL)
do {
let data = try Data(contentsOf: userImageURL!)
cell.userImage.image = UIImage(data: data)
}catch let err {
print("Error : \(err.localizedDescription)")
}
cell.postText.text = post.postText
cell.userName.text = post.userName
cell.createdAt.text = post.createdAt
cell.postLikeButton.titleLabel?.text = "\(post.numberOfLike) Likes"
return cell
}
}
Полагаю, неправильно называть "завершение (сообщения)". Куда мне вместо этого звонить?