From 7c5fdcbec1aace2376e03e237c3bb20124b6c59d Mon Sep 17 00:00:00 2001 From: Marin Todorov Date: Thu, 31 Aug 2017 10:40:44 +0200 Subject: [PATCH] fixes a bug in which severla image cells are asking the table view to relayout at the same time --- RealmContent/Core/View/ContentViewController.swift | 14 ++++++++++++-- 1 file changed, 12 insertions(+), 2 deletions(-) diff --git a/RealmContent/Core/View/ContentViewController.swift b/RealmContent/Core/View/ContentViewController.swift index 9d7da2f..f3981d6 100644 --- a/RealmContent/Core/View/ContentViewController.swift +++ b/RealmContent/Core/View/ContentViewController.swift @@ -180,6 +180,17 @@ public class ContentViewController: UIViewController, UITableViewDataSource, UIT return page.elements.count } + internal var refreshId: UInt64 = 0 + internal func throttledLayoutUpdate() { + refreshId+=1 + let currentId = refreshId + DispatchQueue.main.asyncAfter(deadline: .now() + 0.5) { [weak self] in + guard let this = self, currentId == this.refreshId else { return } + this.tableView.beginUpdates() + this.tableView.endUpdates() + } + } + public func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell { let element = page.elements[indexPath.row] @@ -199,8 +210,7 @@ public class ContentViewController: UIViewController, UITableViewDataSource, UIT let cellId = String(describing: ImageContentCell.self) let cell: ImageContentCell = tableView.dequeueReusableCell(withIdentifier: cellId) as! ImageContentCell cell.populate(with: element) { [weak self] in - self?.tableView.beginUpdates() - self?.tableView.endUpdates() + self?.throttledLayoutUpdate() } cell.delegate = self return cell