-
Notifications
You must be signed in to change notification settings - Fork 1
/
main.swift
106 lines (93 loc) · 2.88 KB
/
main.swift
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
import Foundation
import Shaft
import ShaftCodeHighlight
runApp(
Playground()
)
final class Playground: StatefulWidget {
func createState() -> PlaygroundState {
PlaygroundState()
}
}
final class PlaygroundState: State<Playground> {
let pageByTitle: [String: Widget] = [
"Observation": Concept_Observation(),
"ShaftKit": Concept_ShaftKit(),
"Backend": Concept_Backend(),
"Background": Kit_Background(),
"Button": Kit_Button(),
"Divider": Kit_Divider(),
"Image": Kit_Image(),
"ListView": Kit_ListView(),
"NavigationSplitView": Kit_NavigationSplitView(),
"Resizable": Kit_Resizable(),
"TextField": Kit_TextField(),
"Typography": Kit_Typography(),
"Hacker News": HackerNewsApp(),
"3D Cube": Demo_Cube(),
// "Text Field": TextFieldPage.init,
]
lazy var selectedPage = ValueNotifier("Button")
override func initState() {
super.initState()
updateTitle()
selectedPage.addListener(self, callback: handleSelectedPageChanged)
}
override func dispose() {
selectedPage.removeListener(self)
super.dispose()
}
private func handleSelectedPageChanged() {
updateTitle()
}
private func updateTitle() {
View.maybeOf(context)?.title = "Playground - \(selectedPage.wrappedValue)"
}
override func build(context: BuildContext) -> Widget {
NavigationSplitView {
FixedListView(selection: selectedPage) {
Section {
Text("Concepts")
} content: {
MenuTile("Observation")
MenuTile("ShaftKit")
MenuTile("Backend")
}
Section {
Text("Controls")
} content: {
MenuTile("Background")
MenuTile("Button")
MenuTile("Divider")
MenuTile("Image")
MenuTile("ListView")
MenuTile("NavigationSplitView")
MenuTile("Resizable")
MenuTile("TextField")
MenuTile("Typography")
}
Section {
Text("Demos")
} content: {
MenuTile("Hacker News")
MenuTile("3D Cube")
MenuTile("Video Codec")
}
}
} detail: {
let page = pageByTitle[selectedPage.wrappedValue]
page ?? Text("Under construction").padding(.all(20))
}
}
}
final class MenuTile: StatelessWidget {
init(_ title: String) {
self.title = title
}
let title: String
func build(context: any BuildContext) -> any Widget {
ListTile(title) {
Text(title)
}
}
}