ngx-mask
Version:
awesome ngx mask
431 lines • 48.9 kB
JavaScript
import * as tslib_1 from "tslib";
import { Directive, forwardRef, HostListener, Inject, Input } from '@angular/core';
import { DOCUMENT } from '@angular/common';
import { NG_VALIDATORS, NG_VALUE_ACCESSOR } from '@angular/forms';
import { MaskService } from './mask.service';
import { withoutValidation } from './config';
var MaskDirective = /** @class */ (function () {
function MaskDirective(
// tslint:disable-next-line
document, _maskService) {
this.document = document;
this._maskService = _maskService;
this._position = null;
// tslint:disable-next-line
this.onChange = function (_) { };
this.onTouch = function () { };
}
MaskDirective_1 = MaskDirective;
Object.defineProperty(MaskDirective.prototype, "maskExpression", {
set: function (value) {
this._maskValue = value || '';
if (!this._maskValue) {
return;
}
this._maskService.maskExpression = this._repeatPatternSymbols(this._maskValue);
this._maskService.formElementProperty = [
'value',
this._maskService.applyMask(this._inputValue, this._maskService.maskExpression)
];
},
enumerable: true,
configurable: true
});
Object.defineProperty(MaskDirective.prototype, "specialCharacters", {
set: function (value) {
if (!value || !Array.isArray(value) || (Array.isArray(value) && !value.length)) {
return;
}
this._maskService.maskSpecialCharacters = value;
},
enumerable: true,
configurable: true
});
Object.defineProperty(MaskDirective.prototype, "patterns", {
set: function (value) {
if (!value) {
return;
}
this._maskService.maskAvailablePatterns = value;
},
enumerable: true,
configurable: true
});
Object.defineProperty(MaskDirective.prototype, "prefix", {
set: function (value) {
if (!value) {
return;
}
this._maskService.prefix = value;
},
enumerable: true,
configurable: true
});
Object.defineProperty(MaskDirective.prototype, "sufix", {
set: function (value) {
if (!value) {
return;
}
this._maskService.sufix = value;
},
enumerable: true,
configurable: true
});
Object.defineProperty(MaskDirective.prototype, "dropSpecialCharacters", {
set: function (value) {
this._maskService.dropSpecialCharacters = value;
},
enumerable: true,
configurable: true
});
Object.defineProperty(MaskDirective.prototype, "hiddenInput", {
set: function (value) {
this._maskService.hiddenInput = value;
},
enumerable: true,
configurable: true
});
Object.defineProperty(MaskDirective.prototype, "showMaskTyped", {
set: function (value) {
if (!value) {
return;
}
this._maskService.showMaskTyped = value;
},
enumerable: true,
configurable: true
});
Object.defineProperty(MaskDirective.prototype, "shownMaskExpression", {
set: function (value) {
if (!value) {
return;
}
this._maskService.shownMaskExpression = value;
},
enumerable: true,
configurable: true
});
Object.defineProperty(MaskDirective.prototype, "showTemplate", {
set: function (value) {
this._maskService.showTemplate = value;
},
enumerable: true,
configurable: true
});
Object.defineProperty(MaskDirective.prototype, "clearIfNotMatch", {
set: function (value) {
this._maskService.clearIfNotMatch = value;
},
enumerable: true,
configurable: true
});
Object.defineProperty(MaskDirective.prototype, "validation", {
set: function (value) {
this._maskService.validation = value;
},
enumerable: true,
configurable: true
});
// tslint:disable-next-line: cyclomatic-complexity
MaskDirective.prototype.validate = function (_a) {
var value = _a.value;
if (!this._maskService.validation) {
return null;
}
if (/dot_separator\.\d{1,}/.test(this._maskValue) === true ||
/comma_separator\.\d{1,}/.test(this._maskValue) === true) {
return null;
}
if (withoutValidation.includes(this._maskValue)) {
return null;
}
if (this._maskService.clearIfNotMatch) {
return null;
}
if (value && value.toString().length >= 1) {
var counterOfOpt = 0;
for (var key in this._maskService.maskAvailablePatterns) {
if (this._maskService.maskAvailablePatterns[key].optional &&
this._maskService.maskAvailablePatterns[key].optional === true) {
if (this._maskValue.indexOf(key) !== -1) {
counterOfOpt++;
}
if (this._maskValue.indexOf(key) !== -1 &&
value.toString().length >= this._maskValue.indexOf(key)) {
return null;
}
if (counterOfOpt === this._maskValue.length) {
return null;
}
}
}
if (this._maskValue.indexOf('*') === 1 ||
this._maskValue.indexOf('?') === 1 ||
this._maskValue.indexOf('{') === 1) {
return null;
}
else if ((this._maskValue.indexOf('*') > 1 && value.toString().length < this._maskValue.indexOf('*')) ||
(this._maskValue.indexOf('?') > 1 && value.toString().length < this._maskValue.indexOf('?'))) {
return { 'Mask error': true };
}
if (this._maskValue.indexOf('*') === -1 || this._maskValue.indexOf('?') === -1) {
var length_1 = this._maskService.dropSpecialCharacters
? this._maskValue.length - this._maskService.checkSpecialCharAmount(this._maskValue) - counterOfOpt
: this._maskValue.length - counterOfOpt;
if (value.toString().length !== length_1) {
return { 'Mask error': true };
}
}
}
return null;
};
MaskDirective.prototype.onInput = function (e) {
var el = e.target;
this._inputValue = el.value;
if (!this._maskValue) {
this.onChange(el.value);
return;
}
var position = el.selectionStart === 1
? el.selectionStart + this._maskService.prefix.length
: el.selectionStart;
var caretShift = 0;
this._maskService.applyValueChanges(position, function (shift) { return (caretShift = shift); });
// only set the selection if the element is active
if (this.document.activeElement !== el) {
return;
}
this._position = this._position === 1 && this._inputValue.length === 1 ? null : this._position;
el.selectionStart = el.selectionEnd =
this._position !== null
? this._position
: position +
// tslint:disable-next-line
(this._code === 'Backspace' ? 0 : caretShift);
this._position = null;
};
MaskDirective.prototype.onBlur = function () {
this._maskService.clearIfNotMatchFn();
this.onTouch();
};
MaskDirective.prototype.onFocus = function (e) {
var el = e.target;
var posStart = 0;
var posEnd = 0;
if (el !== null &&
el.selectionStart !== null &&
el.selectionStart === el.selectionEnd &&
el.selectionStart > this._maskService.prefix.length &&
// tslint:disable-next-line
e.keyCode !== 38)
if (this._maskService.showMaskTyped) {
// ) {
// return;
// }
this._maskService.maskIsShown = this._maskService.showMaskInInput();
if (el.setSelectionRange && this._maskService.prefix + this._maskService.maskIsShown === el.value) {
el.focus();
el.setSelectionRange(posStart, posEnd);
}
}
el.value =
!el.value || el.value === this._maskService.prefix
? this._maskService.prefix + this._maskService.maskIsShown
: el.value;
/** fix of cursor position with prefix when mouse click occur */
if ((el.selectionStart || el.selectionEnd) <= this._maskService.prefix.length) {
el.selectionStart = this._maskService.prefix.length;
return;
}
};
MaskDirective.prototype.a = function (e) {
this._code = e.code;
var el = e.target;
this._maskService.selStart = el.selectionStart;
this._maskService.selEnd = el.selectionEnd;
if (e.keyCode === 38) {
e.preventDefault();
}
if (e.keyCode === 37 || e.keyCode === 8) {
if (el.selectionStart <= this._maskService.prefix.length &&
el.selectionEnd <= this._maskService.prefix.length) {
e.preventDefault();
}
var cursorStart = el.selectionStart;
this.onFocus(e);
if (e.keyCode === 8 && cursorStart === 0 && el.selectionEnd === el.value.length) {
this._position = this._maskService.prefix ? this._maskService.prefix.length : 1;
this._maskService.applyMask(this._maskService.prefix, this._maskService.maskExpression, this._position);
}
}
};
MaskDirective.prototype.onPaste = function () {
this._position = Number.MAX_SAFE_INTEGER;
};
/** It writes the value in the input */
MaskDirective.prototype.writeValue = function (inputValue) {
return tslib_1.__awaiter(this, void 0, void 0, function () {
return tslib_1.__generator(this, function (_a) {
if (inputValue === undefined) {
inputValue = '';
}
if (typeof inputValue === 'number') {
inputValue = String(inputValue);
inputValue = this._maskValue.startsWith('dot_separator') ? inputValue.replace('.', ',') : inputValue;
this._maskService.isNumberValue = true;
}
(inputValue && this._maskService.maskExpression) ||
(this._maskService.maskExpression && (this._maskService.prefix || this._maskService.showMaskTyped))
? (this._maskService.formElementProperty = [
'value',
this._maskService.applyMask(inputValue, this._maskService.maskExpression)
])
: (this._maskService.formElementProperty = ['value', inputValue]);
this._inputValue = inputValue;
return [2 /*return*/];
});
});
};
// tslint:disable-next-line
MaskDirective.prototype.registerOnChange = function (fn) {
this.onChange = fn;
this._maskService.onChange = this.onChange;
};
// tslint:disable-next-line
MaskDirective.prototype.registerOnTouched = function (fn) {
this.onTouch = fn;
};
/** It disables the input element */
MaskDirective.prototype.setDisabledState = function (isDisabled) {
this._maskService.formElementProperty = ['disabled', isDisabled];
};
MaskDirective.prototype._repeatPatternSymbols = function (maskExp) {
var _this = this;
return ((maskExp.match(/{[0-9]+}/) &&
maskExp.split('').reduce(function (accum, currval, index) {
_this._start = currval === '{' ? index : _this._start;
if (currval !== '}') {
return _this._maskService._findSpecialChar(currval) ? accum + currval : accum;
}
_this._end = index;
var repeatNumber = Number(maskExp.slice(_this._start + 1, _this._end));
var repaceWith = new Array(repeatNumber + 1).join(maskExp[_this._start - 1]);
return accum + repaceWith;
}, '')) ||
maskExp);
};
var MaskDirective_1;
tslib_1.__decorate([
Input('mask'),
tslib_1.__metadata("design:type", String),
tslib_1.__metadata("design:paramtypes", [String])
], MaskDirective.prototype, "maskExpression", null);
tslib_1.__decorate([
Input(),
tslib_1.__metadata("design:type", Object),
tslib_1.__metadata("design:paramtypes", [Object])
], MaskDirective.prototype, "specialCharacters", null);
tslib_1.__decorate([
Input(),
tslib_1.__metadata("design:type", Object),
tslib_1.__metadata("design:paramtypes", [Object])
], MaskDirective.prototype, "patterns", null);
tslib_1.__decorate([
Input(),
tslib_1.__metadata("design:type", Object),
tslib_1.__metadata("design:paramtypes", [Object])
], MaskDirective.prototype, "prefix", null);
tslib_1.__decorate([
Input(),
tslib_1.__metadata("design:type", Object),
tslib_1.__metadata("design:paramtypes", [Object])
], MaskDirective.prototype, "sufix", null);
tslib_1.__decorate([
Input(),
tslib_1.__metadata("design:type", Object),
tslib_1.__metadata("design:paramtypes", [Object])
], MaskDirective.prototype, "dropSpecialCharacters", null);
tslib_1.__decorate([
Input(),
tslib_1.__metadata("design:type", Object),
tslib_1.__metadata("design:paramtypes", [Object])
], MaskDirective.prototype, "hiddenInput", null);
tslib_1.__decorate([
Input(),
tslib_1.__metadata("design:type", Object),
tslib_1.__metadata("design:paramtypes", [Object])
], MaskDirective.prototype, "showMaskTyped", null);
tslib_1.__decorate([
Input(),
tslib_1.__metadata("design:type", Object),
tslib_1.__metadata("design:paramtypes", [Object])
], MaskDirective.prototype, "shownMaskExpression", null);
tslib_1.__decorate([
Input(),
tslib_1.__metadata("design:type", Object),
tslib_1.__metadata("design:paramtypes", [Object])
], MaskDirective.prototype, "showTemplate", null);
tslib_1.__decorate([
Input(),
tslib_1.__metadata("design:type", Object),
tslib_1.__metadata("design:paramtypes", [Object])
], MaskDirective.prototype, "clearIfNotMatch", null);
tslib_1.__decorate([
Input(),
tslib_1.__metadata("design:type", Object),
tslib_1.__metadata("design:paramtypes", [Object])
], MaskDirective.prototype, "validation", null);
tslib_1.__decorate([
HostListener('input', ['$event']),
tslib_1.__metadata("design:type", Function),
tslib_1.__metadata("design:paramtypes", [KeyboardEvent]),
tslib_1.__metadata("design:returntype", void 0)
], MaskDirective.prototype, "onInput", null);
tslib_1.__decorate([
HostListener('blur'),
tslib_1.__metadata("design:type", Function),
tslib_1.__metadata("design:paramtypes", []),
tslib_1.__metadata("design:returntype", void 0)
], MaskDirective.prototype, "onBlur", null);
tslib_1.__decorate([
HostListener('click', ['$event']),
tslib_1.__metadata("design:type", Function),
tslib_1.__metadata("design:paramtypes", [Object]),
tslib_1.__metadata("design:returntype", void 0)
], MaskDirective.prototype, "onFocus", null);
tslib_1.__decorate([
HostListener('keydown', ['$event']),
tslib_1.__metadata("design:type", Function),
tslib_1.__metadata("design:paramtypes", [KeyboardEvent]),
tslib_1.__metadata("design:returntype", void 0)
], MaskDirective.prototype, "a", null);
tslib_1.__decorate([
HostListener('paste'),
tslib_1.__metadata("design:type", Function),
tslib_1.__metadata("design:paramtypes", []),
tslib_1.__metadata("design:returntype", void 0)
], MaskDirective.prototype, "onPaste", null);
MaskDirective = MaskDirective_1 = tslib_1.__decorate([
Directive({
selector: '[mask]',
providers: [
{
provide: NG_VALUE_ACCESSOR,
useExisting: forwardRef(function () { return MaskDirective_1; }),
multi: true
},
{
provide: NG_VALIDATORS,
useExisting: forwardRef(function () { return MaskDirective_1; }),
multi: true
},
MaskService
]
}),
tslib_1.__param(0, Inject(DOCUMENT)),
tslib_1.__metadata("design:paramtypes", [Object, MaskService])
], MaskDirective);
return MaskDirective;
}());
export { MaskDirective };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"mask.directive.js","sourceRoot":"ng://ngx-mask/","sources":["app/ngx-mask/mask.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, forwardRef, HostListener, Inject, Input } from '@angular/core';\nimport { DOCUMENT } from '@angular/common';\nimport { ControlValueAccessor, FormControl, NG_VALIDATORS, NG_VALUE_ACCESSOR, ValidationErrors } from '@angular/forms';\nimport { MaskService } from './mask.service';\nimport { config, IConfig, withoutValidation } from './config';\n\n@Directive({\n    selector: '[mask]',\n    providers: [\n        {\n            provide: NG_VALUE_ACCESSOR,\n            useExisting: forwardRef(() => MaskDirective),\n            multi: true\n        },\n        {\n            provide: NG_VALIDATORS,\n            useExisting: forwardRef(() => MaskDirective),\n            multi: true\n        },\n        MaskService\n    ]\n})\nexport class MaskDirective implements ControlValueAccessor {\n    private _maskValue!: string;\n    private _inputValue!: string;\n    private _position: number | null = null;\n    // tslint:disable-next-line\n    private _start!: number;\n    private _end!: number;\n    private _code!: string;\n    // tslint:disable-next-line\n    public onChange = (_: any) => {};\n    public onTouch = () => {};\n\n    public constructor(\n        // tslint:disable-next-line\n        @Inject(DOCUMENT) private document: any,\n        private _maskService: MaskService\n    ) {}\n\n    @Input('mask')\n    public set maskExpression(value: string) {\n        this._maskValue = value || '';\n        if (!this._maskValue) {\n            return;\n        }\n        this._maskService.maskExpression = this._repeatPatternSymbols(this._maskValue);\n        this._maskService.formElementProperty = [\n            'value',\n            this._maskService.applyMask(this._inputValue, this._maskService.maskExpression)\n        ];\n    }\n\n    @Input()\n    public set specialCharacters(value: IConfig['specialCharacters']) {\n        if (!value || !Array.isArray(value) || (Array.isArray(value) && !value.length)) {\n            return;\n        }\n        this._maskService.maskSpecialCharacters = value;\n    }\n\n    @Input()\n    public set patterns(value: IConfig['patterns']) {\n        if (!value) {\n            return;\n        }\n        this._maskService.maskAvailablePatterns = value;\n    }\n\n    @Input()\n    public set prefix(value: IConfig['prefix']) {\n        if (!value) {\n            return;\n        }\n        this._maskService.prefix = value;\n    }\n\n    @Input()\n    public set sufix(value: IConfig['sufix']) {\n        if (!value) {\n            return;\n        }\n        this._maskService.sufix = value;\n    }\n\n    @Input()\n    public set dropSpecialCharacters(value: IConfig['dropSpecialCharacters']) {\n        this._maskService.dropSpecialCharacters = value;\n    }\n    @Input()\n    public set hiddenInput(value: IConfig['hiddenInput']) {\n        this._maskService.hiddenInput = value;\n    }\n\n    @Input()\n    public set showMaskTyped(value: IConfig['showMaskTyped']) {\n        if (!value) {\n            return;\n        }\n        this._maskService.showMaskTyped = value;\n    }\n\n    @Input()\n    public set shownMaskExpression(value: IConfig['shownMaskExpression']) {\n        if (!value) {\n            return;\n        }\n        this._maskService.shownMaskExpression = value;\n    }\n\n    @Input()\n    public set showTemplate(value: IConfig['showTemplate']) {\n        this._maskService.showTemplate = value;\n    }\n\n    @Input()\n    public set clearIfNotMatch(value: IConfig['clearIfNotMatch']) {\n        this._maskService.clearIfNotMatch = value;\n    }\n\n    @Input()\n    public set validation(value: IConfig['validation']) {\n        this._maskService.validation = value;\n    }\n\n    // tslint:disable-next-line: cyclomatic-complexity\n    public validate({ value }: FormControl): ValidationErrors | null {\n        if (!this._maskService.validation) {\n            return null;\n        }\n        if (\n            /dot_separator\\.\\d{1,}/.test(this._maskValue) === true ||\n            /comma_separator\\.\\d{1,}/.test(this._maskValue) === true\n        ) {\n            return null;\n        }\n        if (withoutValidation.includes(this._maskValue)) {\n            return null;\n        }\n        if (this._maskService.clearIfNotMatch) {\n            return null;\n        }\n        if (value && value.toString().length >= 1) {\n            let counterOfOpt: number = 0;\n            for (const key in this._maskService.maskAvailablePatterns) {\n                if (\n                    this._maskService.maskAvailablePatterns[key].optional &&\n                    this._maskService.maskAvailablePatterns[key].optional === true\n                ) {\n                    if (this._maskValue.indexOf(key) !== -1) {\n                        counterOfOpt++;\n                    }\n                    if (\n                        this._maskValue.indexOf(key) !== -1 &&\n                        value.toString().length >= this._maskValue.indexOf(key)\n                    ) {\n                        return null;\n                    }\n                    if (counterOfOpt === this._maskValue.length) {\n                        return null;\n                    }\n                }\n            }\n            if (\n                this._maskValue.indexOf('*') === 1 ||\n                this._maskValue.indexOf('?') === 1 ||\n                this._maskValue.indexOf('{') === 1\n            ) {\n                return null;\n            } else if (\n                (this._maskValue.indexOf('*') > 1 && value.toString().length < this._maskValue.indexOf('*')) ||\n                (this._maskValue.indexOf('?') > 1 && value.toString().length < this._maskValue.indexOf('?'))\n            ) {\n                return { 'Mask error': true };\n            }\n            if (this._maskValue.indexOf('*') === -1 || this._maskValue.indexOf('?') === -1) {\n                const length: number = this._maskService.dropSpecialCharacters\n                    ? this._maskValue.length - this._maskService.checkSpecialCharAmount(this._maskValue) - counterOfOpt\n                    : this._maskValue.length - counterOfOpt;\n                if (value.toString().length !== length) {\n                    return { 'Mask error': true };\n                }\n            }\n        }\n        return null;\n    }\n\n    @HostListener('input', ['$event'])\n    public onInput(e: KeyboardEvent): void {\n        const el: HTMLInputElement = e.target as HTMLInputElement;\n        this._inputValue = el.value;\n        if (!this._maskValue) {\n            this.onChange(el.value);\n            return;\n        }\n        const position: number =\n            el.selectionStart === 1\n                ? (el.selectionStart as number) + this._maskService.prefix.length\n                : (el.selectionStart as number);\n        let caretShift: number = 0;\n        this._maskService.applyValueChanges(position, (shift: number) => (caretShift = shift));\n        // only set the selection if the element is active\n        if (this.document.activeElement !== el) {\n            return;\n        }\n        this._position = this._position === 1 && this._inputValue.length === 1 ? null : this._position;\n        el.selectionStart = el.selectionEnd =\n            this._position !== null\n                ? this._position\n                : position +\n                  // tslint:disable-next-line\n                  (this._code === 'Backspace' ? 0 : caretShift);\n        this._position = null;\n    }\n\n    @HostListener('blur')\n    public onBlur(): void {\n        this._maskService.clearIfNotMatchFn();\n        this.onTouch();\n    }\n\n    @HostListener('click', ['$event'])\n    public onFocus(e: MouseEvent | KeyboardEvent): void {\n        const el: HTMLInputElement = e.target as HTMLInputElement;\n        const posStart: number = 0;\n        const posEnd: number = 0;\n        if (\n            el !== null &&\n            el.selectionStart !== null &&\n            el.selectionStart === el.selectionEnd &&\n            el.selectionStart > this._maskService.prefix.length &&\n            // tslint:disable-next-line\n            (e as any).keyCode !== 38\n        )\n            if (this._maskService.showMaskTyped) {\n                // ) {\n                //     return;\n                // }\n                this._maskService.maskIsShown = this._maskService.showMaskInInput();\n                if (el.setSelectionRange && this._maskService.prefix + this._maskService.maskIsShown === el.value) {\n                    el.focus();\n                    el.setSelectionRange(posStart, posEnd);\n                }\n            }\n        el.value =\n            !el.value || el.value === this._maskService.prefix\n                ? this._maskService.prefix + this._maskService.maskIsShown\n                : el.value;\n        /** fix of cursor position with prefix when mouse click occur */\n        if (((el.selectionStart as number) || (el.selectionEnd as number)) <= this._maskService.prefix.length) {\n            el.selectionStart = this._maskService.prefix.length;\n            return;\n        }\n    }\n\n    @HostListener('keydown', ['$event'])\n    public a(e: KeyboardEvent): void {\n        this._code = e.code;\n        const el: HTMLInputElement = e.target as HTMLInputElement;\n        this._maskService.selStart = el.selectionStart;\n        this._maskService.selEnd = el.selectionEnd;\n        if (e.keyCode === 38) {\n            e.preventDefault();\n        }\n        if (e.keyCode === 37 || e.keyCode === 8) {\n            if (\n                (el.selectionStart as number) <= this._maskService.prefix.length &&\n                (el.selectionEnd as number) <= this._maskService.prefix.length\n            ) {\n                e.preventDefault();\n            }\n            const cursorStart: number | null = el.selectionStart;\n            this.onFocus(e);\n            if (e.keyCode === 8 && cursorStart === 0 && el.selectionEnd === el.value.length) {\n                this._position = this._maskService.prefix ? this._maskService.prefix.length : 1;\n                this._maskService.applyMask(this._maskService.prefix, this._maskService.maskExpression, this._position);\n            }\n        }\n    }\n\n    @HostListener('paste')\n    public onPaste(): void {\n        this._position = Number.MAX_SAFE_INTEGER;\n    }\n\n    /** It writes the value in the input */\n    public async writeValue(inputValue: string): Promise<void> {\n        if (inputValue === undefined) {\n            inputValue = '';\n        }\n        if (typeof inputValue === 'number') {\n            inputValue = String(inputValue);\n            inputValue = this._maskValue.startsWith('dot_separator') ? inputValue.replace('.', ',') : inputValue;\n            this._maskService.isNumberValue = true;\n        }\n        (inputValue && this._maskService.maskExpression) ||\n        (this._maskService.maskExpression && (this._maskService.prefix || this._maskService.showMaskTyped))\n            ? (this._maskService.formElementProperty = [\n                  'value',\n                  this._maskService.applyMask(inputValue, this._maskService.maskExpression)\n              ])\n            : (this._maskService.formElementProperty = ['value', inputValue]);\n        this._inputValue = inputValue;\n    }\n\n    // tslint:disable-next-line\n    public registerOnChange(fn: any): void {\n        this.onChange = fn;\n        this._maskService.onChange = this.onChange;\n    }\n\n    // tslint:disable-next-line\n    public registerOnTouched(fn: any): void {\n        this.onTouch = fn;\n    }\n\n    /** It disables the input element */\n    public setDisabledState(isDisabled: boolean): void {\n        this._maskService.formElementProperty = ['disabled', isDisabled];\n    }\n\n    private _repeatPatternSymbols(maskExp: string): string {\n        return (\n            (maskExp.match(/{[0-9]+}/) &&\n                maskExp.split('').reduce((accum: string, currval: string, index: number): string => {\n                    this._start = currval === '{' ? index : this._start;\n\n                    if (currval !== '}') {\n                        return this._maskService._findSpecialChar(currval) ? accum + currval : accum;\n                    }\n                    this._end = index;\n                    const repeatNumber: number = Number(maskExp.slice(this._start + 1, this._end));\n                    const repaceWith: string = new Array(repeatNumber + 1).join(maskExp[this._start - 1]);\n                    return accum + repaceWith;\n                }, '')) ||\n            maskExp\n        );\n    }\n}\n"]}