@SharedObject is an alternative to @StateObject, @ObservedObject, @EnvironmentObject to handle ObservableObject.
If you need to have multiple objects of the same class persisted among multiple view instances, it's difficult to handle the situation with other wrappers: with @StateObject the object will deinit with the view and be generated only for the specific view instance, with @EnvironmentObject you can bind only one instance of the same class for each Environment and with @ObservedObject is difficult to propagate object in nested views.
@SharedObject simply stores the objects using an identifier, so you can retrieve it each time you'll need it.
Retrieve the shared object with the given id or, if not present, create a shared object with an initial value:
@SharedObject("A") var letterA = Letter()If you are sure that the object is already been created you can just retrieve the shared object:
@SharedObject("A") var letterA: LetterYou can give a default initial value to the class, so you don't need to specify in each view you think the object will be created:
final class Letter: SharableObject {
var value: String
init(_ value: String) {
self.value = value
}
static var initialValue: Self {
.init("A")
}
}- In Xcode, open your project and navigate to File → Swift Packages → Add Package Dependency...
- Paste the repository URL (
https://github.com/lorenzofiamingo/swiftui-shared-object) and click Next. - Click Finish.