как передать данные из одного табличного представления в другое табличное представление при нажатии кнопки в ячейке? - PullRequest
3 голосов
/ 31 октября 2019

Я пытаюсь передать данные из ViewController в мой CartViewController. Ячейки в ViewController имеют 3 кнопки (optionBtns), которые имеют метки цены и веса над каждой из них.

То, что я пытаюсь сделать, это выбрать параметр optionBtn, передав данные над ним после нажатия кнопки ATC

кнопка ATC в ячейке передает данные изображения, имени, категории,и optionBtn данных в ячейки CartViewController (CartCell)

как я могу передавать выбранные данные в CartVC при нажатии ATC для представления выбранного имени элемента, изображения и категории в ячейке с выбранными данными optionBtn (Цена и вес)

Я также использую Cloud Firestore для публикации данных для заполнения ячеек VC

enter image description here

import UIKit
import SDWebImage
import Firebase

class Cell: UITableViewCell {

    weak var items: Items!    
    @IBOutlet weak var name: UILabel!
    @IBOutlet weak var category: UILabel!
    @IBOutlet weak var productImage: UIImageView!

    @IBOutlet weak var weightOne: UILabel!
    @IBOutlet weak var weightTwo: UILabel!
    @IBOutlet weak var weightThree: UILabel!

    @IBOutlet weak var priceOne: UILabel!
    @IBOutlet weak var priceTwo: UILabel!
    @IBOutlet weak var priceThree: UILabel!

    @IBOutlet weak var addToCart: RoundButton!

    @IBOutlet weak var optionBtn1: RoundButton!
    @IBOutlet weak var optionBtn2: RoundButton!
    @IBOutlet weak var optionBtn3: RoundButton!

    var addActionHandler: (() -> Void)?

    func configure(withItems items: Items) {
        name.text = items.name
        category.text = items.category
        image.sd_setImage(with: URL(string: items.image))
        priceOne.text = items.price1
        priceTwo.text = items.price2
        priceThree.text = items.price3
        weightOne.text = items.weight1
        weightTwo.text = items.weight2
        weightThree.text = items.weight3
        self.items = items
    }

    var lastSelectedButton = UIButton()
    @IBAction func cartTypeSelected(_ sender: RoundButton) {
        lastSelectedButton.isSelected = false; do {
            self.lastSelectedButton.backgroundColor = UIColor.blue
        lastSelectedButton = sender 
        sender.isSelected = true; do {
            self.lastSelectedButton.backgroundColor = UIColor.lightGreen
        }
    }
    @IBAction func atcBtn(_ sender: UIButton) {
        self.addActionHandler?()
    }   
}

import UIKit
import Firebase
import FirebaseFirestore

class ViewController: UITableViewController {

    @IBOutlet weak var cartButton: BarButtonItem!!
    @IBOutlet weak var tableView: UITableView!

    var itemSetup: [Items] = []

    override func viewDidLoad() {
        super.viewDidLoad()

        tableView.delegate = self

        fetchItems { (items) in
            self.itemSetup = items.sorted
            self.tableView.reloadData()
        }

    }
    func fetchItems(_ completion: @escaping ([Items]) -> Void) {
        let ref = Firestore.firestore().collection("items")
        ref.addSnapshotListener { (snapshot, error) in
            guard error == nil, let snapshot = snapshot, !snapshot.isEmpty else {
                return
            }
            completion(snapshot.documents.compactMap( {Items(dictionary: $0.data())} ))
        }
    }

    override func prepare(for segue: UIStoryboardSegue, sender: Any?) {
        let vc = segue.destination as? CartViewController {
            vc.items = self.itemSetup
        }
    }

    func numberOfSections(in tableView: UITableView) -> Int {
        return 1
    }
    func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {

        return itemSetup.count
    }

    func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
        guard let cell = tableView.dequeueReusableCell(withIdentifier: "Cell") as? Cell else { return UITableViewCell() }

        let item = itemSetup[indexPath.row]
        cell.configure(withItem: item)
        cell.addActionHandler = {
             Cart.currentCart.items.append(item)
        }
        return cell
    }

}

class CartViewController: UIViewController {

    var items: Items!
    @IBOutlet weak var cartTableView: UITableView!

     override func viewDidLoad() {
        super.viewDidLoad()

        // Do any additional setup after loading the view.
        cartTableView.dataSource = self
        cartTableView.delegate = self
    }

}

extension CartViewController: UITableViewDataSource, UITableViewDelegate {

    func numberOfSections(in tableView: UITableView) -> Int {
        return 1
    }

    func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
        return Cart.currentCart.cartItems.count
    }

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

        let cart = Tray.currentCart.cartItems[indexPath.row]
        cell.configure(withItems: cart)

        return cell
    }
}

class CartCell: UITableViewCell {

    var selctedBtn: Cell?

    @IBOutlet weak var lblMealName: UILabel!
    @IBOutlet weak var imageUrl: UIImageView!
    @IBOutlet weak var lblSubTotal: UILabel!
    @IBOutlet weak var lblWeight: UILabel!

    override func awakeFromNib() {
        super.awakeFromNib()
        // Initialization code
    }

    func configure(withItems items: Items) {
        // lblWeight.text = "\(items.weight1)"
        lblMealName.text = "\(items.category): \(items.name)"
        let formatter = NumberFormatter()
        formatter.maximumFractionDigits = 2
        formatter.numberStyle = .decimal
        // lblSubTotal.text = "$\(formatter.string(for: items.price1)!)"
        imageUrl.sd_setImage(with: URL(string: items.imageUrl))

        if selctedBtn?.optionBtn1.isSelected == true {
            lblSubTotal.text = "$\(formatter.string(for: items.price1)!)"
            lblWeight.text = "\(items.weight1)"            

        } else if selctedBtn?.optionBtn2.isSelected == true {
            lblSubTotal.text = "$\(formatter.string(for: items.price2)!)"
            lblWeight.text = "\(items.weight2)"

        } else if selctedBtn?.optionBtn3.isSelected == true {
            lblSubTotal.text = "$\(formatter.string(for: items.price3)!)"
            lblWeight.text = "\(items.weight3)"

        }
    }  
}

import Foundation


class Cart {
    static let currentCart = Cart()
    var cartItems = [Items]()
}

ОБНОВЛЕНИЕ

Я только что обновил свой код, чтобы он теперь передавал данные из ВК в CartVC, но как бы ябыть в состоянии заставить его передавать данные для выбранной опцииBtn (вес и цена) для передачи этих выбранных данных в корзину VC

UPDATE 2:

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

код, который я добавил, был кодом CartCell, и я удалил много бесполезного кода в VC, CartVC и Cell

Ответы [ 2 ]

3 голосов
/ 07 ноября 2019

Если идея заключается в том, чтобы firebase обрабатывал все ваши данные, тогда данные должны проходить через firebase, а не через viewController. т. е. ваша база данных Firebase должна иметь коллекцию items (или, возможно, один на store), а ваша user должна иметь коллекцию cart. Когда пользователь нажимает на кнопку «Добавить в корзину», вы добавляете нужный элемент в коллекцию корзины этого пользователя в firebase, а затем показывает cartViewController. CartViewController должен подписаться на коллекцию cart для текущего пользователя, а затем заполнить ее табличное представление из этой коллекции Firebase.

TLDR Типичный дизайн приложения Firebase заключается в том, что база данных Firebase является источником правды дляприложение, поэтому вы должны записать все изменения в Firebase, а затем просто наблюдать эти коллекции в другом месте в приложении. Это также гарантирует, что если пользователь редактирует корзину на другом устройстве, он обновится на устройстве iOS с новыми элементами корзины.

0 голосов
/ 01 ноября 2019

Вы можете создать класс, подобный CartData, и иметь все свойства, необходимые для передачи их в CartViewController. В вашем случае это будут изображение, имя, категория, цена и вес.

В методе sendData создайте этот экземпляр CartData из параметров, передаваемых в метод, и назначьте его локальной переменной * 1006. * например. Затем используйте метод executeSegueWithIdentifier для перехода к CardViewController.

Конечно, не забудьте назначить переменную cartDataToSend для CartViewController в переопределенном методе prepare(for segue:).

Вот как вы можете передавать данные в новый контроллер представления.

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