69 lines
1.7 KiB
Swift
69 lines
1.7 KiB
Swift
//
|
|
// Demo.swift
|
|
// Adwaita
|
|
//
|
|
// Created by david-swift on 25.09.23.
|
|
//
|
|
|
|
// swiftlint:disable missing_docs implicitly_unwrapped_optional no_magic_numbers
|
|
|
|
import Adwaita
|
|
import GTUI
|
|
|
|
@main
|
|
struct Demo: App {
|
|
|
|
let id = "io.github.david-swift.Demo"
|
|
var app: GTUIApp!
|
|
@State private var toolbar = false
|
|
|
|
var scene: Scene {
|
|
Window(id: "main") { window in
|
|
DemoContent(window: window, app: app)
|
|
}
|
|
Window(id: "content", open: 0) { window in
|
|
Text("This window exists at most once.")
|
|
.padding()
|
|
.topToolbar {
|
|
HeaderBar.empty()
|
|
}
|
|
.onAppear {
|
|
window.setDefaultSize(width: 400, height: 250)
|
|
}
|
|
}
|
|
}
|
|
|
|
struct DemoContent: View {
|
|
|
|
@State private var selection: Page = .welcome
|
|
var window: GTUI.Window
|
|
var app: GTUIApp!
|
|
|
|
var view: Body {
|
|
NavigationSplitView {
|
|
ScrollView {
|
|
List(Page.allCases, selection: $selection) { element in
|
|
Text(element.label)
|
|
.halign(.start)
|
|
.padding()
|
|
}
|
|
.sidebarStyle()
|
|
}
|
|
.topToolbar {
|
|
HeaderBar.empty()
|
|
}
|
|
.navigationTitle("Demo")
|
|
} content: {
|
|
selection.view(app: app)
|
|
}
|
|
.onAppear {
|
|
window.setDefaultSize(width: 650, height: 450)
|
|
}
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
// swiftlint:enable missing_docs implicitly_unwrapped_optional no_magic_numbers
|