๐ฐSwipe Actions
๐ง ๆฝๅทฅไธญ
// Some code
struct AccountView: View {
// view states
@State var isDeleted = false
// view body
var body: some View {
NavigationView { // navigation view
List { // list
Section {
// conditional view โญ๏ธ
if !isDeleted {
Link(destination: URL(string: "https://apple.com")!) {
HStack {
Label("Apple", systemImage: "house")
Spacer()
Image(systemName: "link").tint(.secondary)
}
}
.swipeActions { // swipe actions โญ๏ธ
// first action (default action?)
Button {
isDeleted = true
} label: {
// โญ๏ธ ้็ถ็จ `Label`๏ผไฝๅชๆ้กฏ็คบๅ็คบใ
Label("Delete", systemImage: "trash")
}.tint(.red) // override button color โญ๏ธ
// second action
Button {} label: {
Label("Pin", systemImage: "pin")
}.tint(.yellow)
}
}
// Link
Link(destination: URL(string: "https://youtube.com")!) {
HStack {
Label { Text("YouTube") } icon: {
Image(systemName: "tv")
.foregroundColor(.red)
}
Spacer()
Image(systemName: "link").tint(.secondary)
}
}
}
}
.listStyle(.insetGrouped) // list style
.navigationTitle("Account") // navigation title
}
}
}
Design+Code - States and Swipe Actions
Hacking with Swift - How to add custom swipe action buttons to a List row
Use Your Loaf - SwiftUI Swipe Actions
Last updated