Skip to content
✔️ A text and input validation library in Kotlin for Android
Branch: master
Clone or download
Latest commit 19e1cc6 Feb 13, 2019
Type Name Latest commit message Commit time
Failed to load latest commit information.
buildSrc uploaded v0.0.1 on bintray and fixed #5 May 14, 2018
easyvalidation-core annotation support and equal minimum sdk Nov 1, 2018
easyvalidation-toasts Added extension for all view to show toast mesaage Nov 20, 2018
.gitignore added callbacks for EditText May 12, 2018
LICENSE Update Feb 13, 2019
settings.gradle Adds initial Toast module and nonEmptyToast check for EditText. From … Nov 19, 2018

New in the EasyValidation  The article on how this library was created is now published. You can read it on this link here. →.

Built with ❤︎ by Wajahat Karim and contributors

✔️ Changelog

Changes exist in the releases tab.

💻 Installation

Add this in app's build.gradle file:

   implementation "com.wajahatkarim3.easyvalidation:easyvalidation-core:1.0.1"

📄 Documentation

Full documentation is available at Gitbook.

⭐️ Features

  • The Validator way validation support. - Details
  • 30+ built-in validation rules like empty, email, credit cards, etc. - Rules List
  • Extension methods for String, EditText, TextView, AutoCompleteTextView, TextInputLayout, and Spinner. - Details
  • Multiple Validations and Checks - Details
  • Collection Extension Methods for validations on multiple texts and views - Details
  • Create your own custom rules - Details

Quick Usage

For example, you can validate any email String like this:

   var myEmailStr = ""
   var isValid = myEmailStr.validEmail()  // isValid will be true or false
   // Or you can also validate with an error callback method
   myEmailStr.validEmail() {
       // This method will be called when myEmailStr is not a valid email.
       Toast.makeText(contex, it, Toast.LENGTH_SHORT).show()

These extension methods are also available for String, EditText, TextView, AutoCompleteTextView, TextInputLayout, and Spinner.

   var myEditText = findViewById<EditText>(
   var isValid = myEditText.nonEmpty()        // Checks if edit text is empty or not

   // Or with error callback method like this
   myEditText.nonEmpty() {
       // This method will be called when myEditText is empty.
       myEditText.error = it

There are around 30+ built-in rules in the core module library. You can check all these in Rules page. EasyValidation also supports multiple validation checks at same time using Validator class like this:

// This example will check that whether user entered password has
// atleast one number, one spcial character, and one upper case.
var txtPassword = findViewById<EditText>(
     .addErrorCallback { 
          txtPassword.error = it
          // it will contain the right message. 
          // For example, if edit text is empty, 
          // then 'it' will show "Can't be Empty" message

For more advanced usage, checkout the full documentation at GitBook page.

💰 Donations

This project needs you! If you would like to support this project's further development, the creator of this project or the continuous maintenance of this project, feel free to donate. Your donation is highly appreciated (and I love food, coffee and beer). Thank you!


  • Donate $5: Thank's for creating this project, here's a tea (or some juice) for you!
  • Donate $10: Wow, I am stunned. Let me take you to the movies!
  • Donate $15: I really appreciate your work, let's grab some lunch!
  • Donate $25: That's some awesome stuff you did right there, dinner is on me!
  • Donate $50: I really really want to support this project, great job!
  • Donate $100: You are the man! This project saved me hours (if not days) of struggle and hard work, simply awesome!
  • Donate $2799: Go buddy, buy Macbook Pro for yourself!

Of course, you can also choose what you want to donate, all donations are awesome!

👨 Developed By

Wajahat Karim

👍 How to Contribute

  1. Fork it
  2. Create your feature branch (git checkout -b my-new-feature)
  3. Commit your changes (git commit -am 'Add some feature')
  4. Push to the branch (git push origin my-new-feature)
  5. Create new Pull Request

📃 License

Copyright 2018 Wajahat Karim

Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at

Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
See the License for the specific language governing permissions and
limitations under the License.
You can’t perform that action at this time.