Как исправить изменяющееся состояние UIButton при прокрутке в расширяемых и складываемых разделах табличного представления
У меня есть расширяемый и складной раздел в моей ячейке просмотра таблицы в течение нескольких дней недели. Когда вы нажимаете кнопку открытия, чтобы развернуть раздел, кнопка меняет состояние на закрытое, и вы можете щелкнуть по нему еще раз, чтобы свернуть. Однако, если вы открываете несколько разделов и начинаете прокручивать в табличном представлении, эти разделы закрываются и открываются, но состояние кнопки не изменяется обратно на закрытие после того, как все разделы вновь открылись после прокрутки.
Я проводил некоторые исследования, и похоже, что государство не спасается. Есть ли способ сохранить состояние этих кнопок с помощью dequeuereusableheaderfooterview() в viewForHeaderInSection? Или это должно быть сделано в функции cellForRowAt?
var barDeals: [ExpandableDealsStruct] = []
@IBOutlet weak var daysTable: UITableView!
override func viewDidLoad()
{
super.viewDidLoad()
daysTable.dataSource = self
daysTable.delegate = self
}
func tableView(_ tableView: UITableView, viewForHeaderInSection section: Int) -> UIView?
{
let view = UIView()
view.backgroundColor = .black
let headerLabel = UILabel()
let button = UIButton(type: .system)
let headerList = DaysService.instance.getHeader()
headerLabel.textColor = .white
headerLabel.font = UIFont.boldSystemFont(ofSize: 20)
headerLabel.text = headerList[section]
button.setTitle("Open", for: .normal)
button.setTitleColor(.white, for: .normal)
button.titleLabel?.font = UIFont.boldSystemFont(ofSize: 20)
button.addTarget(self, action: #selector(handleOpenClose), for: .touchUpInside)
button.tag = section
headerLabel.frame = CGRect(x: 5, y: 7.5, width: 150, height: 25)
button.frame = CGRect(x: 150, y: 7.5, width: 150, height: 25)
view.addSubview(headerLabel)
view.addSubview(button)
return view
}
@objc func handleOpenClose(button: UIButton)
{
let section = button.tag
self.daysTable.beginUpdates()
var indexPaths = [IndexPath]()
for deals in self.barDeals[section].deals.indices
{
let indexPath = IndexPath(row: deals, section: section)
indexPaths.append(indexPath)
}
let isExpanded = self.barDeals[section].isExpanded
self.barDeals[section].isExpanded = !isExpanded
button.setTitle(!isExpanded ? "Close" : "Open", for: .normal)
if isExpanded
{
daysTable.deleteRows(at: indexPaths, with: .fade)
}
else
{
daysTable.insertRows(at: indexPaths, with: .fade)
}
self.daysTable.endUpdates()
}
func tableView(_ tableView: UITableView, heightForFooterInSection section: Int) -> CGFloat
{
return 1
}
func tableView(_ tableView: UITableView, heightForHeaderInSection section: Int) -> CGFloat
{
return 40
}
func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int
{
if self.barDeals[section].isExpanded == false
{
return 0
}
return self.barDeals[section].deals.count
}
func numberOfSections(in tableView: UITableView) -> Int
{
return self.barDeals.count
}
func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell
{
let cell = tableView.dequeueReusableCell(withIdentifier: "DaysCell", for: indexPath)
let deals = self.barDeals[indexPath.section].deals[indexPath.row]
cell.textLabel?.text = deals
return cell
}
}