Basically I have a tableview with a custom header for different sections. In the custom cell what I use for the headers I have a button. When that button is clicked I want to add a row under the section for which the button was clicked in. Any suggestions for how I can go about doing this?
Consider the following code:
import UIKit
class ViewController: UITableViewController {
let cellId = "cellId"
var twoDimensionalArray = [
["Amy", "Bill", "Max", "Jack", "Jill", "Mary"],
["Amy", "aa", "Steve", "bb", "Jill", "Mary"]
]
override func viewDidLoad() {
super.viewDidLoad()
tableView.register(UITableViewCell.self, forCellReuseIdentifier: cellId)
}
@objc func handleAddButtonDidTap(button: UIButton) {
let section = button.tag
twoDimensionalArray[section].insert("New Content", at: 0)
let indexPath = IndexPath(row: 0, section: section)
//take care of reloading your tableView
tableView.beginUpdates()
tableView.insertRows(at: [indexPath], with: .automatic)
tableView.endUpdates()
}
//could be refactored into an own UITableViewFooterHeaderView class
override func tableView(_ tableView: UITableView, viewForHeaderInSection section: Int) -> UIView? {
let button = UIButton(type: .system)
button.setTitle("Add new cell", for: .normal)
button.setTitleColor(.black, for: .normal)
button.backgroundColor = .gray
button.titleLabel?.font = UIFont.boldSystemFont(ofSize: 14)
button.addTarget(self, action: #selector(handleAddButtonDidTap), for: .touchUpInside)
button.tag = section //with the help of button.tag we keep track of which section header was clicked.
return button
}
override func tableView(_ tableView: UITableView, heightForHeaderInSection section: Int) -> CGFloat {
return 36
}
override func numberOfSections(in tableView: UITableView) -> Int {
return twoDimensionalArray.count
}
override func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
return twoDimensionalArray[section].count
}
override func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
let cell = tableView.dequeueReusableCell(withIdentifier: cellId, for: indexPath)
let name = twoDimensionalArray[indexPath.section][indexPath.row]
cell.textLabel?.text = name
return cell
}
}