ngx-phone-mask
Advanced tools
Comparing version 3.2.2 to 3.3.0
(function (global, factory) { | ||
typeof exports === 'object' && typeof module !== 'undefined' ? factory(exports, require('@angular/core'), require('@angular/forms'), require('@angular/platform-browser'), require('text-mask-core/dist/textMaskCore'), require('angular2-text-mask')) : | ||
typeof define === 'function' && define.amd ? define('ngx-phone-mask', ['exports', '@angular/core', '@angular/forms', '@angular/platform-browser', 'text-mask-core/dist/textMaskCore', 'angular2-text-mask'], factory) : | ||
(factory((global['ngx-phone-mask'] = {}),global.ng.core,global.ng.forms,global.ng.platformBrowser,global.textMaskCore,global.angular2TextMask)); | ||
}(this, (function (exports,core,forms,platformBrowser,textMaskCore,angular2TextMask) { 'use strict'; | ||
typeof exports === 'object' && typeof module !== 'undefined' ? factory(exports, require('@angular/forms'), require('@angular/platform-browser'), require('text-mask-core/dist/textMaskCore'), require('@angular/core'), require('angular2-text-mask')) : | ||
typeof define === 'function' && define.amd ? define('ngx-phone-mask', ['exports', '@angular/forms', '@angular/platform-browser', 'text-mask-core/dist/textMaskCore', '@angular/core', 'angular2-text-mask'], factory) : | ||
(factory((global['ngx-phone-mask'] = {}),global.ng.forms,global.ng.platformBrowser,global.textMaskCore,global.ng.core,global.angular2TextMask)); | ||
}(this, (function (exports,forms,platformBrowser,textMaskCore,core,angular2TextMask) { 'use strict'; | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingReturn,uselessCode} checked by tsc | ||
* @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
@@ -18,5 +18,8 @@ /** @type {?} */ | ||
/** @type {?} */ | ||
var mask = function () { | ||
var mask = function (maxLength) { | ||
if (maxLength === void 0) { | ||
maxLength = 13; | ||
} | ||
return function (rawValue) { | ||
if (clean(rawValue).length <= 12) { | ||
if (clean(rawValue).length <= 12 || maxLength === 12) { | ||
return ['+', /[1-9]/, ' ', '(', /[1-9]/, /\d/, /\d/, ')', ' ', /\d/, /\d/, /\d/, '-', /\d/, /\d/, '-', /\d/, /\d/]; | ||
@@ -30,3 +33,3 @@ } | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingReturn,uselessCode} checked by tsc | ||
* @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
@@ -54,9 +57,3 @@ var TextMaskConfig = /** @class */ (function () { | ||
this.clean = true; | ||
this.textMaskConfig = { | ||
mask: mask(), | ||
guide: false, | ||
placeholderChar: '_', | ||
pipe: undefined, | ||
keepCharPositions: false, | ||
}; | ||
this.maxNumberLength = 13; | ||
/** | ||
@@ -196,2 +193,9 @@ * Whether the user is creating a composition string (IME events). | ||
} | ||
this.textMaskConfig = { | ||
mask: mask(this.maxNumberLength), | ||
guide: false, | ||
placeholderChar: '_', | ||
pipe: undefined, | ||
keepCharPositions: false, | ||
}; | ||
if (!this.inputElement) { | ||
@@ -259,2 +263,3 @@ if (this._elementRef.nativeElement.tagName.toUpperCase() === 'INPUT') { | ||
clean: [{ type: core.Input }], | ||
maxNumberLength: [{ type: core.Input }], | ||
onBlur: [{ type: core.HostListener, args: ['blur',] }] | ||
@@ -267,3 +272,3 @@ }; | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingReturn,uselessCode} checked by tsc | ||
* @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
@@ -297,3 +302,3 @@ var NgxPhoneMaskPipe = /** @class */ (function () { | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingReturn,uselessCode} checked by tsc | ||
* @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
@@ -321,3 +326,3 @@ var NgxPhoneMaskModule = /** @class */ (function () { | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingReturn,uselessCode} checked by tsc | ||
* @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
@@ -327,3 +332,3 @@ | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingReturn,uselessCode} checked by tsc | ||
* @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
@@ -340,2 +345,2 @@ | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"ngx-phone-mask.umd.js.map","sources":["ng://ngx-phone-mask/lib/utils.ts","ng://ngx-phone-mask/lib/ngx-phone-mask.directive.ts","ng://ngx-phone-mask/lib/ngx-phone-mask.pipe.ts","ng://ngx-phone-mask/lib/ngx-phone-mask.module.ts"],"sourcesContent":["export const clean = (number) => {\n\treturn number\n\t\t.toString()\n\t\t.replace(/[^\\d\\^\\+]/gm, '');\n};\n\nexport const mask = () => (rawValue) => {\n\tif (clean(rawValue).length <= 12) {\n\t\treturn ['+', /[1-9]/, ' ', '(', /[1-9]/, /\\d/, /\\d/, ')', ' ', /\\d/, /\\d/, /\\d/, '-', /\\d/, /\\d/, '-', /\\d/, /\\d/];\n\t}\n\n\treturn ['+', /[1-9]/, ' ', '(', /[1-9]/, /\\d/, /\\d/, ')', ' ', /\\d/, /\\d/, /\\d/, '-', /\\d/, /\\d/, /\\d/, '-', /\\d/, /\\d/];\n\n};\n","import {\n\tDirective,\n\tElementRef,\n\tforwardRef, HostListener,\n\tInject, Input,\n\tOnChanges, OnInit,\n\tOptional,\n\tRenderer2,\n\tSimpleChanges\n} from '@angular/core';\nimport { NG_VALUE_ACCESSOR, ControlValueAccessor, COMPOSITION_BUFFER_MODE } from '@angular/forms';\nimport { ÉµgetDOM as getDOM } from '@angular/platform-browser';\nimport { createTextMaskInputElement } from 'text-mask-core/dist/textMaskCore';\nimport { mask, clean } from './utils';\n\nexport class TextMaskConfig {\n\tmask: Array<string | RegExp> | ((raw: string) => Array<string | RegExp>) | false;\n\tguide?: boolean;\n\tplaceholderChar?: string;\n\tpipe?: (conformedValue: string, config: TextMaskConfig) => false | string | object;\n\tkeepCharPositions?: boolean;\n\tshowMask?: boolean;\n}\n\n/**\n * We must check whether the agent is Android because composition events\n * behave differently between iOS and Android.\n */\nfunction _isAndroid(): boolean {\n\tconst userAgent = getDOM() ? getDOM().getUserAgent() : '';\n\treturn /android (\\d+)/.test(userAgent.toLowerCase());\n}\n\n@Directive({\n\thost: {\n\t\t'(input)': '_handleInput($event.target.value)',\n\t\t'(blur)': 'onTouched()',\n\t\t'(compositionstart)': '_compositionStart()',\n\t\t'(compositionend)': '_compositionEnd($event.target.value)'\n\t},\n\tselector: '[ngxPhoneMask]',\n\texportAs: 'ngxPhoneMask',\n\tproviders: [{\n\t\tprovide: NG_VALUE_ACCESSOR,\n\t\tuseExisting: forwardRef(() => NgxPhoneMaskDirective),\n\t\tmulti: true\n\t}]\n})\nexport class NgxPhoneMaskDirective implements ControlValueAccessor, OnChanges, OnInit {\n\t@Input() clean = true;\n\n\ttextMaskConfig: TextMaskConfig = {\n\t\tmask: mask(),\n\t\tguide: false,\n\t\tplaceholderChar: '_',\n\t\tpipe: undefined,\n\t\tkeepCharPositions: false,\n\t};\n\n\tprivate textMaskInputElement: any;\n\tprivate inputElement: HTMLInputElement;\n\n\t/** Whether the user is creating a composition string (IME events). */\n\tprivate _composing = false;\n\n\tonChange = (_: any) => {\n\t};\n\tonTouched = () => {\n\t};\n\n\tconstructor(\n\t\tprivate _renderer: Renderer2,\n\t\tprivate _elementRef: ElementRef,\n\t\t@Optional() @Inject(COMPOSITION_BUFFER_MODE) private _compositionMode: boolean\n\t) {\n\t\tif (this._compositionMode == null) {\n\t\t\tthis._compositionMode = !_isAndroid();\n\t\t}\n\t}\n\n\tngOnInit() {\n\t\tthis._setupMask(true);\n\t\tif (this.textMaskInputElement !== undefined) {\n\t\t\tthis.textMaskInputElement.update(this.inputElement.value);\n\t\t}\n\t}\n\n\tngOnChanges(changes: SimpleChanges) {\n\t\tthis._setupMask(true);\n\t\tif (this.textMaskInputElement !== undefined) {\n\t\t\tthis.textMaskInputElement.update(this.inputElement.value);\n\t\t}\n\t}\n\n\t@HostListener('blur')\n\tonBlur() {\n\t\tthis.onTouched();\n\t}\n\n\twriteValue(value: any) {\n\t\tthis._setupMask();\n\n\t\t// set the initial value for cases where the mask is disabled\n\t\tconst normalizedValue = value == null ? '' : value;\n\t\tthis._renderer.setProperty(this.inputElement, 'value', normalizedValue);\n\n\t\tif (this.textMaskInputElement !== undefined) {\n\t\t\tthis.textMaskInputElement.update(value);\n\t\t}\n\t}\n\n\tregisterOnChange(fn: (_: any) => void): void {\n\t\tthis.onChange = fn;\n\t}\n\n\tregisterOnTouched(fn: () => void): void {\n\t\tthis.onTouched = fn;\n\t}\n\n\tsetDisabledState(isDisabled: boolean): void {\n\t\tthis._renderer.setProperty(this._elementRef.nativeElement, 'disabled', isDisabled);\n\t}\n\n\t_handleInput(value) {\n\t\tif (!this._compositionMode || (this._compositionMode && !this._composing)) {\n\t\t\tthis._setupMask();\n\n\t\t\tif (this.textMaskInputElement !== undefined) {\n\t\t\t\tthis.textMaskInputElement.update(value);\n\n\t\t\t\t// get the updated value\n\t\t\t\tvalue = this.inputElement.value;\n\n\t\t\t\tif (this.clean) {\n\t\t\t\t\tthis.onChange(clean(value));\n\t\t\t\t} else {\n\t\t\t\t\tthis.onChange(value);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n\t_setupMask(create = false) {\n\t\tif (!this.inputElement) {\n\t\t\tif (this._elementRef.nativeElement.tagName.toUpperCase() === 'INPUT') {\n\t\t\t\t// `textMask` directive is used directly on an input element\n\t\t\t\tthis.inputElement = this._elementRef.nativeElement;\n\t\t\t} else {\n\t\t\t\t// `textMask` directive is used on an abstracted input element, `md-input-container`, etc\n\t\t\t\tthis.inputElement = this._elementRef.nativeElement.getElementsByTagName('INPUT')[0];\n\t\t\t}\n\t\t}\n\n\t\tif (this.inputElement && create) {\n\t\t\tthis.textMaskInputElement = createTextMaskInputElement(\n\t\t\t\tObject.assign({ inputElement: this.inputElement }, this.textMaskConfig)\n\t\t\t);\n\t\t}\n\n\t}\n\n\t_compositionStart(): void {\n\t\tthis._composing = true;\n\t}\n\n\t_compositionEnd(value: any): void {\n\t\tthis._composing = false;\n\t\tthis._compositionMode && this._handleInput(value);\n\t}\n}\n","import { Pipe, PipeTransform } from '@angular/core';\nimport { conformToMask } from 'angular2-text-mask';\nimport { mask } from './utils';\n\n@Pipe({\n\tname: 'ngxPhoneMask'\n})\n\nexport class NgxPhoneMaskPipe implements PipeTransform {\n\ttransform(value: string): string {\n\t\tif (!value) {\n\t\t\treturn '';\n\t\t}\n\n\t\treturn conformToMask(\n\t\t\tvalue,\n\t\t\tmask(),\n\t\t\t{ guide: false }\n\t\t).conformedValue;\n\t}\n}\n","import { NgModule } from '@angular/core';\nimport { NgxPhoneMaskDirective } from './ngx-phone-mask.directive';\nimport { TextMaskModule } from 'angular2-text-mask';\nimport { NgxPhoneMaskPipe } from './ngx-phone-mask.pipe';\n\n@NgModule({\n\timports: [TextMaskModule],\n\tdeclarations: [\n\t\tNgxPhoneMaskDirective,\n\t\tNgxPhoneMaskPipe\n\t],\n\texports: [\n\t\tNgxPhoneMaskDirective,\n\t\tNgxPhoneMaskPipe\n\t]\n})\nexport class NgxPhoneMaskModule {\n}\n"],"names":["getDOM","createTextMaskInputElement","Directive","NG_VALUE_ACCESSOR","forwardRef","Renderer2","ElementRef","Optional","Inject","COMPOSITION_BUFFER_MODE","Input","HostListener","conformToMask","Pipe","NgModule","TextMaskModule"],"mappings":"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"} | ||
//# sourceMappingURL=ngx-phone-mask.umd.js.map |
@@ -1,2 +0,2 @@ | ||
!function(t,e){"object"==typeof exports&&"undefined"!=typeof module?e(exports,require("@angular/core"),require("@angular/forms"),require("@angular/platform-browser"),require("text-mask-core/dist/textMaskCore"),require("angular2-text-mask")):"function"==typeof define&&define.amd?define("ngx-phone-mask",["exports","@angular/core","@angular/forms","@angular/platform-browser","text-mask-core/dist/textMaskCore","angular2-text-mask"],e):e(t["ngx-phone-mask"]={},t.ng.core,t.ng.forms,t.ng.platformBrowser,t.textMaskCore,t.angular2TextMask)}(this,function(t,e,n,i,o,s){"use strict";var r=function(t){return t.toString().replace(/[^\d\^\+]/gm,"")},a=function(){return function(t){return r(t).length<=12?["+",/[1-9]/," ","(",/[1-9]/,/\d/,/\d/,")"," ",/\d/,/\d/,/\d/,"-",/\d/,/\d/,"-",/\d/,/\d/]:["+",/[1-9]/," ","(",/[1-9]/,/\d/,/\d/,")"," ",/\d/,/\d/,/\d/,"-",/\d/,/\d/,/\d/,"-",/\d/,/\d/]}},u=function c(){};var p=function(){function t(t,e,n){this._renderer=t,this._elementRef=e,this._compositionMode=n,this.clean=!0,this.textMaskConfig={mask:a(),guide:!1,placeholderChar:"_",pipe:undefined,keepCharPositions:!1},this._composing=!1,this.onChange=function(t){},this.onTouched=function(){},null==this._compositionMode&&(this._compositionMode=!function o(){var t=i.ɵgetDOM()?i.ɵgetDOM().getUserAgent():"";return/android (\d+)/.test(t.toLowerCase())}())}return t.prototype.ngOnInit=function(){this._setupMask(!0),this.textMaskInputElement!==undefined&&this.textMaskInputElement.update(this.inputElement.value)},t.prototype.ngOnChanges=function(t){this._setupMask(!0),this.textMaskInputElement!==undefined&&this.textMaskInputElement.update(this.inputElement.value)},t.prototype.onBlur=function(){this.onTouched()},t.prototype.writeValue=function(t){this._setupMask();var e=null==t?"":t;this._renderer.setProperty(this.inputElement,"value",e),this.textMaskInputElement!==undefined&&this.textMaskInputElement.update(t)},t.prototype.registerOnChange=function(t){this.onChange=t},t.prototype.registerOnTouched=function(t){this.onTouched=t},t.prototype.setDisabledState=function(t){this._renderer.setProperty(this._elementRef.nativeElement,"disabled",t)},t.prototype._handleInput=function(t){(!this._compositionMode||this._compositionMode&&!this._composing)&&(this._setupMask(),this.textMaskInputElement!==undefined&&(this.textMaskInputElement.update(t),t=this.inputElement.value,this.clean?this.onChange(r(t)):this.onChange(t)))},t.prototype._setupMask=function(t){void 0===t&&(t=!1),this.inputElement||("INPUT"===this._elementRef.nativeElement.tagName.toUpperCase()?this.inputElement=this._elementRef.nativeElement:this.inputElement=this._elementRef.nativeElement.getElementsByTagName("INPUT")[0]),this.inputElement&&t&&(this.textMaskInputElement=o.createTextMaskInputElement(Object.assign({inputElement:this.inputElement},this.textMaskConfig)))},t.prototype._compositionStart=function(){this._composing=!0},t.prototype._compositionEnd=function(t){this._composing=!1,this._compositionMode&&this._handleInput(t)},t.decorators=[{type:e.Directive,args:[{host:{"(input)":"_handleInput($event.target.value)","(blur)":"onTouched()","(compositionstart)":"_compositionStart()","(compositionend)":"_compositionEnd($event.target.value)"},selector:"[ngxPhoneMask]",exportAs:"ngxPhoneMask",providers:[{provide:n.NG_VALUE_ACCESSOR,useExisting:e.forwardRef(function(){return t}),multi:!0}]}]}],t.ctorParameters=function(){return[{type:e.Renderer2},{type:e.ElementRef},{type:Boolean,decorators:[{type:e.Optional},{type:e.Inject,args:[n.COMPOSITION_BUFFER_MODE]}]}]},t.propDecorators={clean:[{type:e.Input}],onBlur:[{type:e.HostListener,args:["blur"]}]},t}(),d=function(){function t(){}return t.prototype.transform=function(t){return t?s.conformToMask(t,a(),{guide:!1}).conformedValue:""},t.decorators=[{type:e.Pipe,args:[{name:"ngxPhoneMask"}]}],t}(),l=function(){function t(){}return t.decorators=[{type:e.NgModule,args:[{imports:[s.TextMaskModule],declarations:[p,d],exports:[p,d]}]}],t}();t.TextMaskConfig=u,t.NgxPhoneMaskDirective=p,t.NgxPhoneMaskModule=l,t.ɵa=d,Object.defineProperty(t,"__esModule",{value:!0})}); | ||
!function(t,e){"object"==typeof exports&&"undefined"!=typeof module?e(exports,require("@angular/forms"),require("@angular/platform-browser"),require("text-mask-core/dist/textMaskCore"),require("@angular/core"),require("angular2-text-mask")):"function"==typeof define&&define.amd?define("ngx-phone-mask",["exports","@angular/forms","@angular/platform-browser","text-mask-core/dist/textMaskCore","@angular/core","angular2-text-mask"],e):e(t["ngx-phone-mask"]={},t.ng.forms,t.ng.platformBrowser,t.textMaskCore,t.ng.core,t.angular2TextMask)}(this,function(t,e,i,n,o,s){"use strict";var r=function(t){return t.toString().replace(/[^\d\^\+]/gm,"")},a=function(e){return void 0===e&&(e=13),function(t){return r(t).length<=12||12===e?["+",/[1-9]/," ","(",/[1-9]/,/\d/,/\d/,")"," ",/\d/,/\d/,/\d/,"-",/\d/,/\d/,"-",/\d/,/\d/]:["+",/[1-9]/," ","(",/[1-9]/,/\d/,/\d/,")"," ",/\d/,/\d/,/\d/,"-",/\d/,/\d/,/\d/,"-",/\d/,/\d/]}},u=function l(){};var p=function(){function t(t,e,n){this._renderer=t,this._elementRef=e,this._compositionMode=n,this.clean=!0,this.maxNumberLength=13,this._composing=!1,this.onChange=function(t){},this.onTouched=function(){},null==this._compositionMode&&(this._compositionMode=!function o(){var t=i.ɵgetDOM()?i.ɵgetDOM().getUserAgent():"";return/android (\d+)/.test(t.toLowerCase())}())}return t.prototype.ngOnInit=function(){this._setupMask(!0),this.textMaskInputElement!==undefined&&this.textMaskInputElement.update(this.inputElement.value)},t.prototype.ngOnChanges=function(t){this._setupMask(!0),this.textMaskInputElement!==undefined&&this.textMaskInputElement.update(this.inputElement.value)},t.prototype.onBlur=function(){this.onTouched()},t.prototype.writeValue=function(t){this._setupMask();var e=null==t?"":t;this._renderer.setProperty(this.inputElement,"value",e),this.textMaskInputElement!==undefined&&this.textMaskInputElement.update(t)},t.prototype.registerOnChange=function(t){this.onChange=t},t.prototype.registerOnTouched=function(t){this.onTouched=t},t.prototype.setDisabledState=function(t){this._renderer.setProperty(this._elementRef.nativeElement,"disabled",t)},t.prototype._handleInput=function(t){(!this._compositionMode||this._compositionMode&&!this._composing)&&(this._setupMask(),this.textMaskInputElement!==undefined&&(this.textMaskInputElement.update(t),t=this.inputElement.value,this.clean?this.onChange(r(t)):this.onChange(t)))},t.prototype._setupMask=function(t){void 0===t&&(t=!1),this.textMaskConfig={mask:a(this.maxNumberLength),guide:!1,placeholderChar:"_",pipe:undefined,keepCharPositions:!1},this.inputElement||("INPUT"===this._elementRef.nativeElement.tagName.toUpperCase()?this.inputElement=this._elementRef.nativeElement:this.inputElement=this._elementRef.nativeElement.getElementsByTagName("INPUT")[0]),this.inputElement&&t&&(this.textMaskInputElement=n.createTextMaskInputElement(Object.assign({inputElement:this.inputElement},this.textMaskConfig)))},t.prototype._compositionStart=function(){this._composing=!0},t.prototype._compositionEnd=function(t){this._composing=!1,this._compositionMode&&this._handleInput(t)},t.decorators=[{type:o.Directive,args:[{host:{"(input)":"_handleInput($event.target.value)","(blur)":"onTouched()","(compositionstart)":"_compositionStart()","(compositionend)":"_compositionEnd($event.target.value)"},selector:"[ngxPhoneMask]",exportAs:"ngxPhoneMask",providers:[{provide:e.NG_VALUE_ACCESSOR,useExisting:o.forwardRef(function(){return t}),multi:!0}]}]}],t.ctorParameters=function(){return[{type:o.Renderer2},{type:o.ElementRef},{type:Boolean,decorators:[{type:o.Optional},{type:o.Inject,args:[e.COMPOSITION_BUFFER_MODE]}]}]},t.propDecorators={clean:[{type:o.Input}],maxNumberLength:[{type:o.Input}],onBlur:[{type:o.HostListener,args:["blur"]}]},t}(),d=function(){function t(){}return t.prototype.transform=function(t){return t?s.conformToMask(t,a(),{guide:!1}).conformedValue:""},t.decorators=[{type:o.Pipe,args:[{name:"ngxPhoneMask"}]}],t}(),h=function(){function t(){}return t.decorators=[{type:o.NgModule,args:[{imports:[s.TextMaskModule],declarations:[p,d],exports:[p,d]}]}],t}();t.TextMaskConfig=u,t.NgxPhoneMaskDirective=p,t.NgxPhoneMaskModule=h,t.ɵa=d,Object.defineProperty(t,"__esModule",{value:!0})}); | ||
//# sourceMappingURL=ngx-phone-mask.umd.min.js.map |
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingReturn,uselessCode} checked by tsc | ||
* @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
@@ -47,9 +47,3 @@ import { Directive, ElementRef, forwardRef, HostListener, Inject, Input, Optional, Renderer2 } from '@angular/core'; | ||
this.clean = true; | ||
this.textMaskConfig = { | ||
mask: mask(), | ||
guide: false, | ||
placeholderChar: '_', | ||
pipe: undefined, | ||
keepCharPositions: false, | ||
}; | ||
this.maxNumberLength = 13; | ||
/** | ||
@@ -152,2 +146,9 @@ * Whether the user is creating a composition string (IME events). | ||
_setupMask(create = false) { | ||
this.textMaskConfig = { | ||
mask: mask(this.maxNumberLength), | ||
guide: false, | ||
placeholderChar: '_', | ||
pipe: undefined, | ||
keepCharPositions: false, | ||
}; | ||
if (!this.inputElement) { | ||
@@ -207,2 +208,3 @@ if (this._elementRef.nativeElement.tagName.toUpperCase() === 'INPUT') { | ||
clean: [{ type: Input }], | ||
maxNumberLength: [{ type: Input }], | ||
onBlur: [{ type: HostListener, args: ['blur',] }] | ||
@@ -214,6 +216,14 @@ }; | ||
/** @type {?} */ | ||
NgxPhoneMaskDirective.prototype.maxNumberLength; | ||
/** @type {?} */ | ||
NgxPhoneMaskDirective.prototype.textMaskConfig; | ||
/** @type {?} */ | ||
/** | ||
* @type {?} | ||
* @private | ||
*/ | ||
NgxPhoneMaskDirective.prototype.textMaskInputElement; | ||
/** @type {?} */ | ||
/** | ||
* @type {?} | ||
* @private | ||
*/ | ||
NgxPhoneMaskDirective.prototype.inputElement; | ||
@@ -223,2 +233,3 @@ /** | ||
* @type {?} | ||
* @private | ||
*/ | ||
@@ -230,9 +241,18 @@ NgxPhoneMaskDirective.prototype._composing; | ||
NgxPhoneMaskDirective.prototype.onTouched; | ||
/** @type {?} */ | ||
/** | ||
* @type {?} | ||
* @private | ||
*/ | ||
NgxPhoneMaskDirective.prototype._renderer; | ||
/** @type {?} */ | ||
/** | ||
* @type {?} | ||
* @private | ||
*/ | ||
NgxPhoneMaskDirective.prototype._elementRef; | ||
/** @type {?} */ | ||
/** | ||
* @type {?} | ||
* @private | ||
*/ | ||
NgxPhoneMaskDirective.prototype._compositionMode; | ||
} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ngx-phone-mask.directive.js","sourceRoot":"ng://ngx-phone-mask/","sources":["lib/ngx-phone-mask.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n\tDirective,\n\tElementRef,\n\tforwardRef, HostListener,\n\tInject, Input,\n\tOnChanges, OnInit,\n\tOptional,\n\tRenderer2,\n\tSimpleChanges\n} from '@angular/core';\nimport { NG_VALUE_ACCESSOR, ControlValueAccessor, COMPOSITION_BUFFER_MODE } from '@angular/forms';\nimport { ɵgetDOM as getDOM } from '@angular/platform-browser';\nimport { createTextMaskInputElement } from 'text-mask-core/dist/textMaskCore';\nimport { mask, clean } from './utils';\n\nexport class TextMaskConfig {\n\tmask: Array<string | RegExp> | ((raw: string) => Array<string | RegExp>) | false;\n\tguide?: boolean;\n\tplaceholderChar?: string;\n\tpipe?: (conformedValue: string, config: TextMaskConfig) => false | string | object;\n\tkeepCharPositions?: boolean;\n\tshowMask?: boolean;\n}\n\n/**\n * We must check whether the agent is Android because composition events\n * behave differently between iOS and Android.\n */\nfunction _isAndroid(): boolean {\n\tconst userAgent = getDOM() ? getDOM().getUserAgent() : '';\n\treturn /android (\\d+)/.test(userAgent.toLowerCase());\n}\n\n@Directive({\n\thost: {\n\t\t'(input)': '_handleInput($event.target.value)',\n\t\t'(blur)': 'onTouched()',\n\t\t'(compositionstart)': '_compositionStart()',\n\t\t'(compositionend)': '_compositionEnd($event.target.value)'\n\t},\n\tselector: '[ngxPhoneMask]',\n\texportAs: 'ngxPhoneMask',\n\tproviders: [{\n\t\tprovide: NG_VALUE_ACCESSOR,\n\t\tuseExisting: forwardRef(() => NgxPhoneMaskDirective),\n\t\tmulti: true\n\t}]\n})\nexport class NgxPhoneMaskDirective implements ControlValueAccessor, OnChanges, OnInit {\n\t@Input() clean = true;\n\n\ttextMaskConfig: TextMaskConfig = {\n\t\tmask: mask(),\n\t\tguide: false,\n\t\tplaceholderChar: '_',\n\t\tpipe: undefined,\n\t\tkeepCharPositions: false,\n\t};\n\n\tprivate textMaskInputElement: any;\n\tprivate inputElement: HTMLInputElement;\n\n\t/** Whether the user is creating a composition string (IME events). */\n\tprivate _composing = false;\n\n\tonChange = (_: any) => {\n\t};\n\tonTouched = () => {\n\t};\n\n\tconstructor(\n\t\tprivate _renderer: Renderer2,\n\t\tprivate _elementRef: ElementRef,\n\t\t@Optional() @Inject(COMPOSITION_BUFFER_MODE) private _compositionMode: boolean\n\t) {\n\t\tif (this._compositionMode == null) {\n\t\t\tthis._compositionMode = !_isAndroid();\n\t\t}\n\t}\n\n\tngOnInit() {\n\t\tthis._setupMask(true);\n\t\tif (this.textMaskInputElement !== undefined) {\n\t\t\tthis.textMaskInputElement.update(this.inputElement.value);\n\t\t}\n\t}\n\n\tngOnChanges(changes: SimpleChanges) {\n\t\tthis._setupMask(true);\n\t\tif (this.textMaskInputElement !== undefined) {\n\t\t\tthis.textMaskInputElement.update(this.inputElement.value);\n\t\t}\n\t}\n\n\t@HostListener('blur')\n\tonBlur() {\n\t\tthis.onTouched();\n\t}\n\n\twriteValue(value: any) {\n\t\tthis._setupMask();\n\n\t\t// set the initial value for cases where the mask is disabled\n\t\tconst normalizedValue = value == null ? '' : value;\n\t\tthis._renderer.setProperty(this.inputElement, 'value', normalizedValue);\n\n\t\tif (this.textMaskInputElement !== undefined) {\n\t\t\tthis.textMaskInputElement.update(value);\n\t\t}\n\t}\n\n\tregisterOnChange(fn: (_: any) => void): void {\n\t\tthis.onChange = fn;\n\t}\n\n\tregisterOnTouched(fn: () => void): void {\n\t\tthis.onTouched = fn;\n\t}\n\n\tsetDisabledState(isDisabled: boolean): void {\n\t\tthis._renderer.setProperty(this._elementRef.nativeElement, 'disabled', isDisabled);\n\t}\n\n\t_handleInput(value) {\n\t\tif (!this._compositionMode || (this._compositionMode && !this._composing)) {\n\t\t\tthis._setupMask();\n\n\t\t\tif (this.textMaskInputElement !== undefined) {\n\t\t\t\tthis.textMaskInputElement.update(value);\n\n\t\t\t\t// get the updated value\n\t\t\t\tvalue = this.inputElement.value;\n\n\t\t\t\tif (this.clean) {\n\t\t\t\t\tthis.onChange(clean(value));\n\t\t\t\t} else {\n\t\t\t\t\tthis.onChange(value);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n\t_setupMask(create = false) {\n\t\tif (!this.inputElement) {\n\t\t\tif (this._elementRef.nativeElement.tagName.toUpperCase() === 'INPUT') {\n\t\t\t\t// `textMask` directive is used directly on an input element\n\t\t\t\tthis.inputElement = this._elementRef.nativeElement;\n\t\t\t} else {\n\t\t\t\t// `textMask` directive is used on an abstracted input element, `md-input-container`, etc\n\t\t\t\tthis.inputElement = this._elementRef.nativeElement.getElementsByTagName('INPUT')[0];\n\t\t\t}\n\t\t}\n\n\t\tif (this.inputElement && create) {\n\t\t\tthis.textMaskInputElement = createTextMaskInputElement(\n\t\t\t\tObject.assign({ inputElement: this.inputElement }, this.textMaskConfig)\n\t\t\t);\n\t\t}\n\n\t}\n\n\t_compositionStart(): void {\n\t\tthis._composing = true;\n\t}\n\n\t_compositionEnd(value: any): void {\n\t\tthis._composing = false;\n\t\tthis._compositionMode && this._handleInput(value);\n\t}\n}\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ngx-phone-mask.directive.js","sourceRoot":"ng://ngx-phone-mask/","sources":["lib/ngx-phone-mask.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n\tDirective,\n\tElementRef,\n\tforwardRef, HostListener,\n\tInject, Input,\n\tOnChanges, OnInit,\n\tOptional,\n\tRenderer2,\n\tSimpleChanges\n} from '@angular/core';\nimport { NG_VALUE_ACCESSOR, ControlValueAccessor, COMPOSITION_BUFFER_MODE } from '@angular/forms';\nimport { ɵgetDOM as getDOM } from '@angular/platform-browser';\nimport { createTextMaskInputElement } from 'text-mask-core/dist/textMaskCore';\nimport { mask, clean } from './utils';\n\nexport class TextMaskConfig {\n\tmask: Array<string | RegExp> | ((raw: string) => Array<string | RegExp>) | false;\n\tguide?: boolean;\n\tplaceholderChar?: string;\n\tpipe?: (conformedValue: string, config: TextMaskConfig) => false | string | object;\n\tkeepCharPositions?: boolean;\n\tshowMask?: boolean;\n}\n\n/**\n * We must check whether the agent is Android because composition events\n * behave differently between iOS and Android.\n */\nfunction _isAndroid(): boolean {\n\tconst userAgent = getDOM() ? getDOM().getUserAgent() : '';\n\treturn /android (\\d+)/.test(userAgent.toLowerCase());\n}\n\n@Directive({\n\thost: {\n\t\t'(input)': '_handleInput($event.target.value)',\n\t\t'(blur)': 'onTouched()',\n\t\t'(compositionstart)': '_compositionStart()',\n\t\t'(compositionend)': '_compositionEnd($event.target.value)'\n\t},\n\tselector: '[ngxPhoneMask]',\n\texportAs: 'ngxPhoneMask',\n\tproviders: [{\n\t\tprovide: NG_VALUE_ACCESSOR,\n\t\tuseExisting: forwardRef(() => NgxPhoneMaskDirective),\n\t\tmulti: true\n\t}]\n})\nexport class NgxPhoneMaskDirective implements ControlValueAccessor, OnChanges, OnInit {\n\t@Input() clean = true;\n\t@Input() maxNumberLength: number = 13;\n\n\ttextMaskConfig: TextMaskConfig;\n\n\tprivate textMaskInputElement: any;\n\tprivate inputElement: HTMLInputElement;\n\n\t/** Whether the user is creating a composition string (IME events). */\n\tprivate _composing = false;\n\n\tonChange = (_: any) => {\n\t};\n\tonTouched = () => {\n\t};\n\n\tconstructor(\n\t\tprivate _renderer: Renderer2,\n\t\tprivate _elementRef: ElementRef,\n\t\t@Optional() @Inject(COMPOSITION_BUFFER_MODE) private _compositionMode: boolean\n\t) {\n\t\tif (this._compositionMode == null) {\n\t\t\tthis._compositionMode = !_isAndroid();\n\t\t}\n\t}\n\n\tngOnInit() {\n\t\tthis._setupMask(true);\n\t\tif (this.textMaskInputElement !== undefined) {\n\t\t\tthis.textMaskInputElement.update(this.inputElement.value);\n\t\t}\n\t}\n\n\tngOnChanges(changes: SimpleChanges) {\n\t\tthis._setupMask(true);\n\t\tif (this.textMaskInputElement !== undefined) {\n\t\t\tthis.textMaskInputElement.update(this.inputElement.value);\n\t\t}\n\t}\n\n\t@HostListener('blur')\n\tonBlur() {\n\t\tthis.onTouched();\n\t}\n\n\twriteValue(value: any) {\n\t\tthis._setupMask();\n\n\t\t// set the initial value for cases where the mask is disabled\n\t\tconst normalizedValue = value == null ? '' : value;\n\t\tthis._renderer.setProperty(this.inputElement, 'value', normalizedValue);\n\n\t\tif (this.textMaskInputElement !== undefined) {\n\t\t\tthis.textMaskInputElement.update(value);\n\t\t}\n\t}\n\n\tregisterOnChange(fn: (_: any) => void): void {\n\t\tthis.onChange = fn;\n\t}\n\n\tregisterOnTouched(fn: () => void): void {\n\t\tthis.onTouched = fn;\n\t}\n\n\tsetDisabledState(isDisabled: boolean): void {\n\t\tthis._renderer.setProperty(this._elementRef.nativeElement, 'disabled', isDisabled);\n\t}\n\n\t_handleInput(value) {\n\t\tif (!this._compositionMode || (this._compositionMode && !this._composing)) {\n\t\t\tthis._setupMask();\n\n\t\t\tif (this.textMaskInputElement !== undefined) {\n\t\t\t\tthis.textMaskInputElement.update(value);\n\n\t\t\t\t// get the updated value\n\t\t\t\tvalue = this.inputElement.value;\n\n\t\t\t\tif (this.clean) {\n\t\t\t\t\tthis.onChange(clean(value));\n\t\t\t\t} else {\n\t\t\t\t\tthis.onChange(value);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n\t_setupMask(create = false) {\n\t\tthis.textMaskConfig = {\n\t\t\tmask: mask(this.maxNumberLength),\n\t\t\tguide: false,\n\t\t\tplaceholderChar: '_',\n\t\t\tpipe: undefined,\n\t\t\tkeepCharPositions: false,\n\t\t};\n\t\tif (!this.inputElement) {\n\t\t\tif (this._elementRef.nativeElement.tagName.toUpperCase() === 'INPUT') {\n\t\t\t\t// `textMask` directive is used directly on an input element\n\t\t\t\tthis.inputElement = this._elementRef.nativeElement;\n\t\t\t} else {\n\t\t\t\t// `textMask` directive is used on an abstracted input element, `md-input-container`, etc\n\t\t\t\tthis.inputElement = this._elementRef.nativeElement.getElementsByTagName('INPUT')[0];\n\t\t\t}\n\t\t}\n\n\t\tif (this.inputElement && create) {\n\t\t\tthis.textMaskInputElement = createTextMaskInputElement(\n\t\t\t\tObject.assign({ inputElement: this.inputElement }, this.textMaskConfig)\n\t\t\t);\n\t\t}\n\n\t}\n\n\t_compositionStart(): void {\n\t\tthis._composing = true;\n\t}\n\n\t_compositionEnd(value: any): void {\n\t\tthis._composing = false;\n\t\tthis._compositionMode && this._handleInput(value);\n\t}\n}\n"]} |
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingReturn,uselessCode} checked by tsc | ||
* @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
@@ -5,0 +5,0 @@ import { NgModule } from '@angular/core'; |
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingReturn,uselessCode} checked by tsc | ||
* @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
@@ -5,0 +5,0 @@ import { Pipe } from '@angular/core'; |
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingReturn,uselessCode} checked by tsc | ||
* @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
@@ -12,4 +12,4 @@ /** @type {?} */ | ||
/** @type {?} */ | ||
export const mask = () => (rawValue) => { | ||
if (clean(rawValue).length <= 12) { | ||
export const mask = (maxLength = 13) => (rawValue) => { | ||
if (clean(rawValue).length <= 12 || maxLength === 12) { | ||
return ['+', /[1-9]/, ' ', '(', /[1-9]/, /\d/, /\d/, ')', ' ', /\d/, /\d/, /\d/, '-', /\d/, /\d/, '-', /\d/, /\d/]; | ||
@@ -19,2 +19,2 @@ } | ||
}; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXRpbHMuanMiLCJzb3VyY2VSb290Ijoibmc6Ly9uZ3gtcGhvbmUtbWFzay8iLCJzb3VyY2VzIjpbImxpYi91dGlscy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztBQUFBLE1BQU0sT0FBTyxLQUFLLEdBQUcsQ0FBQyxNQUFNLEVBQUUsRUFBRTtJQUMvQixPQUFPLE1BQU07U0FDWCxRQUFRLEVBQUU7U0FDVixPQUFPLENBQUMsYUFBYSxFQUFFLEVBQUUsQ0FBQyxDQUFDO0FBQzlCLENBQUM7O0FBRUQsTUFBTSxPQUFPLElBQUksR0FBRyxHQUFHLEVBQUUsQ0FBQyxDQUFDLFFBQVEsRUFBRSxFQUFFO0lBQ3RDLElBQUksS0FBSyxDQUFDLFFBQVEsQ0FBQyxDQUFDLE1BQU0sSUFBSSxFQUFFLEVBQUU7UUFDakMsT0FBTyxDQUFDLEdBQUcsRUFBRSxPQUFPLEVBQUUsR0FBRyxFQUFFLEdBQUcsRUFBRSxPQUFPLEVBQUUsSUFBSSxFQUFFLElBQUksRUFBRSxHQUFHLEVBQUUsR0FBRyxFQUFFLElBQUksRUFBRSxJQUFJLEVBQUUsSUFBSSxFQUFFLEdBQUcsRUFBRSxJQUFJLEVBQUUsSUFBSSxFQUFFLEdBQUcsRUFBRSxJQUFJLEVBQUUsSUFBSSxDQUFDLENBQUM7S0FDbkg7SUFFRCxPQUFPLENBQUMsR0FBRyxFQUFFLE9BQU8sRUFBRSxHQUFHLEVBQUUsR0FBRyxFQUFFLE9BQU8sRUFBRSxJQUFJLEVBQUUsSUFBSSxFQUFFLEdBQUcsRUFBRSxHQUFHLEVBQUUsSUFBSSxFQUFFLElBQUksRUFBRSxJQUFJLEVBQUUsR0FBRyxFQUFFLElBQUksRUFBRSxJQUFJLEVBQUUsSUFBSSxFQUFFLEdBQUcsRUFBRSxJQUFJLEVBQUUsSUFBSSxDQUFDLENBQUM7QUFFMUgsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBjb25zdCBjbGVhbiA9IChudW1iZXIpID0+IHtcblx0cmV0dXJuIG51bWJlclxuXHRcdC50b1N0cmluZygpXG5cdFx0LnJlcGxhY2UoL1teXFxkXFxeXFwrXS9nbSwgJycpO1xufTtcblxuZXhwb3J0IGNvbnN0IG1hc2sgPSAoKSA9PiAocmF3VmFsdWUpID0+IHtcblx0aWYgKGNsZWFuKHJhd1ZhbHVlKS5sZW5ndGggPD0gMTIpIHtcblx0XHRyZXR1cm4gWycrJywgL1sxLTldLywgJyAnLCAnKCcsIC9bMS05XS8sIC9cXGQvLCAvXFxkLywgJyknLCAnICcsIC9cXGQvLCAvXFxkLywgL1xcZC8sICctJywgL1xcZC8sIC9cXGQvLCAnLScsIC9cXGQvLCAvXFxkL107XG5cdH1cblxuXHRyZXR1cm4gWycrJywgL1sxLTldLywgJyAnLCAnKCcsIC9bMS05XS8sIC9cXGQvLCAvXFxkLywgJyknLCAnICcsIC9cXGQvLCAvXFxkLywgL1xcZC8sICctJywgL1xcZC8sIC9cXGQvLCAvXFxkLywgJy0nLCAvXFxkLywgL1xcZC9dO1xuXG59O1xuIl19 | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXRpbHMuanMiLCJzb3VyY2VSb290Ijoibmc6Ly9uZ3gtcGhvbmUtbWFzay8iLCJzb3VyY2VzIjpbImxpYi91dGlscy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztBQUFBLE1BQU0sT0FBTyxLQUFLLEdBQUcsQ0FBQyxNQUFNLEVBQUUsRUFBRTtJQUMvQixPQUFPLE1BQU07U0FDWCxRQUFRLEVBQUU7U0FDVixPQUFPLENBQUMsYUFBYSxFQUFFLEVBQUUsQ0FBQyxDQUFDO0FBQzlCLENBQUM7O0FBRUQsTUFBTSxPQUFPLElBQUksR0FBRyxDQUFDLFlBQW9CLEVBQUUsRUFBRSxFQUFFLENBQUMsQ0FBQyxRQUFRLEVBQUUsRUFBRTtJQUM1RCxJQUFJLEtBQUssQ0FBQyxRQUFRLENBQUMsQ0FBQyxNQUFNLElBQUksRUFBRSxJQUFJLFNBQVMsS0FBSyxFQUFFLEVBQUU7UUFDckQsT0FBTyxDQUFDLEdBQUcsRUFBRSxPQUFPLEVBQUUsR0FBRyxFQUFFLEdBQUcsRUFBRSxPQUFPLEVBQUUsSUFBSSxFQUFFLElBQUksRUFBRSxHQUFHLEVBQUUsR0FBRyxFQUFFLElBQUksRUFBRSxJQUFJLEVBQUUsSUFBSSxFQUFFLEdBQUcsRUFBRSxJQUFJLEVBQUUsSUFBSSxFQUFFLEdBQUcsRUFBRSxJQUFJLEVBQUUsSUFBSSxDQUFDLENBQUM7S0FDbkg7SUFFRCxPQUFPLENBQUMsR0FBRyxFQUFFLE9BQU8sRUFBRSxHQUFHLEVBQUUsR0FBRyxFQUFFLE9BQU8sRUFBRSxJQUFJLEVBQUUsSUFBSSxFQUFFLEdBQUcsRUFBRSxHQUFHLEVBQUUsSUFBSSxFQUFFLElBQUksRUFBRSxJQUFJLEVBQUUsR0FBRyxFQUFFLElBQUksRUFBRSxJQUFJLEVBQUUsSUFBSSxFQUFFLEdBQUcsRUFBRSxJQUFJLEVBQUUsSUFBSSxDQUFDLENBQUM7QUFFMUgsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBjb25zdCBjbGVhbiA9IChudW1iZXIpID0+IHtcblx0cmV0dXJuIG51bWJlclxuXHRcdC50b1N0cmluZygpXG5cdFx0LnJlcGxhY2UoL1teXFxkXFxeXFwrXS9nbSwgJycpO1xufTtcblxuZXhwb3J0IGNvbnN0IG1hc2sgPSAobWF4TGVuZ3RoOiBudW1iZXIgPSAxMykgPT4gKHJhd1ZhbHVlKSA9PiB7XG5cdGlmIChjbGVhbihyYXdWYWx1ZSkubGVuZ3RoIDw9IDEyIHx8IG1heExlbmd0aCA9PT0gMTIpIHtcblx0XHRyZXR1cm4gWycrJywgL1sxLTldLywgJyAnLCAnKCcsIC9bMS05XS8sIC9cXGQvLCAvXFxkLywgJyknLCAnICcsIC9cXGQvLCAvXFxkLywgL1xcZC8sICctJywgL1xcZC8sIC9cXGQvLCAnLScsIC9cXGQvLCAvXFxkL107XG5cdH1cblxuXHRyZXR1cm4gWycrJywgL1sxLTldLywgJyAnLCAnKCcsIC9bMS05XS8sIC9cXGQvLCAvXFxkLywgJyknLCAnICcsIC9cXGQvLCAvXFxkLywgL1xcZC8sICctJywgL1xcZC8sIC9cXGQvLCAvXFxkLywgJy0nLCAvXFxkLywgL1xcZC9dO1xuXG59O1xuIl19 |
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingReturn,uselessCode} checked by tsc | ||
* @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
@@ -5,0 +5,0 @@ /** |
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingReturn,uselessCode} checked by tsc | ||
* @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
@@ -5,0 +5,0 @@ export { TextMaskConfig, NgxPhoneMaskDirective } from './lib/ngx-phone-mask.directive'; |
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingReturn,uselessCode} checked by tsc | ||
* @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
@@ -46,9 +46,3 @@ import { Directive, ElementRef, forwardRef, HostListener, Inject, Input, Optional, Renderer2 } from '@angular/core'; | ||
this.clean = true; | ||
this.textMaskConfig = { | ||
mask: mask(), | ||
guide: false, | ||
placeholderChar: '_', | ||
pipe: undefined, | ||
keepCharPositions: false, | ||
}; | ||
this.maxNumberLength = 13; | ||
/** | ||
@@ -186,2 +180,9 @@ * Whether the user is creating a composition string (IME events). | ||
if (create === void 0) { create = false; } | ||
this.textMaskConfig = { | ||
mask: mask(this.maxNumberLength), | ||
guide: false, | ||
placeholderChar: '_', | ||
pipe: undefined, | ||
keepCharPositions: false, | ||
}; | ||
if (!this.inputElement) { | ||
@@ -247,2 +248,3 @@ if (this._elementRef.nativeElement.tagName.toUpperCase() === 'INPUT') { | ||
clean: [{ type: Input }], | ||
maxNumberLength: [{ type: Input }], | ||
onBlur: [{ type: HostListener, args: ['blur',] }] | ||
@@ -257,6 +259,14 @@ }; | ||
/** @type {?} */ | ||
NgxPhoneMaskDirective.prototype.maxNumberLength; | ||
/** @type {?} */ | ||
NgxPhoneMaskDirective.prototype.textMaskConfig; | ||
/** @type {?} */ | ||
/** | ||
* @type {?} | ||
* @private | ||
*/ | ||
NgxPhoneMaskDirective.prototype.textMaskInputElement; | ||
/** @type {?} */ | ||
/** | ||
* @type {?} | ||
* @private | ||
*/ | ||
NgxPhoneMaskDirective.prototype.inputElement; | ||
@@ -266,2 +276,3 @@ /** | ||
* @type {?} | ||
* @private | ||
*/ | ||
@@ -273,9 +284,18 @@ NgxPhoneMaskDirective.prototype._composing; | ||
NgxPhoneMaskDirective.prototype.onTouched; | ||
/** @type {?} */ | ||
/** | ||
* @type {?} | ||
* @private | ||
*/ | ||
NgxPhoneMaskDirective.prototype._renderer; | ||
/** @type {?} */ | ||
/** | ||
* @type {?} | ||
* @private | ||
*/ | ||
NgxPhoneMaskDirective.prototype._elementRef; | ||
/** @type {?} */ | ||
/** | ||
* @type {?} | ||
* @private | ||
*/ | ||
NgxPhoneMaskDirective.prototype._compositionMode; | ||
} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ngx-phone-mask.directive.js","sourceRoot":"ng://ngx-phone-mask/","sources":["lib/ngx-phone-mask.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n\tDirective,\n\tElementRef,\n\tforwardRef, HostListener,\n\tInject, Input,\n\tOnChanges, OnInit,\n\tOptional,\n\tRenderer2,\n\tSimpleChanges\n} from '@angular/core';\nimport { NG_VALUE_ACCESSOR, ControlValueAccessor, COMPOSITION_BUFFER_MODE } from '@angular/forms';\nimport { ɵgetDOM as getDOM } from '@angular/platform-browser';\nimport { createTextMaskInputElement } from 'text-mask-core/dist/textMaskCore';\nimport { mask, clean } from './utils';\n\nexport class TextMaskConfig {\n\tmask: Array<string | RegExp> | ((raw: string) => Array<string | RegExp>) | false;\n\tguide?: boolean;\n\tplaceholderChar?: string;\n\tpipe?: (conformedValue: string, config: TextMaskConfig) => false | string | object;\n\tkeepCharPositions?: boolean;\n\tshowMask?: boolean;\n}\n\n/**\n * We must check whether the agent is Android because composition events\n * behave differently between iOS and Android.\n */\nfunction _isAndroid(): boolean {\n\tconst userAgent = getDOM() ? getDOM().getUserAgent() : '';\n\treturn /android (\\d+)/.test(userAgent.toLowerCase());\n}\n\n@Directive({\n\thost: {\n\t\t'(input)': '_handleInput($event.target.value)',\n\t\t'(blur)': 'onTouched()',\n\t\t'(compositionstart)': '_compositionStart()',\n\t\t'(compositionend)': '_compositionEnd($event.target.value)'\n\t},\n\tselector: '[ngxPhoneMask]',\n\texportAs: 'ngxPhoneMask',\n\tproviders: [{\n\t\tprovide: NG_VALUE_ACCESSOR,\n\t\tuseExisting: forwardRef(() => NgxPhoneMaskDirective),\n\t\tmulti: true\n\t}]\n})\nexport class NgxPhoneMaskDirective implements ControlValueAccessor, OnChanges, OnInit {\n\t@Input() clean = true;\n\n\ttextMaskConfig: TextMaskConfig = {\n\t\tmask: mask(),\n\t\tguide: false,\n\t\tplaceholderChar: '_',\n\t\tpipe: undefined,\n\t\tkeepCharPositions: false,\n\t};\n\n\tprivate textMaskInputElement: any;\n\tprivate inputElement: HTMLInputElement;\n\n\t/** Whether the user is creating a composition string (IME events). */\n\tprivate _composing = false;\n\n\tonChange = (_: any) => {\n\t};\n\tonTouched = () => {\n\t};\n\n\tconstructor(\n\t\tprivate _renderer: Renderer2,\n\t\tprivate _elementRef: ElementRef,\n\t\t@Optional() @Inject(COMPOSITION_BUFFER_MODE) private _compositionMode: boolean\n\t) {\n\t\tif (this._compositionMode == null) {\n\t\t\tthis._compositionMode = !_isAndroid();\n\t\t}\n\t}\n\n\tngOnInit() {\n\t\tthis._setupMask(true);\n\t\tif (this.textMaskInputElement !== undefined) {\n\t\t\tthis.textMaskInputElement.update(this.inputElement.value);\n\t\t}\n\t}\n\n\tngOnChanges(changes: SimpleChanges) {\n\t\tthis._setupMask(true);\n\t\tif (this.textMaskInputElement !== undefined) {\n\t\t\tthis.textMaskInputElement.update(this.inputElement.value);\n\t\t}\n\t}\n\n\t@HostListener('blur')\n\tonBlur() {\n\t\tthis.onTouched();\n\t}\n\n\twriteValue(value: any) {\n\t\tthis._setupMask();\n\n\t\t// set the initial value for cases where the mask is disabled\n\t\tconst normalizedValue = value == null ? '' : value;\n\t\tthis._renderer.setProperty(this.inputElement, 'value', normalizedValue);\n\n\t\tif (this.textMaskInputElement !== undefined) {\n\t\t\tthis.textMaskInputElement.update(value);\n\t\t}\n\t}\n\n\tregisterOnChange(fn: (_: any) => void): void {\n\t\tthis.onChange = fn;\n\t}\n\n\tregisterOnTouched(fn: () => void): void {\n\t\tthis.onTouched = fn;\n\t}\n\n\tsetDisabledState(isDisabled: boolean): void {\n\t\tthis._renderer.setProperty(this._elementRef.nativeElement, 'disabled', isDisabled);\n\t}\n\n\t_handleInput(value) {\n\t\tif (!this._compositionMode || (this._compositionMode && !this._composing)) {\n\t\t\tthis._setupMask();\n\n\t\t\tif (this.textMaskInputElement !== undefined) {\n\t\t\t\tthis.textMaskInputElement.update(value);\n\n\t\t\t\t// get the updated value\n\t\t\t\tvalue = this.inputElement.value;\n\n\t\t\t\tif (this.clean) {\n\t\t\t\t\tthis.onChange(clean(value));\n\t\t\t\t} else {\n\t\t\t\t\tthis.onChange(value);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n\t_setupMask(create = false) {\n\t\tif (!this.inputElement) {\n\t\t\tif (this._elementRef.nativeElement.tagName.toUpperCase() === 'INPUT') {\n\t\t\t\t// `textMask` directive is used directly on an input element\n\t\t\t\tthis.inputElement = this._elementRef.nativeElement;\n\t\t\t} else {\n\t\t\t\t// `textMask` directive is used on an abstracted input element, `md-input-container`, etc\n\t\t\t\tthis.inputElement = this._elementRef.nativeElement.getElementsByTagName('INPUT')[0];\n\t\t\t}\n\t\t}\n\n\t\tif (this.inputElement && create) {\n\t\t\tthis.textMaskInputElement = createTextMaskInputElement(\n\t\t\t\tObject.assign({ inputElement: this.inputElement }, this.textMaskConfig)\n\t\t\t);\n\t\t}\n\n\t}\n\n\t_compositionStart(): void {\n\t\tthis._composing = true;\n\t}\n\n\t_compositionEnd(value: any): void {\n\t\tthis._composing = false;\n\t\tthis._compositionMode && this._handleInput(value);\n\t}\n}\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ngx-phone-mask.directive.js","sourceRoot":"ng://ngx-phone-mask/","sources":["lib/ngx-phone-mask.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n\tDirective,\n\tElementRef,\n\tforwardRef, HostListener,\n\tInject, Input,\n\tOnChanges, OnInit,\n\tOptional,\n\tRenderer2,\n\tSimpleChanges\n} from '@angular/core';\nimport { NG_VALUE_ACCESSOR, ControlValueAccessor, COMPOSITION_BUFFER_MODE } from '@angular/forms';\nimport { ɵgetDOM as getDOM } from '@angular/platform-browser';\nimport { createTextMaskInputElement } from 'text-mask-core/dist/textMaskCore';\nimport { mask, clean } from './utils';\n\nexport class TextMaskConfig {\n\tmask: Array<string | RegExp> | ((raw: string) => Array<string | RegExp>) | false;\n\tguide?: boolean;\n\tplaceholderChar?: string;\n\tpipe?: (conformedValue: string, config: TextMaskConfig) => false | string | object;\n\tkeepCharPositions?: boolean;\n\tshowMask?: boolean;\n}\n\n/**\n * We must check whether the agent is Android because composition events\n * behave differently between iOS and Android.\n */\nfunction _isAndroid(): boolean {\n\tconst userAgent = getDOM() ? getDOM().getUserAgent() : '';\n\treturn /android (\\d+)/.test(userAgent.toLowerCase());\n}\n\n@Directive({\n\thost: {\n\t\t'(input)': '_handleInput($event.target.value)',\n\t\t'(blur)': 'onTouched()',\n\t\t'(compositionstart)': '_compositionStart()',\n\t\t'(compositionend)': '_compositionEnd($event.target.value)'\n\t},\n\tselector: '[ngxPhoneMask]',\n\texportAs: 'ngxPhoneMask',\n\tproviders: [{\n\t\tprovide: NG_VALUE_ACCESSOR,\n\t\tuseExisting: forwardRef(() => NgxPhoneMaskDirective),\n\t\tmulti: true\n\t}]\n})\nexport class NgxPhoneMaskDirective implements ControlValueAccessor, OnChanges, OnInit {\n\t@Input() clean = true;\n\t@Input() maxNumberLength: number = 13;\n\n\ttextMaskConfig: TextMaskConfig;\n\n\tprivate textMaskInputElement: any;\n\tprivate inputElement: HTMLInputElement;\n\n\t/** Whether the user is creating a composition string (IME events). */\n\tprivate _composing = false;\n\n\tonChange = (_: any) => {\n\t};\n\tonTouched = () => {\n\t};\n\n\tconstructor(\n\t\tprivate _renderer: Renderer2,\n\t\tprivate _elementRef: ElementRef,\n\t\t@Optional() @Inject(COMPOSITION_BUFFER_MODE) private _compositionMode: boolean\n\t) {\n\t\tif (this._compositionMode == null) {\n\t\t\tthis._compositionMode = !_isAndroid();\n\t\t}\n\t}\n\n\tngOnInit() {\n\t\tthis._setupMask(true);\n\t\tif (this.textMaskInputElement !== undefined) {\n\t\t\tthis.textMaskInputElement.update(this.inputElement.value);\n\t\t}\n\t}\n\n\tngOnChanges(changes: SimpleChanges) {\n\t\tthis._setupMask(true);\n\t\tif (this.textMaskInputElement !== undefined) {\n\t\t\tthis.textMaskInputElement.update(this.inputElement.value);\n\t\t}\n\t}\n\n\t@HostListener('blur')\n\tonBlur() {\n\t\tthis.onTouched();\n\t}\n\n\twriteValue(value: any) {\n\t\tthis._setupMask();\n\n\t\t// set the initial value for cases where the mask is disabled\n\t\tconst normalizedValue = value == null ? '' : value;\n\t\tthis._renderer.setProperty(this.inputElement, 'value', normalizedValue);\n\n\t\tif (this.textMaskInputElement !== undefined) {\n\t\t\tthis.textMaskInputElement.update(value);\n\t\t}\n\t}\n\n\tregisterOnChange(fn: (_: any) => void): void {\n\t\tthis.onChange = fn;\n\t}\n\n\tregisterOnTouched(fn: () => void): void {\n\t\tthis.onTouched = fn;\n\t}\n\n\tsetDisabledState(isDisabled: boolean): void {\n\t\tthis._renderer.setProperty(this._elementRef.nativeElement, 'disabled', isDisabled);\n\t}\n\n\t_handleInput(value) {\n\t\tif (!this._compositionMode || (this._compositionMode && !this._composing)) {\n\t\t\tthis._setupMask();\n\n\t\t\tif (this.textMaskInputElement !== undefined) {\n\t\t\t\tthis.textMaskInputElement.update(value);\n\n\t\t\t\t// get the updated value\n\t\t\t\tvalue = this.inputElement.value;\n\n\t\t\t\tif (this.clean) {\n\t\t\t\t\tthis.onChange(clean(value));\n\t\t\t\t} else {\n\t\t\t\t\tthis.onChange(value);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n\t_setupMask(create = false) {\n\t\tthis.textMaskConfig = {\n\t\t\tmask: mask(this.maxNumberLength),\n\t\t\tguide: false,\n\t\t\tplaceholderChar: '_',\n\t\t\tpipe: undefined,\n\t\t\tkeepCharPositions: false,\n\t\t};\n\t\tif (!this.inputElement) {\n\t\t\tif (this._elementRef.nativeElement.tagName.toUpperCase() === 'INPUT') {\n\t\t\t\t// `textMask` directive is used directly on an input element\n\t\t\t\tthis.inputElement = this._elementRef.nativeElement;\n\t\t\t} else {\n\t\t\t\t// `textMask` directive is used on an abstracted input element, `md-input-container`, etc\n\t\t\t\tthis.inputElement = this._elementRef.nativeElement.getElementsByTagName('INPUT')[0];\n\t\t\t}\n\t\t}\n\n\t\tif (this.inputElement && create) {\n\t\t\tthis.textMaskInputElement = createTextMaskInputElement(\n\t\t\t\tObject.assign({ inputElement: this.inputElement }, this.textMaskConfig)\n\t\t\t);\n\t\t}\n\n\t}\n\n\t_compositionStart(): void {\n\t\tthis._composing = true;\n\t}\n\n\t_compositionEnd(value: any): void {\n\t\tthis._composing = false;\n\t\tthis._compositionMode && this._handleInput(value);\n\t}\n}\n"]} |
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingReturn,uselessCode} checked by tsc | ||
* @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
@@ -5,0 +5,0 @@ import { NgModule } from '@angular/core'; |
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingReturn,uselessCode} checked by tsc | ||
* @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
@@ -5,0 +5,0 @@ import { Pipe } from '@angular/core'; |
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingReturn,uselessCode} checked by tsc | ||
* @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
@@ -12,8 +12,11 @@ /** @type {?} */ | ||
/** @type {?} */ | ||
export var mask = function () { return function (rawValue) { | ||
if (clean(rawValue).length <= 12) { | ||
return ['+', /[1-9]/, ' ', '(', /[1-9]/, /\d/, /\d/, ')', ' ', /\d/, /\d/, /\d/, '-', /\d/, /\d/, '-', /\d/, /\d/]; | ||
} | ||
return ['+', /[1-9]/, ' ', '(', /[1-9]/, /\d/, /\d/, ')', ' ', /\d/, /\d/, /\d/, '-', /\d/, /\d/, /\d/, '-', /\d/, /\d/]; | ||
}; }; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXRpbHMuanMiLCJzb3VyY2VSb290Ijoibmc6Ly9uZ3gtcGhvbmUtbWFzay8iLCJzb3VyY2VzIjpbImxpYi91dGlscy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztBQUFBLE1BQU0sS0FBTyxLQUFLLEdBQUcsVUFBQyxNQUFNO0lBQzNCLE9BQU8sTUFBTTtTQUNYLFFBQVEsRUFBRTtTQUNWLE9BQU8sQ0FBQyxhQUFhLEVBQUUsRUFBRSxDQUFDLENBQUM7QUFDOUIsQ0FBQzs7QUFFRCxNQUFNLEtBQU8sSUFBSSxHQUFHLGNBQU0sT0FBQSxVQUFDLFFBQVE7SUFDbEMsSUFBSSxLQUFLLENBQUMsUUFBUSxDQUFDLENBQUMsTUFBTSxJQUFJLEVBQUUsRUFBRTtRQUNqQyxPQUFPLENBQUMsR0FBRyxFQUFFLE9BQU8sRUFBRSxHQUFHLEVBQUUsR0FBRyxFQUFFLE9BQU8sRUFBRSxJQUFJLEVBQUUsSUFBSSxFQUFFLEdBQUcsRUFBRSxHQUFHLEVBQUUsSUFBSSxFQUFFLElBQUksRUFBRSxJQUFJLEVBQUUsR0FBRyxFQUFFLElBQUksRUFBRSxJQUFJLEVBQUUsR0FBRyxFQUFFLElBQUksRUFBRSxJQUFJLENBQUMsQ0FBQztLQUNuSDtJQUVELE9BQU8sQ0FBQyxHQUFHLEVBQUUsT0FBTyxFQUFFLEdBQUcsRUFBRSxHQUFHLEVBQUUsT0FBTyxFQUFFLElBQUksRUFBRSxJQUFJLEVBQUUsR0FBRyxFQUFFLEdBQUcsRUFBRSxJQUFJLEVBQUUsSUFBSSxFQUFFLElBQUksRUFBRSxHQUFHLEVBQUUsSUFBSSxFQUFFLElBQUksRUFBRSxJQUFJLEVBQUUsR0FBRyxFQUFFLElBQUksRUFBRSxJQUFJLENBQUMsQ0FBQztBQUUxSCxDQUFDLEVBUHlCLENBT3pCIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGNvbnN0IGNsZWFuID0gKG51bWJlcikgPT4ge1xuXHRyZXR1cm4gbnVtYmVyXG5cdFx0LnRvU3RyaW5nKClcblx0XHQucmVwbGFjZSgvW15cXGRcXF5cXCtdL2dtLCAnJyk7XG59O1xuXG5leHBvcnQgY29uc3QgbWFzayA9ICgpID0+IChyYXdWYWx1ZSkgPT4ge1xuXHRpZiAoY2xlYW4ocmF3VmFsdWUpLmxlbmd0aCA8PSAxMikge1xuXHRcdHJldHVybiBbJysnLCAvWzEtOV0vLCAnICcsICcoJywgL1sxLTldLywgL1xcZC8sIC9cXGQvLCAnKScsICcgJywgL1xcZC8sIC9cXGQvLCAvXFxkLywgJy0nLCAvXFxkLywgL1xcZC8sICctJywgL1xcZC8sIC9cXGQvXTtcblx0fVxuXG5cdHJldHVybiBbJysnLCAvWzEtOV0vLCAnICcsICcoJywgL1sxLTldLywgL1xcZC8sIC9cXGQvLCAnKScsICcgJywgL1xcZC8sIC9cXGQvLCAvXFxkLywgJy0nLCAvXFxkLywgL1xcZC8sIC9cXGQvLCAnLScsIC9cXGQvLCAvXFxkL107XG5cbn07XG4iXX0= | ||
export var mask = function (maxLength) { | ||
if (maxLength === void 0) { maxLength = 13; } | ||
return function (rawValue) { | ||
if (clean(rawValue).length <= 12 || maxLength === 12) { | ||
return ['+', /[1-9]/, ' ', '(', /[1-9]/, /\d/, /\d/, ')', ' ', /\d/, /\d/, /\d/, '-', /\d/, /\d/, '-', /\d/, /\d/]; | ||
} | ||
return ['+', /[1-9]/, ' ', '(', /[1-9]/, /\d/, /\d/, ')', ' ', /\d/, /\d/, /\d/, '-', /\d/, /\d/, /\d/, '-', /\d/, /\d/]; | ||
}; | ||
}; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXRpbHMuanMiLCJzb3VyY2VSb290Ijoibmc6Ly9uZ3gtcGhvbmUtbWFzay8iLCJzb3VyY2VzIjpbImxpYi91dGlscy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztBQUFBLE1BQU0sS0FBTyxLQUFLLEdBQUcsVUFBQyxNQUFNO0lBQzNCLE9BQU8sTUFBTTtTQUNYLFFBQVEsRUFBRTtTQUNWLE9BQU8sQ0FBQyxhQUFhLEVBQUUsRUFBRSxDQUFDLENBQUM7QUFDOUIsQ0FBQzs7QUFFRCxNQUFNLEtBQU8sSUFBSSxHQUFHLFVBQUMsU0FBc0I7SUFBdEIsMEJBQUEsRUFBQSxjQUFzQjtJQUFLLE9BQUEsVUFBQyxRQUFRO1FBQ3hELElBQUksS0FBSyxDQUFDLFFBQVEsQ0FBQyxDQUFDLE1BQU0sSUFBSSxFQUFFLElBQUksU0FBUyxLQUFLLEVBQUUsRUFBRTtZQUNyRCxPQUFPLENBQUMsR0FBRyxFQUFFLE9BQU8sRUFBRSxHQUFHLEVBQUUsR0FBRyxFQUFFLE9BQU8sRUFBRSxJQUFJLEVBQUUsSUFBSSxFQUFFLEdBQUcsRUFBRSxHQUFHLEVBQUUsSUFBSSxFQUFFLElBQUksRUFBRSxJQUFJLEVBQUUsR0FBRyxFQUFFLElBQUksRUFBRSxJQUFJLEVBQUUsR0FBRyxFQUFFLElBQUksRUFBRSxJQUFJLENBQUMsQ0FBQztTQUNuSDtRQUVELE9BQU8sQ0FBQyxHQUFHLEVBQUUsT0FBTyxFQUFFLEdBQUcsRUFBRSxHQUFHLEVBQUUsT0FBTyxFQUFFLElBQUksRUFBRSxJQUFJLEVBQUUsR0FBRyxFQUFFLEdBQUcsRUFBRSxJQUFJLEVBQUUsSUFBSSxFQUFFLElBQUksRUFBRSxHQUFHLEVBQUUsSUFBSSxFQUFFLElBQUksRUFBRSxJQUFJLEVBQUUsR0FBRyxFQUFFLElBQUksRUFBRSxJQUFJLENBQUMsQ0FBQztJQUUxSCxDQUFDO0FBUCtDLENBTy9DIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGNvbnN0IGNsZWFuID0gKG51bWJlcikgPT4ge1xuXHRyZXR1cm4gbnVtYmVyXG5cdFx0LnRvU3RyaW5nKClcblx0XHQucmVwbGFjZSgvW15cXGRcXF5cXCtdL2dtLCAnJyk7XG59O1xuXG5leHBvcnQgY29uc3QgbWFzayA9IChtYXhMZW5ndGg6IG51bWJlciA9IDEzKSA9PiAocmF3VmFsdWUpID0+IHtcblx0aWYgKGNsZWFuKHJhd1ZhbHVlKS5sZW5ndGggPD0gMTIgfHwgbWF4TGVuZ3RoID09PSAxMikge1xuXHRcdHJldHVybiBbJysnLCAvWzEtOV0vLCAnICcsICcoJywgL1sxLTldLywgL1xcZC8sIC9cXGQvLCAnKScsICcgJywgL1xcZC8sIC9cXGQvLCAvXFxkLywgJy0nLCAvXFxkLywgL1xcZC8sICctJywgL1xcZC8sIC9cXGQvXTtcblx0fVxuXG5cdHJldHVybiBbJysnLCAvWzEtOV0vLCAnICcsICcoJywgL1sxLTldLywgL1xcZC8sIC9cXGQvLCAnKScsICcgJywgL1xcZC8sIC9cXGQvLCAvXFxkLywgJy0nLCAvXFxkLywgL1xcZC8sIC9cXGQvLCAnLScsIC9cXGQvLCAvXFxkL107XG5cbn07XG4iXX0= |
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingReturn,uselessCode} checked by tsc | ||
* @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
@@ -5,0 +5,0 @@ /** |
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingReturn,uselessCode} checked by tsc | ||
* @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
@@ -5,0 +5,0 @@ export { TextMaskConfig, NgxPhoneMaskDirective } from './lib/ngx-phone-mask.directive'; |
@@ -1,5 +0,5 @@ | ||
import { Directive, ElementRef, forwardRef, HostListener, Inject, Input, Optional, Renderer2, Pipe, NgModule } from '@angular/core'; | ||
import { NG_VALUE_ACCESSOR, COMPOSITION_BUFFER_MODE } from '@angular/forms'; | ||
import { ɵgetDOM } from '@angular/platform-browser'; | ||
import { createTextMaskInputElement } from 'text-mask-core/dist/textMaskCore'; | ||
import { Directive, ElementRef, forwardRef, HostListener, Inject, Input, Optional, Renderer2, Pipe, NgModule } from '@angular/core'; | ||
import { conformToMask, TextMaskModule } from 'angular2-text-mask'; | ||
@@ -9,3 +9,3 @@ | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingReturn,uselessCode} checked by tsc | ||
* @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
@@ -19,4 +19,4 @@ /** @type {?} */ | ||
/** @type {?} */ | ||
const mask = () => (rawValue) => { | ||
if (clean(rawValue).length <= 12) { | ||
const mask = (maxLength = 13) => (rawValue) => { | ||
if (clean(rawValue).length <= 12 || maxLength === 12) { | ||
return ['+', /[1-9]/, ' ', '(', /[1-9]/, /\d/, /\d/, ')', ' ', /\d/, /\d/, /\d/, '-', /\d/, /\d/, '-', /\d/, /\d/]; | ||
@@ -29,3 +29,3 @@ } | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingReturn,uselessCode} checked by tsc | ||
* @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
@@ -55,9 +55,3 @@ class TextMaskConfig { | ||
this.clean = true; | ||
this.textMaskConfig = { | ||
mask: mask(), | ||
guide: false, | ||
placeholderChar: '_', | ||
pipe: undefined, | ||
keepCharPositions: false, | ||
}; | ||
this.maxNumberLength = 13; | ||
/** | ||
@@ -160,2 +154,9 @@ * Whether the user is creating a composition string (IME events). | ||
_setupMask(create = false) { | ||
this.textMaskConfig = { | ||
mask: mask(this.maxNumberLength), | ||
guide: false, | ||
placeholderChar: '_', | ||
pipe: undefined, | ||
keepCharPositions: false, | ||
}; | ||
if (!this.inputElement) { | ||
@@ -215,2 +216,3 @@ if (this._elementRef.nativeElement.tagName.toUpperCase() === 'INPUT') { | ||
clean: [{ type: Input }], | ||
maxNumberLength: [{ type: Input }], | ||
onBlur: [{ type: HostListener, args: ['blur',] }] | ||
@@ -221,3 +223,3 @@ }; | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingReturn,uselessCode} checked by tsc | ||
* @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
@@ -244,3 +246,3 @@ class NgxPhoneMaskPipe { | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingReturn,uselessCode} checked by tsc | ||
* @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
@@ -265,3 +267,3 @@ class NgxPhoneMaskModule { | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingReturn,uselessCode} checked by tsc | ||
* @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
@@ -271,3 +273,3 @@ | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingReturn,uselessCode} checked by tsc | ||
* @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
@@ -277,2 +279,2 @@ | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"ngx-phone-mask.js.map","sources":["ng://ngx-phone-mask/lib/utils.ts","ng://ngx-phone-mask/lib/ngx-phone-mask.directive.ts","ng://ngx-phone-mask/lib/ngx-phone-mask.pipe.ts","ng://ngx-phone-mask/lib/ngx-phone-mask.module.ts"],"sourcesContent":["export const clean = (number) => {\n\treturn number\n\t\t.toString()\n\t\t.replace(/[^\\d\\^\\+]/gm, '');\n};\n\nexport const mask = () => (rawValue) => {\n\tif (clean(rawValue).length <= 12) {\n\t\treturn ['+', /[1-9]/, ' ', '(', /[1-9]/, /\\d/, /\\d/, ')', ' ', /\\d/, /\\d/, /\\d/, '-', /\\d/, /\\d/, '-', /\\d/, /\\d/];\n\t}\n\n\treturn ['+', /[1-9]/, ' ', '(', /[1-9]/, /\\d/, /\\d/, ')', ' ', /\\d/, /\\d/, /\\d/, '-', /\\d/, /\\d/, /\\d/, '-', /\\d/, /\\d/];\n\n};\n","import {\n\tDirective,\n\tElementRef,\n\tforwardRef, HostListener,\n\tInject, Input,\n\tOnChanges, OnInit,\n\tOptional,\n\tRenderer2,\n\tSimpleChanges\n} from '@angular/core';\nimport { NG_VALUE_ACCESSOR, ControlValueAccessor, COMPOSITION_BUFFER_MODE } from '@angular/forms';\nimport { ÉµgetDOM as getDOM } from '@angular/platform-browser';\nimport { createTextMaskInputElement } from 'text-mask-core/dist/textMaskCore';\nimport { mask, clean } from './utils';\n\nexport class TextMaskConfig {\n\tmask: Array<string | RegExp> | ((raw: string) => Array<string | RegExp>) | false;\n\tguide?: boolean;\n\tplaceholderChar?: string;\n\tpipe?: (conformedValue: string, config: TextMaskConfig) => false | string | object;\n\tkeepCharPositions?: boolean;\n\tshowMask?: boolean;\n}\n\n/**\n * We must check whether the agent is Android because composition events\n * behave differently between iOS and Android.\n */\nfunction _isAndroid(): boolean {\n\tconst userAgent = getDOM() ? getDOM().getUserAgent() : '';\n\treturn /android (\\d+)/.test(userAgent.toLowerCase());\n}\n\n@Directive({\n\thost: {\n\t\t'(input)': '_handleInput($event.target.value)',\n\t\t'(blur)': 'onTouched()',\n\t\t'(compositionstart)': '_compositionStart()',\n\t\t'(compositionend)': '_compositionEnd($event.target.value)'\n\t},\n\tselector: '[ngxPhoneMask]',\n\texportAs: 'ngxPhoneMask',\n\tproviders: [{\n\t\tprovide: NG_VALUE_ACCESSOR,\n\t\tuseExisting: forwardRef(() => NgxPhoneMaskDirective),\n\t\tmulti: true\n\t}]\n})\nexport class NgxPhoneMaskDirective implements ControlValueAccessor, OnChanges, OnInit {\n\t@Input() clean = true;\n\n\ttextMaskConfig: TextMaskConfig = {\n\t\tmask: mask(),\n\t\tguide: false,\n\t\tplaceholderChar: '_',\n\t\tpipe: undefined,\n\t\tkeepCharPositions: false,\n\t};\n\n\tprivate textMaskInputElement: any;\n\tprivate inputElement: HTMLInputElement;\n\n\t/** Whether the user is creating a composition string (IME events). */\n\tprivate _composing = false;\n\n\tonChange = (_: any) => {\n\t};\n\tonTouched = () => {\n\t};\n\n\tconstructor(\n\t\tprivate _renderer: Renderer2,\n\t\tprivate _elementRef: ElementRef,\n\t\t@Optional() @Inject(COMPOSITION_BUFFER_MODE) private _compositionMode: boolean\n\t) {\n\t\tif (this._compositionMode == null) {\n\t\t\tthis._compositionMode = !_isAndroid();\n\t\t}\n\t}\n\n\tngOnInit() {\n\t\tthis._setupMask(true);\n\t\tif (this.textMaskInputElement !== undefined) {\n\t\t\tthis.textMaskInputElement.update(this.inputElement.value);\n\t\t}\n\t}\n\n\tngOnChanges(changes: SimpleChanges) {\n\t\tthis._setupMask(true);\n\t\tif (this.textMaskInputElement !== undefined) {\n\t\t\tthis.textMaskInputElement.update(this.inputElement.value);\n\t\t}\n\t}\n\n\t@HostListener('blur')\n\tonBlur() {\n\t\tthis.onTouched();\n\t}\n\n\twriteValue(value: any) {\n\t\tthis._setupMask();\n\n\t\t// set the initial value for cases where the mask is disabled\n\t\tconst normalizedValue = value == null ? '' : value;\n\t\tthis._renderer.setProperty(this.inputElement, 'value', normalizedValue);\n\n\t\tif (this.textMaskInputElement !== undefined) {\n\t\t\tthis.textMaskInputElement.update(value);\n\t\t}\n\t}\n\n\tregisterOnChange(fn: (_: any) => void): void {\n\t\tthis.onChange = fn;\n\t}\n\n\tregisterOnTouched(fn: () => void): void {\n\t\tthis.onTouched = fn;\n\t}\n\n\tsetDisabledState(isDisabled: boolean): void {\n\t\tthis._renderer.setProperty(this._elementRef.nativeElement, 'disabled', isDisabled);\n\t}\n\n\t_handleInput(value) {\n\t\tif (!this._compositionMode || (this._compositionMode && !this._composing)) {\n\t\t\tthis._setupMask();\n\n\t\t\tif (this.textMaskInputElement !== undefined) {\n\t\t\t\tthis.textMaskInputElement.update(value);\n\n\t\t\t\t// get the updated value\n\t\t\t\tvalue = this.inputElement.value;\n\n\t\t\t\tif (this.clean) {\n\t\t\t\t\tthis.onChange(clean(value));\n\t\t\t\t} else {\n\t\t\t\t\tthis.onChange(value);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n\t_setupMask(create = false) {\n\t\tif (!this.inputElement) {\n\t\t\tif (this._elementRef.nativeElement.tagName.toUpperCase() === 'INPUT') {\n\t\t\t\t// `textMask` directive is used directly on an input element\n\t\t\t\tthis.inputElement = this._elementRef.nativeElement;\n\t\t\t} else {\n\t\t\t\t// `textMask` directive is used on an abstracted input element, `md-input-container`, etc\n\t\t\t\tthis.inputElement = this._elementRef.nativeElement.getElementsByTagName('INPUT')[0];\n\t\t\t}\n\t\t}\n\n\t\tif (this.inputElement && create) {\n\t\t\tthis.textMaskInputElement = createTextMaskInputElement(\n\t\t\t\tObject.assign({ inputElement: this.inputElement }, this.textMaskConfig)\n\t\t\t);\n\t\t}\n\n\t}\n\n\t_compositionStart(): void {\n\t\tthis._composing = true;\n\t}\n\n\t_compositionEnd(value: any): void {\n\t\tthis._composing = false;\n\t\tthis._compositionMode && this._handleInput(value);\n\t}\n}\n","import { Pipe, PipeTransform } from '@angular/core';\nimport { conformToMask } from 'angular2-text-mask';\nimport { mask } from './utils';\n\n@Pipe({\n\tname: 'ngxPhoneMask'\n})\n\nexport class NgxPhoneMaskPipe implements PipeTransform {\n\ttransform(value: string): string {\n\t\tif (!value) {\n\t\t\treturn '';\n\t\t}\n\n\t\treturn conformToMask(\n\t\t\tvalue,\n\t\t\tmask(),\n\t\t\t{ guide: false }\n\t\t).conformedValue;\n\t}\n}\n","import { NgModule } from '@angular/core';\nimport { NgxPhoneMaskDirective } from './ngx-phone-mask.directive';\nimport { TextMaskModule } from 'angular2-text-mask';\nimport { NgxPhoneMaskPipe } from './ngx-phone-mask.pipe';\n\n@NgModule({\n\timports: [TextMaskModule],\n\tdeclarations: [\n\t\tNgxPhoneMaskDirective,\n\t\tNgxPhoneMaskPipe\n\t],\n\texports: [\n\t\tNgxPhoneMaskDirective,\n\t\tNgxPhoneMaskPipe\n\t]\n})\nexport class NgxPhoneMaskModule {\n}\n"],"names":["getDOM"],"mappings":"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"} | ||
//# sourceMappingURL=ngx-phone-mask.js.map |
@@ -1,5 +0,5 @@ | ||
import { Directive, ElementRef, forwardRef, HostListener, Inject, Input, Optional, Renderer2, Pipe, NgModule } from '@angular/core'; | ||
import { NG_VALUE_ACCESSOR, COMPOSITION_BUFFER_MODE } from '@angular/forms'; | ||
import { ɵgetDOM } from '@angular/platform-browser'; | ||
import { createTextMaskInputElement } from 'text-mask-core/dist/textMaskCore'; | ||
import { Directive, ElementRef, forwardRef, HostListener, Inject, Input, Optional, Renderer2, Pipe, NgModule } from '@angular/core'; | ||
import { conformToMask, TextMaskModule } from 'angular2-text-mask'; | ||
@@ -9,3 +9,3 @@ | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingReturn,uselessCode} checked by tsc | ||
* @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
@@ -19,12 +19,15 @@ /** @type {?} */ | ||
/** @type {?} */ | ||
var mask = function () { return function (rawValue) { | ||
if (clean(rawValue).length <= 12) { | ||
return ['+', /[1-9]/, ' ', '(', /[1-9]/, /\d/, /\d/, ')', ' ', /\d/, /\d/, /\d/, '-', /\d/, /\d/, '-', /\d/, /\d/]; | ||
} | ||
return ['+', /[1-9]/, ' ', '(', /[1-9]/, /\d/, /\d/, ')', ' ', /\d/, /\d/, /\d/, '-', /\d/, /\d/, /\d/, '-', /\d/, /\d/]; | ||
}; }; | ||
var mask = function (maxLength) { | ||
if (maxLength === void 0) { maxLength = 13; } | ||
return function (rawValue) { | ||
if (clean(rawValue).length <= 12 || maxLength === 12) { | ||
return ['+', /[1-9]/, ' ', '(', /[1-9]/, /\d/, /\d/, ')', ' ', /\d/, /\d/, /\d/, '-', /\d/, /\d/, '-', /\d/, /\d/]; | ||
} | ||
return ['+', /[1-9]/, ' ', '(', /[1-9]/, /\d/, /\d/, ')', ' ', /\d/, /\d/, /\d/, '-', /\d/, /\d/, /\d/, '-', /\d/, /\d/]; | ||
}; | ||
}; | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingReturn,uselessCode} checked by tsc | ||
* @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
@@ -52,9 +55,3 @@ var TextMaskConfig = /** @class */ (function () { | ||
this.clean = true; | ||
this.textMaskConfig = { | ||
mask: mask(), | ||
guide: false, | ||
placeholderChar: '_', | ||
pipe: undefined, | ||
keepCharPositions: false, | ||
}; | ||
this.maxNumberLength = 13; | ||
/** | ||
@@ -192,2 +189,9 @@ * Whether the user is creating a composition string (IME events). | ||
if (create === void 0) { create = false; } | ||
this.textMaskConfig = { | ||
mask: mask(this.maxNumberLength), | ||
guide: false, | ||
placeholderChar: '_', | ||
pipe: undefined, | ||
keepCharPositions: false, | ||
}; | ||
if (!this.inputElement) { | ||
@@ -253,2 +257,3 @@ if (this._elementRef.nativeElement.tagName.toUpperCase() === 'INPUT') { | ||
clean: [{ type: Input }], | ||
maxNumberLength: [{ type: Input }], | ||
onBlur: [{ type: HostListener, args: ['blur',] }] | ||
@@ -261,3 +266,3 @@ }; | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingReturn,uselessCode} checked by tsc | ||
* @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
@@ -291,3 +296,3 @@ var NgxPhoneMaskPipe = /** @class */ (function () { | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingReturn,uselessCode} checked by tsc | ||
* @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
@@ -315,3 +320,3 @@ var NgxPhoneMaskModule = /** @class */ (function () { | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingReturn,uselessCode} checked by tsc | ||
* @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
@@ -321,3 +326,3 @@ | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingReturn,uselessCode} checked by tsc | ||
* @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
@@ -327,2 +332,2 @@ | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"ngx-phone-mask.js.map","sources":["ng://ngx-phone-mask/lib/utils.ts","ng://ngx-phone-mask/lib/ngx-phone-mask.directive.ts","ng://ngx-phone-mask/lib/ngx-phone-mask.pipe.ts","ng://ngx-phone-mask/lib/ngx-phone-mask.module.ts"],"sourcesContent":["export const clean = (number) => {\n\treturn number\n\t\t.toString()\n\t\t.replace(/[^\\d\\^\\+]/gm, '');\n};\n\nexport const mask = () => (rawValue) => {\n\tif (clean(rawValue).length <= 12) {\n\t\treturn ['+', /[1-9]/, ' ', '(', /[1-9]/, /\\d/, /\\d/, ')', ' ', /\\d/, /\\d/, /\\d/, '-', /\\d/, /\\d/, '-', /\\d/, /\\d/];\n\t}\n\n\treturn ['+', /[1-9]/, ' ', '(', /[1-9]/, /\\d/, /\\d/, ')', ' ', /\\d/, /\\d/, /\\d/, '-', /\\d/, /\\d/, /\\d/, '-', /\\d/, /\\d/];\n\n};\n","import {\n\tDirective,\n\tElementRef,\n\tforwardRef, HostListener,\n\tInject, Input,\n\tOnChanges, OnInit,\n\tOptional,\n\tRenderer2,\n\tSimpleChanges\n} from '@angular/core';\nimport { NG_VALUE_ACCESSOR, ControlValueAccessor, COMPOSITION_BUFFER_MODE } from '@angular/forms';\nimport { ÉµgetDOM as getDOM } from '@angular/platform-browser';\nimport { createTextMaskInputElement } from 'text-mask-core/dist/textMaskCore';\nimport { mask, clean } from './utils';\n\nexport class TextMaskConfig {\n\tmask: Array<string | RegExp> | ((raw: string) => Array<string | RegExp>) | false;\n\tguide?: boolean;\n\tplaceholderChar?: string;\n\tpipe?: (conformedValue: string, config: TextMaskConfig) => false | string | object;\n\tkeepCharPositions?: boolean;\n\tshowMask?: boolean;\n}\n\n/**\n * We must check whether the agent is Android because composition events\n * behave differently between iOS and Android.\n */\nfunction _isAndroid(): boolean {\n\tconst userAgent = getDOM() ? getDOM().getUserAgent() : '';\n\treturn /android (\\d+)/.test(userAgent.toLowerCase());\n}\n\n@Directive({\n\thost: {\n\t\t'(input)': '_handleInput($event.target.value)',\n\t\t'(blur)': 'onTouched()',\n\t\t'(compositionstart)': '_compositionStart()',\n\t\t'(compositionend)': '_compositionEnd($event.target.value)'\n\t},\n\tselector: '[ngxPhoneMask]',\n\texportAs: 'ngxPhoneMask',\n\tproviders: [{\n\t\tprovide: NG_VALUE_ACCESSOR,\n\t\tuseExisting: forwardRef(() => NgxPhoneMaskDirective),\n\t\tmulti: true\n\t}]\n})\nexport class NgxPhoneMaskDirective implements ControlValueAccessor, OnChanges, OnInit {\n\t@Input() clean = true;\n\n\ttextMaskConfig: TextMaskConfig = {\n\t\tmask: mask(),\n\t\tguide: false,\n\t\tplaceholderChar: '_',\n\t\tpipe: undefined,\n\t\tkeepCharPositions: false,\n\t};\n\n\tprivate textMaskInputElement: any;\n\tprivate inputElement: HTMLInputElement;\n\n\t/** Whether the user is creating a composition string (IME events). */\n\tprivate _composing = false;\n\n\tonChange = (_: any) => {\n\t};\n\tonTouched = () => {\n\t};\n\n\tconstructor(\n\t\tprivate _renderer: Renderer2,\n\t\tprivate _elementRef: ElementRef,\n\t\t@Optional() @Inject(COMPOSITION_BUFFER_MODE) private _compositionMode: boolean\n\t) {\n\t\tif (this._compositionMode == null) {\n\t\t\tthis._compositionMode = !_isAndroid();\n\t\t}\n\t}\n\n\tngOnInit() {\n\t\tthis._setupMask(true);\n\t\tif (this.textMaskInputElement !== undefined) {\n\t\t\tthis.textMaskInputElement.update(this.inputElement.value);\n\t\t}\n\t}\n\n\tngOnChanges(changes: SimpleChanges) {\n\t\tthis._setupMask(true);\n\t\tif (this.textMaskInputElement !== undefined) {\n\t\t\tthis.textMaskInputElement.update(this.inputElement.value);\n\t\t}\n\t}\n\n\t@HostListener('blur')\n\tonBlur() {\n\t\tthis.onTouched();\n\t}\n\n\twriteValue(value: any) {\n\t\tthis._setupMask();\n\n\t\t// set the initial value for cases where the mask is disabled\n\t\tconst normalizedValue = value == null ? '' : value;\n\t\tthis._renderer.setProperty(this.inputElement, 'value', normalizedValue);\n\n\t\tif (this.textMaskInputElement !== undefined) {\n\t\t\tthis.textMaskInputElement.update(value);\n\t\t}\n\t}\n\n\tregisterOnChange(fn: (_: any) => void): void {\n\t\tthis.onChange = fn;\n\t}\n\n\tregisterOnTouched(fn: () => void): void {\n\t\tthis.onTouched = fn;\n\t}\n\n\tsetDisabledState(isDisabled: boolean): void {\n\t\tthis._renderer.setProperty(this._elementRef.nativeElement, 'disabled', isDisabled);\n\t}\n\n\t_handleInput(value) {\n\t\tif (!this._compositionMode || (this._compositionMode && !this._composing)) {\n\t\t\tthis._setupMask();\n\n\t\t\tif (this.textMaskInputElement !== undefined) {\n\t\t\t\tthis.textMaskInputElement.update(value);\n\n\t\t\t\t// get the updated value\n\t\t\t\tvalue = this.inputElement.value;\n\n\t\t\t\tif (this.clean) {\n\t\t\t\t\tthis.onChange(clean(value));\n\t\t\t\t} else {\n\t\t\t\t\tthis.onChange(value);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n\t_setupMask(create = false) {\n\t\tif (!this.inputElement) {\n\t\t\tif (this._elementRef.nativeElement.tagName.toUpperCase() === 'INPUT') {\n\t\t\t\t// `textMask` directive is used directly on an input element\n\t\t\t\tthis.inputElement = this._elementRef.nativeElement;\n\t\t\t} else {\n\t\t\t\t// `textMask` directive is used on an abstracted input element, `md-input-container`, etc\n\t\t\t\tthis.inputElement = this._elementRef.nativeElement.getElementsByTagName('INPUT')[0];\n\t\t\t}\n\t\t}\n\n\t\tif (this.inputElement && create) {\n\t\t\tthis.textMaskInputElement = createTextMaskInputElement(\n\t\t\t\tObject.assign({ inputElement: this.inputElement }, this.textMaskConfig)\n\t\t\t);\n\t\t}\n\n\t}\n\n\t_compositionStart(): void {\n\t\tthis._composing = true;\n\t}\n\n\t_compositionEnd(value: any): void {\n\t\tthis._composing = false;\n\t\tthis._compositionMode && this._handleInput(value);\n\t}\n}\n","import { Pipe, PipeTransform } from '@angular/core';\nimport { conformToMask } from 'angular2-text-mask';\nimport { mask } from './utils';\n\n@Pipe({\n\tname: 'ngxPhoneMask'\n})\n\nexport class NgxPhoneMaskPipe implements PipeTransform {\n\ttransform(value: string): string {\n\t\tif (!value) {\n\t\t\treturn '';\n\t\t}\n\n\t\treturn conformToMask(\n\t\t\tvalue,\n\t\t\tmask(),\n\t\t\t{ guide: false }\n\t\t).conformedValue;\n\t}\n}\n","import { NgModule } from '@angular/core';\nimport { NgxPhoneMaskDirective } from './ngx-phone-mask.directive';\nimport { TextMaskModule } from 'angular2-text-mask';\nimport { NgxPhoneMaskPipe } from './ngx-phone-mask.pipe';\n\n@NgModule({\n\timports: [TextMaskModule],\n\tdeclarations: [\n\t\tNgxPhoneMaskDirective,\n\t\tNgxPhoneMaskPipe\n\t],\n\texports: [\n\t\tNgxPhoneMaskDirective,\n\t\tNgxPhoneMaskPipe\n\t]\n})\nexport class NgxPhoneMaskModule {\n}\n"],"names":["getDOM"],"mappings":"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"} | ||
//# sourceMappingURL=ngx-phone-mask.js.map |
@@ -16,2 +16,3 @@ import { ElementRef, OnChanges, OnInit, Renderer2, SimpleChanges } from '@angular/core'; | ||
clean: boolean; | ||
maxNumberLength: number; | ||
textMaskConfig: TextMaskConfig; | ||
@@ -18,0 +19,0 @@ private textMaskInputElement; |
export declare const clean: (number: any) => any; | ||
export declare const mask: () => (rawValue: any) => (string | RegExp)[]; | ||
export declare const mask: (maxLength?: number) => (rawValue: any) => (string | RegExp)[]; |
@@ -1,1 +0,1 @@ | ||
{"__symbolic":"module","version":4,"metadata":{"TextMaskConfig":{"__symbolic":"class","members":{}},"NgxPhoneMaskDirective":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Directive","line":33,"character":1},"arguments":[{"host":{"(input)":"_handleInput($event.target.value)","(blur)":"onTouched()","(compositionstart)":"_compositionStart()","(compositionend)":"_compositionEnd($event.target.value)","$quoted$":["(input)","(blur)","(compositionstart)","(compositionend)"]},"selector":"[ngxPhoneMask]","exportAs":"ngxPhoneMask","providers":[{"provide":{"__symbolic":"reference","module":"@angular/forms","name":"NG_VALUE_ACCESSOR","line":43,"character":11},"useExisting":{"__symbolic":"reference","name":"NgxPhoneMaskDirective"},"multi":true}]}]}],"members":{"clean":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":49,"character":2}}]}],"__ctor__":[{"__symbolic":"constructor","parameterDecorators":[null,null,[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Optional","line":73,"character":3}},{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Inject","line":73,"character":15},"arguments":[{"__symbolic":"reference","module":"@angular/forms","name":"COMPOSITION_BUFFER_MODE","line":73,"character":22}]}]],"parameters":[{"__symbolic":"reference","module":"@angular/core","name":"Renderer2","line":71,"character":21},{"__symbolic":"reference","module":"@angular/core","name":"ElementRef","line":72,"character":23},{"__symbolic":"reference","name":"boolean"}]}],"ngOnInit":[{"__symbolic":"method"}],"ngOnChanges":[{"__symbolic":"method"}],"onBlur":[{"__symbolic":"method","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostListener","line":94,"character":2},"arguments":["blur"]}]}],"writeValue":[{"__symbolic":"method"}],"registerOnChange":[{"__symbolic":"method"}],"registerOnTouched":[{"__symbolic":"method"}],"setDisabledState":[{"__symbolic":"method"}],"_handleInput":[{"__symbolic":"method"}],"_setupMask":[{"__symbolic":"method"}],"_compositionStart":[{"__symbolic":"method"}],"_compositionEnd":[{"__symbolic":"method"}]}},"NgxPhoneMaskModule":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"NgModule","line":5,"character":1},"arguments":[{"imports":[{"__symbolic":"reference","module":"angular2-text-mask","name":"TextMaskModule","line":6,"character":11}],"declarations":[{"__symbolic":"reference","name":"NgxPhoneMaskDirective"},{"__symbolic":"reference","name":"ɵa"}],"exports":[{"__symbolic":"reference","name":"NgxPhoneMaskDirective"},{"__symbolic":"reference","name":"ɵa"}]}]}],"members":{}},"ɵa":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Pipe","line":4,"character":1},"arguments":[{"name":"ngxPhoneMask"}]}],"members":{"transform":[{"__symbolic":"method"}]}}},"origins":{"TextMaskConfig":"./lib/ngx-phone-mask.directive","NgxPhoneMaskDirective":"./lib/ngx-phone-mask.directive","NgxPhoneMaskModule":"./lib/ngx-phone-mask.module","ɵa":"./lib/ngx-phone-mask.pipe"},"importAs":"ngx-phone-mask"} | ||
{"__symbolic":"module","version":4,"metadata":{"TextMaskConfig":{"__symbolic":"class","members":{}},"NgxPhoneMaskDirective":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Directive","line":33,"character":1},"arguments":[{"host":{"(input)":"_handleInput($event.target.value)","(blur)":"onTouched()","(compositionstart)":"_compositionStart()","(compositionend)":"_compositionEnd($event.target.value)","$quoted$":["(input)","(blur)","(compositionstart)","(compositionend)"]},"selector":"[ngxPhoneMask]","exportAs":"ngxPhoneMask","providers":[{"provide":{"__symbolic":"reference","module":"@angular/forms","name":"NG_VALUE_ACCESSOR","line":43,"character":11},"useExisting":{"__symbolic":"reference","name":"NgxPhoneMaskDirective"},"multi":true}]}]}],"members":{"clean":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":49,"character":2}}]}],"maxNumberLength":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input","line":50,"character":2}}]}],"__ctor__":[{"__symbolic":"constructor","parameterDecorators":[null,null,[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Optional","line":68,"character":3}},{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Inject","line":68,"character":15},"arguments":[{"__symbolic":"reference","module":"@angular/forms","name":"COMPOSITION_BUFFER_MODE","line":68,"character":22}]}]],"parameters":[{"__symbolic":"reference","module":"@angular/core","name":"Renderer2","line":66,"character":21},{"__symbolic":"reference","module":"@angular/core","name":"ElementRef","line":67,"character":23},{"__symbolic":"reference","name":"boolean"}]}],"ngOnInit":[{"__symbolic":"method"}],"ngOnChanges":[{"__symbolic":"method"}],"onBlur":[{"__symbolic":"method","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostListener","line":89,"character":2},"arguments":["blur"]}]}],"writeValue":[{"__symbolic":"method"}],"registerOnChange":[{"__symbolic":"method"}],"registerOnTouched":[{"__symbolic":"method"}],"setDisabledState":[{"__symbolic":"method"}],"_handleInput":[{"__symbolic":"method"}],"_setupMask":[{"__symbolic":"method"}],"_compositionStart":[{"__symbolic":"method"}],"_compositionEnd":[{"__symbolic":"method"}]}},"NgxPhoneMaskModule":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"NgModule","line":5,"character":1},"arguments":[{"imports":[{"__symbolic":"reference","module":"angular2-text-mask","name":"TextMaskModule","line":6,"character":11}],"declarations":[{"__symbolic":"reference","name":"NgxPhoneMaskDirective"},{"__symbolic":"reference","name":"ɵa"}],"exports":[{"__symbolic":"reference","name":"NgxPhoneMaskDirective"},{"__symbolic":"reference","name":"ɵa"}]}]}],"members":{}},"ɵa":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Pipe","line":4,"character":1},"arguments":[{"name":"ngxPhoneMask"}]}],"members":{"transform":[{"__symbolic":"method"}]}}},"origins":{"TextMaskConfig":"./lib/ngx-phone-mask.directive","NgxPhoneMaskDirective":"./lib/ngx-phone-mask.directive","NgxPhoneMaskModule":"./lib/ngx-phone-mask.module","ɵa":"./lib/ngx-phone-mask.pipe"},"importAs":"ngx-phone-mask"} |
{ | ||
"name": "ngx-phone-mask", | ||
"version": "3.2.2", | ||
"version": "3.3.0", | ||
"peerDependencies": { | ||
@@ -5,0 +5,0 @@ "@angular/common": "^6.0.0-rc.0 || ^6.0.0", |
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
1685
145397