UNPKG

@true-directive/grid

Version:

Angular Data Grid from Yopsilon.

128 lines 15.1 kB
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":";;AAAA;;;;EAIE;AACF,OAAO,EAAE,SAAS,EAAE,UAAU,EAAE,KAAK,EAAE,YAAY,EAAE,SAAS,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AAClG,OAAO,EAAwB,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;AAEzE,OAAO,EAAE,2BAA2B,EAAE,MAAM,sDAAsD,CAAC;AAEnG,OAAO,EAAE,YAAY,EAAE,MAAM,sBAAsB,CAAC;AACpD,OAAO,EAAE,SAAS,EAAE,MAAM,sBAAsB,CAAC;AAEjD,OAAO,EAAE,iBAAiB,EAAE,MAAM,uBAAuB,CAAC;AAU1D,IAAa,aAAa,qBAA1B,MAAa,aAAc,SAAQ,iBAAiB;IAyFhD,YACY,SAAoB,EACpB,WAAuB,EACvB,IAAiC;QAC3C,KAAK,CAAC,SAAS,EAAE,WAAW,EAAE,IAAI,CAAC,CAAC;QAH1B,cAAS,GAAT,SAAS,CAAW;QACpB,gBAAW,GAAX,WAAW,CAAY;QACvB,SAAI,GAAJ,IAAI,CAA6B;QA1FrC,aAAQ,GAAG,CAAC,CAAM,EAAE,EAAE,GAAE,CAAC,CAAC;QAC1B,cAAS,GAAG,GAAG,EAAE,GAAE,CAAC,CAAC;IA2F7B,CAAC;IAzFD,gBAAgB,CAAC,EAAoB,IAAU,IAAI,CAAC,QAAQ,GAAG,EAAE,CAAC,CAAC,CAAC;IACpE,iBAAiB,CAAC,EAAc,IAAU,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC,CAAC,CAAC;IAEhE,IAAI;QACF,8BAA8B;QAC9B,MAAM,aAAa,GAAG,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QAC3D,IAAI,aAAa,KAAK,EAAE,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,eAAe,EAAE;YAChE,IAAI,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;SAClB;aAAM;YACL,iDAAiD;YACjD,IAAI,aAAa,KAAK,IAAI,CAAC,SAAS,EAAE;gBACpC,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,CAAC;aAC7B;SACF;QAED,IAAI,CAAC,SAAS,EAAE,CAAC;IACnB,CAAC;IAED,sDAAsD;IACtD,sCAAsC;IACtC,KAAK,CAAC,GAAQ;QACZ,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC;IACpB,CAAC;IAED,sBAAsB;IACZ,WAAW;QACnB,IAAI,IAAI,CAAC,SAAS,KAAK,EAAE,EAAE;YACzB,kBAAkB;YAClB,IAAI,CAAC,KAAK,GAAG,SAAS,CAAC,KAAK,CAAC;SAC9B;aAAM;YACL,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,IAAI,CAAC,SAAS,CAAC,EAAE;gBACzC,6CAA6C;gBAC7C,IAAI,CAAC,KAAK,GAAG,SAAS,CAAC,MAAM,CAAC;aAC/B;iBAAM;gBACL,IAAI,CAAC,KAAK,GAAG,SAAS,CAAC,EAAE,CAAC;aAC3B;SACF;IACH,CAAC;IAES,OAAO;QACf,sBAAsB;QACtB,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QAC9B,sBAAsB;QACtB,IAAI,CAAC,WAAW,EAAE,CAAC;IACrB,CAAC;IAED,6DAA6D;IAC7D,UAAU,CAAC,GAAQ;QACjB,IAAI,IAAI,CAAC,SAAS,KAAK,GAAG,EAAE;YAC1B,IAAI,CAAC,OAAO,CAAC,GAAG,EAAE,KAAK,CAAC,CAAC,CAAC,6FAA6F;SACxH;QACD,iCAAiC;QACjC,IAAI,CAAC,WAAW,EAAE,CAAC;IACrB,CAAC;IAGD,IAAW,OAAO,CAAC,CAAS;QAE1B,IAAI,IAAI,CAAC,SAAS,KAAK,EAAE,IAAI,IAAI,CAAC,KAAK,CAAC,OAAO,KAAK,EAAE,IAAI,IAAI,CAAC,KAAK,CAAC,OAAO,KAAK,CAAC,EAAE;YAClF,mBAAmB;YACnB,IAAI,GAAG,GAAG,IAAI,CAAC,UAAU,EAAE,CAAC;YAC5B,IAAI,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;YAC3C,IAAI,CAAC,KAAK,CAAC,OAAO,GAAG,CAAC,CAAC;YACvB,GAAG,CAAC,QAAQ,GAAG,IAAI,CAAC,KAAK,CAAC,cAAc,CAAC,CAAC,CAAC,CAAC;YAC5C,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;SAClB;aAAM;YACL,IAAI,CAAC,KAAK,CAAC,OAAO,GAAG,CAAC,CAAC;SACxB;IACH,CAAC;IAED,IAAW,OAAO;QAChB,OAAO,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC;IAC5B,CAAC;IAGD,IAAI,QAAQ,CAAC,CAAe;QAC1B,IAAI,CAAC,KAAK,CAAC,QAAQ,GAAG,CAAC,CAAC;IAC1B,CAAC;IAGD,OAAO,CAAC,CAAM;QACZ,OAAO,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC;IAC5B,CAAC;CASJ,CAAA;AAnCG;IADC,KAAK,CAAC,WAAW,CAAC;;;4CAalB;AAOD;IADC,KAAK,CAAC,oBAAoB,CAAC;sCACZ,YAAY;6CAAZ,YAAY;6CAE3B;AAGD;IADC,YAAY,CAAC,SAAS,EAAE,CAAC,QAAQ,CAAC,CAAC;;;;4CAGnC;AAvFQ,aAAa;IARzB,SAAS,CAAC;QACP,QAAQ,EAAE,aAAa;QACvB,IAAI,EAAE,EAAC,SAAS,EAAE,4BAA4B,EAAE,QAAQ,EAAE,QAAQ,EAAC;QACnE,SAAS,EAAE,CAAC;gBACR,OAAO,EAAE,iBAAiB;gBAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,eAAa,CAAC;gBAC5C,KAAK,EAAE,IAAI;aAAC,CAAC;KACpB,CAAC;6CA2FyB,SAAS;QACP,UAAU;QACjB,2BAA2B;GA5FpC,aAAa,CAgGzB;SAhGY,aAAa","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"]}