-
Notifications
You must be signed in to change notification settings - Fork 101
Expand file tree
/
Copy pathContentModeExample.swift
More file actions
76 lines (67 loc) · 2.02 KB
/
ContentModeExample.swift
File metadata and controls
76 lines (67 loc) · 2.02 KB
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
//
// ContentModeExample.swift
// Grid_Example
//
// Created by Denis Obukhov on 28.05.2020.
// Copyright © 2020 Exyte. All rights reserved.
//
import SwiftUI
import ExyteGrid
struct ContentModeExample: View {
private struct Model: Hashable {
let text: String
let span: GridSpan
let color = GridColor.random.lighter(by: 50)
}
@State var contentMode: GridContentMode = .contentFit
var body: some View {
VStack {
self.modesPicker
if self.contentMode == .contentFit {
ScrollView {
myView
}
} else {
myView
}
}
}
var myView: some View {
Grid(models, id: \.self, tracks: 3) {
VCardView(text: $0.text, color: $0.color)
.gridSpan($0.span)
}
.gridContentMode(self.contentMode)
.gridFlow(.rows)
.background(Color.blue)
}
private let models: [Model] = [
Model(text: placeholderText(length: 30), span: [1, 1]),
Model(text: placeholderText(length: 50), span: [1, 1]),
Model(text: placeholderText(length: 20), span: [1, 1]),
Model(text: placeholderText(length: 100), span: [2, 1]),
Model(text: placeholderText(length: 150), span: [1, 1]),
Model(text: placeholderText(length: 75), span: [1, 1]),
Model(text: placeholderText(length: 155), span: [1, 1]),
Model(text: placeholderText(length: 150), span: [1, 2]),
Model(text: placeholderText(length: 160), span: [2, 1]),
Model(text: placeholderText(length: 300), span: [3, 1])
]
private var modesPicker: some View {
Picker("Mode", selection: $contentMode) {
ForEach([GridContentMode.contentFit, GridContentMode.scroll, GridContentMode.fill], id: \.self) {
switch($0) {
case .contentFit: Text("ContentFit").tag($0)
case .scroll: Text("Scroll").tag($0)
case .fill: Text("Fill").tag($0)
}
}
}
.pickerStyle(SegmentedPickerStyle())
}
}
struct ContentModeExample_Previews: PreviewProvider {
static var previews: some View {
ContentModeExample()
}
}