Search code examples
arraysswiftuipickerviewtextfield

picker not selecting values


Hey guys I made a custom picker view which let the user pick from 3 rows instead of keyBoard input. the problem is that the picker doesn't put the selected values into the textfield.

The picker does pop up and works fine. the 3 variables are: "hours" , "halve" and "type".

all help appreciated

var timePickerData = [["4","5","6","7","8","9","10","11","12","13","14","15","16"],["0","15","30","45"],["Hours","Bins"]]

// Setting up timePicker.
// The data to return for the row and component (column) that's being passed in

func numberOfComponents(in pickerView: UIPickerView) -> Int { return timePickerData.count
}

// The number of rows of data
func pickerView(_ pickerView: UIPickerView, numberOfRowsInComponent component: Int) -> Int {
    return timePickerData[component].count
}

// Get title for Row
func pickerView(_ pickerView: UIPickerView, titleForRow row: Int, forComponent component: Int) -> String? {
    return timePickerData[component][row]
}

// Capture the picker view selection
func pickerView(_pickerView: UIPickerView, didSelectRow row: Int, inComponent component: Int) {
    if row == 1 {
        hours = String(describing: timePickerData[component])
    }
    if row == 2 {
        halve = String(describing: timePickerData[component])
    }
    if row == 3 {
        type = String(describing: timePickerData[component])
    }

    calculateMoney()
}

func setTextfield() {
    timeFilledIn.text = hours + "." + halve + " " + type
}


func calculateMoney()
{
    let hoursStr = self.hours
    let hours = (hoursStr as NSString).doubleValue
    let halveStr = self.halve
    let halve = (halveStr as NSString).doubleValue
    let payHours = (payFilledIn.text! as NSString).doubleValue
    let totalMinutes = 60.00
    let tax = 0.85

    let payMinutes = ( payHours/totalMinutes )
    let calculatedHours = ( hours * payHours )
    let calculatedMinutes = (halve * payMinutes)
    let calculatedTotal = (calculatedHours + calculatedMinutes * tax)

    numberFormatter.numberStyle = .currency
    numberFormatter.locale = Locale(identifier: "es_CL")

    moneyMade.text = numberFormatter.string(from: NSNumber(value: calculatedTotal))
}

@objc func doneClick() {
    timeFilledIn.resignFirstResponder()
    calculateMoney()
    setTextfield()
}
@objc func cancelClick() {
    timeFilledIn.resignFirstResponder()
    timeFilledIn.text = "4" + "." + "0" + "    " + "Hours"
    calculateMoney()
}

// viewDidLoad
override func viewDidLoad()
{
    super.viewDidLoad()
    tappedAroundcustom()
    payFilledIn.delegate = self
    farmNameTxt.delegate = self
    timeFilledIn.delegate = self
    calculateMoney()
    timePickerData = [["4","5","6","7","8","9","10","11","12","13","14","15","16"],[ "0","15","30","45" ],["Hours","Bins"]]


    // set up toolbar for picker
    let toolBar = UIToolbar()
    toolBar.barStyle = UIBarStyle.default
    toolBar.isTranslucent = true
    toolBar.tintColor = UIColor.black
    toolBar.sizeToFit()
    let doneButton = UIBarButtonItem(title: "Done", style: UIBarButtonItemStyle.plain, target: self, action: #selector(doneClick))
    let spaceButton = UIBarButtonItem(barButtonSystemItem: .flexibleSpace, target: nil, action: nil)
    let cancelButton = UIBarButtonItem(title: "Cancel", style: UIBarButtonItemStyle.plain, target: self, action: #selector(cancelClick))
    let label = UILabel(frame: CGRect(x: 0, y: 0, width: self.view.frame.size.width / 3, height: self.view.frame.size.height))
    label.font = UIFont(name: "Gill Sans", size: 12)
    label.backgroundColor = UIColor.clear
    label.textColor = UIColor.black
    label.text = "Select work done today"
    label.textAlignment = NSTextAlignment.center
    let textBtn = UIBarButtonItem(customView: label)
    toolBar.setItems([cancelButton, spaceButton, textBtn , spaceButton , doneButton], animated: false)
    toolBar.isUserInteractionEnabled = true

    // set up picker
    let timePicker = UIPickerView()
    timePicker.delegate = self
    timePicker.dataSource = self
    timePicker.backgroundColor = UIColor.lightGray
    timePicker.tintColor = UIColor.black
    timeFilledIn.inputView = timePicker
    timeFilledIn.inputAccessoryView = toolBar

Solution

  • You should call the setTextfield method in didSelectRow like below,

    // Capture the picker view selection
        func pickerView(_pickerView: UIPickerView, didSelectRow row: Int, inComponent component: Int) {
            if row == 1 {
                hours = String(describing: timePickerData[component])
            }
            if row == 2 {
                halve = String(describing: timePickerData[component])
            }
            if row == 3 {
                type = String(describing: timePickerData[component])
            }
    
            calculateMoney()
            setTextfield()
        }