mirror of
https://github.com/yattee/yattee.git
synced 2024-12-15 06:40:32 +05:30
103 lines
3.4 KiB
Swift
103 lines
3.4 KiB
Swift
import Defaults
|
|
import SwiftUI
|
|
|
|
struct ServicesSettings: View {
|
|
@Default(.sponsorBlockInstance) private var sponsorBlockInstance
|
|
@Default(.sponsorBlockCategories) private var sponsorBlockCategories
|
|
|
|
var body: some View {
|
|
Section(header: Text("SponsorBlock API")) {
|
|
TextField(
|
|
"SponsorBlock API Instance",
|
|
text: $sponsorBlockInstance,
|
|
prompt: Text("SponsorBlock API URL, leave blank to disable")
|
|
)
|
|
.labelsHidden()
|
|
#if !os(macOS)
|
|
.autocapitalization(.none)
|
|
.keyboardType(.URL)
|
|
#endif
|
|
}
|
|
|
|
Section(header: Text("Categories to Skip")) {
|
|
#if os(macOS)
|
|
List(SponsorBlockAPI.categories, id: \.self) { category in
|
|
SponsorBlockCategorySelectionRow(
|
|
title: SponsorBlockAPI.categoryDescription(category) ?? "Unknown",
|
|
selected: sponsorBlockCategories.contains(category)
|
|
) { value in
|
|
toggleCategory(category, value: value)
|
|
}
|
|
}
|
|
.listStyle(.inset(alternatesRowBackgrounds: true))
|
|
Spacer()
|
|
#else
|
|
ForEach(SponsorBlockAPI.categories, id: \.self) { category in
|
|
SponsorBlockCategorySelectionRow(
|
|
title: SponsorBlockAPI.categoryDescription(category) ?? "Unknown",
|
|
selected: sponsorBlockCategories.contains(category)
|
|
) { value in
|
|
toggleCategory(category, value: value)
|
|
}
|
|
}
|
|
#endif
|
|
}
|
|
}
|
|
|
|
func toggleCategory(_ category: String, value: Bool) {
|
|
if let index = sponsorBlockCategories.firstIndex(where: { $0 == category }), !value {
|
|
sponsorBlockCategories.remove(at: index)
|
|
} else if value {
|
|
sponsorBlockCategories.insert(category)
|
|
}
|
|
}
|
|
|
|
struct SponsorBlockCategorySelectionRow: View {
|
|
let title: String
|
|
let selected: Bool
|
|
var action: (Bool) -> Void
|
|
|
|
@State private var toggleChecked = false
|
|
|
|
var body: some View {
|
|
Button(action: { action(!selected) }) {
|
|
HStack {
|
|
#if os(macOS)
|
|
Toggle(isOn: $toggleChecked) {
|
|
Text(self.title)
|
|
Spacer()
|
|
}
|
|
.onAppear {
|
|
toggleChecked = selected
|
|
}
|
|
.onChange(of: toggleChecked) { new in
|
|
action(new)
|
|
}
|
|
#else
|
|
Text(self.title)
|
|
Spacer()
|
|
if selected {
|
|
Image(systemName: "checkmark")
|
|
#if os(iOS)
|
|
.foregroundColor(.accentColor)
|
|
#endif
|
|
}
|
|
#endif
|
|
}
|
|
.contentShape(Rectangle())
|
|
}
|
|
#if !os(tvOS)
|
|
.buttonStyle(.plain)
|
|
#endif
|
|
}
|
|
}
|
|
}
|
|
|
|
struct ServicesSettings_Previews: PreviewProvider {
|
|
static var previews: some View {
|
|
VStack {
|
|
ServicesSettings()
|
|
}
|
|
}
|
|
}
|