Use appDelegate’s coalescing queue for fetching unread counts for smart feeds.
This commit is contained in:
parent
9e860321bd
commit
1a5c9d130d
|
@ -35,22 +35,26 @@ final class SmartFeed: PseudoFeed {
|
||||||
}
|
}
|
||||||
|
|
||||||
private let delegate: SmartFeedDelegate
|
private let delegate: SmartFeedDelegate
|
||||||
private var timer: Timer?
|
|
||||||
private var unreadCounts = [Account: Int]()
|
private var unreadCounts = [Account: Int]()
|
||||||
|
|
||||||
init(delegate: SmartFeedDelegate) {
|
init(delegate: SmartFeedDelegate) {
|
||||||
|
|
||||||
self.delegate = delegate
|
self.delegate = delegate
|
||||||
NotificationCenter.default.addObserver(self, selector: #selector(unreadCountDidChange(_:)), name: .UnreadCountDidChange, object: nil)
|
NotificationCenter.default.addObserver(self, selector: #selector(unreadCountDidChange(_:)), name: .UnreadCountDidChange, object: nil)
|
||||||
startTimer() // Fetch unread count at startup
|
queueFetchUnreadCounts() // Fetch unread count at startup
|
||||||
}
|
}
|
||||||
|
|
||||||
@objc func unreadCountDidChange(_ note: Notification) {
|
@objc func unreadCountDidChange(_ note: Notification) {
|
||||||
|
|
||||||
if note.object is Account {
|
if note.object is Account {
|
||||||
startTimer()
|
queueFetchUnreadCounts()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@objc func fetchUnreadCounts() {
|
||||||
|
|
||||||
|
AccountManager.shared.accounts.forEach { self.fetchUnreadCount(for: $0) }
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
extension SmartFeed: ArticleFetcher {
|
extension SmartFeed: ArticleFetcher {
|
||||||
|
@ -68,9 +72,12 @@ extension SmartFeed: ArticleFetcher {
|
||||||
|
|
||||||
private extension SmartFeed {
|
private extension SmartFeed {
|
||||||
|
|
||||||
// MARK: - Unread Counts
|
func queueFetchUnreadCounts() {
|
||||||
|
|
||||||
private func fetchUnreadCount(for account: Account) {
|
appDelegate?.coalescingQueue.add(self, #selector(fetchUnreadCounts))
|
||||||
|
}
|
||||||
|
|
||||||
|
func fetchUnreadCount(for account: Account) {
|
||||||
|
|
||||||
delegate.fetchUnreadCount(for: account) { (accountUnreadCount) in
|
delegate.fetchUnreadCount(for: account) { (accountUnreadCount) in
|
||||||
self.unreadCounts[account] = accountUnreadCount
|
self.unreadCounts[account] = accountUnreadCount
|
||||||
|
@ -78,12 +85,7 @@ private extension SmartFeed {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private func fetchUnreadCounts() {
|
func updateUnreadCount() {
|
||||||
|
|
||||||
AccountManager.shared.accounts.forEach { self.fetchUnreadCount(for: $0) }
|
|
||||||
}
|
|
||||||
|
|
||||||
private func updateUnreadCount() {
|
|
||||||
|
|
||||||
unreadCount = AccountManager.shared.accounts.reduce(0) { (result, account) -> Int in
|
unreadCount = AccountManager.shared.accounts.reduce(0) { (result, account) -> Int in
|
||||||
if let oneUnreadCount = unreadCounts[account] {
|
if let oneUnreadCount = unreadCounts[account] {
|
||||||
|
@ -92,26 +94,4 @@ private extension SmartFeed {
|
||||||
return result
|
return result
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// MARK: - Timer
|
|
||||||
|
|
||||||
func stopTimer() {
|
|
||||||
|
|
||||||
if let timer = timer {
|
|
||||||
timer.rs_invalidateIfValid()
|
|
||||||
}
|
|
||||||
timer = nil
|
|
||||||
}
|
|
||||||
|
|
||||||
private static let fetchCoalescingDelay: TimeInterval = 0.1
|
|
||||||
|
|
||||||
func startTimer() {
|
|
||||||
|
|
||||||
stopTimer()
|
|
||||||
|
|
||||||
timer = Timer.scheduledTimer(withTimeInterval: SmartFeed.fetchCoalescingDelay, repeats: false, block: { (timer) in
|
|
||||||
self.fetchUnreadCounts()
|
|
||||||
self.stopTimer()
|
|
||||||
})
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue