I have a dynamic table inside a view fetching data from Firebase. I need to transfer data from the label in the TableViewCell to a label in the View. Since this is happening on the same screen, the prepareForSegue method cannot be implemented. I am currently writing the database based on the value from the label in the tableViewCell and then fetching it in the label in the View. But there is a considerable lag and sometimes the values differ as well. Is there any way to do it locally? I have to files, one for the TableViewCell and one for the View itself.
P.S I am fairly new to Swift and iOS
This is what my Screen currently looks like And I wish to send data from point A to point B
This the PledgeViewController
import UIKit
import Foundation
import FirebaseDatabase
import Firebase
class PledgeViewController: UIViewController, UITableViewDataSource, UITableViewDelegate{
var getID: String!
var rewards = [Rewards]()
var ticket_count: Int = 0
var ref: DatabaseReference!
let userID = Auth.auth().currentUser!.uid
var rewardID: String!
var total_pledge: Int = 0
@IBOutlet weak var pledgeAmtLabel: UILabel!
@IBOutlet weak var RewardChooseTable: UITableView!
@IBAction func pledgeBtn(_ sender: Any) {
//get the text from the label and run all the checks to see if the tickets are available
//just sending user to the next screen for now
}
func tableView(_ tableView: UITableView, didSelectRowAt indexPath: IndexPath) {
let reward = rewards[indexPath.row]
let id = reward.rewardID
//reward.countUp()
print("The reward that was touched is: " + id )
print("One of the buttons were touched")
}
let RewardRef = Database.database().reference().child("Rewards")
func numberOfSections(in tableView: UITableView) -> Int {
return 1
}
func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
return rewards.count
}
func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
let cell = tableView.dequeueReusableCell(withIdentifier: "TakePledgeCell", for: indexPath) as! PledgeTableViewCell
let reward = rewards[indexPath.row]
cell.reward = reward
cell.currentID = getID
cell.plusBtnAction = { sender in
let reward = self.rewards[indexPath.row]
cell.reward = reward
let local_id = reward.rewardID
self.ref=Database.database().reference().child("Fund_Project_Request").child(self.getID).child(self.userID).child(local_id).child("Ticket_count")
self.ref.observeSingleEvent(of: .value, with: { (snapshot) in
// Get user value
if snapshot.value is NSNull{
self.ticket_count = 0
self.ticket_count += 1
self.ref.setValue(self.ticket_count)
Database.database().reference().child("Rewards").child(self.getID).child(local_id).child("reward_ticket_amount").observeSingleEvent(of: .value, with: { (snapshot) in
// Get user value
let reward_amt = snapshot.value as! Int
let current_value = Int(self.pledgeAmtLabel.text!)
print("current value in the label is:" + String(current_value!) )
print("new updated value is:" + String(reward_amt))
print("reward_amt is:", reward_amt)
self.pledgeAmtLabel.text = String(reward_amt + current_value!)
self.total_pledge = reward_amt + current_value!
}) { (error) in
print(error.localizedDescription)
}
}
else{
self.ticket_count = snapshot.value as! Int
self.ticket_count += 1
self.ref.setValue(self.ticket_count)
Database.database().reference().child("Rewards").child(self.getID).child(local_id).child("reward_ticket_amount").observeSingleEvent(of: .value, with: { (snapshot) in
// Get user value
let reward_amt = snapshot.value as! Int
let current_value = Int(self.pledgeAmtLabel.text!)
print("current value in the label is:" + String(current_value!) )
print("new updated value is:" + String(reward_amt))
print("reward_amt is:", reward_amt)
self.pledgeAmtLabel.text = String(reward_amt + current_value!)
self.total_pledge = reward_amt + current_value!
}) { (error) in
print(error.localizedDescription)
}
}
}) { (error) in
print(error.localizedDescription)
}
// Do whatever you want from your button here.
}
cell.minusBtnAction = { sender in
let reward = self.rewards[indexPath.row]
cell.reward = reward
let local_id = reward.rewardID
self.ref=Database.database().reference().child("Fund_Project_Request").child(self.getID).child(self.userID).child(local_id).child("Ticket_count")
self.ref.observeSingleEvent(of: .value, with: { (snapshot) in
// Get user value
if snapshot.value is NSNull{
}
else{
self.ticket_count = snapshot.value as! Int
if(self.ticket_count != 0)
{
self.ticket_count -= 1
self.ref.setValue(self.ticket_count)
Database.database().reference().child("Rewards").child(self.getID).child(local_id).child("reward_ticket_amount").observeSingleEvent(of: .value, with: { (snapshot) in
// Get user value
let reward_amt = snapshot.value as! Int
let current_value = Int(self.pledgeAmtLabel.text!)
print("current value in the label is:" + String(current_value!) )
print("new updated value is:" + String(reward_amt))
print("reward_amt is:", reward_amt)
self.pledgeAmtLabel.text = String( current_value! - reward_amt)
self.total_pledge = current_value! - reward_amt
}) { (error) in
print(error.localizedDescription)
}
}
}
}) { (error) in
print(error.localizedDescription)
}
}
return cell
}
override func prepare(for segue: UIStoryboardSegue, sender: Any?) {
let vc = segue.destination as! SummaryViewController // else {return}
vc.getID = getID
vc.pledgeAmt = total_pledge
}
override func viewDidAppear(_ animated: Bool) {
super.viewDidAppear(animated)
RewardRef.child(getID).observe(.value, with: { (snapshot) in
self.rewards.removeAll()
for child in snapshot.children {
let childSnapshot = child as! DataSnapshot
let reward = Rewards(snapshot: childSnapshot)
self.rewards.insert(reward, at: 0)
}
self.RewardChooseTable.reloadData()
})
}
override func viewDidLoad() {
super.viewDidLoad()
print("The id received from the SingleViewControl is:" + getID)
}
}
And this is the TableViewCell
import UIKit
import Firebase
import FirebaseDatabase
class PledgeTableViewCell: UITableViewCell {
var plusBtnAction: ((String) -> Void)?
var minusBtnAction: ((String) -> Void)?
@IBOutlet weak var rewardAmtLabel: UILabel!
@IBOutlet weak var ticketClasslabel: UILabel!
@IBOutlet weak var ticketDescLabel: UILabel!
@IBOutlet weak var ticketCountLabel: UILabel!
@IBOutlet weak var plusBtn: UIButton!
@IBOutlet weak var minusBtn: UIButton!
var ref: DatabaseReference!
var currentID = ""
var ticket_count: Int = 0
@IBAction func minusBtn(_ sender: Any) {
if var tickCount = Int(ticketCountLabel.text!) {
if(tickCount > 0)
{
tickCount -= 1
ticketCountLabel.text = String(tickCount)
self.minusBtnAction?(String(tickCount))
}
}
// self.minusBtnAction?(String(tickCount))
}
var reward: Rewards! {
didSet {
rewardAmtLabel.text = "Rs. " + String(reward.rewardAmt)
ticketClasslabel.text = reward.reward_class_name
ticketDescLabel.text = reward.reward_desc
print(reward.reward_class_name + " is one of the rewards")
}
}
@IBAction func plusBtn(_ sender: AnyObject) {
if var tickCount = Int(ticketCountLabel.text!) {
tickCount += 1
ticketCountLabel.text = String(tickCount)
print("The ticket counting before sending is:" + String(tickCount))
self.plusBtnAction?(String(tickCount))
}
}
}