ngx-phone-mask
Advanced tools
Comparing version 2.1.3 to 3.0.0
(function (global, factory) { | ||
typeof exports === 'object' && typeof module !== 'undefined' ? factory(exports, require('@angular/core'), require('@angular/common'), require('@angular/forms')) : | ||
typeof define === 'function' && define.amd ? define(['exports', '@angular/core', '@angular/common', '@angular/forms'], factory) : | ||
(factory((global['ngx-phone-mask'] = {}),global.ng.core,global.ng.common,global.ng.forms)); | ||
}(this, (function (exports,core,common,forms) { 'use strict'; | ||
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'; | ||
var noop = function () { }; | ||
var masks = [ | ||
'1', | ||
'1 (1', | ||
'1 (11', | ||
'1 (111', | ||
'1 (111) 1', | ||
'1 (111) 11', | ||
'1 (111) 11-1', | ||
'1 (111) 11-11', | ||
'1 (111) 11-111', | ||
'1 (111) 111-111', | ||
'1 (111) 111-11-11', | ||
'1 (111) 111-111-11' | ||
]; | ||
var clean = function (number) { | ||
return number | ||
.toString() | ||
.replace(/[^\d\^]/gm, ''); | ||
}; | ||
var format = function (number) { | ||
var /** @type {?} */ lastCharIndex = 0; | ||
var /** @type {?} */ cleanValue = clean(number); | ||
var /** @type {?} */ charCount = cleanValue.replace(/\^/gm, '').length; | ||
if (charCount === 0) { | ||
return { | ||
formatted: '', | ||
cursorPosition: 0 | ||
}; | ||
} | ||
var /** @type {?} */ mask = masks[charCount - 1]; | ||
if (charCount > 1 && !mask) { | ||
return null; | ||
} | ||
var /** @type {?} */ cursorPosition; | ||
var /** @type {?} */ formatted = mask.split('').map(function (c, i) { | ||
if (c === '1') { | ||
if (cleanValue[lastCharIndex] == '^') { | ||
cursorPosition = i + 1; | ||
lastCharIndex++; | ||
} | ||
lastCharIndex++; | ||
return cleanValue[lastCharIndex - 1]; | ||
} | ||
else { | ||
return c; | ||
} | ||
}).join(''); | ||
if (!cursorPosition) { | ||
cursorPosition = formatted.length; | ||
} | ||
cursorPosition++; // because of '+' | ||
return { | ||
formatted: "+" + formatted, | ||
cursorPosition: cursorPosition | ||
}; | ||
}; | ||
var NgxPhoneMaskDirective = (function () { | ||
/** | ||
* @param {?} input | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingReturn,uselessCode} checked by tsc | ||
*/ | ||
function NgxPhoneMaskDirective(input) { | ||
this.input = input; | ||
this.onTouchedCallback = noop; | ||
this.onChangeCallback = noop; | ||
this.valueType = 'clean'; | ||
this.showMask = true; | ||
this.oldValue = ''; | ||
} | ||
/** | ||
* @return {?} | ||
*/ | ||
NgxPhoneMaskDirective.prototype.updateInputView = function () { | ||
var /** @type {?} */ input = this.input.nativeElement; | ||
var /** @type {?} */ cursorPosition = input.selectionStart; | ||
var /** @type {?} */ value = this._value; | ||
var /** @type {?} */ valueWithCursor = value.substring(0, cursorPosition) + '^' + value.substring(cursorPosition); | ||
var /** @type {?} */ formatted = format(valueWithCursor); | ||
if (!formatted) { | ||
input.value = this.oldValue; | ||
return; | ||
var TextMaskConfig = /** @class */ (function () { | ||
function TextMaskConfig() { | ||
} | ||
var /** @type {?} */ newValue = formatted.formatted; | ||
if (newValue != input.value) { | ||
input.value = newValue; | ||
input.setSelectionRange(formatted.cursorPosition, formatted.cursorPosition); | ||
} | ||
this.oldValue = newValue; | ||
this.emitValue(newValue); | ||
return TextMaskConfig; | ||
}()); | ||
/** @type {?} */ | ||
var clean = function (number) { | ||
return number | ||
.toString() | ||
.replace(/[^\d\^\+]/gm, ''); | ||
}; | ||
/** | ||
* @param {?} v | ||
* We must check whether the agent is Android because composition events | ||
* behave differently between iOS and Android. | ||
* @return {?} | ||
*/ | ||
NgxPhoneMaskDirective.prototype.emitValue = function (v) { | ||
var /** @type {?} */ value; | ||
switch (this.valueType) { | ||
case 'clean': | ||
value = v.replace(/[^\d\+]/gm, ''); | ||
break; | ||
case 'full': | ||
value = v; | ||
break; | ||
function _isAndroid() { | ||
/** @type {?} */ | ||
var userAgent = platformBrowser.ɵgetDOM() ? platformBrowser.ɵgetDOM().getUserAgent() : ''; | ||
return /android (\d+)/.test(userAgent.toLowerCase()); | ||
} | ||
var NgxPhoneMaskDirective = /** @class */ (function () { | ||
function NgxPhoneMaskDirective(_renderer, _elementRef, _compositionMode) { | ||
this._renderer = _renderer; | ||
this._elementRef = _elementRef; | ||
this._compositionMode = _compositionMode; | ||
this.clean = true; | ||
this.textMaskConfig = { | ||
mask: ['+', /[1-9]/, ' ', '(', /[1-9]/, /\d/, /\d/, ')', ' ', /\d/, /\d/, /\d/, '-', /\d/, /\d/, '-', /\d/, /\d/], | ||
guide: false, | ||
placeholderChar: '_', | ||
pipe: undefined, | ||
keepCharPositions: false, | ||
}; | ||
/** | ||
* Whether the user is creating a composition string (IME events). | ||
*/ | ||
this._composing = false; | ||
this.onChange = function (_) { | ||
}; | ||
this.onTouched = function () { | ||
}; | ||
if (this._compositionMode == null) { | ||
this._compositionMode = !_isAndroid(); | ||
} | ||
} | ||
this.onChangeCallback(value); | ||
}; | ||
/** | ||
* @return {?} | ||
*/ | ||
NgxPhoneMaskDirective.prototype.onInput = function () { | ||
this._value = this.input.nativeElement.value; | ||
this.updateInputView(); | ||
}; | ||
Object.defineProperty(NgxPhoneMaskDirective.prototype, "value", { | ||
/** | ||
* @param {?} v | ||
* @return {?} | ||
*/ | ||
set: function (v) { | ||
var /** @type {?} */ value = v ? v : ''; | ||
this._value = value; | ||
this.updateInputView(); | ||
}, | ||
enumerable: true, | ||
configurable: true | ||
}); | ||
NgxPhoneMaskDirective.prototype.ngOnInit = /** | ||
* @return {?} | ||
*/ | ||
function () { | ||
this._setupMask(true); | ||
if (this.textMaskInputElement !== undefined) { | ||
this.textMaskInputElement.update(this.inputElement.value); | ||
} | ||
}; | ||
/** | ||
* @param {?} changes | ||
* @return {?} | ||
*/ | ||
NgxPhoneMaskDirective.prototype.ngOnChanges = /** | ||
* @param {?} changes | ||
* @return {?} | ||
*/ | ||
function (changes) { | ||
this._setupMask(true); | ||
if (this.textMaskInputElement !== undefined) { | ||
this.textMaskInputElement.update(this.inputElement.value); | ||
} | ||
}; | ||
/** | ||
* @return {?} | ||
*/ | ||
NgxPhoneMaskDirective.prototype.onBlur = /** | ||
* @return {?} | ||
*/ | ||
function () { | ||
this.onTouched(); | ||
}; | ||
/** | ||
* @param {?} value | ||
* @return {?} | ||
*/ | ||
NgxPhoneMaskDirective.prototype.writeValue = /** | ||
* @param {?} value | ||
* @return {?} | ||
*/ | ||
function (value) { | ||
this._setupMask(); | ||
// set the initial value for cases where the mask is disabled | ||
/** @type {?} */ | ||
var normalizedValue = value == null ? '' : value; | ||
this._renderer.setProperty(this.inputElement, 'value', normalizedValue); | ||
if (this.textMaskInputElement !== undefined) { | ||
this.textMaskInputElement.update(value); | ||
} | ||
}; | ||
/** | ||
* @param {?} fn | ||
* @return {?} | ||
*/ | ||
NgxPhoneMaskDirective.prototype.registerOnChange = /** | ||
* @param {?} fn | ||
* @return {?} | ||
*/ | ||
function (fn) { | ||
this.onChange = fn; | ||
}; | ||
/** | ||
* @param {?} fn | ||
* @return {?} | ||
*/ | ||
NgxPhoneMaskDirective.prototype.registerOnTouched = /** | ||
* @param {?} fn | ||
* @return {?} | ||
*/ | ||
function (fn) { | ||
this.onTouched = fn; | ||
}; | ||
/** | ||
* @param {?} isDisabled | ||
* @return {?} | ||
*/ | ||
NgxPhoneMaskDirective.prototype.setDisabledState = /** | ||
* @param {?} isDisabled | ||
* @return {?} | ||
*/ | ||
function (isDisabled) { | ||
this._renderer.setProperty(this._elementRef.nativeElement, 'disabled', isDisabled); | ||
}; | ||
/** | ||
* @param {?} value | ||
* @return {?} | ||
*/ | ||
NgxPhoneMaskDirective.prototype._handleInput = /** | ||
* @param {?} value | ||
* @return {?} | ||
*/ | ||
function (value) { | ||
if (!this._compositionMode || (this._compositionMode && !this._composing)) { | ||
this._setupMask(); | ||
if (this.textMaskInputElement !== undefined) { | ||
this.textMaskInputElement.update(value); | ||
// get the updated value | ||
value = this.inputElement.value; | ||
if (this.clean) { | ||
this.onChange(clean(value)); | ||
} | ||
else { | ||
this.onChange(value); | ||
} | ||
} | ||
} | ||
}; | ||
/** | ||
* @param {?=} create | ||
* @return {?} | ||
*/ | ||
NgxPhoneMaskDirective.prototype._setupMask = /** | ||
* @param {?=} create | ||
* @return {?} | ||
*/ | ||
function (create) { | ||
if (create === void 0) { | ||
create = false; | ||
} | ||
if (!this.inputElement) { | ||
if (this._elementRef.nativeElement.tagName.toUpperCase() === 'INPUT') { | ||
// `textMask` directive is used directly on an input element | ||
this.inputElement = this._elementRef.nativeElement; | ||
} | ||
else { | ||
// `textMask` directive is used on an abstracted input element, `md-input-container`, etc | ||
this.inputElement = this._elementRef.nativeElement.getElementsByTagName('INPUT')[0]; | ||
} | ||
} | ||
if (this.inputElement && create) { | ||
this.textMaskInputElement = textMaskCore.createTextMaskInputElement(Object.assign({ inputElement: this.inputElement }, this.textMaskConfig)); | ||
} | ||
}; | ||
/** | ||
* @return {?} | ||
*/ | ||
NgxPhoneMaskDirective.prototype._compositionStart = /** | ||
* @return {?} | ||
*/ | ||
function () { | ||
this._composing = true; | ||
}; | ||
/** | ||
* @param {?} value | ||
* @return {?} | ||
*/ | ||
NgxPhoneMaskDirective.prototype._compositionEnd = /** | ||
* @param {?} value | ||
* @return {?} | ||
*/ | ||
function (value) { | ||
this._composing = false; | ||
this._compositionMode && this._handleInput(value); | ||
}; | ||
NgxPhoneMaskDirective.decorators = [ | ||
{ type: core.Directive, args: [{ | ||
host: { | ||
'(input)': '_handleInput($event.target.value)', | ||
'(blur)': 'onTouched()', | ||
'(compositionstart)': '_compositionStart()', | ||
'(compositionend)': '_compositionEnd($event.target.value)' | ||
}, | ||
selector: '[ngxPhoneMask]', | ||
exportAs: 'ngxPhoneMask', | ||
providers: [{ | ||
provide: forms.NG_VALUE_ACCESSOR, | ||
useExisting: core.forwardRef(function () { return NgxPhoneMaskDirective; }), | ||
multi: true | ||
}] | ||
},] } | ||
]; | ||
/** @nocollapse */ | ||
NgxPhoneMaskDirective.ctorParameters = function () { | ||
return [ | ||
{ type: core.Renderer2 }, | ||
{ type: core.ElementRef }, | ||
{ type: Boolean, decorators: [{ type: core.Optional }, { type: core.Inject, args: [forms.COMPOSITION_BUFFER_MODE,] }] } | ||
]; | ||
}; | ||
NgxPhoneMaskDirective.propDecorators = { | ||
clean: [{ type: core.Input }], | ||
onBlur: [{ type: core.HostListener, args: ['blur',] }] | ||
}; | ||
return NgxPhoneMaskDirective; | ||
}()); | ||
/** | ||
* @param {?} value | ||
* @return {?} | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingReturn,uselessCode} checked by tsc | ||
*/ | ||
NgxPhoneMaskDirective.prototype.writeValue = function (value) { | ||
this.value = value; | ||
}; | ||
var NgxPhoneMaskModule = /** @class */ (function () { | ||
function NgxPhoneMaskModule() { | ||
} | ||
NgxPhoneMaskModule.decorators = [ | ||
{ type: core.NgModule, args: [{ | ||
imports: [angular2TextMask.TextMaskModule], | ||
declarations: [NgxPhoneMaskDirective], | ||
exports: [NgxPhoneMaskDirective] | ||
},] } | ||
]; | ||
return NgxPhoneMaskModule; | ||
}()); | ||
/** | ||
* @param {?} fn | ||
* @return {?} | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingReturn,uselessCode} checked by tsc | ||
*/ | ||
NgxPhoneMaskDirective.prototype.registerOnChange = function (fn) { | ||
this.onChangeCallback = fn; | ||
}; | ||
/** | ||
* @param {?} fn | ||
* @return {?} | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingReturn,uselessCode} checked by tsc | ||
*/ | ||
NgxPhoneMaskDirective.prototype.registerOnTouched = function (fn) { | ||
this.onTouchedCallback = fn; | ||
}; | ||
/** | ||
* @param {?} isDisabled | ||
* @return {?} | ||
*/ | ||
NgxPhoneMaskDirective.prototype.setDisabledState = function (isDisabled) { | ||
this.disabled = isDisabled; | ||
}; | ||
return NgxPhoneMaskDirective; | ||
}()); | ||
NgxPhoneMaskDirective.decorators = [ | ||
{ type: core.Directive, args: [{ | ||
selector: '[ngxPhoneMask]', | ||
providers: [ | ||
{ | ||
provide: forms.NG_VALUE_ACCESSOR, | ||
useExisting: core.forwardRef(function () { return NgxPhoneMaskDirective; }), | ||
multi: true | ||
} | ||
] | ||
},] }, | ||
]; | ||
/** | ||
* @nocollapse | ||
*/ | ||
NgxPhoneMaskDirective.ctorParameters = function () { return [ | ||
{ type: core.ElementRef, }, | ||
]; }; | ||
NgxPhoneMaskDirective.propDecorators = { | ||
'valueType': [{ type: core.Input },], | ||
'showMask': [{ type: core.Input },], | ||
'onInput': [{ type: core.HostListener, args: ['input',] },], | ||
}; | ||
var NgxPhoneMaskModule = (function () { | ||
function NgxPhoneMaskModule() { | ||
} | ||
return NgxPhoneMaskModule; | ||
}()); | ||
NgxPhoneMaskModule.decorators = [ | ||
{ type: core.NgModule, args: [{ | ||
imports: [ | ||
common.CommonModule | ||
], | ||
declarations: [NgxPhoneMaskDirective], | ||
exports: [NgxPhoneMaskDirective] | ||
},] }, | ||
]; | ||
/** | ||
* @nocollapse | ||
*/ | ||
NgxPhoneMaskModule.ctorParameters = function () { return []; }; | ||
exports.NgxPhoneMaskModule = NgxPhoneMaskModule; | ||
exports.ɵa = NgxPhoneMaskDirective; | ||
exports.TextMaskConfig = TextMaskConfig; | ||
exports.NgxPhoneMaskDirective = NgxPhoneMaskDirective; | ||
exports.NgxPhoneMaskModule = NgxPhoneMaskModule; | ||
Object.defineProperty(exports, '__esModule', { value: true }); | ||
Object.defineProperty(exports, '__esModule', { value: true }); | ||
}))); | ||
//# sourceMappingURL=ngx-phone-mask.umd.js.map | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"ngx-phone-mask.umd.js.map","sources":["ng://ngx-phone-mask/lib/ngx-phone-mask.directive.ts","ng://ngx-phone-mask/lib/ngx-phone-mask.module.ts"],"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';\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\nconst clean = (number) => {\n\treturn number\n\t\t.toString()\n\t\t.replace(/[^\\d\\^\\+]/gm, '');\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: ['+', /[1-9]/, ' ', '(', /[1-9]/, /\\d/, /\\d/, ')', ' ', /\\d/, /\\d/, /\\d/, '-', /\\d/, /\\d/, '-', /\\d/, /\\d/],\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 { NgModule } from '@angular/core';\nimport { NgxPhoneMaskDirective } from './ngx-phone-mask.directive';\nimport { TextMaskModule } from 'angular2-text-mask';\n\n@NgModule({\n\timports: [TextMaskModule],\n\tdeclarations: [NgxPhoneMaskDirective],\n\texports: [NgxPhoneMaskDirective]\n})\nexport class NgxPhoneMaskModule {\n}\n"],"names":["getDOM","createTextMaskInputElement","Directive","NG_VALUE_ACCESSOR","forwardRef","Renderer2","ElementRef","Optional","Inject","COMPOSITION_BUFFER_MODE","Input","HostListener","NgModule","TextMaskModule"],"mappings":"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"} |
@@ -5,2 +5,1 @@ /** | ||
export * from './public_api'; | ||
export { NgxPhoneMaskDirective as ɵa } from './src/app/ngx-phone-mask/ngx-phone-mask.directive'; |
@@ -1,1 +0,1 @@ | ||
{"__symbolic":"module","version":3,"metadata":{"NgxPhoneMaskModule":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"NgModule"},"arguments":[{"imports":[{"__symbolic":"reference","module":"@angular/common","name":"CommonModule"}],"declarations":[{"__symbolic":"reference","name":"ɵa"}],"exports":[{"__symbolic":"reference","name":"ɵa"}]}]}],"members":{}},"ɵa":{"__symbolic":"class","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Directive"},"arguments":[{"selector":"[ngxPhoneMask]","providers":[{"provide":{"__symbolic":"reference","module":"@angular/forms","name":"NG_VALUE_ACCESSOR"},"useExisting":{"__symbolic":"reference","name":"ɵa"},"multi":true}]}]}],"members":{"valueType":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input"}}]}],"showMask":[{"__symbolic":"property","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Input"}}]}],"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"reference","module":"@angular/core","name":"ElementRef"}]}],"updateInputView":[{"__symbolic":"method"}],"emitValue":[{"__symbolic":"method"}],"onInput":[{"__symbolic":"method","decorators":[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"HostListener"},"arguments":["input"]}]}],"writeValue":[{"__symbolic":"method"}],"registerOnChange":[{"__symbolic":"method"}],"registerOnTouched":[{"__symbolic":"method"}],"setDisabledState":[{"__symbolic":"method"}]}}},"origins":{"NgxPhoneMaskModule":"./src/app/ngx-phone-mask/ngx-phone-mask.module","ɵa":"./src/app/ngx-phone-mask/ngx-phone-mask.directive"},"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":38,"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":48,"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":54,"character":2}}]}],"__ctor__":[{"__symbolic":"constructor","parameterDecorators":[null,null,[{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Optional","line":78,"character":3}},{"__symbolic":"call","expression":{"__symbolic":"reference","module":"@angular/core","name":"Inject","line":78,"character":15},"arguments":[{"__symbolic":"reference","module":"@angular/forms","name":"COMPOSITION_BUFFER_MODE","line":78,"character":22}]}]],"parameters":[{"__symbolic":"reference","module":"@angular/core","name":"Renderer2","line":76,"character":21},{"__symbolic":"reference","module":"@angular/core","name":"ElementRef","line":77,"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":99,"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":4,"character":1},"arguments":[{"imports":[{"__symbolic":"reference","module":"angular2-text-mask","name":"TextMaskModule","line":5,"character":11}],"declarations":[{"__symbolic":"reference","name":"NgxPhoneMaskDirective"}],"exports":[{"__symbolic":"reference","name":"NgxPhoneMaskDirective"}]}]}],"members":{}}},"origins":{"TextMaskConfig":"./lib/ngx-phone-mask.directive","NgxPhoneMaskDirective":"./lib/ngx-phone-mask.directive","NgxPhoneMaskModule":"./lib/ngx-phone-mask.module"},"importAs":"ngx-phone-mask"} |
{ | ||
"name": "ngx-phone-mask", | ||
"version": "2.1.3", | ||
"license": "ISC", | ||
"scripts": { | ||
"ng": "ng", | ||
"start": "ng serve", | ||
"build": "ng-packagr -p ng-package.json", | ||
"test": "ng test", | ||
"lint": "ng lint", | ||
"e2e": "ng e2e" | ||
}, | ||
"repository": { | ||
"type": "git", | ||
"url": "https://github.com/Ledzz/ngx-phone-mask.git" | ||
}, | ||
"bugs": { | ||
"web": "https://github.com/Ledzz/ngx-phone-mask/issues" | ||
}, | ||
"keywords": [ | ||
"angular", | ||
"angular2", | ||
"angular4", | ||
"directive", | ||
"mask", | ||
"phone", | ||
"number", | ||
"ng-model", | ||
"form-control", | ||
"masking", | ||
"international" | ||
], | ||
"author": "Ledzz", | ||
"version": "3.0.0", | ||
"peerDependencies": { | ||
"@angular/common": ">=4.0.0", | ||
"@angular/compiler": ">=4.0.0", | ||
"@angular/core": ">=4.0.0", | ||
"@angular/forms": ">=4.0.0", | ||
"@angular/platform-browser": ">=4.0.0", | ||
"@angular/platform-browser-dynamic": ">=4.0.0", | ||
"core-js": "^2.4.1", | ||
"rxjs": "^5.1.0", | ||
"zone.js": "^0.8.4" | ||
"@angular/common": "^6.0.0-rc.0 || ^6.0.0", | ||
"@angular/core": "^6.0.0-rc.0 || ^6.0.0", | ||
"angular2-text-mask": "^9.0.0" | ||
}, | ||
"devDependencies": { | ||
"@angular/cli": "1.2.0", | ||
"@angular/compiler-cli": ">=4.0.0", | ||
"@types/node": "~6.0.60", | ||
"codelyzer": "~3.0.1", | ||
"ng-packagr": "^1.2.0", | ||
"ts-node": "~3.0.4", | ||
"tslint": "~5.3.2", | ||
"typescript": "~2.3.3" | ||
}, | ||
"main": "bundles/ngx-phone-mask.umd.js", | ||
"module": "ngx-phone-mask/ngx-phone-mask.es5.js", | ||
"es2015": "ngx-phone-mask/ngx-phone-mask.js", | ||
"typings": "ngx-phone-mask.d.ts" | ||
} | ||
"module": "fesm5/ngx-phone-mask.js", | ||
"es2015": "fesm2015/ngx-phone-mask.js", | ||
"esm5": "esm5/ngx-phone-mask.js", | ||
"esm2015": "esm2015/ngx-phone-mask.js", | ||
"fesm5": "fesm5/ngx-phone-mask.js", | ||
"fesm2015": "fesm2015/ngx-phone-mask.js", | ||
"typings": "ngx-phone-mask.d.ts", | ||
"metadata": "ngx-phone-mask.metadata.json", | ||
"sideEffects": false, | ||
"dependencies": { | ||
"tslib": "^1.9.0" | ||
} | ||
} |
@@ -1,1 +0,2 @@ | ||
export * from './src/app/ngx-phone-mask/ngx-phone-mask.module'; | ||
export * from './lib/ngx-phone-mask.directive'; | ||
export * from './lib/ngx-phone-mask.module'; |
@@ -1,10 +0,20 @@ | ||
# NgxPhoneMask | ||
# NgxPhoneMask ![pipeline status](https://gitlab.com/Ledzz/ngx-phone-mask/badges/master/pipeline.svg) | ||
Angular directive for autoformatting international phone numbers. | ||
Angular directive for autoformatting phone numbers. Compatible with Angular 7. | ||
Currently doesn't support phone numbers with lengths other than 11. (`+7 (987) 123-45-67`) | ||
[Demo](https://ngx-phone-mask.surge.sh/) | ||
## Usage | ||
This libs rely on text-mask, so you need to install it. | ||
Install via npm: | ||
```shell | ||
npm install ngx-phone-mask | ||
npm install ngx-phone-mask angular2-text-mask | ||
``` | ||
or yarn: | ||
```shell | ||
yarn add ngx-phone-mask angular2-text-mask | ||
``` | ||
@@ -32,4 +42,3 @@ Import in your `app.module.ts`: | ||
## Config | ||
You can set `valueType` to `'clean'`, `'raw'` or `'full'` to change output format. | ||
Default is `'clean'`. | ||
You can set `clean` to `false` if you want formatted value in model. | ||
```html | ||
@@ -43,8 +52,8 @@ <input ngxPhoneMask [(ngModel)]='yourModelName' valueType='full'> | ||
To publish: | ||
``` | ||
git commit | ||
npm version patch | ||
npm run build | ||
npm publish dist | ||
``` | ||
## Contributing | ||
Please feel free to leave your PRs, issues, feature requests. | ||
## Upcoming features | ||
- [ ] Support other phone lengths | ||
- [ ] Return country when recognized | ||
- [ ] Tests |
Sorry, the diff of this file is not supported yet
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
Major refactor
Supply chain riskPackage has recently undergone a major refactor. It may be unstable or indicate significant internal changes. Use caution when updating to versions that include significant changes.
Found 1 instance in 1 package
Minified code
QualityThis package contains minified code. This may be harmless in some cases where minified code is included in packaged libraries, however packages on npm should not minify code.
Found 1 instance in 1 package
No contributors or author data
MaintenancePackage does not specify a list of contributors or an author in package.json.
Found 1 instance in 1 package
No bug tracker
MaintenancePackage does not have a linked bug tracker in package.json.
Found 1 instance in 1 package
No License Found
License(Experimental) License information could not be found.
Found 1 instance in 1 package
No repository
Supply chain riskPackage does not have a linked source code repository. Without this field, a package will have no reference to the location of the source code use to generate the package.
Found 1 instance in 1 package
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
158717
4
0
23
1397
58
1
3
2
1
1
+ Addedtslib@^1.9.0
+ Added@angular/common@6.1.10(transitive)
+ Added@angular/core@6.1.10(transitive)
+ Addedangular2-text-mask@9.0.0(transitive)
+ Addedrxjs@6.6.7(transitive)
+ Addedtext-mask-core@5.1.2(transitive)
+ Addedtslib@1.14.1(transitive)
- Removed@angular/common@19.0.0(transitive)
- Removed@angular/compiler@19.0.0(transitive)
- Removed@angular/core@19.0.0(transitive)
- Removed@angular/forms@19.0.0(transitive)
- Removed@angular/platform-browser@19.0.0(transitive)
- Removed@angular/platform-browser-dynamic@19.0.0(transitive)
- Removedcore-js@2.6.12(transitive)
- Removedrxjs@5.5.127.8.1(transitive)
- Removedsymbol-observable@1.0.1(transitive)
- Removedtslib@2.8.1(transitive)
- Removedzone.js@0.15.0(transitive)