AsyncOpen
@available(iOS 14.0, macOS 11.0, tvOS 14.0, watchOS 7.0, *)
@MainActor
@propertyWrapper
public struct AsyncOpen : DynamicProperty
Realm を非同期に開く現在のユーザーに対してRealm.asyncOpen()
を開始し、指定されたプロセスの状態を通知するプロパティ ラッパー型
ユーザーがすでにログインしている後、またはユーザーがログインする場合は、 SwiftUI/View
またはSwiftUI/App
に AsyncOpen を追加します
@AsyncOpen(appId: "app_id", partitionValue: <partition_value>) var asyncOpen
これにより、 Realm.asyncOpen()
操作がすぐに開始され、Realm を使用可能な状態にするために必要なすべての作業が実行されます。 ( Realm.asyncOpen() のドキュメントを参照してください)
このプロパティ ラッパーは、進行状況、エラー、開かれたRealmなど、現在のRealm.asyncOpen()
プロセスの状態を公開します。これはビューの更新に使用できます
struct AsyncOpenView: View {
@AsyncOpen(appId: "app_id", partitionValue: <partition_value>) var asyncOpen
var body: some View {
switch asyncOpen {
case .notOpen:
ProgressView()
case .open(let realm):
ListView()
.environment(\.realm, realm)
case .error(_):
ErrorView()
case .progress(let progress):
ProgressView(progress)
}
}
}
この開かれたrealm
は、後で環境値としてビューに入力され、プロパティ ラッパーによって使用され、開かれた Realm のデータをビューに入力します。
ListView()
.environment(\.realm, realm)
-
AsyncOpenState
の パブリッシャー は、 asyncOpen 状態が変化するたびに 状態を発行します。宣言
Swift
@MainActor public var projectedValue: Published<AsyncOpenState>.Publisher { get }
-
これにより、プロパティ ラッパーの状態からの通知がキャンセルされます
宣言
Swift
@MainActor public func cancel()
-
プロパティ ラッパーを初期化
宣言
パラメーター
appId
Realm アプリの一意の識別子が空または
nil
の場合、最新の単数形のキャッシュ アプリの検索が試行されます。partitionValue
Realm が分割される
BSON
値。configuration
Realm の作成時に使用される
Realm.Configuration
は、特定のパーティション値のユーザーの同期構成がsyncConfiguration
として設定され、空の場合はユーザー構成が使用されます。timeout
、接続が完全に確立されるまでの最大時間(ミリ秒)。 空の場合、または
nil
の場合は接続タイムアウトが設定されていません。 -
柔軟な同期構成の プロパティ ラッパーを初期化します。
宣言
Swift
@MainActor public init(appId: String? = nil, configuration: Realm.Configuration? = nil, timeout: UInt? = nil)
パラメーター
appId
Realm アプリの一意の識別子が空または
nil
の場合、最新の単数形のキャッシュ アプリの検索が試行されます。configuration
Realm の作成時に使用される
Realm.Configuration
は、特定のパーティション値のユーザーの同期構成がsyncConfiguration
として設定され、空の場合はユーザー構成が使用されます。timeout
、接続が完全に確立されるまでの最大時間(ミリ秒)。 空の場合、または
nil
の場合は接続タイムアウトが設定されていません。 -
宣言
Swift
nonisolated public func update()