UNPKG

@true-directive/grid

Version:

Angular Data Grid from Yopsilon.

152 lines 16.6 kB
import * as tslib_1 from "tslib"; var MaskDateDirective_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 { MaskBaseDirective } from './mask-base.directive'; import { InternationalizationService } from '../internationalization/internationalization.service'; import { MaskState } from '@true-directive/base'; import { MaskSettings } from '@true-directive/base'; import { DateParserFormatter } from '@true-directive/base'; let MaskDateDirective = MaskDateDirective_1 = class MaskDateDirective extends MaskBaseDirective { constructor(_renderer, _elementRef, intl) { super(_renderer, _elementRef, intl); this._renderer = _renderer; this._elementRef = _elementRef; this.intl = intl; // Implementing ControlValueAccessor this.onChange = (_) => { }; this.onTouched = () => { }; } registerOnChange(fn) { this.onChange = fn; } registerOnTouched(fn) { this.onTouched = fn; } onInput(e) { this.input(e.target.value); } // Focus lost blur(e) { // No need to parse once more if result is as expected let autoCorrected = this._mask.applyMask(this._txtValue); if (autoCorrected !== this._txtValue) { this.setText(autoCorrected); } // Clearing if Date is incorrect if (this._dateValue === null || isNaN(this._dateValue.getTime())) { if (!this._mask.settings.allowIncomplete) { this.setText(''); } } this.onTouched(); } // Updating the state updateState() { if (!this._dateValue) { this.state = MaskState.EMPTY; // empty value } else { if (isNaN(this._dateValue.getTime())) { this.state = MaskState.TYPING; // User input is in progress } else { this.state = MaskState.OK; } } } // Sending a value to model toModel() { // Retrieving value this._dateValue = DateParserFormatter.parse(this._txtValue, this._mask); this.maskValueChanged.emit(this._dateValue); // Sending to model this.onChange(this._dateValue); // Updating the state this.updateState(); } // processKey(e) { return super.processKey(e); } // Parser: View --> Ctrl input(e) { this.doInput(e.target.value); } // Formatter: Ctrl --> View writeValue(value) { this._dateValue = value; const txt = DateParserFormatter.format(value, this._mask); if (txt !== this._txtValue) { this.setText(txt, false); } // No need to send to model, because this processor is called on model change // but state still needs to be updated this.updateState(); } set pattern(m) { this._mask.pattern = m; } get pattern() { return this._mask.pattern; } set settings(v) { this._mask.settings = v; } keyDown(e) { return this.processKey(e); } setLocale(locale) { super.setLocale(locale); this._mask.updateMask(); // Changing format this.writeValue(this._dateValue); // Updating view } }; tslib_1.__decorate([ HostListener('input', ['$event']), tslib_1.__metadata("design:type", Function), tslib_1.__metadata("design:paramtypes", [Object]), tslib_1.__metadata("design:returntype", void 0) ], MaskDateDirective.prototype, "onInput", null); tslib_1.__decorate([ HostListener('blur', ['$event']), tslib_1.__metadata("design:type", Function), tslib_1.__metadata("design:paramtypes", [Object]), tslib_1.__metadata("design:returntype", void 0) ], MaskDateDirective.prototype, "blur", null); tslib_1.__decorate([ HostListener('input', ['$event']), tslib_1.__metadata("design:type", Function), tslib_1.__metadata("design:paramtypes", [Object]), tslib_1.__metadata("design:returntype", void 0) ], MaskDateDirective.prototype, "input", null); tslib_1.__decorate([ Input('true-mask-date'), tslib_1.__metadata("design:type", String), tslib_1.__metadata("design:paramtypes", [String]) ], MaskDateDirective.prototype, "pattern", null); tslib_1.__decorate([ Input('true-mask-settings'), tslib_1.__metadata("design:type", MaskSettings), tslib_1.__metadata("design:paramtypes", [MaskSettings]) ], MaskDateDirective.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) ], MaskDateDirective.prototype, "keyDown", null); MaskDateDirective = MaskDateDirective_1 = tslib_1.__decorate([ Directive({ selector: '[true-mask-date]', providers: [{ provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => MaskDateDirective_1), multi: true }] }), tslib_1.__metadata("design:paramtypes", [Renderer2, ElementRef, InternationalizationService]) ], MaskDateDirective); export { MaskDateDirective }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"mask-date.directive.js","sourceRoot":"ng://@true-directive/grid/","sources":["src/mask/mask-date.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 { MaskBaseDirective } from './mask-base.directive';\r\nimport { InternationalizationService } from '../internationalization/internationalization.service';\r\n\r\nimport { Mask } from '@true-directive/base';\r\nimport { MaskState } from '@true-directive/base';\r\nimport { MaskSettings } from '@true-directive/base';\r\n\r\nimport { DateParserFormatter } from '@true-directive/base';\r\nimport { Locale } from '@true-directive/base';\r\n\r\n@Directive({\r\n    selector: '[true-mask-date]',\r\n    providers: [{\r\n        provide: NG_VALUE_ACCESSOR,\r\n        useExisting: forwardRef(() => MaskDateDirective),\r\n        multi: true}]\r\n})\r\nexport class MaskDateDirective extends MaskBaseDirective implements ControlValueAccessor {\r\n\r\n    private _dateValue: any;\r\n\r\n    // Implementing ControlValueAccessor\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    @HostListener('input', ['$event'])\r\n    onInput(e: any) {\r\n      this.input(e.target.value);\r\n    }\r\n\r\n    // Focus lost\r\n    @HostListener('blur', ['$event'])\r\n    blur(e: any) {\r\n\r\n      // No need to parse once more if result is as expected\r\n      let autoCorrected = this._mask.applyMask(this._txtValue);\r\n      if (autoCorrected !== this._txtValue) {\r\n        this.setText(autoCorrected);\r\n      }\r\n\r\n      // Clearing if Date is incorrect\r\n      if (this._dateValue === null || isNaN(this._dateValue.getTime())) {\r\n        if (!this._mask.settings.allowIncomplete) {\r\n          this.setText('');\r\n        }\r\n      }\r\n\r\n      this.onTouched();\r\n    }\r\n\r\n    // Updating the state\r\n    protected updateState() {\r\n      if (!this._dateValue) {\r\n        this.state = MaskState.EMPTY; // empty value\r\n      } else {\r\n        if (isNaN(this._dateValue.getTime())) {\r\n          this.state = MaskState.TYPING; // User input is in progress\r\n        } else {\r\n          this.state = MaskState.OK;\r\n        }\r\n      }\r\n    }\r\n\r\n    // Sending a value to model\r\n    protected toModel() {\r\n      // Retrieving value\r\n      this._dateValue = DateParserFormatter.parse(this._txtValue, this._mask);\r\n      this.maskValueChanged.emit(this._dateValue);\r\n      // Sending to model\r\n      this.onChange(this._dateValue);\r\n      // Updating the state\r\n      this.updateState();\r\n    }\r\n\r\n    //\r\n    public processKey(e: any): boolean {\r\n      return super.processKey(e);\r\n    }\r\n\r\n    // Parser: View --> Ctrl\r\n    @HostListener('input', ['$event'])\r\n    input(e: any) {\r\n      this.doInput(e.target.value);\r\n    }\r\n\r\n    // Formatter: Ctrl --> View\r\n    writeValue(value: any) {\r\n      this._dateValue = value;\r\n      const txt = DateParserFormatter.format(value, this._mask);      \r\n      if (txt !== this._txtValue) {\r\n        this.setText(txt, false);\r\n      }\r\n\r\n      // No need to send to model, because this processor is called on model change\r\n      // but state still needs to be updated\r\n      this.updateState();\r\n    }\r\n\r\n    @Input('true-mask-date')\r\n    public set pattern(m: string) {\r\n      this._mask.pattern = m;\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    setLocale(locale: Locale) {\r\n      super.setLocale(locale);\r\n      this._mask.updateMask(); // Changing format\r\n      this.writeValue(this._dateValue); // Updating view\r\n    }\r\n\r\n    constructor(protected _renderer: Renderer2, protected _elementRef: ElementRef, protected intl: InternationalizationService) {\r\n      super(_renderer, _elementRef, intl);\r\n    }\r\n}\r\n"]}