2.2.1 • Published 8 years ago
@fagnerlima/ng-mask v2.2.1
NgMask
NgMask is a jQueryMaskPlugin Adapter for Angular.
Dependencies
- @angular/core: 2.4.10 or higher;
- @angular/forms: 2.4.10 or higher;
- jQuery: 3.2.1 or higher;
- jQueryMaskPlugin: 1.14.11 or higher.
Usage
- Install ng-mask using npm:
npm install @fagnerlima/ng-mask- Import NgMaskModule into Module class:
// ...
import { NgMaskModule } from '@fagnerlima/ng-mask';
@NgModule({
  imports: [
    // ...
    NgMaskModule
  ],
  // ...
})
export class AppModule { }- Insert the directive in form inputs with ngControl (ex. ngModel or formControlName):
import { Component } from '@angular/core';
import { Mask } from '@fagnerlima/ng-mask';
@Component({
  selector: 'app-root',
  template: `
    <h1>NgMask</h1>
    <input type="text" [(ngModel)]="money" [mask]="maskMoney" />
  `
})
export class AppComponent {
  // Masks
  readonly maskCep: string = 'brCep';
  readonly maskCoordinateLat: string = 'coordinateLat';
  readonly maskCoordinateLong: string = 'coordinateLong';
  readonly maskCpf: Mask = new Mask('000.000.000-00');
  readonly maskDecimal: string = 'decimal(10,2)';
  readonly maskInteger: string = 'integer(6)';
  readonly maskMoney: string = '#0.00?reverse=true';
  readonly maskPhone: string = '(00) 00000-0000';
  // Controls
  money: string;
}Mask Types
Mask Object
Instance of Mask class.
import { Mask } from '@fagnerlima/ng-mask';
const dateMask: Mask = new Mask('00/00/0000');
const percentMask: Mask = new Mask('##0,00%', { reverse: true })Default Mask
String that represents pattern attribute of Mask class, using default jokers of jQueryMaskPlugin, without extra options.
const dateMask: string = '00/00/0000';| Patterns | jQueryMaskPlugin's Default Configuration | 
|---|---|
| 0 | { pattern: /\d/ } | 
| 9 | { pattern: /\d/, optional: true } | 
| # | { pattern: /\d/, recursive: true } | 
| A | { pattern: /[a-zA-Z0-9/ } | 
| S | { pattern: /a-zA-Z/ } | 
QueryString Mask
String in the QueryString format that contains the pattern and extra options of Mask class.
const percentMask: string = '##0,00%?reverse=true&placeholder=000,00%';| Supported Extra Options | 
|---|
| clearIfNotMatch | 
| placeholder | 
| reverse | 
| selectOnFocus | 
Predefined Type Mask
String that contains a predefined type.
const coordinateLatMask: string = 'coordinateLat';
const coordinateLongMask: string = 'coordinateLong';| Predefined Types | Pattern | Example | 
|---|---|---|
| brCelular | new Mask('(00) 00009-0000') | (11) 95683-1298 | 
| brCep | new Mask('00000-000') | 58035-110 | 
| brCnpj | new Mask('00.000.000/0000-00') | 13.456.131/0000-12 | 
| brCpf | new Mask('000.000.000-00') | 034.465.789-13 | 
| brData | new Mask('00/00/0000') | 15/10/2016 | 
| brMoeda | new Mask('#.##0,00', { reverse: true }) | 2.199,99 | 
| brTelefone | new Mask('(00) 0000-0000') | (83) 3638-8973 | 
| usPhone | new Mask('(000) 000-0000') | (581) 555-5895 | 
| coordinateLat | new Mask('000º00.0000\'~', { translation: { '~': { pattern: /N|S/ } } }) | 123º54.7894'N | 
| coordinateLong | new Mask('000º00.0000\'~', { translation: { '~': { pattern: /E|W/ } } }) | 354º79.6452'E | 
| date | new Mask('00/00/0000') | 01/31/2017 | 
| dateTime | new Mask('00/00/0000 00:00:00') | 05/18/2017 08:30:00 | 
| time | new Mask('00:00:00') | 19:15:00 | 
Numeric Mask
String that contains a numeric type with your precision (and scale for decimal type), similar to many databases.
const integerMask: string = 'integer(6)';
const decimalMask: string = 'decimal(10,2)';| Numeric Types | Examples | 
|---|---|
| integer | integer(6) | 
| decimal | decimal(5,2) | 
2.2.1
8 years ago
2.2.0
8 years ago
2.1.4
8 years ago
2.1.3
8 years ago
2.1.2
8 years ago
2.1.1
8 years ago
2.1.0
8 years ago
2.1.0-beta.2
8 years ago
2.1.0-beta.1
8 years ago
2.0.2
8 years ago
2.0.1
8 years ago
2.0.0
8 years ago
1.1.1
9 years ago
1.1.0
9 years ago
1.0.9
9 years ago
1.0.8
9 years ago
1.0.7
9 years ago
1.0.6
9 years ago
1.0.5
9 years ago
1.0.4
9 years ago
1.0.3
9 years ago
1.0.2
9 years ago
1.0.1
9 years ago
1.0.0-rc1
9 years ago
1.0.0
9 years ago