From 321eaecd21cac24b311c8049a47fe7bb6233b9cc Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Toni=20F=C3=B6rster?= Date: Tue, 23 Apr 2024 11:00:27 +0200 Subject: [PATCH] SponsorBlock align categories with upstream --- Model/SponsorBlock/SponsorBlockAPI.swift | 38 ++++++++++++++-------- Shared/Settings/SponsorBlockSettings.swift | 5 +-- Shared/en.lproj/Localizable.strings | 2 +- 3 files changed, 29 insertions(+), 16 deletions(-) diff --git a/Model/SponsorBlock/SponsorBlockAPI.swift b/Model/SponsorBlock/SponsorBlockAPI.swift index c8517259..4df4ca4e 100644 --- a/Model/SponsorBlock/SponsorBlockAPI.swift +++ b/Model/SponsorBlock/SponsorBlockAPI.swift @@ -5,7 +5,7 @@ import Logging import SwiftyJSON final class SponsorBlockAPI: ObservableObject { - static let categories = ["sponsor", "selfpromo", "intro", "outro", "interaction", "music_offtopic"] + static let categories = ["sponsor", "selfpromo", "interaction", "intro", "outro", "preview", "filler", "music_offtopic"] let logger = Logger(label: "stream.yattee.app.sb") @@ -21,15 +21,19 @@ final class SponsorBlockAPI: ObservableObject { case "sponsor": return "Sponsor".localized() case "selfpromo": - return "Self-promotion".localized() - case "intro": - return "Intro".localized() - case "outro": - return "Outro".localized() + return "Unpaid/Self Promotion".localized() case "interaction": - return "Interaction".localized() + return "Interaction Reminder (Subscribe)".localized() + case "intro": + return "Intermission/Intro Animation".localized() + case "outro": + return "Endcards/Credits".localized() + case "preview": + return "Preview/Recap/Hook".localized() + case "filler": + return "Filler Tangent/Jokes".localized() case "music_offtopic": - return "Offtopic in Music Videos".localized() + return "Music: Non-Music Section".localized() default: return name.capitalized } @@ -46,9 +50,14 @@ final class SponsorBlockAPI: ObservableObject { "The creator will receive payment or compensation in the form of money or free products.").localized() case "selfpromo": - return ("Promoting a product or service that is directly related to the creator themselves. " + + return ("The creator will not receive any payment in exchange for this promotion. " + + "This includes charity drives or free shout outs for products or other people they like.\n\n" + + "Promoting a product or service that is directly related to the creator themselves. " + "This usually includes merchandise or promotion of monetized platforms.").localized() + case "interaction": + return "Explicit reminders to like, subscribe or interact with them on any paid or free platform(s) (e.g. click on a video).".localized() + case "intro": return ("Segments typically found at the start of a video that include an animation, " + "still frame or clip which are also seen in other videos by the same creator.").localized() @@ -56,8 +65,11 @@ final class SponsorBlockAPI: ObservableObject { case "outro": return "Typically near or at the end of the video when the credits pop up and/or endcards are shown.".localized() - case "interaction": - return "Explicit reminders to like, subscribe or interact with them on any paid or free platform(s) (e.g. click on a video).".localized() + case "preview": + return "Collection of clips that show what is coming up in in this video or other videos in a series where all information is repeated later in the video".localized() + + case "filler": + return "Filler Tangent/ Jokes is only for tangential scenes added only for filler or humor that are not required to understand the main content of the video.".localized() case "music_offtopic": return "For videos which feature music as the primary content.".localized() @@ -100,8 +112,8 @@ final class SponsorBlockAPI: ObservableObject { self.segments = JSON(value).arrayValue.map(SponsorBlockSegment.init).sorted { $0.end < $1.end } self.logger.info("loaded \(self.segments.count) SponsorBlock segments") - self.segments.forEach { - self.logger.info("\($0.start) -> \($0.end)") + for segment in self.segments { + self.logger.info("\(segment.start) -> \(segment.end)") } case let .failure(error): self.segments = [] diff --git a/Shared/Settings/SponsorBlockSettings.swift b/Shared/Settings/SponsorBlockSettings.swift index 114a0154..bd7c677a 100644 --- a/Shared/Settings/SponsorBlockSettings.swift +++ b/Shared/Settings/SponsorBlockSettings.swift @@ -79,17 +79,18 @@ struct SponsorBlockSettings: View { ForEach(SponsorBlockAPI.categories, id: \.self) { category in Text(SponsorBlockAPI.categoryDescription(category) ?? "Category") .fontWeight(.bold) + .padding(.bottom, 0.5) #if os(tvOS) .focusable() #endif Text(SponsorBlockAPI.categoryDetails(category) ?? "Details") - .padding(.bottom, 3) + .padding(.bottom, 10) .fixedSize(horizontal: false, vertical: true) } } .foregroundColor(.secondary) - .padding(.top, 3) + .padding(.top, 10) } func toggleCategory(_ category: String, value: Bool) { diff --git a/Shared/en.lproj/Localizable.strings b/Shared/en.lproj/Localizable.strings index f4930fc7..238e7ecc 100644 --- a/Shared/en.lproj/Localizable.strings +++ b/Shared/en.lproj/Localizable.strings @@ -108,7 +108,7 @@ "Enter fullscreen in landscape" = "Enter fullscreen in landscape"; "Error" = "Error"; "Error when accessing playlist" = "Error when accessing playlist"; -"Explicit reminders to like, subscribe or interact with them on any paid or free platform(s) (e.g. click on a video)." = "Explicit reminders to like, subscribe or interact with them on any paid or free platform(s) (e.g. click on a video).\n"; +"Explicit reminders to like, subscribe or interact with them on any paid or free platform(s) (e.g. click on a video)." = "Explicit reminders to like, subscribe or interact with them on any paid or free platform(s) (e.g. click on a video)."; "Favorites" = "Favorites"; "Filter" = "Filter"; "Filter: active" = "Filter: active";