-
Notifications
You must be signed in to change notification settings - Fork 0
/
SectionedList.swift
54 lines (47 loc) · 1.18 KB
/
SectionedList.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
//
// SectionedList.swift
// TCAPlayground
//
// Created by 小田島 直樹 on 1/11/24.
//
import ComposableArchitecture
import SwiftUI
@Reducer
struct SectionedListReducer {
@ObservableState
struct State: Equatable {
var sections: IdentifiedArrayOf<ListSectionReducer.State>
}
enum Action {
case sections(IdentifiedActionOf<ListSectionReducer>)
}
var body: some ReducerOf<Self> {
EmptyReducer()
.forEach(\.sections, action: \.sections) {
ListSectionReducer()
}
}
}
struct SectionedList: View {
let store: StoreOf<SectionedListReducer>
var body: some View {
List {
ForEach(store.scope(state: \.sections, action: \.sections)) { store in
ListSection(store: store)
.listRowInsets(.init())
.listRowSeparator(.hidden)
}
}
.listStyle(.plain)
.navigationTitle("Sectioned List")
}
}
#Preview {
SectionedList(
store: .init(
initialState: SectionedListReducer.State(sections: .template)
) {
SectionedListReducer()
}
)
}