2021-11-05 04:55:51 +05:30
|
|
|
import Defaults
|
|
|
|
import SwiftUI
|
|
|
|
|
|
|
|
struct BrowsingSettings: View {
|
|
|
|
@Default(.channelOnThumbnail) private var channelOnThumbnail
|
|
|
|
@Default(.timeOnThumbnail) private var timeOnThumbnail
|
2021-12-01 16:52:19 +05:30
|
|
|
@Default(.visibleSections) private var visibleSections
|
2021-11-05 04:55:51 +05:30
|
|
|
|
|
|
|
var body: some View {
|
2021-12-01 16:52:19 +05:30
|
|
|
Group {
|
|
|
|
Section(header: SettingsHeader(text: "Browsing")) {
|
|
|
|
Toggle("Show channel name on thumbnail", isOn: $channelOnThumbnail)
|
|
|
|
Toggle("Show video length on thumbnail", isOn: $timeOnThumbnail)
|
|
|
|
}
|
|
|
|
Section(header: SettingsHeader(text: "Sections")) {
|
|
|
|
#if os(macOS)
|
2021-12-03 00:52:55 +05:30
|
|
|
let list = ForEach(VisibleSection.allCases, id: \.self) { section in
|
2021-12-01 16:52:19 +05:30
|
|
|
VisibleSectionSelectionRow(
|
|
|
|
title: section.title,
|
|
|
|
selected: visibleSections.contains(section)
|
|
|
|
) { value in
|
|
|
|
toggleSection(section, value: value)
|
|
|
|
}
|
|
|
|
}
|
2021-11-08 02:21:22 +05:30
|
|
|
|
2021-12-01 16:52:19 +05:30
|
|
|
Group {
|
|
|
|
if #available(macOS 12.0, *) {
|
|
|
|
list
|
|
|
|
.listStyle(.inset(alternatesRowBackgrounds: true))
|
|
|
|
} else {
|
|
|
|
list
|
|
|
|
.listStyle(.inset)
|
|
|
|
}
|
2021-12-03 00:52:55 +05:30
|
|
|
|
|
|
|
Spacer()
|
2021-12-01 16:52:19 +05:30
|
|
|
}
|
|
|
|
#else
|
|
|
|
ForEach(VisibleSection.allCases, id: \.self) { section in
|
|
|
|
VisibleSectionSelectionRow(
|
|
|
|
title: section.title,
|
|
|
|
selected: visibleSections.contains(section)
|
|
|
|
) { value in
|
|
|
|
toggleSection(section, value: value)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
}
|
2021-11-05 04:55:51 +05:30
|
|
|
}
|
|
|
|
.frame(minWidth: 0, maxWidth: .infinity, alignment: .leading)
|
|
|
|
}
|
2021-11-08 02:21:22 +05:30
|
|
|
|
2021-12-01 16:52:19 +05:30
|
|
|
func toggleSection(_ section: VisibleSection, value: Bool) {
|
|
|
|
if value {
|
|
|
|
visibleSections.insert(section)
|
|
|
|
} else {
|
|
|
|
visibleSections.remove(section)
|
|
|
|
}
|
2021-11-08 02:21:22 +05:30
|
|
|
}
|
|
|
|
|
2021-12-01 16:52:19 +05:30
|
|
|
struct VisibleSectionSelectionRow: 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())
|
2021-11-08 02:21:22 +05:30
|
|
|
}
|
2021-12-01 16:52:19 +05:30
|
|
|
#if !os(tvOS)
|
|
|
|
.buttonStyle(.plain)
|
|
|
|
#endif
|
2021-11-08 02:21:22 +05:30
|
|
|
}
|
2021-12-01 16:52:19 +05:30
|
|
|
}
|
2021-11-05 04:55:51 +05:30
|
|
|
}
|
|
|
|
|
|
|
|
struct BrowsingSettings_Previews: PreviewProvider {
|
|
|
|
static var previews: some View {
|
|
|
|
BrowsingSettings()
|
|
|
|
.injectFixtureEnvironmentObjects()
|
|
|
|
}
|
|
|
|
}
|