Перезагрузка TableView после удаления, добавления или изменения документа Firestore и разбиения на страницы результатов - PullRequest
0 голосов
/ 05 марта 2020

Я получаю документы из Firebase Firestore и отображаю их в виде таблицы. Из табличного представления я хочу иметь возможность удалять и добавлять элементы. Я также изменяю документы из подробного представления элемента. Я сосредоточусь на своих проблемах, удаляя пункты для этого вопроса все же. Я получаю постраничные результаты с моим запросом, используя последний снимок, чтобы получить только следующий набор элементов. Я также использую слушатель, чтобы получать обновления в реальном времени, когда элементы изменены. Проблема с удалением заключается в том, как правильно с этим справиться? То, что у меня есть, просто удаляет элементы, но затем удваивает оставшиеся строки в табличном представлении.

var items = [Item]()
    var itemQuery: Query?
    var lastSnapshot: QueryDocumentSnapshot?

func getItems() {
    if lastSnapshot == nil {
            itemQuery = Firestore.firestore().collection("items").whereField("collection", isEqualTo: self.collection!.id).order(by: "name").limit(to: 25)
        } else {
            itemQuery = itemQuery?.start(afterDocument: lastSnapshot!)
        }

        itemQuery!.addSnapshotListener( { (snapshot, error) in
            guard let snapshot = snapshot else {
                return
            }

            if snapshot.documents.last != nil {
                self.lastSnapshot = snapshot.documents.last
            } else {
                return
            }

            if let error = error {
                print(error.localizedDescription)
            } else {
                for document in snapshot.documents {
                    let docName = document["name"] as? String
                    let docId = document.documentID
                    let docImages = document["images"] as? [String]
                    let docCollection = document["collection"] as? String
                    let docInfo = document["info"] as? String
                    let docQuantity = document["quantity"] as? Int
                    let item = Item(id: docId, name: docName!, collection: docCollection!, info: docInfo!, images: docImages!, quantity: docQuantity!)
                    self.items.append(item)
                }
                if self.items.count >= 25 {
                    self.addFooter()
                }
                self.tableView.reloadData()
            }
        })
}

func deleteItem(at indexPath: IndexPath) {
        let itemToDelete = items[indexPath.row]

        // Delete images from storage
        for url in itemToDelete.images {
            let store = Storage.storage()
            let storageRef = store.reference(forURL: url)
            storageRef.delete { error in
                if let error = error {
                    print(error.localizedDescription)
                } else {
                    print("Image file deleted successfully")
                }
            }
        }

        Firestore.firestore().collection("items").document(itemToDelete.id).delete() { error in
            if let error = error {
                print(error.localizedDescription)
            } else {
                print("Item deleted")
            }
        }
    }

override func numberOfSections(in tableView: UITableView) -> Int {
        return 1
    }

    override func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
        print("numberOfRows(): \(items.count)")
        return items.count
    }

    override func tableView(_ tableView: UITableView, heightForRowAt indexPath: IndexPath) -> CGFloat {
        return 100
    }

    override func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
        let cell = tableView.dequeueReusableCell(withIdentifier: "ItemCell", for: indexPath) as! ItemCell

        let item = items[indexPath.row]
        cell.itemNameLabel.text = item.name

        if item.images.count > 0 {
            let thumbnailUrl = item.images[0]
            cell.itemImageView.sd_setImage(with: URL(string: thumbnailUrl), placeholderImage: UIImage(named: "photo"), completed: { (image, error, cacheType, imageUrl) in
                cell.itemImageView.roundCornersForAspectFit(radius: 10)
            })
        } else {
            cell.itemImageView.image = UIImage(named: "photo")
        }

        return cell
    }

    // Override to support conditional editing of the table view.
    override func tableView(_ tableView: UITableView, canEditRowAt indexPath: IndexPath) -> Bool {
        // Return false if you do not want the specified item to be editable.
        return true
    }

    // Override to support editing the table view.
    override func tableView(_ tableView: UITableView, commit editingStyle: UITableViewCell.EditingStyle, forRowAt indexPath: IndexPath) {
        if editingStyle == .delete {
            print("Items before delete: \(items.count)")
            deleteItem(at: indexPath)
            // items.removeAll()
            // tableView.reloadData()
            items.remove(at: indexPath.row)
            tableView.deleteRows(at: [indexPath], with: .fade)
            print("Items after delete: \(items.count)")
        }
    }

1 Ответ

0 голосов
/ 05 марта 2020

Вы можете использовать Property Observer для обработки вашего tableView.reloadData()

var items = [Item]() {
    didSet {
        tableView.reloadData()
    }
}

, что он делает выше, при изменении переменной items, он будет запускать блок кода didSet {}.

Надеюсь, ответит на ваш вопрос.

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