Add setting for thumbnails quality

This commit is contained in:
Arkadiusz Fal 2022-06-26 14:25:54 +02:00
parent 8ebadd4758
commit adb1f72684
3 changed files with 35 additions and 3 deletions

View File

@ -1,3 +1,4 @@
import Defaults
import Foundation import Foundation
final class ThumbnailsModel: ObservableObject { final class ThumbnailsModel: ObservableObject {
@ -16,9 +17,7 @@ final class ThumbnailsModel: ObservableObject {
} }
func best(_ video: Video) -> URL? { func best(_ video: Video) -> URL? {
let qualities = [Thumbnail.Quality.maxresdefault, .medium, .default] for quality in availableQualitites {
for quality in qualities {
let url = video.thumbnailURL(quality: quality) let url = video.thumbnailURL(quality: quality)
if !isUnloadable(url) { if !isUnloadable(url) {
return url return url
@ -27,4 +26,15 @@ final class ThumbnailsModel: ObservableObject {
return nil return nil
} }
private var availableQualitites: [Thumbnail.Quality] {
switch Defaults[.thumbnailsQuality] {
case .highest:
return [.maxresdefault, .medium, .default]
case .medium:
return [.medium, .default]
case .low:
return [.default]
}
}
} }

View File

@ -51,6 +51,7 @@ extension Defaults.Keys {
static let channelOnThumbnail = Key<Bool>("channelOnThumbnail", default: true) static let channelOnThumbnail = Key<Bool>("channelOnThumbnail", default: true)
static let timeOnThumbnail = Key<Bool>("timeOnThumbnail", default: true) static let timeOnThumbnail = Key<Bool>("timeOnThumbnail", default: true)
static let roundedThumbnails = Key<Bool>("roundedThumbnails", default: true) static let roundedThumbnails = Key<Bool>("roundedThumbnails", default: true)
static let thumbnailsQuality = Key<ThumbnailsQuality>("thumbnailsQuality", default: .highest)
static let activeBackend = Key<PlayerBackendType>("activeBackend", default: .mpv) static let activeBackend = Key<PlayerBackendType>("activeBackend", default: .mpv)
static let quality = Key<ResolutionSetting>("quality", default: .best) static let quality = Key<ResolutionSetting>("quality", default: .best)
@ -218,3 +219,7 @@ enum PlayerDetailsPageButtonLabelStyle: String, CaseIterable, Defaults.Serializa
self == .iconAndText self == .iconAndText
} }
} }
enum ThumbnailsQuality: String, CaseIterable, Defaults.Serializable {
case highest, medium, low
}

View File

@ -9,6 +9,7 @@ struct BrowsingSettings: View {
#if os(iOS) #if os(iOS)
@Default(.lockPortraitWhenBrowsing) private var lockPortraitWhenBrowsing @Default(.lockPortraitWhenBrowsing) private var lockPortraitWhenBrowsing
#endif #endif
@Default(.thumbnailsQuality) private var thumbnailsQuality
@Default(.channelOnThumbnail) private var channelOnThumbnail @Default(.channelOnThumbnail) private var channelOnThumbnail
@Default(.timeOnThumbnail) private var timeOnThumbnail @Default(.timeOnThumbnail) private var timeOnThumbnail
@Default(.visibleSections) private var visibleSections @Default(.visibleSections) private var visibleSections
@ -65,6 +66,7 @@ struct BrowsingSettings: View {
private var thumbnailsSettings: some View { private var thumbnailsSettings: some View {
Section(header: SettingsHeader(text: "Thumbnails")) { Section(header: SettingsHeader(text: "Thumbnails")) {
thumbnailsQualityPicker
#if !os(tvOS) #if !os(tvOS)
Toggle("Round corners", isOn: $roundedThumbnails) Toggle("Round corners", isOn: $roundedThumbnails)
#endif #endif
@ -73,6 +75,21 @@ struct BrowsingSettings: View {
} }
} }
private var thumbnailsQualityPicker: some View {
Picker("Quality", selection: $thumbnailsQuality) {
ForEach(ThumbnailsQuality.allCases, id: \.self) { quality in
Text(quality.rawValue.capitalized + " quality").tag(quality)
}
}
.labelsHidden()
#if os(iOS)
.pickerStyle(.automatic)
#elseif os(tvOS)
.pickerStyle(.inline)
#endif
}
private var visibleSectionsSettings: some View { private var visibleSectionsSettings: some View {
Section(header: SettingsHeader(text: "Sections")) { Section(header: SettingsHeader(text: "Sections")) {
#if os(macOS) #if os(macOS)