Popularity
1.9
Declining
Activity
4.0
-
51
1
14

Description

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 (1.5.0) supports Visa, MasterCard and American Express cards, but more will be added soon.

Programming language: Kotlin
Tags: Validation     Credit Card     EditText    
Latest version: v2.1.2

EditCredit alternatives and similar packages

Based on the "Validation" category.
Alternatively, view EditCredit alternatives based on common mentions on social networks and blogs.

Do you think we are missing an alternative of EditCredit or a related project?

Add another 'Validation' Package

README

Android Arsenal JitPack Playstore Donate

[Edit Credit Logo](logo/logo_ldpi.png)

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:2.1.3'
}

Changelog

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.

Summary

XML attributes

Name Description values
separator Sets the separator style no_separatorspacesdashes
drawableGravity Sets the the location of the card drawable startendleftright
disabledCards Sets disabled cardsthis can be multiple values seperated by "\ "(eg. app:disabledCards="visa\

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(int)Sets the separator style. This method has been depracted, use setSeparator(Separator) instead
void setSeparator(Separator)Sets the separator style.
void setDisabledCards(int)Sets the disabled cards. This method has been depracted, use setDisabledCards(Card...) instead
void setDisabledCards(Card...)Sets the disabled cards.
void setDrawableGravity(Gravity)Sets the location of the card drawable.

Usage

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.

PayPal

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>


*Note that all licence references and agreements mentioned in the EditCredit README section above are relevant to that project's source code only.