จะเข้าถึง NSWindow จาก @main App โดยใช้ SwiftUI เพียงอย่างเดียวได้อย่างไร
Aug 16 2020
ที่คำตอบนี้โซลูชันใช้ได้กับ Scene plus swiftUI
อย่างไรก็ตามการใช้ @main เช่น:
@main
struct MyApp: App {
@StateObject private var model = MyModel()
var body: some Scene {
WindowGroup {
Router {
AppContent()
}.environmentObject(self.model)
}
}
}
ฉันยังพยายามรับหน้าต่างหลักโดยใช้ไฟล์
var window: NSWindow? {
let window = NSApplication.shared.mainWindow
return window
}
อย่างไรก็ตามmainWindow
ผลตอบแทนเสมอnil
อัปเดต:
ฉันต้องการNSWindow
เนื่องจากความจำเป็นในการปฏิบัติตามข้อกำหนดASWebAuthenticationPresentationContextProviding
ที่ต้องส่งคืนกNSWindow
. โดยพื้นฐานแล้วฉันกำลังพยายามทำสิ่งที่ชอบ:
LoginView(store: AuthStore(window: window))
ที่AuthStore
ใช้AuthenticationServices
เพื่อดำเนินการตรวจสอบสิทธิ์
คำตอบ
5 Asperi Aug 17 2020 at 00:29
โดยพื้นฐานแล้วฉันกำลังพยายามทำสิ่งที่ชอบ:
LoginView(store: AuthStore(window: window))
นี่คือการสาธิตแนวทางที่เป็นไปได้ (กับเอนทิตีจำลองบางส่วน)

class AuthStore {
var window: NSWindow
init(window: NSWindow) {
self.window = window
}
}
struct DemoWindowAccessor: View {
@State private var window: NSWindow? // << detected in run-time so optional
var body: some View {
VStack {
if nil != window {
LoginView(store: AuthStore(window: window!)) // << usage
}
}.background(WindowAccessor(window: $window))
}
}
struct WindowAccessor: NSViewRepresentable {
@Binding var window: NSWindow?
func makeNSView(context: Context) -> NSView {
let view = NSView()
DispatchQueue.main.async {
self.window = view.window // << right after inserted in window
}
return view
}
func updateNSView(_ nsView: NSView, context: Context) {}
}
struct LoginView: View {
let store: AuthStore
var body: some View {
Text("LoginView with Window: \(store.window)")
}
}