2020-11-18 03:49:12 +01:00
|
|
|
//
|
|
|
|
// StarredWidget.swift
|
|
|
|
// NetNewsWire Widget Extension
|
|
|
|
//
|
|
|
|
// Created by Stuart Breckenridge on 18/11/20.
|
|
|
|
// Copyright © 2020 Ranchero Software. All rights reserved.
|
|
|
|
//
|
|
|
|
|
|
|
|
import WidgetKit
|
|
|
|
import SwiftUI
|
|
|
|
|
|
|
|
struct StarredWidgetView : View {
|
|
|
|
|
|
|
|
@Environment(\.widgetFamily) var family: WidgetFamily
|
2020-12-24 01:45:07 +01:00
|
|
|
@Environment(\.sizeCategory) var sizeCategory: ContentSizeCategory
|
2020-11-18 03:49:12 +01:00
|
|
|
|
|
|
|
var entry: Provider.Entry
|
|
|
|
|
|
|
|
var body: some View {
|
|
|
|
if entry.widgetData.starredArticles.count == 0 {
|
|
|
|
inboxZero
|
2020-11-30 08:41:15 +01:00
|
|
|
.widgetURL(WidgetDeepLink.starred.url)
|
2020-11-18 03:49:12 +01:00
|
|
|
}
|
|
|
|
else {
|
2020-11-23 03:35:25 +01:00
|
|
|
GeometryReader { metrics in
|
2021-01-29 15:34:31 +01:00
|
|
|
HStack {
|
|
|
|
VStack {
|
2020-11-18 03:49:12 +01:00
|
|
|
starredImage
|
2021-01-29 15:34:31 +01:00
|
|
|
.padding(.vertical, 12)
|
|
|
|
.padding(.leading, 8)
|
2020-11-18 03:49:12 +01:00
|
|
|
Spacer()
|
2020-11-23 03:35:25 +01:00
|
|
|
|
2021-01-29 15:34:31 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
.frame(width: metrics.size.width * 0.15)
|
|
|
|
|
|
|
|
Spacer()
|
|
|
|
|
|
|
|
VStack(alignment:.leading, spacing: 0) {
|
|
|
|
ForEach(0..<maxCount(), content: { i in
|
|
|
|
if i != 0 {
|
|
|
|
Divider()
|
|
|
|
ArticleItemView(article: entry.widgetData.starredArticles[i],
|
|
|
|
deepLink: WidgetDeepLink.starredArticle(id: entry.widgetData.starredArticles[i].id).url)
|
|
|
|
.padding(.top, 8)
|
|
|
|
.padding(.bottom, 4)
|
|
|
|
} else {
|
|
|
|
ArticleItemView(article: entry.widgetData.starredArticles[i],
|
|
|
|
deepLink: WidgetDeepLink.starredArticle(id: entry.widgetData.starredArticles[i].id).url)
|
|
|
|
.padding(.bottom, 4)
|
|
|
|
}
|
|
|
|
})
|
|
|
|
Spacer()
|
|
|
|
}
|
|
|
|
.padding(.leading, metrics.size.width * 0.175)
|
|
|
|
.padding([.bottom, .trailing])
|
|
|
|
.padding(.top, 12)
|
|
|
|
.overlay(
|
|
|
|
VStack {
|
2020-11-18 03:49:12 +01:00
|
|
|
Spacer()
|
2021-01-29 15:34:31 +01:00
|
|
|
HStack {
|
|
|
|
Spacer()
|
|
|
|
Text(L10n.starredCount(entry.widgetData.currentStarredCount - maxCount()))
|
|
|
|
.font(.caption2)
|
|
|
|
.bold()
|
|
|
|
.foregroundColor(.secondary)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
.padding(.horizontal)
|
|
|
|
.padding(.bottom, 6)
|
|
|
|
)
|
|
|
|
|
2020-11-30 08:41:15 +01:00
|
|
|
}.widgetURL(WidgetDeepLink.starred.url)
|
2020-11-18 03:49:12 +01:00
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
var starredImage: some View {
|
|
|
|
Image(systemName: "star.fill")
|
|
|
|
.resizable()
|
2020-12-24 01:50:45 +01:00
|
|
|
.frame(width: 30, height: 30, alignment: .center)
|
2020-11-18 03:49:12 +01:00
|
|
|
.cornerRadius(4)
|
|
|
|
.foregroundColor(.yellow)
|
|
|
|
}
|
|
|
|
|
|
|
|
func maxCount() -> Int {
|
2020-12-24 01:45:07 +01:00
|
|
|
var reduceAccessibilityCount: Int = 0
|
|
|
|
if SizeCategories().isSizeCategoryLarge(category: sizeCategory) {
|
|
|
|
reduceAccessibilityCount = 1
|
|
|
|
}
|
|
|
|
|
2020-11-18 08:43:14 +01:00
|
|
|
if family == .systemLarge {
|
2020-12-24 01:45:07 +01:00
|
|
|
return entry.widgetData.currentStarredCount >= 7 ? (7 - reduceAccessibilityCount) : entry.widgetData.currentStarredCount
|
2020-11-18 08:43:14 +01:00
|
|
|
}
|
2020-12-24 01:45:07 +01:00
|
|
|
return entry.widgetData.currentStarredCount >= 3 ? (3 - reduceAccessibilityCount) : entry.widgetData.currentStarredCount
|
2020-11-18 03:49:12 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
var inboxZero: some View {
|
2020-12-15 12:56:50 +01:00
|
|
|
VStack(alignment: .center) {
|
2020-11-18 03:49:12 +01:00
|
|
|
Spacer()
|
2020-12-15 12:56:50 +01:00
|
|
|
Image(systemName: "star.fill")
|
|
|
|
.resizable()
|
|
|
|
.aspectRatio(contentMode: .fit)
|
|
|
|
.frame(width: 30)
|
|
|
|
.foregroundColor(.yellow)
|
|
|
|
|
|
|
|
|
|
|
|
Text(L10n.starredWidgetNoItemsTitle)
|
|
|
|
.font(.headline)
|
|
|
|
.foregroundColor(.primary)
|
2020-11-18 03:49:12 +01:00
|
|
|
|
2020-12-15 12:56:50 +01:00
|
|
|
Text(L10n.starredWidgetNoItems)
|
|
|
|
.font(.caption)
|
|
|
|
.foregroundColor(.gray)
|
2020-11-18 03:49:12 +01:00
|
|
|
Spacer()
|
2020-12-15 12:56:50 +01:00
|
|
|
}
|
|
|
|
.multilineTextAlignment(.center)
|
|
|
|
.padding()
|
2020-11-18 03:49:12 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
}
|