С Firebase я хотел бы получать данные асинхронно и показывать в TableView, но некоторые данные дублируются в TableView - PullRequest
0 голосов
/ 31 января 2019

В 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
    }

}

Полагаю, неправильно называть "завершение (сообщения)". Куда мне вместо этого звонить?

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...