Skip to content
This repository has been archived by the owner on Sep 21, 2021. It is now read-only.
/ NxEnabled Public archive

Library that allows you binding `enabled` property of button with textable elements (TextView, TextField)

License

Notifications You must be signed in to change notification settings

Otbivnoe/NxEnabled

Repository files navigation

NxEnabled

Build Status Carthage compatible CocoaPods compatible Swift 3.0.x platforms

What is NxEnabled?

It's a fairly common case, when the enabled state of button depends on some textable elements such as TextView, TextField. So this library allows the simplest way to achive this purpose with only few lines of code.

Getting started 🚀

Typical login screen with short, beautiful validation code:

loginButton.isEnabled(by: usernameTextField, passwordTextField) { username, password in
    username.characters.count > 5 && password.characters.count > 5
}

you can also combine together UITextView with UITextField's:

signUpButton.isEnabled(by: firstnameTextField, lastnameTextField, bioTextView) { firstname, lastname, bio in
    return /* validation value */
}

So there is also oportunity to add not UI element:

  • Implement Textable protocol

  • Be a successor from NSObject

  • Not forget about dynamic label for property

  • Done.

class Object: NSObject, Textable {
    dynamic var value: String?
    var textKey: String {
        return "value"
    }
}

NOTE:

One important case is that you should clear button's bag. It removes all observers from textable elements. Usually it needs to do in deinit method.

deinit {
    signUpButton.clearBag()
}

Now library allows to add textable elements up to six. 👏

Installation 🔥

CocoaPods

To integrate NxEnabled, simply add the following line to your Podfile:

pod "NxEnabled"

Carthage

To integrate NxEnabled into your Xcode project using Carthage, specify it in your Cartfile:

github "Otbivnoe/NxEnabled"

Run carthage update to build the framework and drag the built NxEnabled.framework into your Xcode project.

Author 💪

Nikita Ermolenko, gnod94@gmail.com

License ❗

NxEnabled is available under the MIT license. See the LICENSE file for more info.

About

Library that allows you binding `enabled` property of button with textable elements (TextView, TextField)

Topics

Resources

License

Stars

Watchers

Forks

Packages

No packages published