An easy-to-use text field validator for Kotlin & Jetpack compose


validable

Validating text fields when using jetpack compose can sometimes be challenging and verbose.

Validable is an extensible library that allows you to validate your text fields in a simpler way while having a reusable code.

This is what it looks like :

@Composable  
fun MyScreen() { 
 
     val emailField = remember { EmailValidable() }  
     
	TextField(  
	    value = emailField.value,
	    onValueChange = { emailField.value = it }, // update the text  
	    isError = emailField.hasError(), // check if the field is not valid    
	)  
  
	AnimatedVisibility(visible = emailField.hasError()) {
	
	    Text(
                text = emailField.errorMessage ?: "",
            	modifier = Modifier.fillMaxWidth(),
            	style = LocalTextStyle.current.copy(color = MaterialTheme.colors.error)
	    )
        
	}  
	
	Button(onClick = {  
	    // pass all fields to the withValidable method 
	    withValidable(emailField) {  
		 
		// will be executed if all fields are valid 		
		Toast.makeText(context,"All fields are valid",Toast.LENGTH_SHORT).show() 
		
		} 
	}) { 
		Text(text = "Submit") 
	}  
}  

Installation

Step 1. Add the JitPack repository to your build file

Add it in your root build.gradle at the end of repositories:

allprojects {
    repositories {
        ...
        maven { url 'https://jitpack.io' }
    }
}

Step 2. Add the dependency

dependencies {
    implementation 'com.github.devscast:validable:x.y.z'
}

The latest version of this library is

For full documentation, check out the wiki page

Contributing

We’d love contributions !

We will also try to tag any issues on our issue tracker that we’d love help with, so
if you just want to dip in, go have a look.

If you do want to contribute to this project, we have a code of conduct.

GitHub

View Github