LiteUtilities


Source link: https://github.com/gurleensethi/LiteUtilities

LiteUtilities

Speed up your android development by removing boilerplate code

To use this library in your project, do as follows:

  1. In your top level build.gradle file, in the repository section add the maven { url 'https://jitpack.io' } as shown below
allprojects {

repositories {

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

}
 
}
  1. Add the LiteUtilities dependency in your app level build.gradle file
compile 'com.github.gurleensethi:LiteUtilities:v1.3.0'

Current Features

  • RecyclerUtils - Remove the need to make an adapter everytime, set up recycler adapter in as little as 4 lines.
  • ScrollUtils - Easily hide/show FloationActionButton on scroll when using RecyclerView or NestedScrollView.
  • ToastUtils - Creating toasts are just a function away.
  • SPUtils - Simple DSL for Shared Preferences.
  • ValidatorUtils - Fast and simple text validation.
  • LogUtils - Simple and easy android logging.
The library is designed in such a way that if don't want to import the complete library but only want a specific Util, then you can download the corresponding file for the required Util, every Util has its own file/files and is independent of any other Util. You can find the code here.

Motivation

Primary motivation behind the development of this library is to hide the day-to-day boilerplate code that android developers have to deal with, by providing a simple and concise API, but also maintaining complete functionality at the same time.

RecyclerUtils

RecyclerUtils contain a very handy class named RecyclerAdapterUtil which can be used to make recycler adapters in as little as 4 lines. No need to create a separate adapter class for every recycler view.

The constructor of RecyclerAdapterUtil takes 3 parameters.

  • Context - Application Context.
  • ItemList - List of objects of type T which will be used as the primary data source for setting data to view holder items.
  • LayoutResourceId - Resource id of the layout that represents single item view for RecyclerView.

So to create a recycler adapter that displays a list of strings, you would write something like this:

val list = listOf("Test", "1", "2", "3", "This is a test", "123") val recyclerAdapter = RecyclerAdapterUtil<String>(this, list, R.layout.item_recycler_view) recyclerAdapter.addViewsList(R.id.textView, R.id.imageView)

The addViewsList function is important, pass the id's of all views contained in the single layout file provided in constructor (in this case it is R.layout.item_recycler_view) that you want to refer to while binding data. There are two ways to pass these id's.

All the views that you want to reference while binding data should be provided before hand, else the app will not function properly.
recyclerAdapter.addViewsList(R.id.textView, R.id.imageView)

 /* OR */ val listOfViews = listOf(R.id.textView, R.id.imageView) recyclerAdapter.addViewsList(listOfViews)

To bind data, add data bind listener:

recyclerAdapter.addOnDataBindListener {
 itemView, item, position. innerViews ->

  val textView = innerViews[R.id.textView] as TextView

 textView.text = item

}

addOnDataBindListener is a lambda which provides three items:

  • itemView - The ViewHolder itself.
  • item - Data item from the list.
  • position - Position of the data item in the list.
  • innerViews - A Map<Int, View> containing the reference to the views that were provided in the addViewsList function.

Click Listeners

You can also add OnClickListener and OnLongClickListener simply by implementing two lambdas.

//OnClickListener recyclerAdapter.addOnClickListener {
 item, position ->

  //Take action when item is pressed

}
  //OnLongClickListener recyclerAdapter.addOnLongClickListener {
 item, position ->

 //Take action when item is long pressed

}

Both addOnClickListener and addOnLongClickListener provide lambda with two parameters:

  • item - Data item from the list.
  • position - Position of the data item in the list.

Using Builder pattern for more consice code

Use RecyclerAdapterUtil.Builder to chain functions as shown below.

RecyclerAdapterUtil.Builder(this, list, R.layout.item_recycler_view)

  .viewsList(R.id.textView, R.id.imageView)

  .bindView {
 itemView, item, position, innerViews ->

val textView = innerViews[R.id.textView] as TextView

textView.text = item

  
}

  .addClickListener {
 item, position ->

//Take action when item is pressed

  
}

  .addLongClickListener {
 item, position ->

//Take action when item is long pressed

  
}

  .into(recyclerView)

into(RecyclerView) function takes the reference of RecyclerView and directly sets the adapter to it so you don't have to do it explicitly. If you want the object of adapter and want to set it manually use build() instead of into(RecyclerView).

ScrollUtils

Hide FloatingActionButton when user scrolls up and show it again when scrolled down. You can achieve this by using function hideFloatingActionButtonOnScroll on NestedScrollView and RecyclerView. These functions are implemented as extension functions.

val nestedScrollView = findViewById(R.id.nestedScrollView) as NestedScrollView val floatingActionButton = findViewById(R.id.floatingActionButton) as FloatingActionButton  nestedSrollView.hideFloatingActionButtonOnScroll(floatingActionButton)

Take custom action when scrolled up and down

If you want to take custom action when scrolled up or down you can implement ScrollListener using the function addScrollListener(ScrollListener). This works with both NestedScrollView and RecyclerView.

nestedScrollView.addScrollListener(object : ScrollListener {

 override fun scrolledDown() {

  //Take Action when user scrolls down

 
}

  override fun scrolledUp() {

  //Take Action when user scrolls up

 
}

}
)

ToastUtils

Making toast has never been easier. Just use shortToast(String) for making short toast and longToast(String) for making long ones. These functions are implemented as extension functions on Context, so wherever Context is available, these functions can be used.

shortToast("This is a short toast") longToast("This is a long toast")

Making colored Toasts

To make a toast with custom background and text color use coloredShortToast(message, backgroundColor, textColor) or coloredLongToast(message, backgroundColor, textColor).

Both of these functions take three parameters:

  • message: String displayed by the toast.
  • backgroundColor: Background Color of the toast.
  • textColor: Color of the text shown.
coloredShortToast("Colored short toast", R.color.darker_gray, R.color.black) coloredLongToast("Colored long toast", R.color.darker_gray, R.color.black)

SPUtils

Easy DSL for sharedpreferences. No need to write long lines of code when using SharedPreferences. The below functions are implemented as extension functions on Context, so they are available wherever Context is available.

Storing values

To use the default SharedPreferences file which is provided by the library itself, use defaultSharedPreferences function which takes a lambda for required operations, much easier to understand with an example. The mode used to open file is MODE_PRIVATE.

defaultSharedPreferences {

 putString("string", "Some Value 123")

 putInt("integer", 1)

}

If you want to use your own file and mode the use sharedPreferences(fileName, mode, lambda).

sharedPreferences("SP", Context.MODE_PRIVATE) {

 putString("string", "Some Value 123")

 putInt("integer", 1)

}

Fetching values

To get value from default SharedPreferences use getFromDefaultSharedPreferences<T>(key, defaultValue).

getFromDefaultSharedPreferences<String>("string", "default value")

You can also eliminate the need to specify a type explicitly, but in that case the type will be inferred from the type of defaultValue which is the second parameter so you can write.

getFromDefaultSharedPreferences("string", "default value")

To get from custom SharedPreferences file use getFromSharedPreferences<T>(fileName, key, defaultValue).

getFromSharedPreferences<String>("SP", "string", "default")

  /* OR */ getFromSharedPreferences("SP", "string", "default")

ValidatorUtils

Set of functions that provide easy and fast text validation. More than 15+ validation types available. Use the Validator class to access all the validation functions. This class is available using an extension function on EditText and TextInputEditText. Just call the validator() function.

Using Validator directly on EditText.

var result: Boolean = editText.validator()

.email()

.atLeastOneUpperCase()

.atLeastOneLowerCase()

.maximumLength(20)

.minimumLength(5)

.noNumbers()

.validate()

The Validator class has all the validation functions, chain all the functions that you require and call validate() to process. The result returned is a Boolean, true if all validation are passed, false if any one of them fails.

Adding callbacks to listen to results

If you want to take action after the validation is complete, there are two callbacks available, addSuccessCallback() and addErrorCallback(ValidationError). The addSuccessCallback is invoked when the valdiation passes, addErrorCallback is invoked when validation fails.

var result = editText.validator()

.email()

.atLeastOneUpperCase()

.atLeastOneLowerCase()

.maximumLength(20)

.minimumLength(5)

.noNumbers()

.addSuccessCallback {

 //Proceed

}

.addErrorCallback {
 errorType ->

 when (errorType) {

  ValidationError.EMAIL -> {

editText.error = "Email format is incorrect"

  
}

  ValidationError.AT_LEAST_ONE_LOWER_CASE -> {

editText.error = "Please provide at-least one lower case letter"

  
}

  ValidationError.AT_LEAST_ONE_UPPER_CASE -> {

editText.error = "Please provide at-least one upper case letter"

  
}

  else -> {

editText.error = "Not Enough"

  
}

 
}

}

.validate()

The addErrorCallback also provides a parameter of type ValidationError. This parameter provies the type of validation error that has occured. ValidationError is an enum, the naming convention is very simple, the names are same as the corresponding validation functions. For example, for validation function atLeastOneLowerCase, the validation error will be ValidationError.AT_LEAST_ONE_LOWER_CASE.

Using Validator independently

Validator class can also be used independently, just instantiate an object of it.

val validator = Validator("somePassword#123") validator.atLeastOneNumber()
  .atLeastOneUpperCase()
  .minimumLength(8)
  .maximumLength(32)
  .atLeastOneSpecialCharacter()
  .validate()

LogUtils

Simple and easy logging for android using LogUtils. Supported 6 log levels. To begin, set the log levels that you want to be logged. Messages will not be logged if no LogLevel is added.

LogUtils.addLevel(LogLevel.DEBUG) LogUtils.addLevel(LogLevel.INFO) LogUtils.addLevel(LogLevel.ERROR) LogUtils.addLevel(LogLevel.VERBOSE) LogUtils.addLevel(LogLevel.WARN) LogUtils.addLevel(LogLevel.WTF)

To enable all log levels just use LogLevel.ALL

LogUtils.addLevel(LogLevel.ALL)

Use the following functions throughout your app for logging purposes.

debug("This is a debug message") error("Some error occurred") warn("This is a warning") info("Some information") verbose("VERBOSE!") wtf("Ignore this") json("{
message:'This is a message', version: {
num: 10
}

}
") shout("Shout this message loud!\nThank YOU") exception(Exception("ERROR"))

JSON

To log a json string use the json(jsonString) function. This function will throw error if json structure is not right. To see the error LogLevel.ERROR should be enabled.

json("{
message:'This is a message', version: {
num: 10
}

}
")

Output:

{

  "message": "This is a message",
  "version": {

"num": 10
  
}
 
}
 

Shout

shout(message) prints a big box around the message.

shout("Shout this message loud!\nThank YOU")

Output:

************************************ *

 * *
  Shout this message loud!
  * *

 Thank YOU

* *

 * ************************************ 

Support

The primary purpose of this library is to speed up development process by removing boilerplate code, so if you have any idea or a new feature that meets the requirement and enhances the library as a whole or you found a bug in the existing code please open an issue, it is much appreciated.

License

MIT License  Copyright (c) 2017, Gurleen Sethi  Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:  The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.  THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. 

Resources

This project offers an ArrayPagerAdapter that offers another alternative PagerAdapter implementation for use with ViewPager.

Android ImageView that supports different radius on each corner. It also supports oval (and circle) shape and border. This would be especially useful for using inside CardView which should be rounded only top left and top right corners.

android-devices is an Android UI statistics for designers, product managers and developers.

Google Dashboards doesn't provide information on the following:

  • What are the popular/existing dp resolutions?
  • What devices could be best used for UI testing for specific generalized size/density bucket combination?
  • What devices could support width configuration introduced with Android 3.2

Besides, this information provides a sneak peak into Android devices market and trends.

The Go mobile repository holds packages and build tools for using Go on Android.

This library provides a useful widget class which automatically detects the presence of faces in the source image and crop it accordingly so to achieve the best visual result.

This project contains utility code related to Android security measures.

At present, it contains:

  • a PermissionUtils class with a checkCustomPermissions() static method, to help you detect if another app has defined your custom permissions before your app was installed
  • a TrustManagerBuilder to help you create a custom TrustManager, describing what sorts of SSL certificates you want to support in your HTTPS operations
  • a SignatureUtils class to help you determine the SHA-256 hash of the signing key of some package, to compare against known values, to help detect whether you are about to be communicating with some hacked version of an app

Topics


2D Engines   3D Engines   9-Patch   Action Bars   Activities   ADB   Advertisements   Analytics   Animations   ANR   AOP   API   APK   APT   Architecture   Audio   Autocomplete   Background Processing   Backward Compatibility   Badges   Bar Codes   Benchmarking   Bitmaps   Bluetooth   Blur Effects   Bread Crumbs   BRMS   Browser Extensions   Build Systems   Bundles   Buttons   Caching   Camera   Canvas   Cards   Carousels   Changelog   Checkboxes   Cloud Storages   Color Analysis   Color Pickers   Colors   Comet/Push   Compass Sensors   Conferences   Content Providers   Continuous Integration   Crash Reports   Credit Cards   Credits   CSV   Curl/Flip   Data Binding   Data Generators   Data Structures   Database   Database Browsers   Date &   Debugging   Decompilers   Deep Links   Dependency Injections   Design   Design Patterns   Dex   Dialogs   Distributed Computing   Distribution Platforms   Download Managers   Drawables   Emoji   Emulators   EPUB   Equalizers &   Event Buses   Exception Handling   Face Recognition   Feedback &   File System   File/Directory   Fingerprint   Floating Action   Fonts   Forms   Fragments   FRP   FSM   Functional Programming   Gamepads   Games   Geocaching   Gestures   GIF   Glow Pad   Gradle Plugins   Graphics   Grid Views   Highlighting   HTML   HTTP Mocking   Icons   IDE   IDE Plugins   Image Croppers   Image Loaders   Image Pickers   Image Processing   Image Views   Instrumentation   Intents   Job Schedulers   JSON   Keyboard   Kotlin   Layouts   Library Demos   List View   List Views   Localization   Location   Lock Patterns   Logcat   Logging   Mails   Maps   Markdown   Mathematics   Maven Plugins   MBaaS   Media   Menus   Messaging   MIME   Mobile Web   Native Image   Navigation   NDK   Networking   NFC   NoSQL   Number Pickers   OAuth   Object Mocking   OCR Engines   OpenGL   ORM   Other Pickers   Parallax List   Parcelables   Particle Systems   Password Inputs   PDF   Permissions   Physics Engines   Platforms   Plugin Frameworks   Preferences   Progress Indicators   ProGuard   Properties   Protocol Buffer   Pull To   Purchases   Push/Pull   QR Codes   Quick Return   Radio Buttons   Range Bars   Ratings   Recycler Views   Resources   REST   Ripple Effects   RSS   Screenshots   Scripting   Scroll Views   SDK   Search Inputs   Security   Sensors   Services   Showcase Views   Signatures   Sliding Panels   Snackbars   SOAP   Social Networks   Spannable   Spinners   Splash Screens   SSH   Static Analysis   Status Bars   Styling   SVG   System   Tags   Task Managers   TDD &   Template Engines   Testing   Testing Tools   Text Formatting   Text Views   Text Watchers   Text-to   Toasts   Toolkits For   Tools   Tooltips   Trainings   TV   Twitter   Updaters   USB   User Stories   Utils   Validation   Video   View Adapters   View Pagers   Views   Watch Face   Wearable Data   Wearables   Weather   Web Tools   Web Views   WebRTC   WebSockets   Wheel Widgets   Wi-Fi   Widgets   Windows   Wizards   XML   XMPP   YAML   ZIP Codes