используя UISegmentedControl в представлении таблицы данных - PullRequest
0 голосов
/ 17 мая 2019

enter image description hereenter image description here «Я использую управление сегментами, и у меня есть два сегмента: один сегмент (Рецепты) и второй сегмент (Ресторан). Я должен нажать первымсегмент и данные показывают первый сегмент массива и второй сегмент щелкают по второму сегменту, а данные показывают вторичный ”

var dataArray = [FollowedData]()
var restdataArray = [RestaurantFollowed]()

   @IBAction func btnActionSegmnet(_ sender: UISegmentedControl) {
        switch (segmentSelect.selectedSegmentIndex) {
        case 0:
            dataArray.removeAll()
            ShowPostRecipesData()
            tableView.reloadData()
            break
        case 1:
            restdataArray.removeAll()
            ShowPostRestaurantsData()
            tableView.reloadData()
            break
        default:
            break
        }
    }
 func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {

    switch (segmentSelect.selectedSegmentIndex) {
    case 0:
     return dataArray.count

    case 1:
      return restdataArray.count

    default:
        return 0
    }
}


func tableView(_ tableView: UITableView, heightForRowAt indexPath: IndexPath) -> CGFloat {
    return 430
}

func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {

    let cell = tableView.dequeueReusableCell(withIdentifier: "FollowedCell")as! FollowedCell
  switch (segmentSelect.selectedSegmentIndex)
    case 0:

        cell.tittleLbl.text = dataArray[indexPath.row].postDetailsData.title
        cell.descriptionLbl.text = dataArray[indexPath.row].postDetailsData.descriptions
        let date =  getDateFromTime(timeStanp: dataArray[indexPath.row].mbersdata.created)

        cell.showDateLbl.text = date  +  "/ "  + dataArray[indexPath.row].postDetailsData.viewscount  +  "views "
        let urlString = "https://myfoodtalk.com:3001/storage/posts/\(dataArray[indexPath.row].postDetailsData.image1)"
        let escapedString1 = urlString.addingPercentEncoding(withAllowedCharacters: .urlQueryAllowed)
        print(escapedString1!)
        if let imgurls = URL(string: escapedString1!) {
            print(imgurls)
            cell.recipesImage.sd_setImage(with:imgurls, placeholderImage: UIImage(named:"placeholder"))
        }
        let urlStrings = "https://myfoodtalk.com:3001/storage/members/\(dataArray[indexPath.row].mbersdata.photo)"
        let escapedStrings = urlStrings.addingPercentEncoding(withAllowedCharacters: .urlQueryAllowed)
        print(escapedStrings!)
        if let imgurl = URL(string: escapedStrings!) {
            print(imgurl)
            cell.userImage.sd_setImage(with:imgurl, placeholderImage: UIImage(named:"placeholder"))
        }
        break
    case 1:
        cell.tittleLbl.text = restdataArray[indexPath.row].restaurantDetailsData.title
        cell.descriptionLbl.text = restdataArray[indexPath.row].restaurantDetailsData.descriptions
        let dates =  getDateFromTime(timeStanp: restdataArray[indexPath.row].created)

        cell.showDateLbl.text = dates  +  "/ "  + restdataArray[indexPath.row].restaurantDetailsData.viewscount  +  "views "
        let urls = "https://myfoodtalk.com:3001/storage/members/\(restdataArray[indexPath.row].mbersdata.photo)"
        let escapedString2 = urls.addingPercentEncoding(withAllowedCharacters: .urlQueryAllowed)
        print(escapedString2!)
        if let imgurls = URL(string: escapedString2!) {
            print(imgurls)
            cell.userImage.sd_setImage(with:imgurls, placeholderImage: UIImage(named:"placeholder"))
        }
        let url = "https://myfoodtalk.com:3001/storage/restaurants/\(restdataArray[indexPath.row].restaurantDetailsData.image1)"
        let escapedStrings3 = url.addingPercentEncoding(withAllowedCharacters: .urlQueryAllowed)
        print(escapedStrings3!)
        if let imgurl = URL(string: escapedStrings3!) {
            print(imgurl)
            cell.recipesImage.sd_setImage(with:imgurl, placeholderImage: UIImage(named:"placeholder"))
        }

        break
    default:
        break
    }

  return cell
}

func ShowPostRecipesData () {

    let accessToken = UserDefaults.standard.value(forKey: "access_token")as! String
    let userid = UserDefaults.standard.value(forKey: "userId")as! String
    var mainString = ""
    var url = ""

        mainString = """
        {"where":{"m_id":"\(userid)"},"include":[{"relation":"posts"},{"relation":"members"}]}
        """
        url = "follow-posts?filter=\(mainString)&access_token=\(accessToken)"


    let escapedString = url.addingPercentEncoding(withAllowedCharacters: .urlQueryAllowed)
    print(escapedString!)
    FTHelper.requestGETURLArray(escapedString!, isShowHud: true, headers: nil, success:
        { (response) in
            let dataArray = response
            if dataArray.isEmpty{
                _ = presentAlertWithOptions("", message: "You have no recipes data ", controller: self, buttons: ["OK"], tapBlock:
                    {
                        (UIAlertAction, position) in
                        if position == 0{

                        }
                })
            }else{

                let followObj  = FollowedData()
                self.dataArray = followObj.getfollowData(dataArray: dataArray)
                self.tableView.reloadData()

            }

    })
    { (error) in
        print(error)
    }

}



func ShowPostRestaurantsData(){

    let accessToken = UserDefaults.standard.value(forKey: "access_token")as! String
    let mid = UserDefaults.standard.value(forKey: "userId")as! String

    var mainString = ""
    var url = ""
    mainString = """
    {"where":{"m_id": "\(mid)"},"include":[{"relation":"restaurants"},{"relation":"members"}]}
    """
    url = "follow-restaurants?filter=\(mainString)&access_token=\(accessToken)"


    let escapedString = url.addingPercentEncoding(withAllowedCharacters: .urlQueryAllowed)
    print(escapedString!)
    FTHelper.requestGETURLArray(escapedString!, isShowHud: true, headers: nil, success:
        { (response) in
            let dataArray = response
            if dataArray.isEmpty{
                _ = presentAlertWithOptions("", message: "You have no recipes data ", controller: self, buttons: ["OK"], tapBlock:
                    {
                        (UIAlertAction, position) in
                        if position == 0{

                        }
                })
            }else{

                let followObj  = RestaurantFollowed()
                self.restdataArray = followObj.getfollowData(dataArray: dataArray)
                self.tableView.reloadData()

            }

    })
    { (error) in
        print(error)
    }

}

Я кликаю данные первого сегмента, показываю в табличном представлениино я нажимаю на второй сегмент, но данные не отображаются в табличном представлении, я не могу понять, что я могу сделать

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...