Как искать данные из модели в Swift? - PullRequest
0 голосов
/ 02 апреля 2019

Я хочу найти некоторые данные в табличном представлении с помощью панели поиска, но когда я пытаюсь найти данные в моей модели, я не могу найти эти данные.
Я создал ячейку развернутого табличного представления и создал панель поиска для поиска данных, но я все еще не могу искать данные в модели. Как мне этого добиться?

вот мой код:

import UIKit

class FAQViewController: UIViewController, UITableViewDataSource {

    var dataFaq = [modelFAQ]()

    let items = [
        modelFAQ(name: "1. search box", description: "The design led users to instinctively search for their question first before clicking the FAQs"),
        modelFAQ(name: "2.list of FAQs ", description: "Customers clicked around on the FAQs first."),
        modelFAQ(name: "3. customers", description: "top issues first and then use the search for the questions instead of browsing and yielding more relevant results")

        ]

    @IBOutlet fileprivate weak var tableView: UITableView!
    @IBOutlet weak var searchDataBar: UISearchBar!
    fileprivate var indexPaths: Set<IndexPath> = []
    var cellIdentifier = "dataSourceFAQ"

    var searchData = [String]()
    var searching = false

    override var preferredStatusBarStyle: UIStatusBarStyle{
        return .lightContent
    }

    override func viewDidLoad() {
        super.viewDidLoad()
        setupTableView()
        searchDataBar.delegate = self
    }

    func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {

        if searching {
            return searchData.count
        }else {
            return items.count
        }
    }

    func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
        let cell = tableView.dequeueReusableCell(withIdentifier: cellIdentifier, for: indexPath) as! FAQTableViewCell

        if searching{
            cell.titleLabel.text = searchData[indexPath.row]
        }else{
            cell.titleLabel.text = items[indexPath.row].name
        }

        let nameDetail = self[indexPath].name as? String
        let description = self[indexPath].description


        cell.update(name: nameDetail ?? "0", description: description)


        cell.state = cellIsExpanded(at: indexPath) ? .expanded : .collapsed
        return cell
    }

    override func viewWillAppear(_ animated: Bool) {
        tabBarController?.tabBar.isHidden = true
    }

    private func setupTableView(){
        tableView.delegate = self
        tableView.dataSource = self
        tableView.rowHeight = UITableView.automaticDimension
        tableView.estimatedRowHeight = 200.0
        tableView.separatorStyle = .none
         }

     }

    extension FAQViewController: UITableViewDelegate{
        func tableView(_ tableView: UITableView, didSelectRowAt indexPath: IndexPath) {
            let cell = tableView.cellForRow(at: indexPath) as!FAQTableViewCell


            cell.state = .expanded
            self.addExpandedIndexPath(indexPath)

            tableView.beginUpdates()
            tableView.endUpdates()
            print("1")
        }

    func tableView(_ tableView: UITableView, didDeselectRowAt indexPath: IndexPath) {
        let cell = tableView.cellForRow(at: indexPath) as! FAQTableViewCell

        cell.state = .collapsed
        self.removeExpandedIndexPath(indexPath)


        tableView.beginUpdates()
        tableView.endUpdates()
        print("2")
}
}

extension FAQViewController {
    func cellIsExpanded(at indexPath: IndexPath) -> Bool {
        return indexPaths.contains(indexPath)
    }

    func addExpandedIndexPath(_ indexPath: IndexPath) {
        indexPaths.insert(indexPath)
    }

    func removeExpandedIndexPath(_ indexPath: IndexPath) {
        indexPaths.remove(indexPath)
    }
}

extension FAQViewController {
    subscript(indexPath: IndexPath) -> modelFAQ {
        return items[indexPath.row]
    }
}


    extension FAQViewController: UISearchBarDelegate {

        func searchBar(_ searchBar: UISearchBar, textDidChange searchText: String) {

            searchData = searchText.isEmpty ? items: items.filter{ $0.name(searchText)}

            searching = true
            tableView.reloadData()
        }
       }

вот моя ячейка просмотра таблицы

    import UIKit

    class FAQTableViewCell: UITableViewCell {

        enum cellState{
            case collapsed
            case expanded

            var carretImage: UIImage {
                switch self {
                case .collapsed:
                    return UIImage(named: "ic_arrow_down")!
                case .expanded:
                    return UIImage(named: "ic_arrow_up")!
                }
            }

        }

        @IBOutlet private weak var stackView: UIStackView!
        @IBOutlet private weak var containerView: UIView!
        @IBOutlet weak var titleLabel: UILabel!
        @IBOutlet private weak var carret: UIImageView!
        @IBOutlet private weak var descriptionLabel: UILabel!


        private let expandedViewIndex: Int = 1

        var state: cellState = .expanded {
            didSet{
                toggle()
            }
        }

        override func awakeFromNib() {
            selectionStyle = .none
            containerView.layer.cornerRadius = 5.0
        }

        private func toggle(){
            stackView.arrangedSubviews[expandedViewIndex].isHidden = stateIsCollapsed()
            carret.image = state.carretImage
        }

        private func stateIsCollapsed() -> Bool{
            return state == .collapsed
        }

        func update(name: String, description: String){
            titleLabel.text = name
            descriptionLabel.text = description

        }
    }

вот моя модель

    struct modelFAQ {
        var name: String
        var description: String
    }

Ответы [ 2 ]

0 голосов
/ 02 апреля 2019

ПРИМЕЧАНИЕ. Всегда начинайте имя класса / структуры с ЗАГЛАВНОЙ БУКВЫ

  • Неправильно: modelFAQ

  • правильно: ModelFAQ

Вы допустили одну ошибку, вам нужно объявить массив searchData, как показано ниже

var searchData = [ModelFAQ]()

, а в методе источника данных вы должныполучите имя от объекта ModelFAQ и назначьте его на ярлык.

Надеюсь, это поможет вам.

0 голосов
/ 02 апреля 2019

Две проблемы:

  1. Вы должны объявить searchData в качестве того же типа, что и основные данные.

    Кстати, в соответствии со структурой соглашения об именах иимена классов начинаются с заглавной буквы

    var searchData = [ModelFAQ]()
    
  2. Поиск filter закрытие неверно.Напишите

    searchData = searchText.isEmpty ? items : items.filter{ $0.name.contains(searchText)}
    

    или если вы хотите искать без учета регистра

    searchData = searchText.isEmpty ? items : items.filter{ $0.name.range(of: searchText, options: .caseInsensitive) != nil }
    

И вам нужно изменить cellForRowAt

cell.titleLabel.text = searchData[indexPath.row].name
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...