ecabs-components 1.0.36 → 1.0.37
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
|
@@ -17,6 +17,7 @@ import * as i9 from "../base/directives/date-mask.directive";
|
|
|
17
17
|
export class EcabsDateTimePickerComponent extends ElementBaseComponent {
|
|
18
18
|
injector;
|
|
19
19
|
decimalPipe;
|
|
20
|
+
cd;
|
|
20
21
|
minDate;
|
|
21
22
|
maxDate;
|
|
22
23
|
touchUi = false;
|
|
@@ -34,6 +35,8 @@ export class EcabsDateTimePickerComponent extends ElementBaseComponent {
|
|
|
34
35
|
header = EcabsDateTimePickerHeaderComponent;
|
|
35
36
|
maxValueHours = 23;
|
|
36
37
|
maxValueMinutesSeconds = 59;
|
|
38
|
+
preventCallSetterPickerValue = false;
|
|
39
|
+
runTimeout = false;
|
|
37
40
|
get value() {
|
|
38
41
|
return this.val;
|
|
39
42
|
}
|
|
@@ -65,26 +68,48 @@ export class EcabsDateTimePickerComponent extends ElementBaseComponent {
|
|
|
65
68
|
}
|
|
66
69
|
}
|
|
67
70
|
set value(val) {
|
|
68
|
-
if (val && this.val !== new Date(val)) {
|
|
69
|
-
this.
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
this.
|
|
71
|
+
if (val && this.val?.getTime() !== new Date(val).getTime()) {
|
|
72
|
+
if (!this.preventCallSetterPickerValue) {
|
|
73
|
+
this.pickerValue = this.formatDateTime(val);
|
|
74
|
+
}
|
|
75
|
+
this.preventCallSetterPickerValue = false;
|
|
73
76
|
}
|
|
74
77
|
}
|
|
75
78
|
set pickerValue(val) {
|
|
76
79
|
if (val) {
|
|
77
80
|
const date = parse(val.replace('_', ''), this.hideSeconds ? `dd/MM/yyyy, HH:mm` : `dd/MM/yyyy, HH:mm:ss`, new Date());
|
|
78
81
|
if (isValid(date) && this._pickerValue !== val) {
|
|
82
|
+
if (this.minDate && date < this.minDate) {
|
|
83
|
+
this.setValues(this.minDate);
|
|
84
|
+
this._pickerValue = val;
|
|
85
|
+
this.preventCallSetterPickerValue = true;
|
|
86
|
+
this.value = this.minDate;
|
|
87
|
+
this.runTimeout = true;
|
|
88
|
+
this.refreshPickerValue(this.minDate);
|
|
89
|
+
return;
|
|
90
|
+
}
|
|
91
|
+
if (this.maxDate && date > this.maxDate) {
|
|
92
|
+
this.setValues(this.maxDate);
|
|
93
|
+
this._pickerValue = val;
|
|
94
|
+
this.preventCallSetterPickerValue = true;
|
|
95
|
+
this.value = this.maxDate;
|
|
96
|
+
this.runTimeout = true;
|
|
97
|
+
this.refreshPickerValue(this.maxDate);
|
|
98
|
+
return;
|
|
99
|
+
}
|
|
100
|
+
this.runTimeout = false;
|
|
79
101
|
this._pickerValue = val;
|
|
102
|
+
this.preventCallSetterPickerValue = true;
|
|
80
103
|
this.value = date;
|
|
104
|
+
this.setValues(date);
|
|
81
105
|
}
|
|
82
106
|
}
|
|
83
107
|
}
|
|
84
|
-
constructor(injector, decimalPipe) {
|
|
108
|
+
constructor(injector, decimalPipe, cd) {
|
|
85
109
|
super();
|
|
86
110
|
this.injector = injector;
|
|
87
111
|
this.decimalPipe = decimalPipe;
|
|
112
|
+
this.cd = cd;
|
|
88
113
|
}
|
|
89
114
|
ngAfterViewInit() {
|
|
90
115
|
const ngControl = this.injector.get(NgControl, null);
|
|
@@ -115,19 +140,17 @@ export class EcabsDateTimePickerComponent extends ElementBaseComponent {
|
|
|
115
140
|
onApply() {
|
|
116
141
|
if (this._date && this._seconds && this._minutes && this._hours) {
|
|
117
142
|
const date = setSeconds(setMinutes(setHours(new Date(this._date), +this._hours), +this._minutes), +this._seconds);
|
|
118
|
-
if (this.minDate && date < this.minDate) {
|
|
119
|
-
this.setValues(this.minDate);
|
|
120
|
-
this.value = this.minDate;
|
|
121
|
-
return;
|
|
122
|
-
}
|
|
123
|
-
if (this.maxDate && date > this.maxDate) {
|
|
124
|
-
this.setValues(this.maxDate);
|
|
125
|
-
this.value = this.maxDate;
|
|
126
|
-
return;
|
|
127
|
-
}
|
|
128
143
|
this.value = date;
|
|
129
144
|
}
|
|
130
145
|
}
|
|
146
|
+
refreshPickerValue(date) {
|
|
147
|
+
setTimeout(() => {
|
|
148
|
+
if (this.runTimeout) {
|
|
149
|
+
this._pickerValue = this.formatDateTime(date);
|
|
150
|
+
this.cd.detectChanges();
|
|
151
|
+
}
|
|
152
|
+
}, 3000);
|
|
153
|
+
}
|
|
131
154
|
formatDateTime(date) {
|
|
132
155
|
let result = '';
|
|
133
156
|
if (date && isValid(new Date(date))) {
|
|
@@ -141,12 +164,14 @@ export class EcabsDateTimePickerComponent extends ElementBaseComponent {
|
|
|
141
164
|
return this.decimalPipe.transform(num, '2.0-0') ?? '00';
|
|
142
165
|
}
|
|
143
166
|
setValues(date) {
|
|
167
|
+
this.onChange(date);
|
|
168
|
+
this.onTouch(date);
|
|
144
169
|
this._date = date;
|
|
145
170
|
this.hours = date.getHours().toString();
|
|
146
171
|
this.minutes = date.getMinutes().toString();
|
|
147
172
|
this.seconds = date.getSeconds().toString();
|
|
148
173
|
}
|
|
149
|
-
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: EcabsDateTimePickerComponent, deps: [{ token: i0.Injector }, { token: i1.DecimalPipe }], target: i0.ɵɵFactoryTarget.Component });
|
|
174
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: EcabsDateTimePickerComponent, deps: [{ token: i0.Injector }, { token: i1.DecimalPipe }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
150
175
|
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: EcabsDateTimePickerComponent, selector: "ecabs-date-time-picker", inputs: { minDate: "minDate", maxDate: "maxDate", touchUi: "touchUi", hideSeconds: "hideSeconds", cancelLabel: "cancelLabel", applyLabel: "applyLabel", selectDateLabel: "selectDateLabel" }, outputs: { onblur: "onblur" }, providers: [
|
|
151
176
|
{
|
|
152
177
|
provide: NG_VALUE_ACCESSOR,
|
|
@@ -166,7 +191,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
166
191
|
},
|
|
167
192
|
DecimalPipe,
|
|
168
193
|
], template: "<app-element-wrapper [data]=\"getData()\">\r\n <div class=\"form-field__input--wrapper w-full\">\r\n <input\r\n class=\"fake-input\"\r\n [id]=\"_date\"\r\n [(ngModel)]=\"_date\"\r\n [placeholder]=\"placeholder\"\r\n [disabled]=\"disabled\"\r\n [matDatepicker]=\"picker\"\r\n [min]=\"minDate\"\r\n [max]=\"maxDate\"\r\n (blur)=\"onTouch()\"\r\n />\r\n <mat-datepicker #picker [calendarHeaderComponent]=\"header\" [touchUi]=\"touchUi\" class=\"datepicker-ui\">\r\n <mat-datepicker-actions>\r\n <div class=\"actions\">\r\n <div class=\"time--inputs\">\r\n <input\r\n class=\"form-field__input time\"\r\n appDigitsOnly\r\n appNumberBorder\r\n [digitsOnly]=\"true\"\r\n [id]=\"hours\"\r\n [value]=\"_hours\"\r\n [maxValue]=\"maxValueHours\"\r\n [(ngModel)]=\"hours\"\r\n />\r\n <span class=\"font-bold\">:</span>\r\n <input\r\n class=\"form-field__input time\"\r\n [id]=\"minutes\"\r\n [(ngModel)]=\"minutes\"\r\n appDigitsOnly\r\n appNumberBorder\r\n [digitsOnly]=\"true\"\r\n [maxValue]=\"maxValueMinutesSeconds\"\r\n />\r\n\r\n <ng-container *ngIf=\"!hideSeconds\">\r\n <span class=\"font-bold\">:</span>\r\n <input\r\n class=\"form-field__input time\"\r\n [id]=\"seconds\"\r\n [(ngModel)]=\"seconds\"\r\n appDigitsOnly\r\n appNumberBorder\r\n [digitsOnly]=\"true\"\r\n [maxValue]=\"maxValueMinutesSeconds\"\r\n />\r\n </ng-container>\r\n </div>\r\n\r\n <div class=\"grid grid-cols-2\">\r\n <button type=\"button\" mat-stroked-button class=\"w-full cancel-button\" color=\"primary\" matDatepickerCancel>\r\n {{ cancelLabel }}\r\n </button>\r\n\r\n <button\r\n type=\"button\"\r\n mat-button\r\n class=\"w-full ml-0 apply-button\"\r\n color=\"primary\"\r\n matDatepickerApply\r\n (click)=\"onApply()\"\r\n >\r\n {{ applyLabel }}\r\n </button>\r\n </div>\r\n </div>\r\n </mat-datepicker-actions>\r\n </mat-datepicker>\r\n <input\r\n class=\"form-field__input w-full date-input\"\r\n [id]=\"name\"\r\n [(ngModel)]=\"pickerValue\"\r\n [placeholder]=\"placeholder\"\r\n [disabled]=\"disabled\"\r\n appMaskDate\r\n [isDateTimeMask]=\"true\"\r\n [considerSeconds]=\"!hideSeconds\"\r\n (blur)=\"onTouch()\"\r\n />\r\n <button type=\"button\" mat-icon-button class=\"datepicker-toggle\" (click)=\"picker.open()\">\r\n <mat-icon>calendar_today</mat-icon>\r\n </button>\r\n </div>\r\n</app-element-wrapper>\r\n", styles: [".time--inputs:before,.time--inputs:after{position:absolute;content:\"\"}:host ::ng-deep .form-field{margin-right:-1.25rem;margin-left:-.125rem}.datepicker-toggle{transform:translate(-1.25rem);background-color:inherit;left:-.125rem}.time{width:3.375rem}.fake-input{visibility:hidden;width:0;padding:0;margin:0}.date-input{margin:0rem -1.25rem 0rem -.25rem}.time--inputs{position:relative;display:flex;gap:.5rem;justify-content:center;align-items:center;margin-top:2.4rem;margin-bottom:2.4rem}.time--inputs:before,.time--inputs:after{height:1px;right:0;left:0;background-color:var(--color-gray-300)}.time--inputs:before{top:-1.6rem}.time--inputs:after{bottom:-1.6rem}.font-bold{font-weight:700}.actions{display:flex;flex-direction:column;width:100%!important;row-gap:1rem}\n"] }]
|
|
169
|
-
}], ctorParameters: function () { return [{ type: i0.Injector }, { type: i1.DecimalPipe }]; }, propDecorators: { minDate: [{
|
|
194
|
+
}], ctorParameters: function () { return [{ type: i0.Injector }, { type: i1.DecimalPipe }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { minDate: [{
|
|
170
195
|
type: Input
|
|
171
196
|
}], maxDate: [{
|
|
172
197
|
type: Input
|
|
@@ -183,4 +208,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
183
208
|
}], onblur: [{
|
|
184
209
|
type: Output
|
|
185
210
|
}] } });
|
|
186
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ecabs-date-time-picker.component.js","sourceRoot":"","sources":["../../../../../projects/ecabs-components/src/lib/ecabs-date-time-picker/ecabs-date-time-picker.component.ts","../../../../../projects/ecabs-components/src/lib/ecabs-date-time-picker/ecabs-date-time-picker.component.html"],"names":[],"mappings":"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","sourcesContent":["import { DecimalPipe } from '@angular/common';\r\nimport { AfterViewInit, Component, EventEmitter, Injector, Input, Output } from '@angular/core';\r\nimport { format, isValid, parse, setHours, setMinutes, setSeconds } from 'date-fns';\r\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR, NgControl, UntypedFormControl } from '@angular/forms';\r\nimport ElementBaseComponent from '../base/element-base';\r\nimport { EcabsDateTimePickerHeaderComponent } from './components/ecabs-date-time-picker-header/ecabs-date-time-picker-header.component';\r\n\r\n@Component( {\r\n  selector: 'ecabs-date-time-picker',\r\n  templateUrl: './ecabs-date-time-picker.component.html',\r\n  styleUrls: [ './ecabs-date-time-picker.component.scss' ],\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: EcabsDateTimePickerComponent,\r\n      multi: true,\r\n    },\r\n    DecimalPipe,\r\n  ],\r\n} )\r\nexport class EcabsDateTimePickerComponent extends ElementBaseComponent implements ControlValueAccessor, AfterViewInit {\r\n  @Input() minDate: Date;\r\n  @Input() maxDate: Date;\r\n  @Input() touchUi = false;\r\n  @Input() hideSeconds = true;\r\n  @Input() cancelLabel = 'Cancel';\r\n  @Input() applyLabel = 'Apply';\r\n  @Input() selectDateLabel = 'Select date and time';\r\n\r\n  @Output() onblur = new EventEmitter<any>();\r\n\r\n  _hours = '12';\r\n  _minutes = '00';\r\n  _seconds = '00';\r\n  _date: Date;\r\n  _pickerValue: string;\r\n  val: Date;\r\n  header = EcabsDateTimePickerHeaderComponent;\r\n  maxValueHours = 23;\r\n  maxValueMinutesSeconds = 59;\r\n\r\n  get value(): Date {\r\n    return this.val;\r\n  }\r\n\r\n  get pickerValue(): string {\r\n    return this._pickerValue;\r\n  }\r\n\r\n  get hours(): string {\r\n    return this._hours;\r\n  }\r\n\r\n  get minutes(): string {\r\n    return this._minutes;\r\n  }\r\n\r\n  get seconds(): string {\r\n    return this._seconds;\r\n  }\r\n\r\n  set hours( value: string ) {\r\n    if ( value !== undefined && this._hours !== value ) {\r\n      this._hours = this.roundNumber( +value );\r\n    }\r\n  }\r\n\r\n  set minutes( value: string ) {\r\n    if ( value !== undefined && this._minutes !== value ) {\r\n      this._minutes = this.roundNumber( +value );\r\n    }\r\n  }\r\n\r\n  set seconds( value: string ) {\r\n    if ( value !== undefined && this._seconds !== value ) {\r\n      this._seconds = this.roundNumber( +value );\r\n    }\r\n  }\r\n\r\n  set value( val ) {\r\n    if ( val && this.val !== new Date( val ) ) {\r\n      this.val = new Date( val );\r\n      this.pickerValue = this.formatDateTime( val );\r\n      this.onChange( val );\r\n      this.onTouch( val );\r\n    }\r\n  }\r\n\r\n  set pickerValue( val: string ) {\r\n    if ( val ) {\r\n      const date = parse(\r\n        val.replace( '_', '' ),\r\n        this.hideSeconds ? `dd/MM/yyyy, HH:mm` : `dd/MM/yyyy, HH:mm:ss`,\r\n        new Date()\r\n      );\r\n      if ( isValid( date ) && this._pickerValue !== val ) {\r\n        this._pickerValue = val;\r\n        this.value = date;\r\n      }\r\n    }\r\n  }\r\n\r\n  constructor( private readonly injector: Injector, private readonly decimalPipe: DecimalPipe ) {\r\n    super();\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    const ngControl: NgControl = this.injector.get( NgControl, null );\r\n    if ( ngControl ) {\r\n      this.control = ngControl.control as UntypedFormControl;\r\n\r\n      setTimeout( () => {\r\n        const controlDate = !!this.control.value ? new Date( this.control.value ) : new Date();\r\n\r\n        if ( controlDate ) {\r\n          this.setValues( controlDate );\r\n        }\r\n      }, 10 );\r\n    }\r\n  }\r\n\r\n  onChange: any = () => { };\r\n  onTouch: any = () => { };\r\n\r\n  writeValue( value: any ): void {\r\n    this.value = value;\r\n  }\r\n\r\n  registerOnChange( fn: any ): void {\r\n    this.onChange = fn;\r\n  }\r\n\r\n  registerOnTouched( fn: any ): void {\r\n    this.onTouch = fn;\r\n  }\r\n\r\n  blurChange( e: any ): void {\r\n    this.onblur.emit( e );\r\n  }\r\n\r\n  onApply(): void {\r\n    if ( this._date && this._seconds && this._minutes && this._hours ) {\r\n      const date = setSeconds( setMinutes( setHours( new Date( this._date ), +this._hours ), +this._minutes ), +this._seconds );\r\n\r\n      if ( this.minDate && date < this.minDate ) {\r\n        this.setValues( this.minDate );\r\n        this.value = this.minDate;\r\n\r\n        return;\r\n      }\r\n\r\n      if ( this.maxDate && date > this.maxDate ) {\r\n        this.setValues( this.maxDate );\r\n        this.value = this.maxDate;\r\n\r\n        return;\r\n      }\r\n\r\n      this.value = date;\r\n    }\r\n  }\r\n\r\n  private formatDateTime( date: Date ): string {\r\n    let result = '';\r\n\r\n    if ( date && isValid( new Date( date ) ) ) {\r\n      result = this.hideSeconds\r\n        ? format( new Date( date ), `dd/MM/yyyy, HH:mm` )\r\n        : format( new Date( date ), `dd/MM/yyyy, HH:mm:ss` );\r\n    }\r\n\r\n    return result;\r\n  }\r\n\r\n  private roundNumber( num: number ): string | null {\r\n    return this.decimalPipe.transform( num, '2.0-0' ) ?? '00';\r\n  }\r\n\r\n  private setValues( date: Date ): void {\r\n    this._date = date;\r\n    this.hours = date.getHours().toString();\r\n    this.minutes = date.getMinutes().toString();\r\n    this.seconds = date.getSeconds().toString();\r\n  }\r\n}\r\n","<app-element-wrapper [data]=\"getData()\">\r\n  <div class=\"form-field__input--wrapper w-full\">\r\n    <input\r\n      class=\"fake-input\"\r\n      [id]=\"_date\"\r\n      [(ngModel)]=\"_date\"\r\n      [placeholder]=\"placeholder\"\r\n      [disabled]=\"disabled\"\r\n      [matDatepicker]=\"picker\"\r\n      [min]=\"minDate\"\r\n      [max]=\"maxDate\"\r\n      (blur)=\"onTouch()\"\r\n    />\r\n    <mat-datepicker #picker [calendarHeaderComponent]=\"header\" [touchUi]=\"touchUi\" class=\"datepicker-ui\">\r\n      <mat-datepicker-actions>\r\n        <div class=\"actions\">\r\n          <div class=\"time--inputs\">\r\n            <input\r\n              class=\"form-field__input time\"\r\n              appDigitsOnly\r\n              appNumberBorder\r\n              [digitsOnly]=\"true\"\r\n              [id]=\"hours\"\r\n              [value]=\"_hours\"\r\n              [maxValue]=\"maxValueHours\"\r\n              [(ngModel)]=\"hours\"\r\n            />\r\n            <span class=\"font-bold\">:</span>\r\n            <input\r\n              class=\"form-field__input time\"\r\n              [id]=\"minutes\"\r\n              [(ngModel)]=\"minutes\"\r\n              appDigitsOnly\r\n              appNumberBorder\r\n              [digitsOnly]=\"true\"\r\n              [maxValue]=\"maxValueMinutesSeconds\"\r\n            />\r\n\r\n            <ng-container *ngIf=\"!hideSeconds\">\r\n              <span class=\"font-bold\">:</span>\r\n              <input\r\n                class=\"form-field__input time\"\r\n                [id]=\"seconds\"\r\n                [(ngModel)]=\"seconds\"\r\n                appDigitsOnly\r\n                appNumberBorder\r\n                [digitsOnly]=\"true\"\r\n                [maxValue]=\"maxValueMinutesSeconds\"\r\n              />\r\n            </ng-container>\r\n          </div>\r\n\r\n          <div class=\"grid grid-cols-2\">\r\n            <button type=\"button\" mat-stroked-button class=\"w-full cancel-button\" color=\"primary\" matDatepickerCancel>\r\n              {{ cancelLabel }}\r\n            </button>\r\n\r\n            <button\r\n              type=\"button\"\r\n              mat-button\r\n              class=\"w-full ml-0 apply-button\"\r\n              color=\"primary\"\r\n              matDatepickerApply\r\n              (click)=\"onApply()\"\r\n            >\r\n              {{ applyLabel }}\r\n            </button>\r\n          </div>\r\n        </div>\r\n      </mat-datepicker-actions>\r\n    </mat-datepicker>\r\n    <input\r\n      class=\"form-field__input w-full date-input\"\r\n      [id]=\"name\"\r\n      [(ngModel)]=\"pickerValue\"\r\n      [placeholder]=\"placeholder\"\r\n      [disabled]=\"disabled\"\r\n      appMaskDate\r\n      [isDateTimeMask]=\"true\"\r\n      [considerSeconds]=\"!hideSeconds\"\r\n      (blur)=\"onTouch()\"\r\n    />\r\n    <button type=\"button\" mat-icon-button class=\"datepicker-toggle\" (click)=\"picker.open()\">\r\n      <mat-icon>calendar_today</mat-icon>\r\n    </button>\r\n  </div>\r\n</app-element-wrapper>\r\n"]}
|
|
211
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ecabs-date-time-picker.component.js","sourceRoot":"","sources":["../../../../../projects/ecabs-components/src/lib/ecabs-date-time-picker/ecabs-date-time-picker.component.ts","../../../../../projects/ecabs-components/src/lib/ecabs-date-time-picker/ecabs-date-time-picker.component.html"],"names":[],"mappings":"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","sourcesContent":["import { DecimalPipe } from '@angular/common';\r\nimport { AfterViewInit, ChangeDetectorRef, Component, EventEmitter, Injector, Input, Output } from '@angular/core';\r\nimport { format, isValid, parse, setHours, setMinutes, setSeconds } from 'date-fns';\r\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR, NgControl, UntypedFormControl } from '@angular/forms';\r\nimport ElementBaseComponent from '../base/element-base';\r\nimport { EcabsDateTimePickerHeaderComponent } from './components/ecabs-date-time-picker-header/ecabs-date-time-picker-header.component';\r\n\r\n@Component( {\r\n  selector: 'ecabs-date-time-picker',\r\n  templateUrl: './ecabs-date-time-picker.component.html',\r\n  styleUrls: [ './ecabs-date-time-picker.component.scss' ],\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: EcabsDateTimePickerComponent,\r\n      multi: true,\r\n    },\r\n    DecimalPipe,\r\n  ],\r\n} )\r\nexport class EcabsDateTimePickerComponent extends ElementBaseComponent implements ControlValueAccessor, AfterViewInit {\r\n  @Input() minDate: Date;\r\n  @Input() maxDate: Date;\r\n  @Input() touchUi = false;\r\n  @Input() hideSeconds = true;\r\n  @Input() cancelLabel = 'Cancel';\r\n  @Input() applyLabel = 'Apply';\r\n  @Input() selectDateLabel = 'Select date and time';\r\n\r\n  @Output() onblur = new EventEmitter<any>();\r\n\r\n  _hours = '12';\r\n  _minutes = '00';\r\n  _seconds = '00';\r\n  _date: Date;\r\n  _pickerValue: string;\r\n  val: Date;\r\n  header = EcabsDateTimePickerHeaderComponent;\r\n  maxValueHours = 23;\r\n  maxValueMinutesSeconds = 59;\r\n  preventCallSetterPickerValue = false;\r\n  runTimeout = false;\r\n\r\n  get value(): Date {\r\n    return this.val;\r\n  }\r\n\r\n  get pickerValue(): string {\r\n    return this._pickerValue;\r\n  }\r\n\r\n  get hours(): string {\r\n    return this._hours;\r\n  }\r\n\r\n  get minutes(): string {\r\n    return this._minutes;\r\n  }\r\n\r\n  get seconds(): string {\r\n    return this._seconds;\r\n  }\r\n\r\n  set hours( value: string ) {\r\n    if ( value !== undefined && this._hours !== value ) {\r\n      this._hours = this.roundNumber( +value );\r\n    }\r\n  }\r\n\r\n  set minutes( value: string ) {\r\n    if ( value !== undefined && this._minutes !== value ) {\r\n      this._minutes = this.roundNumber( +value );\r\n    }\r\n  }\r\n\r\n  set seconds( value: string ) {\r\n    if ( value !== undefined && this._seconds !== value ) {\r\n      this._seconds = this.roundNumber( +value );\r\n    }\r\n  }\r\n\r\n  set value(val) {\r\n    if (val && this.val?.getTime() !== new Date(val).getTime()) {\r\n      if (!this.preventCallSetterPickerValue) {\r\n        this.pickerValue = this.formatDateTime(val);\r\n      }\r\n      this.preventCallSetterPickerValue = false;\r\n    }\r\n  }\r\n\r\n  set pickerValue(val: string) {\r\n    if (val) {\r\n      const date = parse(\r\n        val.replace('_', ''),\r\n        this.hideSeconds ? `dd/MM/yyyy, HH:mm` : `dd/MM/yyyy, HH:mm:ss`,\r\n        new Date(),\r\n      );\r\n      if (isValid(date) && this._pickerValue !== val) {\r\n        if (this.minDate && date < this.minDate) {\r\n          this.setValues(this.minDate);\r\n          this._pickerValue = val;\r\n          this.preventCallSetterPickerValue = true;\r\n          this.value = this.minDate;\r\n          this.runTimeout = true;\r\n          this.refreshPickerValue(this.minDate);\r\n\r\n          return;\r\n        }\r\n\r\n        if (this.maxDate && date > this.maxDate) {\r\n          this.setValues(this.maxDate);\r\n          this._pickerValue = val;\r\n          this.preventCallSetterPickerValue = true;\r\n          this.value = this.maxDate;\r\n          this.runTimeout = true;\r\n          this.refreshPickerValue(this.maxDate);\r\n\r\n          return;\r\n        }\r\n\r\n        this.runTimeout = false;\r\n        this._pickerValue = val;\r\n        this.preventCallSetterPickerValue = true;\r\n        this.value = date;\r\n        this.setValues(date);\r\n      }\r\n    }\r\n  }\r\n\r\n  constructor( private readonly injector: Injector, private readonly decimalPipe: DecimalPipe, private cd: ChangeDetectorRef ) {\r\n    super();\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    const ngControl: NgControl = this.injector.get( NgControl, null );\r\n    if ( ngControl ) {\r\n      this.control = ngControl.control as UntypedFormControl;\r\n\r\n      setTimeout( () => {\r\n        const controlDate = !!this.control.value ? new Date( this.control.value ) : new Date();\r\n\r\n        if ( controlDate ) {\r\n          this.setValues( controlDate );\r\n        }\r\n      }, 10 );\r\n    }\r\n  }\r\n\r\n  onChange: any = () => { };\r\n  onTouch: any = () => { };\r\n\r\n  writeValue( value: any ): void {\r\n    this.value = value;\r\n  }\r\n\r\n  registerOnChange( fn: any ): void {\r\n    this.onChange = fn;\r\n  }\r\n\r\n  registerOnTouched( fn: any ): void {\r\n    this.onTouch = fn;\r\n  }\r\n\r\n  blurChange( e: any ): void {\r\n    this.onblur.emit( e );\r\n  }\r\n\r\n  onApply(): void {\r\n    if (this._date && this._seconds && this._minutes && this._hours) {\r\n      const date = setSeconds(setMinutes(setHours(new Date(this._date), +this._hours), +this._minutes), +this._seconds);\r\n      this.value = date;\r\n    }\r\n  }\r\n\r\n  refreshPickerValue(date: Date): void {\r\n    setTimeout(() => {\r\n      if (this.runTimeout) {\r\n        this._pickerValue = this.formatDateTime(date);\r\n        this.cd.detectChanges();\r\n      }\r\n    }, 3000);\r\n  }\r\n\r\n  private formatDateTime( date: Date ): string {\r\n    let result = '';\r\n\r\n    if ( date && isValid( new Date( date ) ) ) {\r\n      result = this.hideSeconds\r\n        ? format( new Date( date ), `dd/MM/yyyy, HH:mm` )\r\n        : format( new Date( date ), `dd/MM/yyyy, HH:mm:ss` );\r\n    }\r\n\r\n    return result;\r\n  }\r\n\r\n  private roundNumber( num: number ): string | null {\r\n    return this.decimalPipe.transform( num, '2.0-0' ) ?? '00';\r\n  }\r\n\r\n  private setValues( date: Date ): void {\r\n    this.onChange(date);\r\n    this.onTouch(date);\r\n    this._date = date;\r\n    this.hours = date.getHours().toString();\r\n    this.minutes = date.getMinutes().toString();\r\n    this.seconds = date.getSeconds().toString();\r\n  }\r\n}\r\n","<app-element-wrapper [data]=\"getData()\">\r\n  <div class=\"form-field__input--wrapper w-full\">\r\n    <input\r\n      class=\"fake-input\"\r\n      [id]=\"_date\"\r\n      [(ngModel)]=\"_date\"\r\n      [placeholder]=\"placeholder\"\r\n      [disabled]=\"disabled\"\r\n      [matDatepicker]=\"picker\"\r\n      [min]=\"minDate\"\r\n      [max]=\"maxDate\"\r\n      (blur)=\"onTouch()\"\r\n    />\r\n    <mat-datepicker #picker [calendarHeaderComponent]=\"header\" [touchUi]=\"touchUi\" class=\"datepicker-ui\">\r\n      <mat-datepicker-actions>\r\n        <div class=\"actions\">\r\n          <div class=\"time--inputs\">\r\n            <input\r\n              class=\"form-field__input time\"\r\n              appDigitsOnly\r\n              appNumberBorder\r\n              [digitsOnly]=\"true\"\r\n              [id]=\"hours\"\r\n              [value]=\"_hours\"\r\n              [maxValue]=\"maxValueHours\"\r\n              [(ngModel)]=\"hours\"\r\n            />\r\n            <span class=\"font-bold\">:</span>\r\n            <input\r\n              class=\"form-field__input time\"\r\n              [id]=\"minutes\"\r\n              [(ngModel)]=\"minutes\"\r\n              appDigitsOnly\r\n              appNumberBorder\r\n              [digitsOnly]=\"true\"\r\n              [maxValue]=\"maxValueMinutesSeconds\"\r\n            />\r\n\r\n            <ng-container *ngIf=\"!hideSeconds\">\r\n              <span class=\"font-bold\">:</span>\r\n              <input\r\n                class=\"form-field__input time\"\r\n                [id]=\"seconds\"\r\n                [(ngModel)]=\"seconds\"\r\n                appDigitsOnly\r\n                appNumberBorder\r\n                [digitsOnly]=\"true\"\r\n                [maxValue]=\"maxValueMinutesSeconds\"\r\n              />\r\n            </ng-container>\r\n          </div>\r\n\r\n          <div class=\"grid grid-cols-2\">\r\n            <button type=\"button\" mat-stroked-button class=\"w-full cancel-button\" color=\"primary\" matDatepickerCancel>\r\n              {{ cancelLabel }}\r\n            </button>\r\n\r\n            <button\r\n              type=\"button\"\r\n              mat-button\r\n              class=\"w-full ml-0 apply-button\"\r\n              color=\"primary\"\r\n              matDatepickerApply\r\n              (click)=\"onApply()\"\r\n            >\r\n              {{ applyLabel }}\r\n            </button>\r\n          </div>\r\n        </div>\r\n      </mat-datepicker-actions>\r\n    </mat-datepicker>\r\n    <input\r\n      class=\"form-field__input w-full date-input\"\r\n      [id]=\"name\"\r\n      [(ngModel)]=\"pickerValue\"\r\n      [placeholder]=\"placeholder\"\r\n      [disabled]=\"disabled\"\r\n      appMaskDate\r\n      [isDateTimeMask]=\"true\"\r\n      [considerSeconds]=\"!hideSeconds\"\r\n      (blur)=\"onTouch()\"\r\n    />\r\n    <button type=\"button\" mat-icon-button class=\"datepicker-toggle\" (click)=\"picker.open()\">\r\n      <mat-icon>calendar_today</mat-icon>\r\n    </button>\r\n  </div>\r\n</app-element-wrapper>\r\n"]}
|
|
@@ -1708,6 +1708,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
1708
1708
|
class EcabsDateTimePickerComponent extends ElementBaseComponent {
|
|
1709
1709
|
injector;
|
|
1710
1710
|
decimalPipe;
|
|
1711
|
+
cd;
|
|
1711
1712
|
minDate;
|
|
1712
1713
|
maxDate;
|
|
1713
1714
|
touchUi = false;
|
|
@@ -1725,6 +1726,8 @@ class EcabsDateTimePickerComponent extends ElementBaseComponent {
|
|
|
1725
1726
|
header = EcabsDateTimePickerHeaderComponent;
|
|
1726
1727
|
maxValueHours = 23;
|
|
1727
1728
|
maxValueMinutesSeconds = 59;
|
|
1729
|
+
preventCallSetterPickerValue = false;
|
|
1730
|
+
runTimeout = false;
|
|
1728
1731
|
get value() {
|
|
1729
1732
|
return this.val;
|
|
1730
1733
|
}
|
|
@@ -1756,26 +1759,48 @@ class EcabsDateTimePickerComponent extends ElementBaseComponent {
|
|
|
1756
1759
|
}
|
|
1757
1760
|
}
|
|
1758
1761
|
set value(val) {
|
|
1759
|
-
if (val && this.val !== new Date(val)) {
|
|
1760
|
-
this.
|
|
1761
|
-
|
|
1762
|
-
|
|
1763
|
-
this.
|
|
1762
|
+
if (val && this.val?.getTime() !== new Date(val).getTime()) {
|
|
1763
|
+
if (!this.preventCallSetterPickerValue) {
|
|
1764
|
+
this.pickerValue = this.formatDateTime(val);
|
|
1765
|
+
}
|
|
1766
|
+
this.preventCallSetterPickerValue = false;
|
|
1764
1767
|
}
|
|
1765
1768
|
}
|
|
1766
1769
|
set pickerValue(val) {
|
|
1767
1770
|
if (val) {
|
|
1768
1771
|
const date = parse(val.replace('_', ''), this.hideSeconds ? `dd/MM/yyyy, HH:mm` : `dd/MM/yyyy, HH:mm:ss`, new Date());
|
|
1769
1772
|
if (isValid(date) && this._pickerValue !== val) {
|
|
1773
|
+
if (this.minDate && date < this.minDate) {
|
|
1774
|
+
this.setValues(this.minDate);
|
|
1775
|
+
this._pickerValue = val;
|
|
1776
|
+
this.preventCallSetterPickerValue = true;
|
|
1777
|
+
this.value = this.minDate;
|
|
1778
|
+
this.runTimeout = true;
|
|
1779
|
+
this.refreshPickerValue(this.minDate);
|
|
1780
|
+
return;
|
|
1781
|
+
}
|
|
1782
|
+
if (this.maxDate && date > this.maxDate) {
|
|
1783
|
+
this.setValues(this.maxDate);
|
|
1784
|
+
this._pickerValue = val;
|
|
1785
|
+
this.preventCallSetterPickerValue = true;
|
|
1786
|
+
this.value = this.maxDate;
|
|
1787
|
+
this.runTimeout = true;
|
|
1788
|
+
this.refreshPickerValue(this.maxDate);
|
|
1789
|
+
return;
|
|
1790
|
+
}
|
|
1791
|
+
this.runTimeout = false;
|
|
1770
1792
|
this._pickerValue = val;
|
|
1793
|
+
this.preventCallSetterPickerValue = true;
|
|
1771
1794
|
this.value = date;
|
|
1795
|
+
this.setValues(date);
|
|
1772
1796
|
}
|
|
1773
1797
|
}
|
|
1774
1798
|
}
|
|
1775
|
-
constructor(injector, decimalPipe) {
|
|
1799
|
+
constructor(injector, decimalPipe, cd) {
|
|
1776
1800
|
super();
|
|
1777
1801
|
this.injector = injector;
|
|
1778
1802
|
this.decimalPipe = decimalPipe;
|
|
1803
|
+
this.cd = cd;
|
|
1779
1804
|
}
|
|
1780
1805
|
ngAfterViewInit() {
|
|
1781
1806
|
const ngControl = this.injector.get(NgControl, null);
|
|
@@ -1806,19 +1831,17 @@ class EcabsDateTimePickerComponent extends ElementBaseComponent {
|
|
|
1806
1831
|
onApply() {
|
|
1807
1832
|
if (this._date && this._seconds && this._minutes && this._hours) {
|
|
1808
1833
|
const date = setSeconds(setMinutes(setHours(new Date(this._date), +this._hours), +this._minutes), +this._seconds);
|
|
1809
|
-
if (this.minDate && date < this.minDate) {
|
|
1810
|
-
this.setValues(this.minDate);
|
|
1811
|
-
this.value = this.minDate;
|
|
1812
|
-
return;
|
|
1813
|
-
}
|
|
1814
|
-
if (this.maxDate && date > this.maxDate) {
|
|
1815
|
-
this.setValues(this.maxDate);
|
|
1816
|
-
this.value = this.maxDate;
|
|
1817
|
-
return;
|
|
1818
|
-
}
|
|
1819
1834
|
this.value = date;
|
|
1820
1835
|
}
|
|
1821
1836
|
}
|
|
1837
|
+
refreshPickerValue(date) {
|
|
1838
|
+
setTimeout(() => {
|
|
1839
|
+
if (this.runTimeout) {
|
|
1840
|
+
this._pickerValue = this.formatDateTime(date);
|
|
1841
|
+
this.cd.detectChanges();
|
|
1842
|
+
}
|
|
1843
|
+
}, 3000);
|
|
1844
|
+
}
|
|
1822
1845
|
formatDateTime(date) {
|
|
1823
1846
|
let result = '';
|
|
1824
1847
|
if (date && isValid(new Date(date))) {
|
|
@@ -1832,12 +1855,14 @@ class EcabsDateTimePickerComponent extends ElementBaseComponent {
|
|
|
1832
1855
|
return this.decimalPipe.transform(num, '2.0-0') ?? '00';
|
|
1833
1856
|
}
|
|
1834
1857
|
setValues(date) {
|
|
1858
|
+
this.onChange(date);
|
|
1859
|
+
this.onTouch(date);
|
|
1835
1860
|
this._date = date;
|
|
1836
1861
|
this.hours = date.getHours().toString();
|
|
1837
1862
|
this.minutes = date.getMinutes().toString();
|
|
1838
1863
|
this.seconds = date.getSeconds().toString();
|
|
1839
1864
|
}
|
|
1840
|
-
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: EcabsDateTimePickerComponent, deps: [{ token: i0.Injector }, { token: i1.DecimalPipe }], target: i0.ɵɵFactoryTarget.Component });
|
|
1865
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: EcabsDateTimePickerComponent, deps: [{ token: i0.Injector }, { token: i1.DecimalPipe }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
1841
1866
|
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: EcabsDateTimePickerComponent, selector: "ecabs-date-time-picker", inputs: { minDate: "minDate", maxDate: "maxDate", touchUi: "touchUi", hideSeconds: "hideSeconds", cancelLabel: "cancelLabel", applyLabel: "applyLabel", selectDateLabel: "selectDateLabel" }, outputs: { onblur: "onblur" }, providers: [
|
|
1842
1867
|
{
|
|
1843
1868
|
provide: NG_VALUE_ACCESSOR,
|
|
@@ -1857,7 +1882,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
1857
1882
|
},
|
|
1858
1883
|
DecimalPipe,
|
|
1859
1884
|
], template: "<app-element-wrapper [data]=\"getData()\">\r\n <div class=\"form-field__input--wrapper w-full\">\r\n <input\r\n class=\"fake-input\"\r\n [id]=\"_date\"\r\n [(ngModel)]=\"_date\"\r\n [placeholder]=\"placeholder\"\r\n [disabled]=\"disabled\"\r\n [matDatepicker]=\"picker\"\r\n [min]=\"minDate\"\r\n [max]=\"maxDate\"\r\n (blur)=\"onTouch()\"\r\n />\r\n <mat-datepicker #picker [calendarHeaderComponent]=\"header\" [touchUi]=\"touchUi\" class=\"datepicker-ui\">\r\n <mat-datepicker-actions>\r\n <div class=\"actions\">\r\n <div class=\"time--inputs\">\r\n <input\r\n class=\"form-field__input time\"\r\n appDigitsOnly\r\n appNumberBorder\r\n [digitsOnly]=\"true\"\r\n [id]=\"hours\"\r\n [value]=\"_hours\"\r\n [maxValue]=\"maxValueHours\"\r\n [(ngModel)]=\"hours\"\r\n />\r\n <span class=\"font-bold\">:</span>\r\n <input\r\n class=\"form-field__input time\"\r\n [id]=\"minutes\"\r\n [(ngModel)]=\"minutes\"\r\n appDigitsOnly\r\n appNumberBorder\r\n [digitsOnly]=\"true\"\r\n [maxValue]=\"maxValueMinutesSeconds\"\r\n />\r\n\r\n <ng-container *ngIf=\"!hideSeconds\">\r\n <span class=\"font-bold\">:</span>\r\n <input\r\n class=\"form-field__input time\"\r\n [id]=\"seconds\"\r\n [(ngModel)]=\"seconds\"\r\n appDigitsOnly\r\n appNumberBorder\r\n [digitsOnly]=\"true\"\r\n [maxValue]=\"maxValueMinutesSeconds\"\r\n />\r\n </ng-container>\r\n </div>\r\n\r\n <div class=\"grid grid-cols-2\">\r\n <button type=\"button\" mat-stroked-button class=\"w-full cancel-button\" color=\"primary\" matDatepickerCancel>\r\n {{ cancelLabel }}\r\n </button>\r\n\r\n <button\r\n type=\"button\"\r\n mat-button\r\n class=\"w-full ml-0 apply-button\"\r\n color=\"primary\"\r\n matDatepickerApply\r\n (click)=\"onApply()\"\r\n >\r\n {{ applyLabel }}\r\n </button>\r\n </div>\r\n </div>\r\n </mat-datepicker-actions>\r\n </mat-datepicker>\r\n <input\r\n class=\"form-field__input w-full date-input\"\r\n [id]=\"name\"\r\n [(ngModel)]=\"pickerValue\"\r\n [placeholder]=\"placeholder\"\r\n [disabled]=\"disabled\"\r\n appMaskDate\r\n [isDateTimeMask]=\"true\"\r\n [considerSeconds]=\"!hideSeconds\"\r\n (blur)=\"onTouch()\"\r\n />\r\n <button type=\"button\" mat-icon-button class=\"datepicker-toggle\" (click)=\"picker.open()\">\r\n <mat-icon>calendar_today</mat-icon>\r\n </button>\r\n </div>\r\n</app-element-wrapper>\r\n", styles: [".time--inputs:before,.time--inputs:after{position:absolute;content:\"\"}:host ::ng-deep .form-field{margin-right:-1.25rem;margin-left:-.125rem}.datepicker-toggle{transform:translate(-1.25rem);background-color:inherit;left:-.125rem}.time{width:3.375rem}.fake-input{visibility:hidden;width:0;padding:0;margin:0}.date-input{margin:0rem -1.25rem 0rem -.25rem}.time--inputs{position:relative;display:flex;gap:.5rem;justify-content:center;align-items:center;margin-top:2.4rem;margin-bottom:2.4rem}.time--inputs:before,.time--inputs:after{height:1px;right:0;left:0;background-color:var(--color-gray-300)}.time--inputs:before{top:-1.6rem}.time--inputs:after{bottom:-1.6rem}.font-bold{font-weight:700}.actions{display:flex;flex-direction:column;width:100%!important;row-gap:1rem}\n"] }]
|
|
1860
|
-
}], ctorParameters: function () { return [{ type: i0.Injector }, { type: i1.DecimalPipe }]; }, propDecorators: { minDate: [{
|
|
1885
|
+
}], ctorParameters: function () { return [{ type: i0.Injector }, { type: i1.DecimalPipe }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { minDate: [{
|
|
1861
1886
|
type: Input
|
|
1862
1887
|
}], maxDate: [{
|
|
1863
1888
|
type: Input
|