UNPKG

@true-directive/grid

Version:

Angular Data Grid from Yopsilon.

164 lines 17.9 kB
import * as tslib_1 from "tslib"; /** * 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'; var MaskDateDirective = /** @class */ (function (_super) { tslib_1.__extends(MaskDateDirective, _super); function MaskDateDirective(_renderer, _elementRef, intl) { var _this = _super.call(this, _renderer, _elementRef, intl) || this; _this._renderer = _renderer; _this._elementRef = _elementRef; _this.intl = intl; // Implementing ControlValueAccessor _this.onChange = function (_) { }; _this.onTouched = function () { }; return _this; } MaskDateDirective_1 = MaskDateDirective; MaskDateDirective.prototype.registerOnChange = function (fn) { this.onChange = fn; }; MaskDateDirective.prototype.registerOnTouched = function (fn) { this.onTouched = fn; }; MaskDateDirective.prototype.onInput = function (e) { this.input(e.target.value); }; // Focus lost MaskDateDirective.prototype.blur = function (e) { // No need to parse once more if result is as expected var 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 MaskDateDirective.prototype.updateState = function () { 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 MaskDateDirective.prototype.toModel = function () { // 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(); }; // MaskDateDirective.prototype.processKey = function (e) { return _super.prototype.processKey.call(this, e); }; // Parser: View --> Ctrl MaskDateDirective.prototype.input = function (e) { this.doInput(e.target.value); }; // Formatter: Ctrl --> View MaskDateDirective.prototype.writeValue = function (value) { this._dateValue = value; var 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(); }; Object.defineProperty(MaskDateDirective.prototype, "pattern", { get: function () { return this._mask.pattern; }, set: function (m) { this._mask.pattern = m; }, enumerable: true, configurable: true }); Object.defineProperty(MaskDateDirective.prototype, "settings", { set: function (v) { this._mask.settings = v; }, enumerable: true, configurable: true }); MaskDateDirective.prototype.keyDown = function (e) { return this.processKey(e); }; MaskDateDirective.prototype.setLocale = function (locale) { _super.prototype.setLocale.call(this, locale); this._mask.updateMask(); // Changing format this.writeValue(this._dateValue); // Updating view }; var MaskDateDirective_1; 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(function () { return MaskDateDirective_1; }), multi: true }] }), tslib_1.__metadata("design:paramtypes", [Renderer2, ElementRef, InternationalizationService]) ], MaskDateDirective); return MaskDateDirective; }(MaskBaseDirective)); 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"]}