Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/divadretlaw/windowkit
🪟 Easily present SwiftUI views in their own UIWindow
https://github.com/divadretlaw/windowkit
swift swiftui uiwindow window
Last synced: 2 days ago
JSON representation
🪟 Easily present SwiftUI views in their own UIWindow
- Host: GitHub
- URL: https://github.com/divadretlaw/windowkit
- Owner: divadretlaw
- License: mit
- Created: 2023-10-15T09:16:33.000Z (over 1 year ago)
- Default Branch: main
- Last Pushed: 2025-02-01T10:14:35.000Z (18 days ago)
- Last Synced: 2025-02-01T11:20:38.512Z (17 days ago)
- Topics: swift, swiftui, uiwindow, window
- Language: Swift
- Homepage:
- Size: 89.8 KB
- Stars: 28
- Watchers: 3
- Forks: 8
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# WindowKit
[data:image/s3,"s3://crabby-images/690af/690af4c6d56a257784083b45cc6c7f7dbec57008" alt=""](https://swiftpackageindex.com/divadretlaw/WindowKit)
[data:image/s3,"s3://crabby-images/4644e/4644e08d6db3e8033c6dc9ad3a025f94a9db347d" alt=""](https://swiftpackageindex.com/divadretlaw/WindowKit)
Handle `UIWindow` & `UIWindowScene` within SwifUI and present SwiftUI Views in their own window.
## Usage
### `windowCover(isPresented:content:)`
data:image/s3,"s3://crabby-images/ddca7/ddca7f030c2ce3447b50f06aed4f7bc4006a95a6" alt="Static Badge"
Present a modal view within it's own `UIWindow` from any SwiftUI view.
Usage is similar to `fullscreenCover(isPresented:content:)`
```swift
.windowCover(isPresented: $isPresented) {
MyWindowCover()
}
```You can also configure the window presentation
```swift
.windowCover(isPresented: $isPresented) {
MyWindowCover()
} configure { configuration in
// Customize the window cover presentation
}
```#### Environment
In order to dismiss the window cover, use the `dismissWindowCover` from the environment
```swift
@Environment(\.dismissWindowCover) var dismiss
```In case the current view is not presented within a window cover the `dismissWindowCover` action will do nothing.
### `windowOverlay(content:)`
data:image/s3,"s3://crabby-images/ddca7/ddca7f030c2ce3447b50f06aed4f7bc4006a95a6" alt="Static Badge"
Present a modal view within it's own `UIWindow` from any SwiftUI view.
Usage is similar to `overlay(content:)`
```swift
.windowOverlay {
MyWindowOverlay()
}
```You can also configure the window presentation
```swift
.windowOverlay {
MyWindowOverlay()
} configure { configuration in
// Customize the window overlay presentation
}
```### [`WindowReader`](https://github.com/divadretlaw/WindowReader)
data:image/s3,"s3://crabby-images/94bb0/94bb06551480a4ca7a4e6ffb3df087cb2f65aed1" alt="Static Badge"
Read the current `UIWindow` or `NSWindow` with `WindowReader`
```swift
@main
struct MyView: View {
var body: some Scene {
WindowReader { window in
...
}
}
}
```On child views the `UIWindow` or `NSWindow` will be available in the `Environment`
#### Environment
```swift
@Environment(\.window) var window
```### [`WindowSceneReader`](https://github.com/divadretlaw/WindowSceneReader)
data:image/s3,"s3://crabby-images/ddca7/ddca7f030c2ce3447b50f06aed4f7bc4006a95a6" alt="Static Badge"
#### SwiftUI LifecycleRead the current `UIWindowScene` with `WindowSceneReader`
```swift
@main
struct MyApp: App {
var body: some Scene {
WindowGroup {
WindowSceneReader { windowScene in
ContentView()
}
}
}
}
```alternatively, just add `windowScene()` if you only need the window scene on child views.
```swift
@main
struct MyApp: App {
var body: some Scene {
WindowGroup {
ContentView()
.windowScene()
}
}
}
```On child views the `UIWindowScene` will be available in the `Environment`
#### UIKit Lifecycle
```swift
class SceneDelegate: UIResponder, UIWindowSceneDelegate {
var window: UIWindow?
func scene(_ scene: UIScene, willConnectTo session: UISceneSession, options connectionOptions: UIScene.ConnectionOptions) {
if let windowScene = scene as? UIWindowScene {
let rootView = ContentView()
.windowScene(windowScene)
let window = UIWindow(windowScene: windowScene)
window.rootViewController = UIHostingController(rootView: rootView)
self.window = window
window.makeKeyAndVisible()
}
}
```#### Environment
```swift
@Environment(\.windowScene) var windowScene
```The `@Environment(\.windowScene) var windowScene` defaults to the first connected `UIWindowScene` or `nil` if no `UIWindowScene` is connected.
## License
See [LICENSE](LICENSE)