65 lines
2.0 KiB
Swift
65 lines
2.0 KiB
Swift
//
|
|
// AppearObserver.swift
|
|
// Meta
|
|
//
|
|
// Created by david-swift on 29.06.24.
|
|
//
|
|
|
|
/// Run a custom code accessing the view's storage when initializing the view.
|
|
struct AppearObserver: ConvenienceWidget {
|
|
|
|
/// The custom code to edit the widget.
|
|
var modify: @Sendable (ViewStorage) async -> Void
|
|
/// The wrapped view.
|
|
var content: AnyView
|
|
|
|
/// The view storage.
|
|
/// - Parameters:
|
|
/// - data: Modify views before being updated.
|
|
/// - type: The view render data type.
|
|
/// - Returns: The view storage.
|
|
func container<Data>(
|
|
data: WidgetData,
|
|
type: Data.Type
|
|
) async -> ViewStorage where Data: ViewRenderData {
|
|
let storage = await content.storage(data: data, type: type)
|
|
await modify(storage)
|
|
return storage
|
|
}
|
|
|
|
/// Update the stored content.
|
|
/// - Parameters:
|
|
/// - storage: The storage to update.
|
|
/// - data: Modify views before being updated
|
|
/// - updateProperties: Whether to update the view's properties.
|
|
/// - type: The view render data type.
|
|
func update<Data>(
|
|
_ storage: ViewStorage,
|
|
data: WidgetData,
|
|
updateProperties: Bool,
|
|
type: Data.Type
|
|
) async where Data: ViewRenderData {
|
|
await content.updateStorage(storage, data: data, updateProperties: updateProperties, type: type)
|
|
}
|
|
|
|
}
|
|
|
|
/// Extend any view.
|
|
extension AnyView {
|
|
|
|
/// Run a function on the widget when it appears for the first time.
|
|
/// - Parameter closure: The function.
|
|
/// - Returns: A view.
|
|
public func inspectOnAppear(_ closure: @Sendable @escaping (ViewStorage) async -> Void) -> AnyView {
|
|
AppearObserver(modify: closure, content: self)
|
|
}
|
|
|
|
/// Run a function when the view appears for the first time.
|
|
/// - Parameter closure: The function.
|
|
/// - Returns: A view.
|
|
public func onAppear(_ closure: @Sendable @escaping () async -> Void) -> AnyView {
|
|
inspectOnAppear { _ in await closure() }
|
|
}
|
|
|
|
}
|