Search code examples
swiftbuttonuialertcontroller

Add checkmark boxes to UIAlertController


I want my code to add a UIAlertController with the ability to add checkmark boxes. Ideally what I am looking for is how to add a yes and no checkmark box on the alert and have it displayed on the tableview cell. I added a photo of what I am specifically looking for. Right now my code just displays the image on the left and adds the name to the tableview cell.

import UIKit
import CoreData

var singers = [Singer]()

class SingerVC: UIViewController {
    let tableView = UITableView()
    let navigationBar = UINavigationBar()
    
    override func viewDidLoad() {
        super.viewDidLoad()
        setupUI()
        singers = DataManager.shared.singers()
    }
    
    func setupUI() {
        title = "Singers"
        
        tableView.register(UITableViewCell.self, forCellReuseIdentifier: "singerCell")
        tableView.dataSource = self
        tableView.delegate = self
        tableView.translatesAutoresizingMaskIntoConstraints = false
        view.addSubview(tableView)
        
        NSLayoutConstraint.activate([
            tableView.topAnchor.constraint(equalTo: view.topAnchor),
            tableView.leftAnchor.constraint(equalTo: view.leftAnchor),
            tableView.bottomAnchor.constraint(equalTo: view.bottomAnchor),
            tableView.rightAnchor.constraint(equalTo: view.rightAnchor)
        ])
        
        navigationBar.translatesAutoresizingMaskIntoConstraints = false
        tableView.addSubview(navigationBar)
        navigationItem.rightBarButtonItem = UIBarButtonItem(barButtonSystemItem: .add, target: self, action: #selector(addSinger))
    }
    
    @objc func addSinger(_ sender: UIBarButtonItem) {
        var textfield = UITextField()
        
        let alert = UIAlertController(title: "Enter new singer", message: "", preferredStyle: .alert)
        let createAction = UIAlertAction(title: "Create", style: .default) { (action) in
            let singer = DataManager.shared.singer(name: textfield.text ?? "")
            singers.append(singer)
            DataManager.shared.save()
            self.tableView.reloadData()
        }
        
        alert.addTextField { (alertTextField) in
            alertTextField.placeholder = "Ex: Beyonce"
            textfield = alertTextField
        }
        
        let cancelAction = UIAlertAction(title: "Cancel", style: .destructive) { (action) in
            self.dismiss(animated: true, completion: nil)
        }
        
        alert.addAction(createAction)
        alert.addAction(cancelAction)
        present(alert, animated: true, completion: nil)
    }
}

// MARK: - UITableView extensions
extension SingerVC: UITableViewDelegate, UITableViewDataSource {
    
    func numberOfSections(in tableView: UITableView) -> Int {
        1
    }
    
    func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
        return singers.count
    }
    
    func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
        let singer = singers[indexPath.row]
        let cell = tableView.dequeueReusableCell(withIdentifier: "singerCell", for: indexPath) as UITableViewCell
        cell.textLabel?.text = singer.name
        cell.accessoryType = .disclosureIndicator
        tableView.deselectRow(at: indexPath, animated: true)
        return cell
    }
    
 
    
    private func editSingerAction(indexPath: IndexPath) {
        let singer = singers[indexPath.row]
        var nameTextField = UITextField()

        let alert = UIAlertController(title: "Edit singer", message: "", preferredStyle: .alert)
        let editAction = UIAlertAction(title: "Edit", style: .default) { (action) in
            singer.setValue(nameTextField.text ?? "", forKey: "name")
            DataManager.shared.save()
            self.tableView.reloadData()
        }
        
        alert.addTextField { (alertTextField) in
            alertTextField.placeholder = "Ex: Beyonce"
            alertTextField.text = singer.name
            nameTextField = alertTextField
        }

        let cancelAction = UIAlertAction(title: "Cancel", style: .destructive) { (action) in
            self.dismiss(animated: true, completion: nil)
        }
        
        alert.addAction(editAction)
        alert.addAction(cancelAction)
        present(alert, animated: true, completion: nil)
    }
    
    private func deleteSingerAction(indexPath: IndexPath) {
        let singer = singers[indexPath.row]
        let areYouSureAlert = UIAlertController(title: "Are you sure you want to delete this singer?", message: "", preferredStyle: .alert)
        let yesDeleteAction = UIAlertAction(title: "Yes", style: .destructive) { [self] (action) in
            DataManager.shared.deleteSinger(singer: singer)
            singers.remove(at: indexPath.row)
            tableView.deleteRows(at: [indexPath], with: .fade)
            tableView.reloadData()
        }
        let noDeleteAction = UIAlertAction(title: "No", style: .default) { (action) in
            //do nothing
        }
        areYouSureAlert.addAction(noDeleteAction)
        areYouSureAlert.addAction(yesDeleteAction)
        self.present(areYouSureAlert, animated: true, completion: nil)
    }
}

enter image description here


Solution

  • for this type of requirement create own custom