1.2.5 • Published 6 years ago
ng-cc-library v1.2.5
Note
Originally forkde from (Angular CC Library)'https://github.com/nogorilla/angular-cc-library'
Description
Angular CC Library - for validation and formating of input parameters
Demo
- Clone repo
- run npm install
- run npm run dev
- visit http://localhost:4200
Usage
Installation
npm install angular-cc-library --saveFormating Directive
On the input fields, add the specific directive to format inputs. 
All fields must be type='tel' in order to support spacing and additional characters
import { NgModule } from '@angular/core';
import { BrowserModule } from '@angular/platform-browser';
import { FormsModule } from '@angular/forms';
import { CreditCardDirectivesModule } from 'angular-cc-library';
import { AppComponent } from './app.component';
@NgModule({
    imports: [BrowserModule, FormsModule, CreditCardDirectivesModule],
    declarations: [AppComponent],
    bootstrap: [AppComponent]
})
export class AppModule {
}Credit Card Formater
- add ccNumberdirective:
<input id="cc-number" type="tel" autocomplete="cc-number" ccNumber>- this will also apply a class name based off the card .visa,.amex, etc. See the array of card types incredit-card.tsfor all available types
Expiration Date Formater Will support format of MM/YY or MM/YYYY
- add ccExpdirective:
<input id="cc-exp-date" type="tel" autocomplete="cc-exp" ccExp>CVC Formater
- add ccCvcdirective:
<input id="cc-cvc" type="tel" autocomplete="off" ccCVC>Validation
Current only Model Validation is supported. To implement, import the validator library and apply the specific validator on each form control
import { CreditCardValidator } from 'angular-cc-library';
@Component({
  selector: 'app',
  template: `
    <form #demoForm="ngForm" (ngSubmit)="onSubmit(demoForm)" novalidate>
        <input id="cc-number" formControlName="creditCard" type="tel" autocomplete="cc-number" ccNumber>
        <input id="cc-exp-date" formControlName="expirationDate" type="tel" autocomplete="cc-exp" ccExp>
        <input id="cc-cvc" formControlName="cvc" type="tel" autocomplete="off" ccCvc>
    </form>
  `
})
export class AppComponent implements OnInit {
  form: FormGroup;
  submitted: boolean = false;
  constructor(private _fb: FormBuilder) {}
  ngOnInit() {
    this.form = this._fb.group({
      creditCard: ['', [<any>CreditCardValidator.validateCCNumber]],
      expirationDate: ['', [<any>CreditCardValidator.validateExpDate]],
      cvc: ['', [<any>Validators.required, <any>Validators.minLength(3), <any>Validators.maxLength(4)]] 
    });
  }
  onSubmit(form) {
    this.submitted = true;
    console.log(form);
  }
}Inspiration
Based on Stripe's jquery.payment plugin but adapted for use by Angular2
License
MIT
1.2.5
6 years ago