Skip to content

Commit

Permalink
Bugfix FXIOS-7498 [v119] Crash when adding icon to sync now setting (m…
Browse files Browse the repository at this point in the history
…ozilla-mobile#17151)

* Bugfix FXIOS-7498 [v121] Crash when adding icon to sync now setting (mozilla-mobile#16644)

* addressed PR comments

---------

Co-authored-by: Stefan Vladut <[email protected]>
  • Loading branch information
petruSt24 and Stefan Vladut authored Nov 6, 2023
1 parent 47615a6 commit e76a521
Show file tree
Hide file tree
Showing 2 changed files with 14 additions and 5 deletions.
10 changes: 6 additions & 4 deletions Client/Frontend/Settings/Main/Account/SyncNowSetting.swift
Original file line number Diff line number Diff line change
Expand Up @@ -239,10 +239,12 @@ class SyncNowSetting: WithAccountSetting {
}

private func addAccessoryView(with image: UIImageView, to cell: UITableViewCell) {
accessoryViewContainer.addArrangedSubview(image)
accessoryViewContainer.addArrangedSubview(troubleshootButton)

cell.accessoryView = accessoryViewContainer
DispatchQueue.main.async { [weak self] in
guard let troubleshootButton = self?.troubleshootButton else { return }
self?.accessoryViewContainer.addArrangedSubview(image)
self?.accessoryViewContainer.addArrangedSubview(troubleshootButton )
cell.accessoryView = self?.accessoryViewContainer
}
}

override func onClick(_ navigationController: UINavigationController?) {
Expand Down
9 changes: 8 additions & 1 deletion Client/Frontend/Settings/SettingsTableViewController.swift
Original file line number Diff line number Diff line change
Expand Up @@ -830,12 +830,19 @@ class SettingsTableViewController: ThemedTableViewController {
if let setting = section[indexPath.row] {
let cell = dequeueCellFor(indexPath: indexPath, setting: setting)
setting.onConfigureCell(cell, theme: themeManager.currentTheme)
cell.applyTheme(theme: themeManager.currentTheme)
return cell
}
return super.tableView(tableView, cellForRowAt: indexPath)
}

override func tableView(_ tableView: UITableView, willDisplay cell: UITableViewCell, forRowAt indexPath: IndexPath) {
let section = settings[indexPath.section]
if let setting = section[indexPath.row], let themedCell = cell as? ThemedTableViewCell {
setting.onConfigureCell(themedCell, theme: themeManager.currentTheme)
themedCell.applyTheme(theme: themeManager.currentTheme)
}
}

private func dequeueCellFor(indexPath: IndexPath, setting: Setting) -> ThemedTableViewCell {
if setting.style == .subtitle {
guard let cell = tableView.dequeueReusableCell(withIdentifier: ThemedSubtitleTableViewCell.cellIdentifier, for: indexPath) as? ThemedSubtitleTableViewCell else {
Expand Down

0 comments on commit e76a521

Please sign in to comment.