Отправить данные из TableView в DetailView Swift, даже если они не включены в UITableList - PullRequest
0 голосов
/ 26 октября 2018

Всякий раз, когда пользователь вводит имя в строке поиска и если это имя присутствует в моем JSON и отображается в UITableView, я могу щелкнуть это имя, и строка будет передана в мой другой контроллер представления.Но теперь я также хочу сохранить и передать искомое имя, даже если оно отсутствует в моем JSON.Таким образом, пользователь может искать любое имя «лекарства», которое он хочет, и если это имя отсутствует в моем списке JSON, оно все равно сохраняется и передается моему другому контроллеру представления.

Вот код моегоtableView:

import UIKit
import SwiftyJSON

class rxListTableViewController: UITableViewController {
    let searchController = UISearchController(searchResultsController: nil)
    let rxlist = try! JSON(data: NSData(contentsOfFile: Bundle.main.path(forResource: "rxList01", ofType: "json")!)! as Data)
    var filteredRxList = [JSON]()

    override func viewDidLoad() {
        self.tableView.backgroundColor = UIColor.lightGray
        super.viewDidLoad()
        searchController.searchResultsUpdater = self
        searchController.dimsBackgroundDuringPresentation = false
        definesPresentationContext = true
        tableView.tableHeaderView = searchController.searchBar
        tableView.setContentOffset(CGPoint(x: 0, y: searchController.searchBar.frame.size.height), animated: false)
    }

    override func viewWillAppear(_ animated: Bool) {
        super.viewWillAppear(animated)
        navigationItem.hidesSearchBarWhenScrolling = false
    }

    override func viewDidAppear(_ animated: Bool) {
        super.viewDidAppear(animated)
        searchController.isActive = true
        navigationItem.hidesSearchBarWhenScrolling = true
    }

    override func tableView(_ tableView: UITableView, willDisplay cell: UITableViewCell, forRowAt indexPath: IndexPath) {
        cell.backgroundColor = UIColor.clear
    }

    // MARK: - Table view data source
    override func numberOfSections(in tableView: UITableView) -> Int {
        return 1
    }

    override func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
        if isFiltering(){
            return filteredRxList.count
        }
        return rxlist.count
    }

    override func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
        let cell = tableView.dequeueReusableCell(withIdentifier: "rxCell", for: indexPath)

        var data: JSON

        if searchController.isActive && searchController.searchBar.text != "" {
            data = filteredRxList[indexPath.row]
            let countryName = data["term"].stringValue

            cell.textLabel?.text = countryName
        }else{
            data = rxlist[indexPath.row]
            tableView.reloadData()
        }

        return cell
    }

    func filteredContentForSearchText(searchText: String){
        filteredRxList = rxlist.array!.filter { country in
            return country["term"].stringValue.localizedLowercase.contains(searchText.localizedLowercase)
        }
        tableView.reloadData()
    }

    func searchBarIsEmpty() -> Bool{
        return searchController.searchBar.text?.isEmpty ?? true
    }

    func isFiltering() -> Bool{
        return searchController.isActive && !searchBarIsEmpty()
    }

    override func prepare(for segue: UIStoryboardSegue, sender: Any?) {
        if segue.identifier == "moreinfo"{
            if let indexPath = tableView.indexPathForSelectedRow{
                let data: JSON
                if isFiltering(){
                    data = filteredRxList[indexPath.row]
                }else{
                    data = rxlist[indexPath.row]
                }
                let controller = segue.destination as? medDetailsViewController
                let final = data["term"].stringValue
                controller?.name = final
                controller?.navigationItem.leftBarButtonItem = splitViewController?.displayModeButtonItem
                controller?.navigationItem.leftItemsSupplementBackButton = true
            }
        }
    } 
}

extension rxListPetsTablViewController: UISearchResultsUpdating{
    func updateSearchResults(for searchController: UISearchController) {
        filteredContentForSearchText(searchText: searchController.searchBar.text!)
    }
}

А вот мой код для viewController:

import UIKit

class medDetailsViewController: UIViewController {
    @IBOutlet weak var lbl: UILabel!
    var name = ""

    override func viewDidLoad() {
        super.viewDidLoad()
        lbl.text = "\(name) "
    }

Есть ли способ реализовать этот запрос?

1 Ответ

0 голосов
/ 27 октября 2018

В вашем следующем контроллере представления создайте необязательную переменную String и передайте значение «searchController.searchBar.text!».Например, в вашем методе подготовки добавьте следующий код:

let controller = segue.destination as? medDetailsViewController
controller.searchText = searchController.searchBar.text!
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...