@wavemaker/app-ng-runtime 11.7.1-next.26354 → 11.7.1-next.26356

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.
@@ -1802,7 +1802,8 @@
1802
1802
  };
1803
1803
  }
1804
1804
 
1805
- const _c0$2 = ["wmDate", ""];
1805
+ const _c0$2 = ["dateInput"];
1806
+ const _c1 = ["wmDate", ""];
1806
1807
  function DateComponent_ng_template_8_Template(rf, ctx) { if (rf & 1) {
1807
1808
  const _r4 = i0__namespace.ɵɵgetCurrentView();
1808
1809
  i0__namespace.ɵɵelementStart(0, "wm-datetimepicker", 9);
@@ -1847,7 +1848,7 @@
1847
1848
  return validateTheMaskedDate(this.datepattern);
1848
1849
  }
1849
1850
  else {
1850
- return false;
1851
+ return {};
1851
1852
  }
1852
1853
  }
1853
1854
  // Todo[Shubham]: needs to be redefined
@@ -1882,11 +1883,17 @@
1882
1883
  this._bsDefaultLoadCheck = true;
1883
1884
  this.datepattern = this.appDefaults.dateFormat || i1$1.getDisplayDateTimeFormat(i1$1.FormWidgetType.DATE);
1884
1885
  this.updateFormat('datepattern');
1886
+ if (this.imask) {
1887
+ this.imask.maskRef.updateValue();
1888
+ }
1885
1889
  }
1886
1890
  /**
1887
1891
  * This is an internal method triggered when the date input changes
1888
1892
  */
1889
1893
  onDisplayDateChange($event, isNativePicker = false) {
1894
+ if (this.imask) {
1895
+ this.imask.maskRef.updateValue();
1896
+ }
1890
1897
  if (this.isEnterPressedOnDateInput) {
1891
1898
  this.isEnterPressedOnDateInput = false;
1892
1899
  return;
@@ -1902,6 +1909,9 @@
1902
1909
  if (isNativePicker && this.minDateMaxDateValidationOnInput(newVal, $event, this.displayValue, isNativePicker)) {
1903
1910
  return;
1904
1911
  }
1912
+ if (this.imask) {
1913
+ this.imask.maskRef.value = newVal.toDateString();
1914
+ }
1905
1915
  this.setDataValue(newVal);
1906
1916
  }
1907
1917
  // sets the dataValue and computes the display model values
@@ -1915,6 +1925,7 @@
1915
1925
  }
1916
1926
  if (newVal) {
1917
1927
  this.bsDataValue = newVal;
1928
+ this.imask.maskRef.value = newVal.toDateString();
1918
1929
  }
1919
1930
  else {
1920
1931
  this.bsDataValue = undefined;
@@ -1927,6 +1938,9 @@
1927
1938
  if (!this.bsDataValue) {
1928
1939
  this.hightlightToday(this.activeDate);
1929
1940
  }
1941
+ if (this.imask) {
1942
+ this.imask.maskRef.updateValue();
1943
+ }
1930
1944
  // We are using the two input tags(To maintain the modal and proxy modal) for the date control.
1931
1945
  // So actual bootstrap input target width we made it to 0, so bootstrap calculating the calendar container top position improperly.
1932
1946
  // To fix the container top position set the width 1px;
@@ -1942,11 +1956,19 @@
1942
1956
  i1$1.adjustContainerRightEdges($('bs-datepicker-container'), this.nativeElement, this.bsDatePickerDirective._datepicker);
1943
1957
  }
1944
1958
  onInputBlur($event) {
1959
+ if (this.imask) {
1960
+ this.imask.maskRef.updateValue();
1961
+ }
1945
1962
  if (!$($event.relatedTarget).hasClass('current-date')) {
1946
1963
  this.invokeOnTouched();
1947
1964
  this.invokeEventCallback('blur', { $event });
1948
1965
  }
1949
1966
  }
1967
+ onInputFocus($event) {
1968
+ if (this.imask) {
1969
+ this.imask.maskRef.value = $event.target.value;
1970
+ }
1971
+ }
1950
1972
  hideDatepickerDropdown() {
1951
1973
  this.invokeOnTouched();
1952
1974
  this.isOpen = false;
@@ -2021,6 +2043,9 @@
2021
2043
  this.invalidDateTimeFormat = false;
2022
2044
  this.isEnterPressedOnDateInput = true;
2023
2045
  this.bsDatePickerDirective.bsValue = event.target.value ? newVal : '';
2046
+ if (this.imask) {
2047
+ this.imask.maskRef.value = event.target.value;
2048
+ }
2024
2049
  }
2025
2050
  this.toggleDpDropdown(event);
2026
2051
  }
@@ -2051,16 +2076,18 @@
2051
2076
  static { this.ɵfac = function DateComponent_Factory(t) { return new (t || DateComponent)(i0__namespace.ɵɵdirectiveInject(i0__namespace.Injector), i0__namespace.ɵɵdirectiveInject(i0__namespace.ChangeDetectorRef), i0__namespace.ɵɵdirectiveInject(i1$1__namespace.AppDefaults)); }; }
2052
2077
  static { this.ɵcmp = /*@__PURE__*/ i0__namespace.ɵɵdefineComponent({ type: DateComponent, selectors: [["", "wmDate", ""]], viewQuery: function DateComponent_Query(rf, ctx) { if (rf & 1) {
2053
2078
  i0__namespace.ɵɵviewQuery(i3.BsDatepickerDirective, 5);
2079
+ i0__namespace.ɵɵviewQuery(_c0$2, 5, i4.IMaskDirective);
2054
2080
  } if (rf & 2) {
2055
2081
  let _t;
2056
2082
  i0__namespace.ɵɵqueryRefresh(_t = i0__namespace.ɵɵloadQuery()) && (ctx.bsDatePickerDirective = _t.first);
2083
+ i0__namespace.ɵɵqueryRefresh(_t = i0__namespace.ɵɵloadQuery()) && (ctx.imask = _t.first);
2057
2084
  } }, features: [i0__namespace.ɵɵProvidersFeature([
2058
2085
  base.provideAs(DateComponent, i5.NG_VALUE_ACCESSOR, true),
2059
2086
  base.provideAs(DateComponent, i5.NG_VALIDATORS, true),
2060
2087
  base.provideAsWidgetRef(DateComponent)
2061
- ]), i0__namespace.ɵɵInheritDefinitionFeature], attrs: _c0$2, decls: 9, vars: 27, consts: [["focus-target", "", "type", "text", 1, "form-control", "app-textbox", "app-dateinput", "display-input", 3, "name", "imask", "unmask", "tabindex", "value", "disabled", "autofocus", "required", "readOnly", "click", "focus", "blur", "change", "keydown"], ["dateInput", ""], [1, "input-group-btn"], ["type", "button", "aria-haspopup", "true", "aria-expanded", "false", 1, "btn", "btn-default", "btn-time", 3, "tabindex", "disabled", "click"], ["aria-hidden", "true", 1, "app-icon", "wm-sl-l", "sl-calendar"], [2, "width", "0", "display", "inline-block"], ["aria-label", "datepicker dropdownmenu", "aria-controls", "date", "bsDatepicker", "", "placement", "bottom right", 1, "model-holder", 3, "tabindex", "container", "bsConfig", "isOpen", "daysDisabled", "datesDisabled", "isDisabled", "bsValue", "onShown", "onHidden", "bsValueChange"], ["datepicker", "bsDatepicker"], [3, "ngIf"], ["dateTimePicker", "", "mode", "DATE", 3, "config", "placement", "excludedDaysToDisable", "excludedDatesToDisable", "displayFormat", "value", "change"], ["role", "button", 1, "mobile-input", "mobile-datepicker-container", 3, "tabindex", "click", "focus", "blur"]], template: function DateComponent_Template(rf, ctx) { if (rf & 1) {
2088
+ ]), i0__namespace.ɵɵInheritDefinitionFeature], attrs: _c1, decls: 9, vars: 27, consts: [["focus-target", "", "type", "text", 1, "form-control", "app-textbox", "app-dateinput", "display-input", 3, "name", "imask", "unmask", "tabindex", "value", "disabled", "autofocus", "required", "readOnly", "click", "focus", "blur", "change", "keydown"], ["dateInput", ""], [1, "input-group-btn"], ["type", "button", "aria-haspopup", "true", "aria-expanded", "false", 1, "btn", "btn-default", "btn-time", 3, "tabindex", "disabled", "click"], ["aria-hidden", "true", 1, "app-icon", "wm-sl-l", "sl-calendar"], [2, "width", "0", "display", "inline-block"], ["aria-label", "datepicker dropdownmenu", "aria-controls", "date", "bsDatepicker", "", "placement", "bottom right", 1, "model-holder", 3, "tabindex", "container", "bsConfig", "isOpen", "daysDisabled", "datesDisabled", "isDisabled", "bsValue", "onShown", "onHidden", "bsValueChange"], ["datepicker", "bsDatepicker"], [3, "ngIf"], ["dateTimePicker", "", "mode", "DATE", 3, "config", "placement", "excludedDaysToDisable", "excludedDatesToDisable", "displayFormat", "value", "change"], ["role", "button", 1, "mobile-input", "mobile-datepicker-container", 3, "tabindex", "click", "focus", "blur"]], template: function DateComponent_Template(rf, ctx) { if (rf & 1) {
2062
2089
  i0__namespace.ɵɵelementStart(0, "input", 0, 1);
2063
- i0__namespace.ɵɵlistener("click", function DateComponent_Template_input_click_0_listener($event) { return ctx.toggleDpDropdown($event, true); })("focus", function DateComponent_Template_input_focus_0_listener($event) { ctx.onDateTimeInputFocus(); return ctx.invokeOnFocus($event); })("blur", function DateComponent_Template_input_blur_0_listener($event) { return ctx.onInputBlur($event); })("change", function DateComponent_Template_input_change_0_listener($event) { return ctx.onDisplayDateChange($event); })("keydown", function DateComponent_Template_input_keydown_0_listener($event) { ctx._triggeredByUser = true; return ctx.onDisplayKeydown($event); });
2090
+ i0__namespace.ɵɵlistener("click", function DateComponent_Template_input_click_0_listener($event) { return ctx.toggleDpDropdown($event, true); })("focus", function DateComponent_Template_input_focus_0_listener($event) { ctx.onDateTimeInputFocus(); ctx.invokeOnFocus($event); return ctx.onInputFocus($event); })("blur", function DateComponent_Template_input_blur_0_listener($event) { return ctx.onInputBlur($event); })("change", function DateComponent_Template_input_change_0_listener($event) { return ctx.onDisplayDateChange($event); })("keydown", function DateComponent_Template_input_keydown_0_listener($event) { ctx._triggeredByUser = true; return ctx.onDisplayKeydown($event); });
2064
2091
  i0__namespace.ɵɵelementEnd();
2065
2092
  i0__namespace.ɵɵelementStart(2, "span", 2)(3, "button", 3);
2066
2093
  i0__namespace.ɵɵlistener("click", function DateComponent_Template_button_click_3_listener($event) { return ctx.toggleDpDropdown($event, false); });
@@ -2089,10 +2116,13 @@
2089
2116
  base.provideAs(DateComponent, i5.NG_VALUE_ACCESSOR, true),
2090
2117
  base.provideAs(DateComponent, i5.NG_VALIDATORS, true),
2091
2118
  base.provideAsWidgetRef(DateComponent)
2092
- ], template: " <input class=\"form-control app-textbox app-dateinput display-input\"\n focus-target\n type=\"text\"\n #dateInput\n [name]=\"name\"\n [imask]=\"mask\"\n [unmask]=\"true\"\n [tabindex]=\"loadNativeDateInput ? '-1' : tabindex\"\n [attr.aria-hidden]=\"!!loadNativeDateInput\"\n [value]=\"displayValue\"\n (click)=\"toggleDpDropdown($event, true)\"\n (focus)=\"onDateTimeInputFocus(); invokeOnFocus($event);\"\n (blur)=\"onInputBlur($event)\"\n [disabled]=\"disabled || readonly\"\n [autofocus]=\"autofocus\"\n [required]=\"required\"\n [readOnly]=\"isReadOnly\"\n [attr.placeholder]=\"placeholder\"\n [attr.accesskey]=\"shortcutkey\"\n [attr.aria-label]=\"hint\"\n (change)=\"onDisplayDateChange($event)\"\n (keydown)=\"this._triggeredByUser = true; onDisplayKeydown($event);\">\n\n <span class=\"input-group-btn\">\n <button type=\"button\"\n class=\"btn btn-default btn-time\"\n [tabindex]=\"loadNativeDateInput ? '-1' : tabindex\"\n [attr.aria-hidden]=\"!!loadNativeDateInput\"\n [disabled]=\"disabled || readonly\"\n [attr.aria-label]=\"displayValue ? 'Change Date ' + displayValue : 'Choose date by pressing enter'\"\n aria-haspopup=\"true\"\n aria-expanded=\"false\"\n (click)=\"toggleDpDropdown($event, false)\">\n <i aria-hidden=\"true\"\n class=\"app-icon wm-sl-l sl-calendar\"></i>\n </button>\n </span>\n <div style=\"width: 0;display: inline-block;\">\n <input class=\"model-holder\"\n aria-label=\"datepicker dropdownmenu\"\n aria-controls=\"date\"\n [tabindex]=\"-1\"\n [attr.aria-hidden]=\"!!loadNativeDateInput\"\n [container]=\"containerTarget || 'body'\"\n [bsConfig]=\"_dateOptions\"\n [isOpen]=\"isOpen\"\n #datepicker=\"bsDatepicker\"\n bsDatepicker\n [daysDisabled]=\"excludedDaysToDisable\"\n [datesDisabled]=\"excludedDatesToDisable\"\n placement=\"bottom right\"\n [isDisabled]=\"disabled || readonly\"\n [bsValue]=\"bsDataValue\"\n (onShown)=\"onDatePickerOpen()\"\n (onHidden)=\"hideDatepickerDropdown()\"\n (bsValueChange)=\"onDateChange($event)\">\n</div>\n\n<ng-template [ngIf]=\"loadNativeDateInput\">\n <wm-datetimepicker\n dateTimePicker\n mode=\"DATE\"\n [config]=\"_dateOptions\"\n [placement]=\"modal\"\n [excludedDaysToDisable]=\"excludedDaysToDisable\"\n [excludedDatesToDisable]=\"excludedDatesToDisable\"\n [displayFormat]=\"dateInputFormat\"\n [value]=\"bsDataValue\"\n (change)=\"onDateChange($event)\">\n </wm-datetimepicker>\n <div class=\"mobile-input mobile-datepicker-container\"\n [tabindex]=\"tabindex || 0\"\n (click)=\"!(disabled || readonly || isCurrentDate) && showDatePickerModal(bsDataValue)\"\n (focus)=\"onDateTimeInputFocus(true); invokeOnFocus($event);\"\n (blur)=\"onDateTimeInputBlur(); invokeOnTouched($event)\"\n [attr.aria-label]=\"displayValue ? 'Change Date ' + displayValue : hint || 'Choose Date'\"\n role=\"button\">\n </div>\n</ng-template>\n" }]
2119
+ ], template: " <input class=\"form-control app-textbox app-dateinput display-input\"\n focus-target\n type=\"text\"\n #dateInput\n [name]=\"name\"\n [imask]=\"mask\"\n [unmask]=\"true\"\n [tabindex]=\"loadNativeDateInput ? '-1' : tabindex\"\n [attr.aria-hidden]=\"!!loadNativeDateInput\"\n [value]=\"displayValue\"\n (click)=\"toggleDpDropdown($event, true)\"\n (focus)=\"onDateTimeInputFocus(); invokeOnFocus($event);onInputFocus($event)\"\n (blur)=\"onInputBlur($event)\"\n [disabled]=\"disabled || readonly\"\n [autofocus]=\"autofocus\"\n [required]=\"required\"\n [readOnly]=\"isReadOnly\"\n [attr.placeholder]=\"placeholder\"\n [attr.accesskey]=\"shortcutkey\"\n [attr.aria-label]=\"hint\"\n (change)=\"onDisplayDateChange($event)\"\n (keydown)=\"this._triggeredByUser = true; onDisplayKeydown($event);\">\n\n <span class=\"input-group-btn\">\n <button type=\"button\"\n class=\"btn btn-default btn-time\"\n [tabindex]=\"loadNativeDateInput ? '-1' : tabindex\"\n [attr.aria-hidden]=\"!!loadNativeDateInput\"\n [disabled]=\"disabled || readonly\"\n [attr.aria-label]=\"displayValue ? 'Change Date ' + displayValue : 'Choose date by pressing enter'\"\n aria-haspopup=\"true\"\n aria-expanded=\"false\"\n (click)=\"toggleDpDropdown($event, false)\">\n <i aria-hidden=\"true\"\n class=\"app-icon wm-sl-l sl-calendar\"></i>\n </button>\n </span>\n <div style=\"width: 0;display: inline-block;\">\n <input class=\"model-holder\"\n aria-label=\"datepicker dropdownmenu\"\n aria-controls=\"date\"\n [tabindex]=\"-1\"\n [attr.aria-hidden]=\"!!loadNativeDateInput\"\n [container]=\"containerTarget || 'body'\"\n [bsConfig]=\"_dateOptions\"\n [isOpen]=\"isOpen\"\n #datepicker=\"bsDatepicker\"\n bsDatepicker\n [daysDisabled]=\"excludedDaysToDisable\"\n [datesDisabled]=\"excludedDatesToDisable\"\n placement=\"bottom right\"\n [isDisabled]=\"disabled || readonly\"\n [bsValue]=\"bsDataValue\"\n (onShown)=\"onDatePickerOpen()\"\n (onHidden)=\"hideDatepickerDropdown()\"\n (bsValueChange)=\"onDateChange($event)\">\n</div>\n\n<ng-template [ngIf]=\"loadNativeDateInput\">\n <wm-datetimepicker\n dateTimePicker\n mode=\"DATE\"\n [config]=\"_dateOptions\"\n [placement]=\"modal\"\n [excludedDaysToDisable]=\"excludedDaysToDisable\"\n [excludedDatesToDisable]=\"excludedDatesToDisable\"\n [displayFormat]=\"dateInputFormat\"\n [value]=\"bsDataValue\"\n (change)=\"onDateChange($event)\">\n </wm-datetimepicker>\n <div class=\"mobile-input mobile-datepicker-container\"\n [tabindex]=\"tabindex || 0\"\n (click)=\"!(disabled || readonly || isCurrentDate) && showDatePickerModal(bsDataValue)\"\n (focus)=\"onDateTimeInputFocus(true); invokeOnFocus($event);\"\n (blur)=\"onDateTimeInputBlur(); invokeOnTouched($event)\"\n [attr.aria-label]=\"displayValue ? 'Change Date ' + displayValue : hint || 'Choose Date'\"\n role=\"button\">\n </div>\n</ng-template>\n" }]
2093
2120
  }], function () { return [{ type: i0__namespace.Injector }, { type: i0__namespace.ChangeDetectorRef }, { type: i1$1__namespace.AppDefaults }]; }, { bsDatePickerDirective: [{
2094
2121
  type: i0.ViewChild,
2095
2122
  args: [i3.BsDatepickerDirective]
2123
+ }], imask: [{
2124
+ type: i0.ViewChild,
2125
+ args: ['dateInput', { read: i4.IMaskDirective }]
2096
2126
  }] }); })();
2097
2127
 
2098
2128
  const dateTimeProps = new Map([
@@ -1,6 +1,7 @@
1
1
  import { ChangeDetectorRef, Injector } from '@angular/core';
2
2
  import { AppDefaults } from '@wm/core';
3
3
  import { BaseDateTimeComponent } from './../base-date-time.component';
4
+ import { IMaskDirective } from 'angular-imask';
4
5
  import * as i0 from "@angular/core";
5
6
  export declare class DateComponent extends BaseDateTimeComponent {
6
7
  private cdRef;
@@ -21,7 +22,7 @@ export declare class DateComponent extends BaseDateTimeComponent {
21
22
  get displayValue(): any;
22
23
  get nativeDisplayValue(): any;
23
24
  get datavalue(): any;
24
- get mask(): false | {
25
+ get mask(): {
25
26
  mask?: undefined;
26
27
  pattern?: undefined;
27
28
  format?: undefined;
@@ -126,6 +127,7 @@ export declare class DateComponent extends BaseDateTimeComponent {
126
127
  };
127
128
  set datavalue(newVal: any);
128
129
  protected bsDatePickerDirective: any;
130
+ imask: IMaskDirective<any>;
129
131
  constructor(inj: Injector, cdRef: ChangeDetectorRef, appDefaults: AppDefaults);
130
132
  /**
131
133
  * This is an internal method triggered when the date input changes
@@ -134,6 +136,7 @@ export declare class DateComponent extends BaseDateTimeComponent {
134
136
  private setDataValue;
135
137
  onDatePickerOpen(): void;
136
138
  onInputBlur($event: any): void;
139
+ onInputFocus($event: any): void;
137
140
  hideDatepickerDropdown(): void;
138
141
  protected handleEvent(node: HTMLElement, eventName: string, callback: Function, locals: any): void;
139
142
  /**
@@ -6,13 +6,15 @@ import { provideAs, provideAsWidgetRef, setFocusTrap, styler } from '@wm/compone
6
6
  import { BaseDateTimeComponent } from './../base-date-time.component';
7
7
  import { registerProps } from './date.props';
8
8
  import { validateTheMaskedDate } from './imaskUtil';
9
+ import { IMaskDirective } from 'angular-imask';
9
10
  import * as i0 from "@angular/core";
10
11
  import * as i1 from "@wm/core";
11
12
  import * as i2 from "@angular/common";
12
13
  import * as i3 from "ngx-bootstrap/datepicker";
13
14
  import * as i4 from "angular-imask";
14
15
  import * as i5 from "../date-time/date-time-picker.component";
15
- const _c0 = ["wmDate", ""];
16
+ const _c0 = ["dateInput"];
17
+ const _c1 = ["wmDate", ""];
16
18
  function DateComponent_ng_template_8_Template(rf, ctx) { if (rf & 1) {
17
19
  const _r4 = i0.ɵɵgetCurrentView();
18
20
  i0.ɵɵelementStart(0, "wm-datetimepicker", 9);
@@ -57,7 +59,7 @@ export class DateComponent extends BaseDateTimeComponent {
57
59
  return validateTheMaskedDate(this.datepattern);
58
60
  }
59
61
  else {
60
- return false;
62
+ return {};
61
63
  }
62
64
  }
63
65
  // Todo[Shubham]: needs to be redefined
@@ -92,11 +94,17 @@ export class DateComponent extends BaseDateTimeComponent {
92
94
  this._bsDefaultLoadCheck = true;
93
95
  this.datepattern = this.appDefaults.dateFormat || getDisplayDateTimeFormat(FormWidgetType.DATE);
94
96
  this.updateFormat('datepattern');
97
+ if (this.imask) {
98
+ this.imask.maskRef.updateValue();
99
+ }
95
100
  }
96
101
  /**
97
102
  * This is an internal method triggered when the date input changes
98
103
  */
99
104
  onDisplayDateChange($event, isNativePicker = false) {
105
+ if (this.imask) {
106
+ this.imask.maskRef.updateValue();
107
+ }
100
108
  if (this.isEnterPressedOnDateInput) {
101
109
  this.isEnterPressedOnDateInput = false;
102
110
  return;
@@ -112,6 +120,9 @@ export class DateComponent extends BaseDateTimeComponent {
112
120
  if (isNativePicker && this.minDateMaxDateValidationOnInput(newVal, $event, this.displayValue, isNativePicker)) {
113
121
  return;
114
122
  }
123
+ if (this.imask) {
124
+ this.imask.maskRef.value = newVal.toDateString();
125
+ }
115
126
  this.setDataValue(newVal);
116
127
  }
117
128
  // sets the dataValue and computes the display model values
@@ -125,6 +136,7 @@ export class DateComponent extends BaseDateTimeComponent {
125
136
  }
126
137
  if (newVal) {
127
138
  this.bsDataValue = newVal;
139
+ this.imask.maskRef.value = newVal.toDateString();
128
140
  }
129
141
  else {
130
142
  this.bsDataValue = undefined;
@@ -137,6 +149,9 @@ export class DateComponent extends BaseDateTimeComponent {
137
149
  if (!this.bsDataValue) {
138
150
  this.hightlightToday(this.activeDate);
139
151
  }
152
+ if (this.imask) {
153
+ this.imask.maskRef.updateValue();
154
+ }
140
155
  // We are using the two input tags(To maintain the modal and proxy modal) for the date control.
141
156
  // So actual bootstrap input target width we made it to 0, so bootstrap calculating the calendar container top position improperly.
142
157
  // To fix the container top position set the width 1px;
@@ -152,11 +167,19 @@ export class DateComponent extends BaseDateTimeComponent {
152
167
  adjustContainerRightEdges($('bs-datepicker-container'), this.nativeElement, this.bsDatePickerDirective._datepicker);
153
168
  }
154
169
  onInputBlur($event) {
170
+ if (this.imask) {
171
+ this.imask.maskRef.updateValue();
172
+ }
155
173
  if (!$($event.relatedTarget).hasClass('current-date')) {
156
174
  this.invokeOnTouched();
157
175
  this.invokeEventCallback('blur', { $event });
158
176
  }
159
177
  }
178
+ onInputFocus($event) {
179
+ if (this.imask) {
180
+ this.imask.maskRef.value = $event.target.value;
181
+ }
182
+ }
160
183
  hideDatepickerDropdown() {
161
184
  this.invokeOnTouched();
162
185
  this.isOpen = false;
@@ -231,6 +254,9 @@ export class DateComponent extends BaseDateTimeComponent {
231
254
  this.invalidDateTimeFormat = false;
232
255
  this.isEnterPressedOnDateInput = true;
233
256
  this.bsDatePickerDirective.bsValue = event.target.value ? newVal : '';
257
+ if (this.imask) {
258
+ this.imask.maskRef.value = event.target.value;
259
+ }
234
260
  }
235
261
  this.toggleDpDropdown(event);
236
262
  }
@@ -261,16 +287,18 @@ export class DateComponent extends BaseDateTimeComponent {
261
287
  static { this.ɵfac = function DateComponent_Factory(t) { return new (t || DateComponent)(i0.ɵɵdirectiveInject(i0.Injector), i0.ɵɵdirectiveInject(i0.ChangeDetectorRef), i0.ɵɵdirectiveInject(i1.AppDefaults)); }; }
262
288
  static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: DateComponent, selectors: [["", "wmDate", ""]], viewQuery: function DateComponent_Query(rf, ctx) { if (rf & 1) {
263
289
  i0.ɵɵviewQuery(BsDatepickerDirective, 5);
290
+ i0.ɵɵviewQuery(_c0, 5, IMaskDirective);
264
291
  } if (rf & 2) {
265
292
  let _t;
266
293
  i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.bsDatePickerDirective = _t.first);
294
+ i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.imask = _t.first);
267
295
  } }, features: [i0.ɵɵProvidersFeature([
268
296
  provideAs(DateComponent, NG_VALUE_ACCESSOR, true),
269
297
  provideAs(DateComponent, NG_VALIDATORS, true),
270
298
  provideAsWidgetRef(DateComponent)
271
- ]), i0.ɵɵInheritDefinitionFeature], attrs: _c0, decls: 9, vars: 27, consts: [["focus-target", "", "type", "text", 1, "form-control", "app-textbox", "app-dateinput", "display-input", 3, "name", "imask", "unmask", "tabindex", "value", "disabled", "autofocus", "required", "readOnly", "click", "focus", "blur", "change", "keydown"], ["dateInput", ""], [1, "input-group-btn"], ["type", "button", "aria-haspopup", "true", "aria-expanded", "false", 1, "btn", "btn-default", "btn-time", 3, "tabindex", "disabled", "click"], ["aria-hidden", "true", 1, "app-icon", "wm-sl-l", "sl-calendar"], [2, "width", "0", "display", "inline-block"], ["aria-label", "datepicker dropdownmenu", "aria-controls", "date", "bsDatepicker", "", "placement", "bottom right", 1, "model-holder", 3, "tabindex", "container", "bsConfig", "isOpen", "daysDisabled", "datesDisabled", "isDisabled", "bsValue", "onShown", "onHidden", "bsValueChange"], ["datepicker", "bsDatepicker"], [3, "ngIf"], ["dateTimePicker", "", "mode", "DATE", 3, "config", "placement", "excludedDaysToDisable", "excludedDatesToDisable", "displayFormat", "value", "change"], ["role", "button", 1, "mobile-input", "mobile-datepicker-container", 3, "tabindex", "click", "focus", "blur"]], template: function DateComponent_Template(rf, ctx) { if (rf & 1) {
299
+ ]), i0.ɵɵInheritDefinitionFeature], attrs: _c1, decls: 9, vars: 27, consts: [["focus-target", "", "type", "text", 1, "form-control", "app-textbox", "app-dateinput", "display-input", 3, "name", "imask", "unmask", "tabindex", "value", "disabled", "autofocus", "required", "readOnly", "click", "focus", "blur", "change", "keydown"], ["dateInput", ""], [1, "input-group-btn"], ["type", "button", "aria-haspopup", "true", "aria-expanded", "false", 1, "btn", "btn-default", "btn-time", 3, "tabindex", "disabled", "click"], ["aria-hidden", "true", 1, "app-icon", "wm-sl-l", "sl-calendar"], [2, "width", "0", "display", "inline-block"], ["aria-label", "datepicker dropdownmenu", "aria-controls", "date", "bsDatepicker", "", "placement", "bottom right", 1, "model-holder", 3, "tabindex", "container", "bsConfig", "isOpen", "daysDisabled", "datesDisabled", "isDisabled", "bsValue", "onShown", "onHidden", "bsValueChange"], ["datepicker", "bsDatepicker"], [3, "ngIf"], ["dateTimePicker", "", "mode", "DATE", 3, "config", "placement", "excludedDaysToDisable", "excludedDatesToDisable", "displayFormat", "value", "change"], ["role", "button", 1, "mobile-input", "mobile-datepicker-container", 3, "tabindex", "click", "focus", "blur"]], template: function DateComponent_Template(rf, ctx) { if (rf & 1) {
272
300
  i0.ɵɵelementStart(0, "input", 0, 1);
273
- i0.ɵɵlistener("click", function DateComponent_Template_input_click_0_listener($event) { return ctx.toggleDpDropdown($event, true); })("focus", function DateComponent_Template_input_focus_0_listener($event) { ctx.onDateTimeInputFocus(); return ctx.invokeOnFocus($event); })("blur", function DateComponent_Template_input_blur_0_listener($event) { return ctx.onInputBlur($event); })("change", function DateComponent_Template_input_change_0_listener($event) { return ctx.onDisplayDateChange($event); })("keydown", function DateComponent_Template_input_keydown_0_listener($event) { ctx._triggeredByUser = true; return ctx.onDisplayKeydown($event); });
301
+ i0.ɵɵlistener("click", function DateComponent_Template_input_click_0_listener($event) { return ctx.toggleDpDropdown($event, true); })("focus", function DateComponent_Template_input_focus_0_listener($event) { ctx.onDateTimeInputFocus(); ctx.invokeOnFocus($event); return ctx.onInputFocus($event); })("blur", function DateComponent_Template_input_blur_0_listener($event) { return ctx.onInputBlur($event); })("change", function DateComponent_Template_input_change_0_listener($event) { return ctx.onDisplayDateChange($event); })("keydown", function DateComponent_Template_input_keydown_0_listener($event) { ctx._triggeredByUser = true; return ctx.onDisplayKeydown($event); });
274
302
  i0.ɵɵelementEnd();
275
303
  i0.ɵɵelementStart(2, "span", 2)(3, "button", 3);
276
304
  i0.ɵɵlistener("click", function DateComponent_Template_button_click_3_listener($event) { return ctx.toggleDpDropdown($event, false); });
@@ -299,9 +327,12 @@ export class DateComponent extends BaseDateTimeComponent {
299
327
  provideAs(DateComponent, NG_VALUE_ACCESSOR, true),
300
328
  provideAs(DateComponent, NG_VALIDATORS, true),
301
329
  provideAsWidgetRef(DateComponent)
302
- ], template: " <input class=\"form-control app-textbox app-dateinput display-input\"\n focus-target\n type=\"text\"\n #dateInput\n [name]=\"name\"\n [imask]=\"mask\"\n [unmask]=\"true\"\n [tabindex]=\"loadNativeDateInput ? '-1' : tabindex\"\n [attr.aria-hidden]=\"!!loadNativeDateInput\"\n [value]=\"displayValue\"\n (click)=\"toggleDpDropdown($event, true)\"\n (focus)=\"onDateTimeInputFocus(); invokeOnFocus($event);\"\n (blur)=\"onInputBlur($event)\"\n [disabled]=\"disabled || readonly\"\n [autofocus]=\"autofocus\"\n [required]=\"required\"\n [readOnly]=\"isReadOnly\"\n [attr.placeholder]=\"placeholder\"\n [attr.accesskey]=\"shortcutkey\"\n [attr.aria-label]=\"hint\"\n (change)=\"onDisplayDateChange($event)\"\n (keydown)=\"this._triggeredByUser = true; onDisplayKeydown($event);\">\n\n <span class=\"input-group-btn\">\n <button type=\"button\"\n class=\"btn btn-default btn-time\"\n [tabindex]=\"loadNativeDateInput ? '-1' : tabindex\"\n [attr.aria-hidden]=\"!!loadNativeDateInput\"\n [disabled]=\"disabled || readonly\"\n [attr.aria-label]=\"displayValue ? 'Change Date ' + displayValue : 'Choose date by pressing enter'\"\n aria-haspopup=\"true\"\n aria-expanded=\"false\"\n (click)=\"toggleDpDropdown($event, false)\">\n <i aria-hidden=\"true\"\n class=\"app-icon wm-sl-l sl-calendar\"></i>\n </button>\n </span>\n <div style=\"width: 0;display: inline-block;\">\n <input class=\"model-holder\"\n aria-label=\"datepicker dropdownmenu\"\n aria-controls=\"date\"\n [tabindex]=\"-1\"\n [attr.aria-hidden]=\"!!loadNativeDateInput\"\n [container]=\"containerTarget || 'body'\"\n [bsConfig]=\"_dateOptions\"\n [isOpen]=\"isOpen\"\n #datepicker=\"bsDatepicker\"\n bsDatepicker\n [daysDisabled]=\"excludedDaysToDisable\"\n [datesDisabled]=\"excludedDatesToDisable\"\n placement=\"bottom right\"\n [isDisabled]=\"disabled || readonly\"\n [bsValue]=\"bsDataValue\"\n (onShown)=\"onDatePickerOpen()\"\n (onHidden)=\"hideDatepickerDropdown()\"\n (bsValueChange)=\"onDateChange($event)\">\n</div>\n\n<ng-template [ngIf]=\"loadNativeDateInput\">\n <wm-datetimepicker\n dateTimePicker\n mode=\"DATE\"\n [config]=\"_dateOptions\"\n [placement]=\"modal\"\n [excludedDaysToDisable]=\"excludedDaysToDisable\"\n [excludedDatesToDisable]=\"excludedDatesToDisable\"\n [displayFormat]=\"dateInputFormat\"\n [value]=\"bsDataValue\"\n (change)=\"onDateChange($event)\">\n </wm-datetimepicker>\n <div class=\"mobile-input mobile-datepicker-container\"\n [tabindex]=\"tabindex || 0\"\n (click)=\"!(disabled || readonly || isCurrentDate) && showDatePickerModal(bsDataValue)\"\n (focus)=\"onDateTimeInputFocus(true); invokeOnFocus($event);\"\n (blur)=\"onDateTimeInputBlur(); invokeOnTouched($event)\"\n [attr.aria-label]=\"displayValue ? 'Change Date ' + displayValue : hint || 'Choose Date'\"\n role=\"button\">\n </div>\n</ng-template>\n" }]
330
+ ], template: " <input class=\"form-control app-textbox app-dateinput display-input\"\n focus-target\n type=\"text\"\n #dateInput\n [name]=\"name\"\n [imask]=\"mask\"\n [unmask]=\"true\"\n [tabindex]=\"loadNativeDateInput ? '-1' : tabindex\"\n [attr.aria-hidden]=\"!!loadNativeDateInput\"\n [value]=\"displayValue\"\n (click)=\"toggleDpDropdown($event, true)\"\n (focus)=\"onDateTimeInputFocus(); invokeOnFocus($event);onInputFocus($event)\"\n (blur)=\"onInputBlur($event)\"\n [disabled]=\"disabled || readonly\"\n [autofocus]=\"autofocus\"\n [required]=\"required\"\n [readOnly]=\"isReadOnly\"\n [attr.placeholder]=\"placeholder\"\n [attr.accesskey]=\"shortcutkey\"\n [attr.aria-label]=\"hint\"\n (change)=\"onDisplayDateChange($event)\"\n (keydown)=\"this._triggeredByUser = true; onDisplayKeydown($event);\">\n\n <span class=\"input-group-btn\">\n <button type=\"button\"\n class=\"btn btn-default btn-time\"\n [tabindex]=\"loadNativeDateInput ? '-1' : tabindex\"\n [attr.aria-hidden]=\"!!loadNativeDateInput\"\n [disabled]=\"disabled || readonly\"\n [attr.aria-label]=\"displayValue ? 'Change Date ' + displayValue : 'Choose date by pressing enter'\"\n aria-haspopup=\"true\"\n aria-expanded=\"false\"\n (click)=\"toggleDpDropdown($event, false)\">\n <i aria-hidden=\"true\"\n class=\"app-icon wm-sl-l sl-calendar\"></i>\n </button>\n </span>\n <div style=\"width: 0;display: inline-block;\">\n <input class=\"model-holder\"\n aria-label=\"datepicker dropdownmenu\"\n aria-controls=\"date\"\n [tabindex]=\"-1\"\n [attr.aria-hidden]=\"!!loadNativeDateInput\"\n [container]=\"containerTarget || 'body'\"\n [bsConfig]=\"_dateOptions\"\n [isOpen]=\"isOpen\"\n #datepicker=\"bsDatepicker\"\n bsDatepicker\n [daysDisabled]=\"excludedDaysToDisable\"\n [datesDisabled]=\"excludedDatesToDisable\"\n placement=\"bottom right\"\n [isDisabled]=\"disabled || readonly\"\n [bsValue]=\"bsDataValue\"\n (onShown)=\"onDatePickerOpen()\"\n (onHidden)=\"hideDatepickerDropdown()\"\n (bsValueChange)=\"onDateChange($event)\">\n</div>\n\n<ng-template [ngIf]=\"loadNativeDateInput\">\n <wm-datetimepicker\n dateTimePicker\n mode=\"DATE\"\n [config]=\"_dateOptions\"\n [placement]=\"modal\"\n [excludedDaysToDisable]=\"excludedDaysToDisable\"\n [excludedDatesToDisable]=\"excludedDatesToDisable\"\n [displayFormat]=\"dateInputFormat\"\n [value]=\"bsDataValue\"\n (change)=\"onDateChange($event)\">\n </wm-datetimepicker>\n <div class=\"mobile-input mobile-datepicker-container\"\n [tabindex]=\"tabindex || 0\"\n (click)=\"!(disabled || readonly || isCurrentDate) && showDatePickerModal(bsDataValue)\"\n (focus)=\"onDateTimeInputFocus(true); invokeOnFocus($event);\"\n (blur)=\"onDateTimeInputBlur(); invokeOnTouched($event)\"\n [attr.aria-label]=\"displayValue ? 'Change Date ' + displayValue : hint || 'Choose Date'\"\n role=\"button\">\n </div>\n</ng-template>\n" }]
303
331
  }], function () { return [{ type: i0.Injector }, { type: i0.ChangeDetectorRef }, { type: i1.AppDefaults }]; }, { bsDatePickerDirective: [{
304
332
  type: ViewChild,
305
333
  args: [BsDatepickerDirective]
334
+ }], imask: [{
335
+ type: ViewChild,
336
+ args: ['dateInput', { read: IMaskDirective }]
306
337
  }] }); })();
307
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date.component.js","sourceRoot":"","sources":["../../../../../../projects/components/widgets/input/epoch/src/date/date.component.ts","../../../../../../projects/components/widgets/input/epoch/src/date/date.component.html"],"names":[],"mappings":"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","sourcesContent":["import {ChangeDetectorRef, Component, Inject, Injector, Optional, ViewChild} from '@angular/core';\nimport { NG_VALUE_ACCESSOR, NG_VALIDATORS } from '@angular/forms';\n\nimport { BsDatepickerDirective } from 'ngx-bootstrap/datepicker';\n\n\nimport {\n    adjustContainerPosition,\n    addEventListenerOnElement,\n    AppDefaults,\n    EVENT_LIFE,\n    FormWidgetType,\n    getDateObj,\n    getDisplayDateTimeFormat,\n    getFormattedDate,\n    adjustContainerRightEdges,\n    getMomentLocaleObject,\n    App\n} from '@wm/core';\nimport { IWidgetConfig, provideAs, provideAsWidgetRef, setFocusTrap, styler } from '@wm/components/base';\nimport { BaseDateTimeComponent } from './../base-date-time.component';\nimport { registerProps } from './date.props';\nimport { validateTheMaskedDate } from './imaskUtil';\n\n\ndeclare const _, $, moment;\n\nconst CURRENT_DATE = 'CURRENT_DATE';\nconst DEFAULT_CLS = 'app-date input-group';\nconst WIDGET_CONFIG: IWidgetConfig = {\n    widgetType: 'wm-date',\n    hostClass: DEFAULT_CLS\n};\n\n@Component({\n    selector: '[wmDate]',\n    templateUrl: './date.component.html',\n    providers: [\n        provideAs(DateComponent, NG_VALUE_ACCESSOR, true),\n        provideAs(DateComponent, NG_VALIDATORS, true),\n        provideAsWidgetRef(DateComponent)\n    ]\n})\nexport class DateComponent extends BaseDateTimeComponent {\n    static initializeProps = registerProps();\n\n    public bsDataValue;\n    public showdropdownon: string;\n    private dateContainerCls: string;\n    public isOpen: boolean = false;\n    private isEnterPressedOnDateInput = false;\n    private _bsDefaultLoadCheck: boolean;\n    public hint: string;\n\n    private deregisterEventListener;\n    private isCurrentDate;\n    private focusTrap;\n\n    get timestamp() {\n        return this.bsDataValue ? this.bsDataValue.valueOf() : undefined;\n    }\n\n    get dateInputFormat() {\n        return this._dateOptions.dateInputFormat || 'yyyy-MM-dd';\n    }\n\n    get displayValue() {\n        return getFormattedDate(this.datePipe, this.bsDataValue, this.dateInputFormat, this.timeZone, null, this.isCurrentDate, this) || '';\n    }\n\n    get nativeDisplayValue() {\n        return getFormattedDate(this.datePipe, this.bsDataValue, 'yyyy-MM-dd', this.timeZone, null, this.isCurrentDate, this) || '';\n    }\n\n    // @ts-ignore\n    get datavalue() {\n        return getFormattedDate(this.datePipe, this.bsDataValue, this.outputformat, this.timeZone, null, this.isCurrentDate, this) || '';\n    }\n    get mask() {\n        if (this.datepattern) {\n           return validateTheMaskedDate(this.datepattern);\n        }\n        else {\n            return false;\n        }\n    }\n\n\n    // Todo[Shubham]: needs to be redefined\n    // sets the dataValue and computes the display model values\n    // @ts-ignore\n    set datavalue(newVal) {\n        if (newVal === CURRENT_DATE) {\n            setTimeout(() => {\n                this.bsDataValue = this.timeZone ? getMomentLocaleObject(this.timeZone) : new Date();\n            }, 50);\n            this.isCurrentDate = true;\n        } else {\n            this.bsDataValue = newVal ? getDateObj(newVal, {isNativePicker: this.loadNativeDateInput}, this.timeZone) : undefined;\n            this.isCurrentDate = false;\n        }\n        // update the previous datavalue.\n        this.invokeOnChange(this.datavalue, undefined, true);\n        this.cdRef.detectChanges();\n    }\n\n    @ViewChild(BsDatepickerDirective) protected bsDatePickerDirective;\n\n\n    // TODO use BsLocaleService to set the current user's locale to see the localized labels\n    constructor(\n        inj: Injector,\n        private cdRef: ChangeDetectorRef,\n        private appDefaults: AppDefaults\n    ) {\n        super(inj, WIDGET_CONFIG);\n        styler(this.nativeElement, this);\n\n        this.dateContainerCls = `app-date-${this.widgetId}`;\n        this._dateOptions.containerClass = `app-date ${this.dateContainerCls}`;\n        this._dateOptions.showWeekNumbers = false;\n        this._bsDefaultLoadCheck = true;\n        this.datepattern = this.appDefaults.dateFormat || getDisplayDateTimeFormat(FormWidgetType.DATE);\n        this.updateFormat('datepattern');\n    }\n\n    /**\n     * This is an internal method triggered when the date input changes\n     */\n    onDisplayDateChange($event, isNativePicker: boolean = false) {\n        if (this.isEnterPressedOnDateInput) {\n            this.isEnterPressedOnDateInput = false;\n            return;\n        }\n        const newVal = getDateObj($event.target.value, {pattern: this.datepattern, isNativePicker: isNativePicker});\n        // date pattern validation\n        // if invalid pattern is entered, device is showing an error.\n        if (!this.formatValidation(newVal, $event.target.value, isNativePicker)) {\n            return;\n        }\n        // min date and max date validation in mobile view.\n        // if invalid dates are entered, device is showing an alert.\n        if (isNativePicker && this.minDateMaxDateValidationOnInput(newVal, $event, this.displayValue, isNativePicker)) {\n            return;\n        }\n        this.setDataValue(newVal);\n    }\n\n    // sets the dataValue and computes the display model values\n    private setDataValue(newVal): void {\n        this.invalidDateTimeFormat = false;\n        // min date and max date validation in web.\n        // if invalid dates are entered, device is showing validation message.\n        this.minDateMaxDateValidationOnInput(newVal);\n        if (getFormattedDate(this.datePipe, newVal, this.dateInputFormat, this.timeZone, null, this.isCurrentDate, this) === this.displayValue) {\n            $(this.nativeElement).find('.display-input').val(this.displayValue);\n        }\n        if (newVal) {\n            this.bsDataValue = newVal;\n        } else {\n            this.bsDataValue = undefined;\n        }\n        this.invokeOnChange(this.datavalue, {}, true);\n    }\n\n    onDatePickerOpen() {\n        this.isOpen = true;\n        this.bsDataValue ? this.activeDate = this.bsDataValue : this.activeDate = new Date();\n        if (!this.bsDataValue) {\n            this.hightlightToday(this.activeDate);\n        }\n\n        // We are using the two input tags(To maintain the modal and proxy modal) for the date control.\n        // So actual bootstrap input target width we made it to 0, so bootstrap calculating the calendar container top position improperly.\n        // To fix the container top position set the width 1px;\n        this.$element.find('.model-holder').width('1px');\n        const dpContainerEl = $('bs-datepicker-container');\n        dpContainerEl.attr('aria-label', 'Use Arrow keys to navigate dates, Choose Date from datepicker');\n        $('.bs-calendar-container').removeAttr('role');\n        const datePickerContainer = $('.bs-datepicker-container')[0];\n        this.focusTrap = setFocusTrap(datePickerContainer, true);\n        this.focusTrap.activate();\n        this.addDatepickerKeyboardEvents(this, false);\n        adjustContainerPosition($('bs-datepicker-container'), this.nativeElement, this.bsDatePickerDirective._datepicker);\n        adjustContainerRightEdges($('bs-datepicker-container'), this.nativeElement, this.bsDatePickerDirective._datepicker);\n    }\n    onInputBlur($event) {\n        if (!$($event.relatedTarget).hasClass('current-date')) {\n            this.invokeOnTouched();\n            this.invokeEventCallback('blur', { $event });\n        }\n    }\n\n    public hideDatepickerDropdown() {\n        this.invokeOnTouched();\n        this.isOpen = false;\n        this.focusTrap?.deactivate();\n        this.isEnterPressedOnDateInput = false;\n        if (this.deregisterEventListener) {\n            this.deregisterEventListener();\n        }\n        this.blurDateInput(this.isOpen);\n    }\n\n    // change and blur events are added from the template\n    protected handleEvent(node: HTMLElement, eventName: string, callback: Function, locals: any) {\n        if (!_.includes(['blur', 'focus', 'change', 'click'], eventName)) {\n            super.handleEvent(node, eventName, callback, locals);\n        }\n    }\n\n    /**\n     * This is an internal method used to toggle the dropdown of the date widget\n     */\n     public toggleDpDropdown($event, skipFocus: boolean = false) {\n        if (this.loadNativeDateInput) {\n             // Fixes click event getting triggred twice in Mobile devices.\n            if (!skipFocus) {\n                this.onDateTimeInputFocus();\n            }\n        }\n        if ($event.type === 'click') {\n            this.invokeEventCallback('click', { $event: $event });\n          //  this.focusOnInputEl();\n        }\n        if ($event.target && $($event.target).is('input') && !(this.isDropDownDisplayEnabledOnInput(this.showdropdownon))) {\n            $event.stopPropagation();\n            return;\n        }\n        this.bsDatePickerDirective.toggle();\n        this.addBodyClickListener(this.bsDatePickerDirective.isOpen);\n    }\n\n    private addBodyClickListener(skipListener) {\n        if (!skipListener) {\n            return;\n        }\n        const bodyElement = document.querySelector('body');\n        setTimeout(() => {\n            const bsDateContainerElement = bodyElement.querySelector(`.${this.dateContainerCls}`);\n            this.deregisterEventListener = addEventListenerOnElement(bodyElement, bsDateContainerElement, this.nativeElement, 'click', this.isDropDownDisplayEnabledOnInput(this.showdropdownon), () => {\n                this.isOpen = false;\n            }, EVENT_LIFE.ONCE, true);\n        }, 350);\n    }\n\n    /**\n     * This is an internal method triggered when pressing key on the date input\n     */\n    public onDisplayKeydown(event) {\n        if (this.isDropDownDisplayEnabledOnInput(this.showdropdownon)) {\n            event.stopPropagation();\n            if (event.key === 'Enter') {\n                const newVal = getDateObj(event.target.value, {pattern: this.datepattern});\n                event.preventDefault();\n                const formattedDate = getFormattedDate(this.datePipe, newVal, this.dateInputFormat, this.timeZone, null, this.isCurrentDate, this);\n                const inputVal = event.target.value.trim();\n                if (inputVal && this.datepattern === 'timestamp') {\n                    if (!_.isNaN(inputVal) && _.parseInt(inputVal) !== formattedDate) {\n                        this.invalidDateTimeFormat = true;\n                        this.invokeOnChange(this.datavalue, event, false);\n                    }\n                } else if (inputVal && inputVal !== formattedDate) {\n                    this.invalidDateTimeFormat = true;\n                    this.invokeOnChange(this.datavalue, event, false);\n                } else {\n                    this.invalidDateTimeFormat = false;\n                    this.isEnterPressedOnDateInput = true;\n                    this.bsDatePickerDirective.bsValue =  event.target.value ? newVal : '';\n                }\n                this.toggleDpDropdown(event);\n            } else {\n                this.hideDatepickerDropdown();\n            }\n        } else {\n            this.hideDatepickerDropdown();\n        }\n    }\n\n    /**\n     * This is an internal method triggered when the date selection changes\n     */\n    onDateChange(newVal): void {\n        /**\n         *  Ngx-bootstrap upgrade : To avoid the page load datechange event;\n         *  TODO:\n         *  https://github.com/valor-software/ngx-bootstrap/issues/6016\n         *  For above issue, once we get the solution from Ngx-Bootstrap team,  remove the _bsDefaultLoadCheck check and update accordingly.\n         * */\n        if (this._bsDefaultLoadCheck) {\n            this._bsDefaultLoadCheck = false;\n            return;\n        }\n\n        this.setDataValue(newVal);\n    }\n}\n","    <input class=\"form-control app-textbox app-dateinput display-input\"\n        focus-target\n        type=\"text\"\n           #dateInput\n        [name]=\"name\"\n       [imask]=\"mask\"\n       [unmask]=\"true\"\n        [tabindex]=\"loadNativeDateInput ? '-1' : tabindex\"\n        [attr.aria-hidden]=\"!!loadNativeDateInput\"\n        [value]=\"displayValue\"\n        (click)=\"toggleDpDropdown($event, true)\"\n        (focus)=\"onDateTimeInputFocus(); invokeOnFocus($event);\"\n        (blur)=\"onInputBlur($event)\"\n        [disabled]=\"disabled || readonly\"\n        [autofocus]=\"autofocus\"\n        [required]=\"required\"\n        [readOnly]=\"isReadOnly\"\n        [attr.placeholder]=\"placeholder\"\n        [attr.accesskey]=\"shortcutkey\"\n        [attr.aria-label]=\"hint\"\n        (change)=\"onDisplayDateChange($event)\"\n        (keydown)=\"this._triggeredByUser = true; onDisplayKeydown($event);\">\n\n    <span class=\"input-group-btn\">\n        <button type=\"button\"\n            class=\"btn btn-default btn-time\"\n            [tabindex]=\"loadNativeDateInput ? '-1' : tabindex\"\n            [attr.aria-hidden]=\"!!loadNativeDateInput\"\n            [disabled]=\"disabled || readonly\"\n            [attr.aria-label]=\"displayValue ? 'Change Date ' + displayValue : 'Choose date by pressing enter'\"\n            aria-haspopup=\"true\"\n            aria-expanded=\"false\"\n            (click)=\"toggleDpDropdown($event, false)\">\n            <i aria-hidden=\"true\"\n                class=\"app-icon wm-sl-l sl-calendar\"></i>\n        </button>\n    </span>\n    <div style=\"width: 0;display: inline-block;\">\n    <input class=\"model-holder\"\n        aria-label=\"datepicker dropdownmenu\"\n        aria-controls=\"date\"\n        [tabindex]=\"-1\"\n        [attr.aria-hidden]=\"!!loadNativeDateInput\"\n        [container]=\"containerTarget || 'body'\"\n        [bsConfig]=\"_dateOptions\"\n        [isOpen]=\"isOpen\"\n        #datepicker=\"bsDatepicker\"\n        bsDatepicker\n        [daysDisabled]=\"excludedDaysToDisable\"\n        [datesDisabled]=\"excludedDatesToDisable\"\n        placement=\"bottom right\"\n        [isDisabled]=\"disabled || readonly\"\n        [bsValue]=\"bsDataValue\"\n        (onShown)=\"onDatePickerOpen()\"\n        (onHidden)=\"hideDatepickerDropdown()\"\n        (bsValueChange)=\"onDateChange($event)\">\n</div>\n\n<ng-template [ngIf]=\"loadNativeDateInput\">\n    <wm-datetimepicker\n        dateTimePicker\n        mode=\"DATE\"\n        [config]=\"_dateOptions\"\n        [placement]=\"modal\"\n        [excludedDaysToDisable]=\"excludedDaysToDisable\"\n        [excludedDatesToDisable]=\"excludedDatesToDisable\"\n        [displayFormat]=\"dateInputFormat\"\n        [value]=\"bsDataValue\"\n        (change)=\"onDateChange($event)\">\n    </wm-datetimepicker>\n    <div class=\"mobile-input mobile-datepicker-container\"\n        [tabindex]=\"tabindex || 0\"\n         (click)=\"!(disabled || readonly || isCurrentDate) && showDatePickerModal(bsDataValue)\"\n        (focus)=\"onDateTimeInputFocus(true); invokeOnFocus($event);\"\n        (blur)=\"onDateTimeInputBlur(); invokeOnTouched($event)\"\n         [attr.aria-label]=\"displayValue ? 'Change Date ' + displayValue : hint || 'Choose Date'\"\n         role=\"button\">\n    </div>\n</ng-template>\n"]}
338
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date.component.js","sourceRoot":"","sources":["../../../../../../projects/components/widgets/input/epoch/src/date/date.component.ts","../../../../../../projects/components/widgets/input/epoch/src/date/date.component.html"],"names":[],"mappings":"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","sourcesContent":["import {ChangeDetectorRef, Component, ElementRef, Inject, Injector, Optional, ViewChild} from '@angular/core';\nimport { NG_VALUE_ACCESSOR, NG_VALIDATORS } from '@angular/forms';\n\nimport { BsDatepickerDirective } from 'ngx-bootstrap/datepicker';\n\n\nimport {\n    adjustContainerPosition,\n    addEventListenerOnElement,\n    AppDefaults,\n    EVENT_LIFE,\n    FormWidgetType,\n    getDateObj,\n    getDisplayDateTimeFormat,\n    getFormattedDate,\n    adjustContainerRightEdges,\n    getMomentLocaleObject,\n    App\n} from '@wm/core';\nimport { IWidgetConfig, provideAs, provideAsWidgetRef, setFocusTrap, styler } from '@wm/components/base';\nimport { BaseDateTimeComponent } from './../base-date-time.component';\nimport { registerProps } from './date.props';\nimport { validateTheMaskedDate } from './imaskUtil';\nimport { IMaskDirective } from 'angular-imask';\n\n\n\ndeclare const _, $, moment;\n\nconst CURRENT_DATE = 'CURRENT_DATE';\nconst DEFAULT_CLS = 'app-date input-group';\nconst WIDGET_CONFIG: IWidgetConfig = {\n    widgetType: 'wm-date',\n    hostClass: DEFAULT_CLS\n};\n\n@Component({\n    selector: '[wmDate]',\n    templateUrl: './date.component.html',\n    providers: [\n        provideAs(DateComponent, NG_VALUE_ACCESSOR, true),\n        provideAs(DateComponent, NG_VALIDATORS, true),\n        provideAsWidgetRef(DateComponent)\n    ]\n})\nexport class DateComponent extends BaseDateTimeComponent {\n    static initializeProps = registerProps();\n\n    public bsDataValue;\n    public showdropdownon: string;\n    private dateContainerCls: string;\n    public isOpen: boolean = false;\n    private isEnterPressedOnDateInput = false;\n    private _bsDefaultLoadCheck: boolean;\n    public hint: string;\n\n    private deregisterEventListener;\n    private isCurrentDate;\n    private focusTrap;\n\n    get timestamp() {\n        return this.bsDataValue ? this.bsDataValue.valueOf() : undefined;\n    }\n\n    get dateInputFormat() {\n        return this._dateOptions.dateInputFormat || 'yyyy-MM-dd';\n    }\n\n    get displayValue() {\n        return getFormattedDate(this.datePipe, this.bsDataValue, this.dateInputFormat, this.timeZone, null, this.isCurrentDate, this) || '';\n    }\n\n    get nativeDisplayValue() {\n        return getFormattedDate(this.datePipe, this.bsDataValue, 'yyyy-MM-dd', this.timeZone, null, this.isCurrentDate, this) || '';\n    }\n\n    // @ts-ignore\n    get datavalue() {\n        return getFormattedDate(this.datePipe, this.bsDataValue, this.outputformat, this.timeZone, null, this.isCurrentDate, this) || '';\n    }\n    get mask() {\n        if (this.datepattern) {\n           return validateTheMaskedDate(this.datepattern);\n        }\n        else {\n            return {};\n        }\n    }\n\n\n    // Todo[Shubham]: needs to be redefined\n    // sets the dataValue and computes the display model values\n    // @ts-ignore\n    set datavalue(newVal) {\n        if (newVal === CURRENT_DATE) {\n            setTimeout(() => {\n                this.bsDataValue = this.timeZone ? getMomentLocaleObject(this.timeZone) : new Date();\n            }, 50);\n            this.isCurrentDate = true;\n        } else {\n            this.bsDataValue = newVal ? getDateObj(newVal, {isNativePicker: this.loadNativeDateInput}, this.timeZone) : undefined;\n            this.isCurrentDate = false;\n        }\n        // update the previous datavalue.\n        this.invokeOnChange(this.datavalue, undefined, true);\n        this.cdRef.detectChanges();\n    }\n\n    @ViewChild(BsDatepickerDirective) protected bsDatePickerDirective;\n    @ViewChild('dateInput', {read: IMaskDirective}) imask: IMaskDirective<any>;\n\n    // TODO use BsLocaleService to set the current user's locale to see the localized labels\n    constructor(\n        inj: Injector,\n        private cdRef: ChangeDetectorRef,\n        private appDefaults: AppDefaults\n    ) {\n        super(inj, WIDGET_CONFIG);\n        styler(this.nativeElement, this);\n\n        this.dateContainerCls = `app-date-${this.widgetId}`;\n        this._dateOptions.containerClass = `app-date ${this.dateContainerCls}`;\n        this._dateOptions.showWeekNumbers = false;\n        this._bsDefaultLoadCheck = true;\n        this.datepattern = this.appDefaults.dateFormat || getDisplayDateTimeFormat(FormWidgetType.DATE);\n        this.updateFormat('datepattern');\n        if (this.imask) {\n            this.imask.maskRef.updateValue();\n        }\n    }\n    /**\n     * This is an internal method triggered when the date input changes\n     */\n    onDisplayDateChange($event, isNativePicker: boolean = false) {\n        if (this.imask) {\n            this.imask.maskRef.updateValue();\n        }\n        if (this.isEnterPressedOnDateInput) {\n            this.isEnterPressedOnDateInput = false;\n            return;\n        }\n        const newVal = getDateObj($event.target.value, {pattern: this.datepattern, isNativePicker: isNativePicker});\n        // date pattern validation\n        // if invalid pattern is entered, device is showing an error.\n        if (!this.formatValidation(newVal, $event.target.value, isNativePicker)) {\n            return;\n        }\n        // min date and max date validation in mobile view.\n        // if invalid dates are entered, device is showing an alert.\n        if (isNativePicker && this.minDateMaxDateValidationOnInput(newVal, $event, this.displayValue, isNativePicker)) {\n            return;\n        }\n        if (this.imask) {\n            this.imask.maskRef.value = newVal.toDateString();\n        }\n        this.setDataValue(newVal);\n    }\n\n    // sets the dataValue and computes the display model values\n    private setDataValue(newVal): void {\n        this.invalidDateTimeFormat = false;\n        // min date and max date validation in web.\n        // if invalid dates are entered, device is showing validation message.\n        this.minDateMaxDateValidationOnInput(newVal);\n        if (getFormattedDate(this.datePipe, newVal, this.dateInputFormat, this.timeZone, null, this.isCurrentDate, this) === this.displayValue) {\n            $(this.nativeElement).find('.display-input').val(this.displayValue);\n        }\n        if (newVal) {\n            this.bsDataValue = newVal;\n            this.imask.maskRef.value = newVal.toDateString();\n        } else {\n            this.bsDataValue = undefined;\n        }\n        this.invokeOnChange(this.datavalue, {}, true);\n    }\n\n    onDatePickerOpen() {\n        this.isOpen = true;\n        this.bsDataValue ? this.activeDate = this.bsDataValue : this.activeDate = new Date();\n        if (!this.bsDataValue) {\n            this.hightlightToday(this.activeDate);\n        }\n        if (this.imask) {\n            this.imask.maskRef.updateValue();\n        }\n\n        // We are using the two input tags(To maintain the modal and proxy modal) for the date control.\n        // So actual bootstrap input target width we made it to 0, so bootstrap calculating the calendar container top position improperly.\n        // To fix the container top position set the width 1px;\n        this.$element.find('.model-holder').width('1px');\n        const dpContainerEl = $('bs-datepicker-container');\n        dpContainerEl.attr('aria-label', 'Use Arrow keys to navigate dates, Choose Date from datepicker');\n        $('.bs-calendar-container').removeAttr('role');\n        const datePickerContainer = $('.bs-datepicker-container')[0];\n        this.focusTrap = setFocusTrap(datePickerContainer, true);\n        this.focusTrap.activate();\n        this.addDatepickerKeyboardEvents(this, false);\n        adjustContainerPosition($('bs-datepicker-container'), this.nativeElement, this.bsDatePickerDirective._datepicker);\n        adjustContainerRightEdges($('bs-datepicker-container'), this.nativeElement, this.bsDatePickerDirective._datepicker);\n    }\n    onInputBlur($event) {\n        if (this.imask) {\n            this.imask.maskRef.updateValue();\n        }\n        if (!$($event.relatedTarget).hasClass('current-date')) {\n            this.invokeOnTouched();\n            this.invokeEventCallback('blur', { $event });\n        }\n    }\n\n    onInputFocus($event) {\n        if (this.imask) {\n            this.imask.maskRef.value = $event.target.value;\n        }\n    }\n\n    public hideDatepickerDropdown() {\n        this.invokeOnTouched();\n        this.isOpen = false;\n        this.focusTrap?.deactivate();\n        this.isEnterPressedOnDateInput = false;\n        if (this.deregisterEventListener) {\n            this.deregisterEventListener();\n        }\n        this.blurDateInput(this.isOpen);\n    }\n\n    // change and blur events are added from the template\n    protected handleEvent(node: HTMLElement, eventName: string, callback: Function, locals: any) {\n        if (!_.includes(['blur', 'focus', 'change', 'click'], eventName)) {\n            super.handleEvent(node, eventName, callback, locals);\n        }\n    }\n\n    /**\n     * This is an internal method used to toggle the dropdown of the date widget\n     */\n     public toggleDpDropdown($event, skipFocus: boolean = false) {\n        if (this.loadNativeDateInput) {\n             // Fixes click event getting triggred twice in Mobile devices.\n            if (!skipFocus) {\n                this.onDateTimeInputFocus();\n            }\n        }\n        if ($event.type === 'click') {\n            this.invokeEventCallback('click', { $event: $event });\n          //  this.focusOnInputEl();\n        }\n        if ($event.target && $($event.target).is('input') && !(this.isDropDownDisplayEnabledOnInput(this.showdropdownon))) {\n            $event.stopPropagation();\n            return;\n        }\n        this.bsDatePickerDirective.toggle();\n        this.addBodyClickListener(this.bsDatePickerDirective.isOpen);\n    }\n\n    private addBodyClickListener(skipListener) {\n        if (!skipListener) {\n            return;\n        }\n        const bodyElement = document.querySelector('body');\n        setTimeout(() => {\n            const bsDateContainerElement = bodyElement.querySelector(`.${this.dateContainerCls}`);\n            this.deregisterEventListener = addEventListenerOnElement(bodyElement, bsDateContainerElement, this.nativeElement, 'click', this.isDropDownDisplayEnabledOnInput(this.showdropdownon), () => {\n                this.isOpen = false;\n            }, EVENT_LIFE.ONCE, true);\n        }, 350);\n    }\n\n    /**\n     * This is an internal method triggered when pressing key on the date input\n     */\n    public onDisplayKeydown(event) {\n        if (this.isDropDownDisplayEnabledOnInput(this.showdropdownon)) {\n            event.stopPropagation();\n            if (event.key === 'Enter') {\n                const newVal = getDateObj(event.target.value, {pattern: this.datepattern});\n                event.preventDefault();\n                const formattedDate = getFormattedDate(this.datePipe, newVal, this.dateInputFormat, this.timeZone, null, this.isCurrentDate, this);\n                const inputVal = event.target.value.trim();\n                if (inputVal && this.datepattern === 'timestamp') {\n                    if (!_.isNaN(inputVal) && _.parseInt(inputVal) !== formattedDate) {\n                        this.invalidDateTimeFormat = true;\n                        this.invokeOnChange(this.datavalue, event, false);\n                    }\n                } else if (inputVal && inputVal !== formattedDate) {\n                    this.invalidDateTimeFormat = true;\n                    this.invokeOnChange(this.datavalue, event, false);\n                } else {\n                    this.invalidDateTimeFormat = false;\n                    this.isEnterPressedOnDateInput = true;\n                    this.bsDatePickerDirective.bsValue =  event.target.value ? newVal : '';\n                    if (this.imask) {\n                        this.imask.maskRef.value = event.target.value;\n                    }\n                }\n                this.toggleDpDropdown(event);\n            } else {\n                this.hideDatepickerDropdown();\n            }\n        } else {\n            this.hideDatepickerDropdown();\n        }\n    }\n\n    /**\n     * This is an internal method triggered when the date selection changes\n     */\n    onDateChange(newVal): void {\n        /**\n         *  Ngx-bootstrap upgrade : To avoid the page load datechange event;\n         *  TODO:\n         *  https://github.com/valor-software/ngx-bootstrap/issues/6016\n         *  For above issue, once we get the solution from Ngx-Bootstrap team,  remove the _bsDefaultLoadCheck check and update accordingly.\n         * */\n        if (this._bsDefaultLoadCheck) {\n            this._bsDefaultLoadCheck = false;\n            return;\n        }\n\n        this.setDataValue(newVal);\n    }\n}\n","    <input class=\"form-control app-textbox app-dateinput display-input\"\n        focus-target\n        type=\"text\"\n           #dateInput\n        [name]=\"name\"\n       [imask]=\"mask\"\n       [unmask]=\"true\"\n        [tabindex]=\"loadNativeDateInput ? '-1' : tabindex\"\n        [attr.aria-hidden]=\"!!loadNativeDateInput\"\n        [value]=\"displayValue\"\n        (click)=\"toggleDpDropdown($event, true)\"\n        (focus)=\"onDateTimeInputFocus(); invokeOnFocus($event);onInputFocus($event)\"\n        (blur)=\"onInputBlur($event)\"\n        [disabled]=\"disabled || readonly\"\n        [autofocus]=\"autofocus\"\n        [required]=\"required\"\n        [readOnly]=\"isReadOnly\"\n        [attr.placeholder]=\"placeholder\"\n        [attr.accesskey]=\"shortcutkey\"\n        [attr.aria-label]=\"hint\"\n        (change)=\"onDisplayDateChange($event)\"\n        (keydown)=\"this._triggeredByUser = true; onDisplayKeydown($event);\">\n\n    <span class=\"input-group-btn\">\n        <button type=\"button\"\n            class=\"btn btn-default btn-time\"\n            [tabindex]=\"loadNativeDateInput ? '-1' : tabindex\"\n            [attr.aria-hidden]=\"!!loadNativeDateInput\"\n            [disabled]=\"disabled || readonly\"\n            [attr.aria-label]=\"displayValue ? 'Change Date ' + displayValue : 'Choose date by pressing enter'\"\n            aria-haspopup=\"true\"\n            aria-expanded=\"false\"\n            (click)=\"toggleDpDropdown($event, false)\">\n            <i aria-hidden=\"true\"\n                class=\"app-icon wm-sl-l sl-calendar\"></i>\n        </button>\n    </span>\n    <div style=\"width: 0;display: inline-block;\">\n    <input class=\"model-holder\"\n        aria-label=\"datepicker dropdownmenu\"\n        aria-controls=\"date\"\n        [tabindex]=\"-1\"\n        [attr.aria-hidden]=\"!!loadNativeDateInput\"\n        [container]=\"containerTarget || 'body'\"\n        [bsConfig]=\"_dateOptions\"\n        [isOpen]=\"isOpen\"\n        #datepicker=\"bsDatepicker\"\n        bsDatepicker\n        [daysDisabled]=\"excludedDaysToDisable\"\n        [datesDisabled]=\"excludedDatesToDisable\"\n        placement=\"bottom right\"\n        [isDisabled]=\"disabled || readonly\"\n        [bsValue]=\"bsDataValue\"\n        (onShown)=\"onDatePickerOpen()\"\n        (onHidden)=\"hideDatepickerDropdown()\"\n        (bsValueChange)=\"onDateChange($event)\">\n</div>\n\n<ng-template [ngIf]=\"loadNativeDateInput\">\n    <wm-datetimepicker\n        dateTimePicker\n        mode=\"DATE\"\n        [config]=\"_dateOptions\"\n        [placement]=\"modal\"\n        [excludedDaysToDisable]=\"excludedDaysToDisable\"\n        [excludedDatesToDisable]=\"excludedDatesToDisable\"\n        [displayFormat]=\"dateInputFormat\"\n        [value]=\"bsDataValue\"\n        (change)=\"onDateChange($event)\">\n    </wm-datetimepicker>\n    <div class=\"mobile-input mobile-datepicker-container\"\n        [tabindex]=\"tabindex || 0\"\n         (click)=\"!(disabled || readonly || isCurrentDate) && showDatePickerModal(bsDataValue)\"\n        (focus)=\"onDateTimeInputFocus(true); invokeOnFocus($event);\"\n        (blur)=\"onDateTimeInputBlur(); invokeOnTouched($event)\"\n         [attr.aria-label]=\"displayValue ? 'Change Date ' + displayValue : hint || 'Choose Date'\"\n         role=\"button\">\n    </div>\n</ng-template>\n"]}