-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathViewModels.swift
99 lines (81 loc) · 2.59 KB
/
ViewModels.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
import SwiftUI
struct FruitModel: Identifiable {
let id: String = UUID().uuidString
let name: String
let count: Int
}
class FruitViewModel: ObservableObject {
@Published var fruits: [FruitModel] = []
@Published var isLoading: Bool = false
init() {
getFruits()
}
func onDeleteFruit(index: IndexSet) {
fruits.remove(atOffsets: index)
}
func getFruits() {
let fruit1 = FruitModel(name: "Orange", count: 8)
let fruit2 = FruitModel(name: "Strawberry", count: 3)
let fruit3 = FruitModel(name: "Grapes", count: 48)
isLoading = true
DispatchQueue.main.asyncAfter(deadline: .now() + 1) {
self.fruits.append(fruit1)
self.fruits.append(fruit2)
self.fruits.append(fruit3)
self.isLoading = false
}
}
}
struct ViewModels: View {
// @StateObject: Use this for creation / init
// @ObservedObject: Use this for Subviews
// When the view rerender, the data persists when using @StateObject
@StateObject var fruitViewModel: FruitViewModel = FruitViewModel()
var body: some View {
NavigationStack {
List {
if fruitViewModel.isLoading {
ProgressView()
} else {
ForEach(fruitViewModel.fruits) { fruit in
HStack {
Text(fruit.name)
Spacer()
Text("\(fruit.count)")
}
}
.onDelete(perform: fruitViewModel.onDeleteFruit)
}
}
.navigationTitle("Fruits")
.toolbar {
ToolbarItem(placement: .topBarTrailing) {
NavigationLink(
destination: RandomScreen(fruitViewModel: fruitViewModel),
label: {
Image(systemName: "arrow.right")
}
)
}
}
}
}
}
struct RandomScreen: View {
@Environment(\.dismiss) var dismiss
@ObservedObject var fruitViewModel: FruitViewModel
var body: some View {
ZStack {
Color.green.ignoresSafeArea()
VStack {
ForEach(fruitViewModel.fruits) { fruit in
Text(fruit.name)
.foregroundStyle(.white)
}
}
}
}
}
#Preview {
ViewModels()
}