@true-directive/grid
Version:
Angular Data Grid from Yopsilon.
152 lines • 16.6 kB
JavaScript
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"]}