For ObservableObject
the pairing ObservedObject
makes view refresh, so to solve the task in question I would recommend the following approach:
Demo
Code
import SwiftUI
import Combine
class Sport: ObservableObject, Hashable, Identifiable {
static func == (lhs: Sport, rhs: Sport) -> Bool {
lhs.name == rhs.name && lhs.isFavorite == rhs.isFavorite && lhs.school == rhs.school
}
func hash(into hasher: inout Hasher) {
hasher.combine(name)
hasher.combine(isFavorite)
hasher.combine(school)
}
@Published var name : String
@Published var isFavorite = false
@Published var school : String
init(name: String, isFavorite: Bool, school: String) {
self.name = name
self.isFavorite = isFavorite
self.school = school
}
}
final class SportData: ObservableObject {
@Published var store =
[
Sport(name: "soccer", isFavorite: false, school: "WPI"),
Sport(name: "tennis", isFavorite: false, school: "WPI"),
Sport(name: "swimming", isFavorite: true, school: "WPI"),
Sport(name: "running", isFavorite: true, school: "RIT"),
]
}
struct TestingObservedObject: View {
@ObservedObject var sports = SportData()
var body: some View {
NavigationView{
List{
ForEach(sports.store){ sport in
NavigationLink(destination: ScreenTwo(sport: sport)) {
HStack {
Text("\(sport.name)")
Spacer()
Text(sport.isFavorite.description)
}
}
.onReceive(sport.$isFavorite) { _ in self.sports.objectWillChange.send() }
}
}
}.navigationBarTitle("Settings")
}
}
struct ScreenTwo : View{
@ObservedObject var sport : Sport
var body: some View{
NavigationLink(destination: DetailsView(sport: sport)){
Text(sport.isFavorite.description)
}
}
}
struct DetailsView: View {
@ObservedObject var sport : Sport
var body: some View {
Button(action: {
self.sport.isFavorite.toggle()
self.sport.name = "Ricky"
}) {
Text(sport.isFavorite.description)
Text(sport.name)
}
}
}
#if DEBUG
struct Testing_Previews: PreviewProvider {
static var previews: some View {
TestingObservedObject()
}
}
#endif