У меня есть приложение, извлекающее данные JSON и отображающее данные, но когда я пытаюсь сделать это в разделах, я получаю дубликаты на раздел и слишком много разделов.Цель состоит в том, чтобы каждое состояние было разделом, а каждый бонус для этого состояния указан ниже.Вот код, который у меня сейчас есть:
ViewController:
import UIKit
import os.log
class BonusListViewController: UITableViewController {
var bonuses = [JsonFile.JsonBonuses]()
override func viewDidLoad() {
super.viewDidLoad()
//MARK: Trigger JSON Download
downloadJSON {
}
}
// MARK: - Table View Configuration
// MARK: Table view data source
override func numberOfSections(in tableView: UITableView) -> Int {
print("Found \(bonuses.count) sections.")
return bonuses.count
}
override func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
print("Found \(bonuses[section].bonusCode.count) rows in section.")
return bonuses[section].bonusCode.count
}
override func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
let cell = UITableViewCell(style: .default, reuseIdentifier: nil)
cell.textLabel?.text = bonuses[indexPath.section].name.capitalized
return cell
}
override func tableView(_ tableView: UITableView, didSelectRowAt indexPath: IndexPath) {
performSegue(withIdentifier: "showDetail", sender: self)
}
// MARK: - Table View Header
override func tableView(_ tableView: UITableView, heightForHeaderInSection section: Int) -> CGFloat {
return 30
}
override func tableView(_ tableView: UITableView, titleForHeaderInSection section: Int) -> String? {
return bonuses[section].state
}
override func tableView(_ tableView: UITableView, heightForFooterInSection section: Int) -> CGFloat {
return 3
}
// MARK: Functions
// MARK: - Download JSON from ToH webserver
func downloadJSON(completed: @escaping () -> ()) {
let url = URL(string: "http://tourofhonor.com/BonusData.json")
URLSession.shared.dataTask(with: url!) { [weak self] (data, response, error) in
if error == nil {
do {
let posts = try JSONDecoder().decode(JsonFile.self, from: data!)
DispatchQueue.main.async {
completed()
}
print("JSON Version \(posts.meta.version) loaded.")
print(posts.bonuses.map {$0.bonusCode})
self?.bonuses = posts.bonuses
DispatchQueue.main.async {
//reload table in the main queue
self?.tableView.reloadData()
}
} catch {
print("JSON Download Failed")
}
}
}.resume()
}
// MARK: - Navigation
override func prepare(for segue: UIStoryboardSegue, sender: Any?) {
if let destination = segue.destination as? BonusDetailViewController {
destination.bonus = bonuses[(tableView.indexPathForSelectedRow?.row)!]
}
}
}
JsonFile.swift - это просто структура:
import Foundation
struct JsonFile: Codable {
struct Meta: Codable {
let fileName: String
let version: String
}
struct JsonBonuses: Codable {
let bonusCode: String
let category: String
let name: String
let value: Int
let city: String
let state: String
let flavor: String
let imageName: String
}
let meta: Meta
let bonuses: [JsonBonuses]
}
Файл JSON содержит два состояния иВсего 9 записей.Мои операторы печати показывают, что он нашел 9 разделов по 3 строки в каждом разделе.Когда я пытаюсь установить для return bonuses.count
что-то вроде return bonuses.state.count
, я получаю сообщение об ошибке «Значение типа» [JsonFile.JsonBonuses] 'не имеет члена «состояние». »Но в моей структуре явно есть пункт «состояние».