From 2a4a13ed138a3ed044aeadeae769d776da242926 Mon Sep 17 00:00:00 2001 From: Maurice Parker Date: Fri, 17 Jul 2020 20:29:53 -0500 Subject: [PATCH] Implement mark all as read in feed context menu for timeline --- .../Shared/Timeline/TimelineContextMenu.swift | 12 ++++++++++++ Multiplatform/Shared/Timeline/TimelineModel.swift | 13 +++++++++++++ 2 files changed, 25 insertions(+) diff --git a/Multiplatform/Shared/Timeline/TimelineContextMenu.swift b/Multiplatform/Shared/Timeline/TimelineContextMenu.swift index 98d5949ea..b32ae9309 100644 --- a/Multiplatform/Shared/Timeline/TimelineContextMenu.swift +++ b/Multiplatform/Shared/Timeline/TimelineContextMenu.swift @@ -81,6 +81,18 @@ struct TimelineContextMenu: View { } } + if let feed = timelineItem.article.webFeed, timelineModel.canMarkAllAsReadInFeed(feed) { + Divider() + Button { + timelineModel.markAllAsReadInFeed(feed) + } label: { + Text("Mark All as Read in “\(feed.nameForDisplay)”") + #if os(iOS) + AppAssets.markAllAsReadImage + #endif + } + } + if timelineModel.canOpenIndicatedArticleInBrowser(timelineItem.article) { Divider() Button { diff --git a/Multiplatform/Shared/Timeline/TimelineModel.swift b/Multiplatform/Shared/Timeline/TimelineModel.swift index 44f68d9de..855e14e9f 100644 --- a/Multiplatform/Shared/Timeline/TimelineModel.swift +++ b/Multiplatform/Shared/Timeline/TimelineModel.swift @@ -189,6 +189,19 @@ class TimelineModel: ObservableObject, UndoableCommandRunner { markArticlesWithUndo(articlesToMark, statusKey: .read, flag: true) } + func canMarkAllAsReadInFeed(_ feed: Feed) -> Bool { + guard let articlesSet = try? feed.fetchArticles() else { + return false + } + return Array(articlesSet).canMarkAllAsRead() + } + + func markAllAsReadInFeed(_ feed: Feed) { + guard let articlesSet = try? feed.fetchArticles() else { return } + let articlesToMark = Array(articlesSet) + markArticlesWithUndo(articlesToMark, statusKey: .read, flag: true) + } + func toggleStarredStatusForSelectedArticles() { guard !selectedArticles.isEmpty else { return