EditCredit

Additional

Language
Kotlin
Version
3.0.3 (Dec 4, 2023)
Created
Jun 4, 2017
Updated
Dec 4, 2023
Owner
Mostafa Said (Mostafa-MA-Saleh)
Contributors
Mostafa Said (Mostafa-MA-Saleh)
iqbalhood
2
Activity
Badge
Generate
Download
Source code

Advertisement


Custom EditText for entering Credit Card numbers, this EditText will also display the image of the card number type being entered (after entering the second digit). And supports adding a separator (spaces or dashes) after every four digits.
This version supports Visa, MasterCard, American Express and Discover cards.

Installation via Gradle:

Step 1. Add the JitPack repository to 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.Mostafa-MA-Saleh:EditCredit:3.0.3'
}

Changelog

v 3.0.3

  • Updated the compileSdk to the latest version.
  • Updated kotlin to the latest version.
  • Migrated the gradle files to Kotlin DSL.

v 3.0.1

  • Fixed a issue with caret sometimes moving to where it shouldn't.

v 3.0.0

  • Updated the library to more follow kotlin conventions.
  • Replaced some methods with kotlin standard equivalents.
  • Fixed an issue wherein trying to change the separator style during runtime would sometimes crash the app.
  • Added a Java example activity.
  • Cleaned up the code a bit.

v 2.2.0

  • Added support for Diners Club cards.
  • Removed the deprecated methods and constants.
  • Updated dependencies.
  • Other minor improvements.

v 2.1.3

  • Updated dependencies.
  • Minor enhancements.

v 2.1.2

  • Added instant experience to the demo app.
  • Minor enhancements.

v 2.1.1

  • Reduced the drawables' sizes.
  • Fixed the blurry card images on some devices.
  • Updated the target SDK.
  • Added dark mode support to the demo app.
  • Other minor enhancements.

v 2.1.0

  • Fixed the card icon size on Android Pie (API 28).

v 2.0.0

  • Added the ability to get the card type.
  • Rewrote the library in kotlin.
  • Migrated to AndroidX.

v 1.7.1

  • Added support for Discover cards.

v 1.6.3

  • Minor bug fixes.

v 1.6.1

  • Updated the demo app to include the gravity options.
  • Added the ability to change the drawable gravity.
  • Deprecated setSeparator(int) and replaced it with setSeparator(Separator).
  • Deprecated setDisabledCards(int) and replaced it with setDisabledCards(Card...).
  • The minSDK is now 14 (because of AppCompat).

v 1.5.0

  • Added support for American Express.
  • Added the ability to disable cards.
  • Lowered the minSDK to 9.
  • Changed the demo app icon.

v 1.0.1

  • Changed the package name.

v 1.0

  • Initial Version.

Usage

Java

Public Methods

return Name/Description
Card getCardType()
Returns the current card type.
String getTextWithoutSeparator()
Returns the card number without the separators.
boolean isCardValid()
Validates the entered card number.
void setSeparator(Separator)
Sets the separator style.
Separator getSeparator()
Returns the current separator style.
void setDisabledCards(Card...)
Sets the disabled cards.
void setDrawableGravity(Gravity)
Sets the location of the card drawable.
Gravity getDrawableGravity()
Returns the current location of the card drawable.

Kotlin

Public Methods

return Name/Description
void setDisabledCards(Card...)
Sets the disabled cards.

Public Attributes

Type Name/Description Read Only
Card cardType
The current card type.
*
String textWithoutSeparator
The card number without the separators.
*
Boolean isCardValid
Validates the entered card number.
*
Separator separator
The current separator style.
Gravity drawableGravity
The location of the card drawable.

XML

Attributes

Name Description values
separator Sets the separator style no_separator
spaces
dashes
drawableGravity Sets the the location of the card drawable start
end
left
right
disabledCards Sets disabled cards
this can be multiple values seperated by "|"
(eg. app:disabledCards="visa|amex")
none
visa
mastercard
amex
discover
diners

Example

EditCredit can be used just like a normal EditText

<mostafa.ma.saleh.gmail.com.editcredit.EditCredit
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        app:disabledCards="visa|amex"
        app:drawableGravity="end"
        app:separator="spaces" />

Donation

If this project helps you, and you wanna buy me a cup of coffee.

License

This is free and unencumbered software released into the public domain.

Anyone is free to copy, modify, publish, use, compile, sell, or
distribute this software, either in source code form or as a compiled
binary, for any purpose, commercial or non-commercial, and by any
means.

In jurisdictions that recognize copyright laws, the author or authors
of this software dedicate any and all copyright interest in the
software to the public domain. We make this dedication for the benefit
of the public at large and to the detriment of our heirs and
successors. We intend this dedication to be an overt act of
relinquishment in perpetuity of all present and future rights to this
software under copyright law.

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 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.

For more information, please refer to <http://unlicense.org>