@catull/igniteui-angular
Version:
Ignite UI for Angular is a dependency-free Angular toolkit for building modern web apps
335 lines • 34.6 kB
JavaScript
import { __decorate, __metadata } from "tslib";
import { CommonModule } from '@angular/common';
import { Directive, ElementRef, EventEmitter, HostListener, Input, NgModule, OnInit, Output, PipeTransform } from '@angular/core';
import { NG_VALUE_ACCESSOR } from '@angular/forms';
import { KEYS, MaskHelper } from './mask-helper';
import { isIE } from '../../core/utils';
var noop = function () { };
var ɵ0 = noop;
var IgxMaskDirective = /** @class */ (function () {
function IgxMaskDirective(elementRef) {
this.elementRef = elementRef;
/**
* Emits an event each time the value changes.
* Provides `rawValue: string` and `formattedValue: string` as event arguments.
* ```html
* <input (onValueChange) = "onValueChange(rawValue: string, formattedValue: string)">
* ```
*/
this.onValueChange = new EventEmitter();
/**
*@hidden
*/
this._maskOptions = {
format: '',
promptChar: ''
};
/**
*@hidden
*/
this._onTouchedCallback = noop;
/**
*@hidden
*/
this._onChangeCallback = noop;
this.maskHelper = new MaskHelper();
}
IgxMaskDirective_1 = IgxMaskDirective;
Object.defineProperty(IgxMaskDirective.prototype, "placeholder", {
get: function () {
return this._placeholder;
},
/**
* Specifies a placeholder.
* ```html
* <input placeholder = "enter text...">
* ```
* @memberof IgxMaskDirective
*/
set: function (val) {
this._placeholder = val;
this.nativeElement.setAttribute('placeholder', this._placeholder);
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxMaskDirective.prototype, "value", {
/**
*@hidden
*/
get: function () {
return this.nativeElement.value;
},
/**
*@hidden
*/
set: function (val) {
this.nativeElement.value = val;
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxMaskDirective.prototype, "nativeElement", {
/**
*@hidden
*/
get: function () {
return this.elementRef.nativeElement;
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxMaskDirective.prototype, "selectionStart", {
/**
*@hidden
*/
get: function () {
return this.nativeElement.selectionStart;
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxMaskDirective.prototype, "selectionEnd", {
/**
*@hidden
*/
get: function () {
return this.nativeElement.selectionEnd;
},
enumerable: true,
configurable: true
});
/**
*@hidden
*/
IgxMaskDirective.prototype.ngOnInit = function () {
if (this.promptChar && this.promptChar.length > 1) {
this._maskOptions.promptChar = this.promptChar = this.promptChar.substring(0, 1);
}
this._maskOptions.format = this.mask ? this.mask : 'CCCCCCCCCC';
this._maskOptions.promptChar = this.promptChar ? this.promptChar : '_';
this.nativeElement.setAttribute('placeholder', this.placeholder ? this.placeholder : this._maskOptions.format);
};
/**
*@hidden
*/
IgxMaskDirective.prototype.onKeydown = function (event) {
var key = event.keyCode || event.charCode;
if (isIE() && this._stopPropagation) {
this._stopPropagation = false;
}
if (key === KEYS.Ctrl) {
this._ctrlDown = true;
}
if ((this._ctrlDown && key === KEYS.Z) || (this._ctrlDown && key === KEYS.Y)) {
event.preventDefault();
}
this._key = key;
this._selection = Math.abs(this.selectionEnd - this.selectionStart);
};
/**
*@hidden
*/
IgxMaskDirective.prototype.onKeyup = function (event) {
var key = event.keyCode || event.charCode;
if (key === KEYS.Ctrl) {
this._ctrlDown = false;
}
};
/**
*@hidden
*/
IgxMaskDirective.prototype.onPaste = function (event) {
this._paste = true;
this._valOnPaste = this.value;
this._cursorOnPaste = this.getCursorPosition();
};
/**
*@hidden
*/
IgxMaskDirective.prototype.onInputChanged = function (event) {
if (isIE() && this._stopPropagation) {
this._stopPropagation = false;
return;
}
if (this._paste) {
this._paste = false;
var clipboardData = this.value.substring(this._cursorOnPaste, this.getCursorPosition());
this.value = this.maskHelper.parseValueByMaskUponCopyPaste(this._valOnPaste, this._maskOptions, this._cursorOnPaste, clipboardData, this._selection);
this.setCursorPosition(this.maskHelper.cursor);
}
else {
var currentCursorPos = this.getCursorPosition();
this.maskHelper.data = (this._key === KEYS.BACKSPACE) || (this._key === KEYS.DELETE);
this.value = this._selection && this._selection !== 0 ?
this.maskHelper.parseValueByMaskUponSelection(this.value, this._maskOptions, currentCursorPos - 1, this._selection) :
this.maskHelper.parseValueByMask(this.value, this._maskOptions, currentCursorPos - 1);
this.setCursorPosition(this.maskHelper.cursor);
}
var rawVal = this.maskHelper.restoreValueFromMask(this.value, this._maskOptions);
this.dataValue = this.includeLiterals ? this.value : rawVal;
this._onChangeCallback(this.dataValue);
this.onValueChange.emit({ rawValue: rawVal, formattedValue: this.value });
};
/**
*@hidden
*/
IgxMaskDirective.prototype.onFocus = function (value) {
if (this.focusedValuePipe) {
if (isIE()) {
this._stopPropagation = true;
}
this.value = this.focusedValuePipe.transform(value);
}
else {
this.value = this.maskHelper.parseValueByMaskOnInit(this.value, this._maskOptions);
}
};
/**
*@hidden
*/
IgxMaskDirective.prototype.onBlur = function (value) {
if (this.displayValuePipe) {
this.value = this.displayValuePipe.transform(value);
}
else if (value === this.maskHelper.parseMask(this._maskOptions)) {
this.value = '';
}
};
/**
*@hidden
*/
IgxMaskDirective.prototype.getCursorPosition = function () {
return this.nativeElement.selectionStart;
};
/**
*@hidden
*/
IgxMaskDirective.prototype.setCursorPosition = function (start, end) {
if (end === void 0) { end = start; }
this.nativeElement.setSelectionRange(start, end);
};
/**
*@hidden
*/
IgxMaskDirective.prototype.writeValue = function (value) {
if (this.promptChar && this.promptChar.length > 1) {
this._maskOptions.promptChar = this.promptChar.substring(0, 1);
}
this.value = value ? this.maskHelper.parseValueByMaskOnInit(value, this._maskOptions) : '';
if (this.displayValuePipe) {
this.value = this.displayValuePipe.transform(this.value);
}
this.dataValue = this.includeLiterals ? this.value : value;
this._onChangeCallback(this.dataValue);
this.onValueChange.emit({ rawValue: value, formattedValue: this.value });
};
/**
*@hidden
*/
IgxMaskDirective.prototype.registerOnChange = function (fn) { this._onChangeCallback = fn; };
/**
*@hidden
*/
IgxMaskDirective.prototype.registerOnTouched = function (fn) { this._onTouchedCallback = fn; };
var IgxMaskDirective_1;
IgxMaskDirective.ctorParameters = function () { return [
{ type: ElementRef }
]; };
__decorate([
Input('igxMask'),
__metadata("design:type", String)
], IgxMaskDirective.prototype, "mask", void 0);
__decorate([
Input(),
__metadata("design:type", String)
], IgxMaskDirective.prototype, "promptChar", void 0);
__decorate([
Input(),
__metadata("design:type", Boolean)
], IgxMaskDirective.prototype, "includeLiterals", void 0);
__decorate([
Input(),
__metadata("design:type", String),
__metadata("design:paramtypes", [String])
], IgxMaskDirective.prototype, "placeholder", null);
__decorate([
Input(),
__metadata("design:type", Object)
], IgxMaskDirective.prototype, "displayValuePipe", void 0);
__decorate([
Input(),
__metadata("design:type", Object)
], IgxMaskDirective.prototype, "focusedValuePipe", void 0);
__decorate([
Input(),
__metadata("design:type", String)
], IgxMaskDirective.prototype, "dataValue", void 0);
__decorate([
Output(),
__metadata("design:type", Object)
], IgxMaskDirective.prototype, "onValueChange", void 0);
__decorate([
HostListener('keydown', ['$event']),
__metadata("design:type", Function),
__metadata("design:paramtypes", [Object]),
__metadata("design:returntype", void 0)
], IgxMaskDirective.prototype, "onKeydown", null);
__decorate([
HostListener('keyup', ['$event']),
__metadata("design:type", Function),
__metadata("design:paramtypes", [Object]),
__metadata("design:returntype", void 0)
], IgxMaskDirective.prototype, "onKeyup", null);
__decorate([
HostListener('paste', ['$event']),
__metadata("design:type", Function),
__metadata("design:paramtypes", [Object]),
__metadata("design:returntype", void 0)
], IgxMaskDirective.prototype, "onPaste", null);
__decorate([
HostListener('input', ['$event']),
__metadata("design:type", Function),
__metadata("design:paramtypes", [Object]),
__metadata("design:returntype", void 0)
], IgxMaskDirective.prototype, "onInputChanged", null);
__decorate([
HostListener('focus', ['$event.target.value']),
__metadata("design:type", Function),
__metadata("design:paramtypes", [Object]),
__metadata("design:returntype", void 0)
], IgxMaskDirective.prototype, "onFocus", null);
__decorate([
HostListener('blur', ['$event.target.value']),
__metadata("design:type", Function),
__metadata("design:paramtypes", [Object]),
__metadata("design:returntype", void 0)
], IgxMaskDirective.prototype, "onBlur", null);
IgxMaskDirective = IgxMaskDirective_1 = __decorate([
Directive({
providers: [{ provide: NG_VALUE_ACCESSOR, useExisting: IgxMaskDirective_1, multi: true }],
selector: '[igxMask]'
}),
__metadata("design:paramtypes", [ElementRef])
], IgxMaskDirective);
return IgxMaskDirective;
}());
export { IgxMaskDirective };
/**
* @hidden
*/
var IgxMaskModule = /** @class */ (function () {
function IgxMaskModule() {
}
IgxMaskModule = __decorate([
NgModule({
declarations: [IgxMaskDirective],
exports: [IgxMaskDirective],
imports: [CommonModule]
})
], IgxMaskModule);
return IgxMaskModule;
}());
export { IgxMaskModule };
export { ɵ0 };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"mask.directive.js","sourceRoot":"ng://igniteui-angular/","sources":["lib/directives/mask/mask.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport {\n    Directive,\n    ElementRef,\n    EventEmitter,\n    HostListener,\n    Input,\n    NgModule,\n    OnInit,\n    Output,\n    PipeTransform\n} from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { KEYS, MaskHelper } from './mask-helper';\nimport { isIE, IBaseEventArgs } from '../../core/utils';\n\nconst noop = () => { };\n\n@Directive({\n    providers: [{ provide: NG_VALUE_ACCESSOR, useExisting: IgxMaskDirective, multi: true }],\n    selector: '[igxMask]'\n})\nexport class IgxMaskDirective implements OnInit, ControlValueAccessor {\n    /**\n     * Sets the input mask.\n     * ```html\n     * <input [igxMask] = \"'00/00/0000'\">\n     * ```\n     * @memberof IgxMaskDirective\n     */\n    @Input('igxMask')\n    public mask: string;\n\n    /**\n     * Sets the character representing a fillable spot in the input mask.\n     * Default value is \"'_'\".\n     * ```html\n     * <input [promptChar] = \"'/'\">\n     * ```\n     * @memberof IgxMaskDirective\n     */\n    @Input()\n    public promptChar: string;\n\n    /**\n     * Specifies if the bound value includes the formatting symbols.\n     * ```html\n     * <input [includeLiterals] = \"true\">\n     * ```\n     * @memberof IgxMaskDirective\n     */\n    @Input()\n    public includeLiterals: boolean;\n\n    /**\n     * Specifies a placeholder.\n     * ```html\n     * <input placeholder = \"enter text...\">\n     * ```\n     * @memberof IgxMaskDirective\n     */\n    @Input()\n    public set placeholder(val: string) {\n        this._placeholder = val;\n        this.nativeElement.setAttribute('placeholder', this._placeholder);\n    }\n\n    public get placeholder(): string {\n        return this._placeholder;\n    }\n\n    /**\n     * Specifies a pipe to be used on blur.\n     * ```html\n     * <input [displayValuePipe] = \"displayFormatPipe\">\n     * ```\n     * @memberof IgxMaskDirective\n     */\n    @Input()\n    public displayValuePipe: PipeTransform;\n\n    /**\n     * Specifies a pipe to be used on focus.\n     * ```html\n     * <input [focusedValuePipe] = \"inputFormatPipe\">\n     * ```\n     * @memberof IgxMaskDirective\n     */\n    @Input()\n    public focusedValuePipe: PipeTransform;\n\n    /**\n     *@hidden\n     */\n    @Input()\n    private dataValue: string;\n\n    /**\n     * Emits an event each time the value changes.\n     * Provides `rawValue: string` and `formattedValue: string` as event arguments.\n     * ```html\n     * <input (onValueChange) = \"onValueChange(rawValue: string, formattedValue: string)\">\n     * ```\n     */\n    @Output()\n    public onValueChange = new EventEmitter<IMaskEventArgs>();\n\n    /**\n     *@hidden\n     */\n    private get value() {\n        return this.nativeElement.value;\n    }\n\n    /**\n     *@hidden\n     */\n    private set value(val) {\n        this.nativeElement.value = val;\n    }\n\n    /**\n     *@hidden\n     */\n    private get nativeElement() {\n        return this.elementRef.nativeElement;\n    }\n\n    /**\n     *@hidden\n     */\n    private get selectionStart() {\n        return this.nativeElement.selectionStart;\n    }\n\n    /**\n     *@hidden\n     */\n    private get selectionEnd() {\n        return this.nativeElement.selectionEnd;\n    }\n\n    /**\n     *@hidden\n     */\n    private _ctrlDown: boolean;\n\n    /**\n     *@hidden\n     */\n    private _paste: boolean;\n\n    /**\n     *@hidden\n     */\n    private _selection: number;\n\n    /**\n     *@hidden\n     */\n    private _placeholder: string;\n\n    /**\n     *@hidden\n     */\n    private _maskOptions = {\n        format: '',\n        promptChar: ''\n    };\n\n    /**\n     *@hidden\n     */\n    private _key;\n\n    /**\n     *@hidden\n     */\n    private _cursorOnPaste;\n\n    /**\n     *@hidden\n     */\n    private _valOnPaste;\n\n    private _stopPropagation: boolean;\n\n    /**\n     *@hidden\n     */\n    private maskHelper: MaskHelper;\n\n    /**\n     *@hidden\n     */\n    private _onTouchedCallback: () => void = noop;\n\n    /**\n     *@hidden\n     */\n    private _onChangeCallback: (_: any) => void = noop;\n\n    constructor(private elementRef: ElementRef) {\n        this.maskHelper = new MaskHelper();\n    }\n\n    /**\n     *@hidden\n     */\n    public ngOnInit(): void {\n        if (this.promptChar && this.promptChar.length > 1) {\n            this._maskOptions.promptChar = this.promptChar = this.promptChar.substring(0, 1);\n        }\n\n        this._maskOptions.format = this.mask ? this.mask : 'CCCCCCCCCC';\n        this._maskOptions.promptChar = this.promptChar ? this.promptChar : '_';\n        this.nativeElement.setAttribute('placeholder', this.placeholder ? this.placeholder : this._maskOptions.format);\n    }\n\n    /**\n     *@hidden\n     */\n    @HostListener('keydown', ['$event'])\n    public onKeydown(event): void {\n        const key = event.keyCode || event.charCode;\n\n        if (isIE() && this._stopPropagation) {\n            this._stopPropagation = false;\n        }\n\n        if (key === KEYS.Ctrl) {\n            this._ctrlDown = true;\n        }\n\n        if ((this._ctrlDown && key === KEYS.Z) || (this._ctrlDown && key === KEYS.Y)) {\n            event.preventDefault();\n        }\n\n        this._key = key;\n        this._selection = Math.abs(this.selectionEnd - this.selectionStart);\n    }\n\n    /**\n     *@hidden\n     */\n    @HostListener('keyup', ['$event'])\n    public onKeyup(event): void {\n        const key = event.keyCode || event.charCode;\n\n        if (key === KEYS.Ctrl) {\n            this._ctrlDown = false;\n        }\n    }\n\n    /**\n     *@hidden\n     */\n    @HostListener('paste', ['$event'])\n    public onPaste(event): void {\n        this._paste = true;\n\n        this._valOnPaste = this.value;\n        this._cursorOnPaste = this.getCursorPosition();\n    }\n\n    /**\n     *@hidden\n     */\n    @HostListener('input', ['$event'])\n    public onInputChanged(event): void {\n        if (isIE() && this._stopPropagation) {\n            this._stopPropagation = false;\n            return;\n        }\n\n        if (this._paste) {\n            this._paste = false;\n\n            const clipboardData = this.value.substring(this._cursorOnPaste, this.getCursorPosition());\n            this.value = this.maskHelper.parseValueByMaskUponCopyPaste(\n                this._valOnPaste, this._maskOptions, this._cursorOnPaste, clipboardData, this._selection);\n\n            this.setCursorPosition(this.maskHelper.cursor);\n        } else {\n            const currentCursorPos = this.getCursorPosition();\n\n            this.maskHelper.data = (this._key === KEYS.BACKSPACE) || (this._key === KEYS.DELETE);\n\n            this.value = this._selection && this._selection !== 0 ?\n                this.maskHelper.parseValueByMaskUponSelection(this.value, this._maskOptions, currentCursorPos - 1, this._selection) :\n                this.maskHelper.parseValueByMask(this.value, this._maskOptions, currentCursorPos - 1);\n\n            this.setCursorPosition(this.maskHelper.cursor);\n        }\n\n        const rawVal = this.maskHelper.restoreValueFromMask(this.value, this._maskOptions);\n\n        this.dataValue = this.includeLiterals ? this.value : rawVal;\n        this._onChangeCallback(this.dataValue);\n\n        this.onValueChange.emit({ rawValue: rawVal, formattedValue: this.value });\n    }\n\n    /**\n     *@hidden\n     */\n    @HostListener('focus', ['$event.target.value'])\n    public onFocus(value) {\n        if (this.focusedValuePipe) {\n            if (isIE()) {\n                this._stopPropagation = true;\n            }\n            this.value = this.focusedValuePipe.transform(value);\n        } else {\n            this.value = this.maskHelper.parseValueByMaskOnInit(this.value, this._maskOptions);\n        }\n    }\n\n    /**\n     *@hidden\n     */\n    @HostListener('blur', ['$event.target.value'])\n    public onBlur(value) {\n        if (this.displayValuePipe) {\n            this.value = this.displayValuePipe.transform(value);\n        } else if (value === this.maskHelper.parseMask(this._maskOptions)) {\n            this.value = '';\n        }\n    }\n\n    /**\n     *@hidden\n     */\n    private getCursorPosition(): number {\n        return this.nativeElement.selectionStart;\n    }\n\n    /**\n     *@hidden\n     */\n    private setCursorPosition(start: number, end: number = start): void {\n        this.nativeElement.setSelectionRange(start, end);\n    }\n\n    /**\n     *@hidden\n     */\n    public writeValue(value) {\n        if (this.promptChar && this.promptChar.length > 1) {\n            this._maskOptions.promptChar = this.promptChar.substring(0, 1);\n        }\n\n        this.value = value ? this.maskHelper.parseValueByMaskOnInit(value, this._maskOptions) : '';\n        if (this.displayValuePipe) {\n            this.value = this.displayValuePipe.transform(this.value);\n        }\n\n        this.dataValue = this.includeLiterals ? this.value : value;\n        this._onChangeCallback(this.dataValue);\n\n        this.onValueChange.emit({ rawValue: value, formattedValue: this.value });\n    }\n\n    /**\n     *@hidden\n     */\n    public registerOnChange(fn: (_: any) => void) { this._onChangeCallback = fn; }\n\n    /**\n     *@hidden\n     */\n    public registerOnTouched(fn: () => void) { this._onTouchedCallback = fn; }\n}\n\n/**\n * The IgxMaskModule provides the {@link IgxMaskDirective} inside your application.\n */\nexport interface IMaskEventArgs extends IBaseEventArgs {\n    rawValue: string;\n    formattedValue: string;\n}\n\n/**\n * @hidden\n */\n@NgModule({\n    declarations: [IgxMaskDirective],\n    exports: [IgxMaskDirective],\n    imports: [CommonModule]\n})\nexport class IgxMaskModule { }\n"]}