2022-08-13 14:12:45 +00:00
|
|
|
import SwiftUI
|
|
|
|
|
|
|
|
struct MultiselectRow: View {
|
|
|
|
let title: String
|
2022-08-14 17:02:36 +00:00
|
|
|
var selected: Bool
|
|
|
|
var disabled = false
|
2022-08-13 14:12:45 +00:00
|
|
|
var action: (Bool) -> Void
|
|
|
|
|
|
|
|
@State private var toggleChecked = false
|
|
|
|
|
|
|
|
var body: some View {
|
2024-04-26 10:27:25 +00:00
|
|
|
#if os(tvOS)
|
2022-11-11 18:53:52 +00:00
|
|
|
Button(action: { action(!selected) }) {
|
|
|
|
HStack {
|
2022-08-13 14:12:45 +00:00
|
|
|
Text(self.title)
|
|
|
|
Spacer()
|
|
|
|
if selected {
|
|
|
|
Image(systemName: "checkmark")
|
|
|
|
}
|
2022-11-11 18:53:52 +00:00
|
|
|
}
|
|
|
|
.contentShape(Rectangle())
|
2022-08-13 14:12:45 +00:00
|
|
|
}
|
2022-11-11 18:53:52 +00:00
|
|
|
.disabled(disabled)
|
2024-04-26 10:27:25 +00:00
|
|
|
#else
|
|
|
|
Toggle(title, isOn: $toggleChecked)
|
|
|
|
#if os(macOS)
|
|
|
|
.toggleStyle(.checkbox)
|
2022-11-11 18:53:52 +00:00
|
|
|
#endif
|
2024-04-26 10:27:25 +00:00
|
|
|
.onAppear {
|
|
|
|
guard !disabled else { return }
|
|
|
|
toggleChecked = selected
|
|
|
|
}
|
|
|
|
.onChange(of: toggleChecked) { new in
|
|
|
|
action(new)
|
|
|
|
}
|
2022-08-13 14:12:45 +00:00
|
|
|
#endif
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
struct MultiselectRow_Previews: PreviewProvider {
|
|
|
|
static var previews: some View {
|
2022-08-25 17:09:55 +00:00
|
|
|
MultiselectRow(title: "Title", selected: false) { _ in }
|
2022-08-13 14:12:45 +00:00
|
|
|
}
|
|
|
|
}
|