๐Ÿ”ฐ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
        }
    }
}

Last updated