@true-directive/grid
Version:
Angular Data Grid from Yopsilon.
128 lines • 15.1 kB
JavaScript
import * as tslib_1 from "tslib";
var MaskDirective_1;
/**
* Copyright (c) 2018-2019 Aleksey Melnikov, True Directive Company.
* @link https://truedirective.com/
* @license MIT
*/
import { Directive, ElementRef, Input, HostListener, Renderer2, forwardRef } from '@angular/core';
import { NG_VALUE_ACCESSOR } from '@angular/forms';
import { InternationalizationService } from '../internationalization/internationalization.service';
import { MaskSettings } from '@true-directive/base';
import { MaskState } from '@true-directive/base';
import { MaskBaseDirective } from './mask-base.directive';
let MaskDirective = MaskDirective_1 = class MaskDirective extends MaskBaseDirective {
constructor(_renderer, _elementRef, intl) {
super(_renderer, _elementRef, intl);
this._renderer = _renderer;
this._elementRef = _elementRef;
this.intl = intl;
this.onChange = (_) => { };
this.onTouched = () => { };
}
registerOnChange(fn) { this.onChange = fn; }
registerOnTouched(fn) { this.onTouched = fn; }
blur() {
// Очищаем, если маска неверна
const autocorrected = this._mask.applyMask(this._txtValue);
if (autocorrected === '' && !this._mask.settings.allowIncomplete) {
this.setText('');
}
else {
// Маска верна, но нужно автокоррекцию провернуть
if (autocorrected !== this._txtValue) {
this.setText(autocorrected);
}
}
this.onTouched();
}
// Пользователь вносит значение. Parser: View --> Ctrl
// Только то, что не обработано маской
input(txt) {
this.doInput(txt);
}
// Обновляем состояние
updateState() {
if (this._txtValue === '') {
// Пустое значение
this.state = MaskState.EMPTY;
}
else {
if (!this._mask.checkMask(this._txtValue)) {
// Считаем, что пользователь не завершил ввод
this.state = MaskState.TYPING;
}
else {
this.state = MaskState.OK;
}
}
}
toModel() {
// Отправляем в модель
this.onChange(this._txtValue);
// Обновляем состояние
this.updateState();
}
// Отображаем значение в компоненте. Formatter: Ctrl --> View
writeValue(txt) {
if (this._txtValue !== txt) {
this.setText(txt, false); // Не отправляем значение в модель, т.к. этот метод вызывается как раз после изменения модели
}
// Но обновить состояние нужно...
this.updateState();
}
set pattern(m) {
if (this._txtValue !== '' && this._mask.pattern !== '' && this._mask.pattern !== m) {
// По сложному пути
let res = this.currentRes();
let s = this._mask.pureValue(res.newValue);
this._mask.pattern = m;
res.newValue = this._mask.applyPureValue(s);
this.setRes(res);
}
else {
this._mask.pattern = m;
}
}
get pattern() {
return this._mask.pattern;
}
set settings(v) {
this._mask.settings = v;
}
keyDown(e) {
return this.processKey(e);
}
};
tslib_1.__decorate([
Input('true-mask'),
tslib_1.__metadata("design:type", String),
tslib_1.__metadata("design:paramtypes", [String])
], MaskDirective.prototype, "pattern", null);
tslib_1.__decorate([
Input('true-mask-settings'),
tslib_1.__metadata("design:type", MaskSettings),
tslib_1.__metadata("design:paramtypes", [MaskSettings])
], MaskDirective.prototype, "settings", null);
tslib_1.__decorate([
HostListener('keydown', ['$event']),
tslib_1.__metadata("design:type", Function),
tslib_1.__metadata("design:paramtypes", [Object]),
tslib_1.__metadata("design:returntype", void 0)
], MaskDirective.prototype, "keyDown", null);
MaskDirective = MaskDirective_1 = tslib_1.__decorate([
Directive({
selector: '[true-mask]',
host: { '(input)': 'input($event.target.value)', '(blur)': 'blur()' },
providers: [{
provide: NG_VALUE_ACCESSOR,
useExisting: forwardRef(() => MaskDirective_1),
multi: true
}]
}),
tslib_1.__metadata("design:paramtypes", [Renderer2,
ElementRef,
InternationalizationService])
], MaskDirective);
export { MaskDirective };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"mask.directive.js","sourceRoot":"ng://@true-directive/grid/","sources":["src/mask/mask.directive.ts"],"names":[],"mappings":"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","sourcesContent":["/**\r\n * Copyright (c) 2018-2019 Aleksey Melnikov, True Directive Company.\r\n * @link https://truedirective.com/\r\n * @license MIT\r\n*/\r\nimport { Directive, ElementRef, Input, HostListener, Renderer2, forwardRef } from '@angular/core';\r\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\r\n\r\nimport { InternationalizationService } from '../internationalization/internationalization.service';\r\nimport { Mask } from '@true-directive/base';\r\nimport { MaskSettings } from '@true-directive/base';\r\nimport { MaskState } from '@true-directive/base';\r\n\r\nimport { MaskBaseDirective } from './mask-base.directive';\r\n\r\n@Directive({\r\n    selector: '[true-mask]',\r\n    host: {'(input)': 'input($event.target.value)', '(blur)': 'blur()'},\r\n    providers: [{\r\n        provide: NG_VALUE_ACCESSOR,\r\n        useExisting: forwardRef(() => MaskDirective),\r\n        multi: true}]\r\n})\r\nexport class MaskDirective extends MaskBaseDirective implements ControlValueAccessor {\r\n\r\n    private onChange = (_: any) => {};\r\n    private onTouched = () => {};\r\n\r\n    registerOnChange(fn: (_: any) => void): void { this.onChange = fn; }\r\n    registerOnTouched(fn: () => void): void { this.onTouched = fn; }\r\n\r\n    blur() {\r\n      // Очищаем, если маска неверна\r\n      const autocorrected = this._mask.applyMask(this._txtValue);\r\n      if (autocorrected === '' && !this._mask.settings.allowIncomplete) {\r\n        this.setText('');\r\n      } else {\r\n        // Маска верна, но нужно автокоррекцию провернуть\r\n        if (autocorrected !== this._txtValue) {\r\n          this.setText(autocorrected);\r\n        }\r\n      }\r\n\r\n      this.onTouched();\r\n    }\r\n\r\n    // Пользователь вносит значение. Parser: View --> Ctrl\r\n    // Только то, что не обработано маской\r\n    input(txt: any) {\r\n      this.doInput(txt);\r\n    }\r\n\r\n    // Обновляем состояние\r\n    protected updateState() {\r\n      if (this._txtValue === '') {\r\n        // Пустое значение\r\n        this.state = MaskState.EMPTY;\r\n      } else {\r\n        if (!this._mask.checkMask(this._txtValue)) {\r\n          // Считаем, что пользователь не завершил ввод\r\n          this.state = MaskState.TYPING;\r\n        } else {\r\n          this.state = MaskState.OK;\r\n        }\r\n      }\r\n    }\r\n\r\n    protected toModel(): void {\r\n      // Отправляем в модель\r\n      this.onChange(this._txtValue);\r\n      // Обновляем состояние\r\n      this.updateState();\r\n    }\r\n\r\n    // Отображаем значение в компоненте. Formatter: Ctrl --> View\r\n    writeValue(txt: any): void {\r\n      if (this._txtValue !== txt) {\r\n        this.setText(txt, false); // Не отправляем значение в модель, т.к. этот метод вызывается как раз после изменения модели\r\n      }\r\n      // Но обновить состояние нужно...\r\n      this.updateState();\r\n    }\r\n\r\n    @Input('true-mask')\r\n    public set pattern(m: string) {\r\n\r\n      if (this._txtValue !== '' && this._mask.pattern !== '' && this._mask.pattern !== m) {\r\n        // По сложному пути\r\n        let res = this.currentRes();\r\n        let s = this._mask.pureValue(res.newValue);\r\n        this._mask.pattern = m;\r\n        res.newValue = this._mask.applyPureValue(s);\r\n        this.setRes(res);\r\n      } else {\r\n        this._mask.pattern = m;\r\n      }\r\n    }\r\n\r\n    public get pattern(): string {\r\n      return this._mask.pattern;\r\n    }\r\n\r\n    @Input('true-mask-settings')\r\n    set settings(v: MaskSettings) {\r\n      this._mask.settings = v;\r\n    }\r\n\r\n    @HostListener('keydown', ['$event'])\r\n    keyDown(e: any) {\r\n      return this.processKey(e);\r\n    }\r\n\r\n    constructor(\r\n      protected _renderer: Renderer2,\r\n      protected _elementRef: ElementRef,\r\n      protected intl: InternationalizationService) {\r\n      super(_renderer, _elementRef, intl);\r\n    }\r\n\r\n}\r\n"]}