Как отключить NSTextField и сделать его недоступным для редактирования? [isEditable свойство не работает] - PullRequest
3 голосов
/ 16 июня 2019

Я получаю ввод промо-кода в NSTextField и при нажатии кнопки применить промо-код применяется.

На этом этапе мое текстовое поле должно быть недоступно для редактирования, пока не будет нажата кнопка удаления промо-кода.при нажатии кнопки удаления промо-кода текстовое поле становится редактируемым.Это работает так же, как коды купонов Zomato применяются и удаляются.

Я пытался isEditable = false, но это не работает

@IBOutlet weak var promoCodeValidity: NSTextField!
@IBOutlet weak var promoCode: NSTextField!

func applyCoupon(){
    let couponCode = promoCode.stringValue
    if let offer = bookingView!.applyOffer(offerCode:couponCode){
        promoCodeValidity.stringValue="Offer Applied "+String(offer)+"% Off"
        promoCode.isEditable=false
    }
    else{
        promoCodeValidity.stringValue="Offer Code Invalid"

    }
}

, почему isEditable не работает

Ответы [ 2 ]

1 голос
/ 17 июня 2019

Попробуйте переключить свойство isEnabled текстового поля, а затем измените свойство isEnabled текстового поля. т.е. сначала отключите текстовое поле, затем измените редактируемое свойство текстового поля, а затем снова включите текстовое поле. Надеюсь, это решит вашу проблему.Я также приложил небольшой пример кода:)

class ViewController: NSViewController {
    let textField = NSTextField()
    let button = NSButton()
    override func viewDidLoad() {
        textField.translatesAutoresizingMaskIntoConstraints=false
        textField.placeholderString = "ENTER PROMO CODE"
        button.translatesAutoresizingMaskIntoConstraints=false
        super.viewDidLoad()
        textField.isEditable = true
        button.action = #selector(buttonClicked(_:))
        view.addSubview(textField)
        view.addSubview(button)
        NSLayoutConstraint(item: textField, attribute: .centerY, relatedBy: .equal, toItem: view, attribute: .centerY, multiplier: 1.0, constant: 0).isActive = true
        NSLayoutConstraint(item: textField, attribute: .centerX, relatedBy: .equal, toItem: view, attribute: .centerX, multiplier: 1.0, constant: 0).isActive = true
        NSLayoutConstraint(item: textField, attribute: .width, relatedBy: .equal, toItem: nil , attribute: .notAnAttribute, multiplier: 1.0, constant: 100).isActive = true
        NSLayoutConstraint(item: button, attribute: .centerY, relatedBy: .equal, toItem: view, attribute: .centerY, multiplier: 1.0, constant: 0).isActive  = true
        NSLayoutConstraint(item: button, attribute: .leading, relatedBy: .equal, toItem: textField, attribute: .trailing, multiplier: 1.0, constant: 20).isActive = true
        NSLayoutConstraint(item: button, attribute: .width, relatedBy: .equal, toItem: nil , attribute: .notAnAttribute, multiplier: 1.0, constant: 50).isActive = true
        // Do any additional setup after loading the view.
    }

    override var representedObject: Any? {
        didSet {
        // Update the view, if already loaded.
        }
    }
    @objc func buttonClicked(_ sender: Any) {
        textField.isEnabled = false
        textField.isEditable = false
        textField.isEnabled = true
    }


}
0 голосов
/ 17 июня 2019
add extention:
extension UITextField

{
    open override func canPerformAction(_ action: Selector, withSender sender: Any?) -> Bool {
        if action == #selector(UIResponderStandardEditActions.paste(_:)) || action == #selector(UIResponderStandardEditActions.cut(_:)) || action == #selector(UIResponderStandardEditActions.copy(_:)) || action == #selector(UIResponderStandardEditActions.select(_:)) || action == #selector(UIResponderStandardEditActions.selectAll(_:))  {
            return false
        }
        return false
}
}

and:
textFiled.isEditable = false 
...