@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.
- app-ng-runtime/components/input/epoch/bundles/index.umd.js +35 -5
- app-ng-runtime/components/input/epoch/date/date.component.d.ts +4 -1
- app-ng-runtime/components/input/epoch/esm2022/date/date.component.mjs +37 -6
- app-ng-runtime/components/input/epoch/fesm2022/index.mjs +36 -6
- app-ng-runtime/components/input/epoch/fesm2022/index.mjs.map +1 -1
- app-ng-runtime/package.json +1 -1
|
@@ -1802,7 +1802,8 @@
|
|
|
1802
1802
|
};
|
|
1803
1803
|
}
|
|
1804
1804
|
|
|
1805
|
-
const _c0$2 = ["
|
|
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
|
|
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:
|
|
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.
|
|
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)
|
|
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():
|
|
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 = ["
|
|
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
|
|
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:
|
|
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.
|
|
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)
|
|
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":"AAAA,OAAO,EAAC,iBAAiB,EAAE,SAAS,EAAsB,QAAQ,EAAY,SAAS,EAAC,MAAM,eAAe,CAAC;AAC9G,OAAO,EAAE,iBAAiB,EAAE,aAAa,EAAE,MAAM,gBAAgB,CAAC;AAElE,OAAO,EAAE,qBAAqB,EAAE,MAAM,0BAA0B,CAAC;AAGjE,OAAO,EACH,uBAAuB,EACvB,yBAAyB,EACzB,WAAW,EAEX,cAAc,EACd,UAAU,EACV,wBAAwB,EACxB,gBAAgB,EAChB,yBAAyB,EACzB,qBAAqB,EAExB,MAAM,UAAU,CAAC;AAClB,OAAO,EAAiB,SAAS,EAAE,kBAAkB,EAAE,YAAY,EAAE,MAAM,EAAE,MAAM,qBAAqB,CAAC;AACzG,OAAO,EAAE,qBAAqB,EAAE,MAAM,+BAA+B,CAAC;AACtE,OAAO,EAAE,aAAa,EAAE,MAAM,cAAc,CAAC;AAC7C,OAAO,EAAE,qBAAqB,EAAE,MAAM,aAAa,CAAC;AACpD,OAAO,EAAE,cAAc,EAAE,MAAM,eAAe,CAAC;;;;;;;;;;;ICoC3C,4CASoC;IAAhC,qLAAU,eAAA,2BAAoB,CAAA,IAAC;IACnC,iBAAoB;IACpB,+BAMmB;IAJd,+JAAS,gFAA4C,8CAAgC,CAAA,IAAC,iJAC9E,4BAAqB,IAAI,CAAC,SAAE,eAAA,4BAAqB,CAAA,IAD6B,+IAE/E,4BAAqB,SAAE,eAAA,8BAAuB,CAAA,IAFiC;IAK3F,iBAAM;;;IAfF,4CAAuB,2BAAA,uDAAA,yDAAA,yCAAA,6BAAA;IASvB,eAA0B;IAA1B,+CAA0B;IAIzB,uHAAwF;;AD9CjG,MAAM,YAAY,GAAG,cAAc,CAAC;AACpC,MAAM,WAAW,GAAG,sBAAsB,CAAC;AAC3C,MAAM,aAAa,GAAkB;IACjC,UAAU,EAAE,SAAS;IACrB,SAAS,EAAE,WAAW;CACzB,CAAC;AAWF,MAAM,OAAO,aAAc,SAAQ,qBAAqB;aAC7C,oBAAe,GAAG,aAAa,EAAE,CAAC;IAczC,IAAI,SAAS;QACT,OAAO,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC,SAAS,CAAC;IACrE,CAAC;IAED,IAAI,eAAe;QACf,OAAO,IAAI,CAAC,YAAY,CAAC,eAAe,IAAI,YAAY,CAAC;IAC7D,CAAC;IAED,IAAI,YAAY;QACZ,OAAO,gBAAgB,CAAC,IAAI,CAAC,QAAQ,EAAE,IAAI,CAAC,WAAW,EAAE,IAAI,CAAC,eAAe,EAAE,IAAI,CAAC,QAAQ,EAAE,IAAI,EAAE,IAAI,CAAC,aAAa,EAAE,IAAI,CAAC,IAAI,EAAE,CAAC;IACxI,CAAC;IAED,IAAI,kBAAkB;QAClB,OAAO,gBAAgB,CAAC,IAAI,CAAC,QAAQ,EAAE,IAAI,CAAC,WAAW,EAAE,YAAY,EAAE,IAAI,CAAC,QAAQ,EAAE,IAAI,EAAE,IAAI,CAAC,aAAa,EAAE,IAAI,CAAC,IAAI,EAAE,CAAC;IAChI,CAAC;IAED,aAAa;IACb,IAAI,SAAS;QACT,OAAO,gBAAgB,CAAC,IAAI,CAAC,QAAQ,EAAE,IAAI,CAAC,WAAW,EAAE,IAAI,CAAC,YAAY,EAAE,IAAI,CAAC,QAAQ,EAAE,IAAI,EAAE,IAAI,CAAC,aAAa,EAAE,IAAI,CAAC,IAAI,EAAE,CAAC;IACrI,CAAC;IACD,IAAI,IAAI;QACJ,IAAI,IAAI,CAAC,WAAW,EAAE;YACnB,OAAO,qBAAqB,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;SACjD;aACI;YACD,OAAO,EAAE,CAAC;SACb;IACL,CAAC;IAGD,uCAAuC;IACvC,2DAA2D;IAC3D,aAAa;IACb,IAAI,SAAS,CAAC,MAAM;QAChB,IAAI,MAAM,KAAK,YAAY,EAAE;YACzB,UAAU,CAAC,GAAG,EAAE;gBACZ,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,qBAAqB,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,IAAI,IAAI,EAAE,CAAC;YACzF,CAAC,EAAE,EAAE,CAAC,CAAC;YACP,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC;SAC7B;aAAM;YACH,IAAI,CAAC,WAAW,GAAG,MAAM,CAAC,CAAC,CAAC,UAAU,CAAC,MAAM,EAAE,EAAC,cAAc,EAAE,IAAI,CAAC,mBAAmB,EAAC,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC;YACtH,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC;SAC9B;QACD,iCAAiC;QACjC,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,SAAS,EAAE,SAAS,EAAE,IAAI,CAAC,CAAC;QACrD,IAAI,CAAC,KAAK,CAAC,aAAa,EAAE,CAAC;IAC/B,CAAC;IAKD,wFAAwF;IACxF,YACI,GAAa,EACL,KAAwB,EACxB,WAAwB;QAEhC,KAAK,CAAC,GAAG,EAAE,aAAa,CAAC,CAAC;QAHlB,UAAK,GAAL,KAAK,CAAmB;QACxB,gBAAW,GAAX,WAAW,CAAa;QAhE7B,WAAM,GAAY,KAAK,CAAC;QACvB,8BAAyB,GAAG,KAAK,CAAC;QAkEtC,MAAM,CAAC,IAAI,CAAC,aAAa,EAAE,IAAI,CAAC,CAAC;QAEjC,IAAI,CAAC,gBAAgB,GAAG,YAAY,IAAI,CAAC,QAAQ,EAAE,CAAC;QACpD,IAAI,CAAC,YAAY,CAAC,cAAc,GAAG,YAAY,IAAI,CAAC,gBAAgB,EAAE,CAAC;QACvE,IAAI,CAAC,YAAY,CAAC,eAAe,GAAG,KAAK,CAAC;QAC1C,IAAI,CAAC,mBAAmB,GAAG,IAAI,CAAC;QAChC,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,WAAW,CAAC,UAAU,IAAI,wBAAwB,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC;QAChG,IAAI,CAAC,YAAY,CAAC,aAAa,CAAC,CAAC;QACjC,IAAI,IAAI,CAAC,KAAK,EAAE;YACZ,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,WAAW,EAAE,CAAC;SACpC;IACL,CAAC;IACD;;OAEG;IACH,mBAAmB,CAAC,MAAM,EAAE,iBAA0B,KAAK;QACvD,IAAI,IAAI,CAAC,KAAK,EAAE;YACZ,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,WAAW,EAAE,CAAC;SACpC;QACD,IAAI,IAAI,CAAC,yBAAyB,EAAE;YAChC,IAAI,CAAC,yBAAyB,GAAG,KAAK,CAAC;YACvC,OAAO;SACV;QACD,MAAM,MAAM,GAAG,UAAU,CAAC,MAAM,CAAC,MAAM,CAAC,KAAK,EAAE,EAAC,OAAO,EAAE,IAAI,CAAC,WAAW,EAAE,cAAc,EAAE,cAAc,EAAC,CAAC,CAAC;QAC5G,0BAA0B;QAC1B,6DAA6D;QAC7D,IAAI,CAAC,IAAI,CAAC,gBAAgB,CAAC,MAAM,EAAE,MAAM,CAAC,MAAM,CAAC,KAAK,EAAE,cAAc,CAAC,EAAE;YACrE,OAAO;SACV;QACD,mDAAmD;QACnD,4DAA4D;QAC5D,IAAI,cAAc,IAAI,IAAI,CAAC,+BAA+B,CAAC,MAAM,EAAE,MAAM,EAAE,IAAI,CAAC,YAAY,EAAE,cAAc,CAAC,EAAE;YAC3G,OAAO;SACV;QACD,IAAI,IAAI,CAAC,KAAK,EAAE;YACZ,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,KAAK,GAAG,MAAM,CAAC,YAAY,EAAE,CAAC;SACpD;QACD,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC;IAC9B,CAAC;IAED,2DAA2D;IACnD,YAAY,CAAC,MAAM;QACvB,IAAI,CAAC,qBAAqB,GAAG,KAAK,CAAC;QACnC,2CAA2C;QAC3C,sEAAsE;QACtE,IAAI,CAAC,+BAA+B,CAAC,MAAM,CAAC,CAAC;QAC7C,IAAI,gBAAgB,CAAC,IAAI,CAAC,QAAQ,EAAE,MAAM,EAAE,IAAI,CAAC,eAAe,EAAE,IAAI,CAAC,QAAQ,EAAE,IAAI,EAAE,IAAI,CAAC,aAAa,EAAE,IAAI,CAAC,KAAK,IAAI,CAAC,YAAY,EAAE;YACpI,CAAC,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;SACvE;QACD,IAAI,MAAM,EAAE;YACR,IAAI,CAAC,WAAW,GAAG,MAAM,CAAC;YAC1B,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,KAAK,GAAG,MAAM,CAAC,YAAY,EAAE,CAAC;SACpD;aAAM;YACH,IAAI,CAAC,WAAW,GAAG,SAAS,CAAC;SAChC;QACD,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,SAAS,EAAE,EAAE,EAAE,IAAI,CAAC,CAAC;IAClD,CAAC;IAED,gBAAgB;QACZ,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC;QACnB,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,IAAI,CAAC,UAAU,GAAG,IAAI,IAAI,EAAE,CAAC;QACrF,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE;YACnB,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;SACzC;QACD,IAAI,IAAI,CAAC,KAAK,EAAE;YACZ,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,WAAW,EAAE,CAAC;SACpC;QAED,+FAA+F;QAC/F,mIAAmI;QACnI,uDAAuD;QACvD,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;QACjD,MAAM,aAAa,GAAG,CAAC,CAAC,yBAAyB,CAAC,CAAC;QACnD,aAAa,CAAC,IAAI,CAAC,YAAY,EAAE,+DAA+D,CAAC,CAAC;QAClG,CAAC,CAAC,wBAAwB,CAAC,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC;QAC/C,MAAM,mBAAmB,GAAG,CAAC,CAAC,0BAA0B,CAAC,CAAC,CAAC,CAAC,CAAC;QAC7D,IAAI,CAAC,SAAS,GAAG,YAAY,CAAC,mBAAmB,EAAE,IAAI,CAAC,CAAC;QACzD,IAAI,CAAC,SAAS,CAAC,QAAQ,EAAE,CAAC;QAC1B,IAAI,CAAC,2BAA2B,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC;QAC9C,uBAAuB,CAAC,CAAC,CAAC,yBAAyB,CAAC,EAAE,IAAI,CAAC,aAAa,EAAE,IAAI,CAAC,qBAAqB,CAAC,WAAW,CAAC,CAAC;QAClH,yBAAyB,CAAC,CAAC,CAAC,yBAAyB,CAAC,EAAE,IAAI,CAAC,aAAa,EAAE,IAAI,CAAC,qBAAqB,CAAC,WAAW,CAAC,CAAC;IACxH,CAAC;IACD,WAAW,CAAC,MAAM;QACd,IAAI,IAAI,CAAC,KAAK,EAAE;YACZ,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,WAAW,EAAE,CAAC;SACpC;QACD,IAAI,CAAC,CAAC,CAAC,MAAM,CAAC,aAAa,CAAC,CAAC,QAAQ,CAAC,cAAc,CAAC,EAAE;YACnD,IAAI,CAAC,eAAe,EAAE,CAAC;YACvB,IAAI,CAAC,mBAAmB,CAAC,MAAM,EAAE,EAAE,MAAM,EAAE,CAAC,CAAC;SAChD;IACL,CAAC;IAED,YAAY,CAAC,MAAM;QACf,IAAI,IAAI,CAAC,KAAK,EAAE;YACZ,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,KAAK,GAAG,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC;SAClD;IACL,CAAC;IAEM,sBAAsB;QACzB,IAAI,CAAC,eAAe,EAAE,CAAC;QACvB,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;QACpB,IAAI,CAAC,SAAS,EAAE,UAAU,EAAE,CAAC;QAC7B,IAAI,CAAC,yBAAyB,GAAG,KAAK,CAAC;QACvC,IAAI,IAAI,CAAC,uBAAuB,EAAE;YAC9B,IAAI,CAAC,uBAAuB,EAAE,CAAC;SAClC;QACD,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IACpC,CAAC;IAED,qDAAqD;IAC3C,WAAW,CAAC,IAAiB,EAAE,SAAiB,EAAE,QAAkB,EAAE,MAAW;QACvF,IAAI,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,MAAM,EAAE,OAAO,EAAE,QAAQ,EAAE,OAAO,CAAC,EAAE,SAAS,CAAC,EAAE;YAC9D,KAAK,CAAC,WAAW,CAAC,IAAI,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,CAAC,CAAC;SACxD;IACL,CAAC;IAED;;OAEG;IACK,gBAAgB,CAAC,MAAM,EAAE,YAAqB,KAAK;QACvD,IAAI,IAAI,CAAC,mBAAmB,EAAE;YACzB,8DAA8D;YAC/D,IAAI,CAAC,SAAS,EAAE;gBACZ,IAAI,CAAC,oBAAoB,EAAE,CAAC;aAC/B;SACJ;QACD,IAAI,MAAM,CAAC,IAAI,KAAK,OAAO,EAAE;YACzB,IAAI,CAAC,mBAAmB,CAAC,OAAO,EAAE,EAAE,MAAM,EAAE,MAAM,EAAE,CAAC,CAAC;YACxD,0BAA0B;SAC3B;QACD,IAAI,MAAM,CAAC,MAAM,IAAI,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,+BAA+B,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC,EAAE;YAC/G,MAAM,CAAC,eAAe,EAAE,CAAC;YACzB,OAAO;SACV;QACD,IAAI,CAAC,qBAAqB,CAAC,MAAM,EAAE,CAAC;QACpC,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC,qBAAqB,CAAC,MAAM,CAAC,CAAC;IACjE,CAAC;IAEO,oBAAoB,CAAC,YAAY;QACrC,IAAI,CAAC,YAAY,EAAE;YACf,OAAO;SACV;QACD,MAAM,WAAW,GAAG,QAAQ,CAAC,aAAa,CAAC,MAAM,CAAC,CAAC;QACnD,UAAU,CAAC,GAAG,EAAE;YACZ,MAAM,sBAAsB,GAAG,WAAW,CAAC,aAAa,CAAC,IAAI,IAAI,CAAC,gBAAgB,EAAE,CAAC,CAAC;YACtF,IAAI,CAAC,uBAAuB,GAAG,yBAAyB,CAAC,WAAW,EAAE,sBAAsB,EAAE,IAAI,CAAC,aAAa,EAAE,OAAO,EAAE,IAAI,CAAC,+BAA+B,CAAC,IAAI,CAAC,cAAc,CAAC,EAAE,GAAG,EAAE;gBACvL,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;YACxB,CAAC,2BAAmB,IAAI,CAAC,CAAC;QAC9B,CAAC,EAAE,GAAG,CAAC,CAAC;IACZ,CAAC;IAED;;OAEG;IACI,gBAAgB,CAAC,KAAK;QACzB,IAAI,IAAI,CAAC,+BAA+B,CAAC,IAAI,CAAC,cAAc,CAAC,EAAE;YAC3D,KAAK,CAAC,eAAe,EAAE,CAAC;YACxB,IAAI,KAAK,CAAC,GAAG,KAAK,OAAO,EAAE;gBACvB,MAAM,MAAM,GAAG,UAAU,CAAC,KAAK,CAAC,MAAM,CAAC,KAAK,EAAE,EAAC,OAAO,EAAE,IAAI,CAAC,WAAW,EAAC,CAAC,CAAC;gBAC3E,KAAK,CAAC,cAAc,EAAE,CAAC;gBACvB,MAAM,aAAa,GAAG,gBAAgB,CAAC,IAAI,CAAC,QAAQ,EAAE,MAAM,EAAE,IAAI,CAAC,eAAe,EAAE,IAAI,CAAC,QAAQ,EAAE,IAAI,EAAE,IAAI,CAAC,aAAa,EAAE,IAAI,CAAC,CAAC;gBACnI,MAAM,QAAQ,GAAG,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC,IAAI,EAAE,CAAC;gBAC3C,IAAI,QAAQ,IAAI,IAAI,CAAC,WAAW,KAAK,WAAW,EAAE;oBAC9C,IAAI,CAAC,CAAC,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,QAAQ,CAAC,QAAQ,CAAC,KAAK,aAAa,EAAE;wBAC9D,IAAI,CAAC,qBAAqB,GAAG,IAAI,CAAC;wBAClC,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,SAAS,EAAE,KAAK,EAAE,KAAK,CAAC,CAAC;qBACrD;iBACJ;qBAAM,IAAI,QAAQ,IAAI,QAAQ,KAAK,aAAa,EAAE;oBAC/C,IAAI,CAAC,qBAAqB,GAAG,IAAI,CAAC;oBAClC,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,SAAS,EAAE,KAAK,EAAE,KAAK,CAAC,CAAC;iBACrD;qBAAM;oBACH,IAAI,CAAC,qBAAqB,GAAG,KAAK,CAAC;oBACnC,IAAI,CAAC,yBAAyB,GAAG,IAAI,CAAC;oBACtC,IAAI,CAAC,qBAAqB,CAAC,OAAO,GAAI,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC;oBACvE,IAAI,IAAI,CAAC,KAAK,EAAE;wBACZ,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,KAAK,GAAG,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC;qBACjD;iBACJ;gBACD,IAAI,CAAC,gBAAgB,CAAC,KAAK,CAAC,CAAC;aAChC;iBAAM;gBACH,IAAI,CAAC,sBAAsB,EAAE,CAAC;aACjC;SACJ;aAAM;YACH,IAAI,CAAC,sBAAsB,EAAE,CAAC;SACjC;IACL,CAAC;IAED;;OAEG;IACH,YAAY,CAAC,MAAM;QACf;;;;;aAKK;QACL,IAAI,IAAI,CAAC,mBAAmB,EAAE;YAC1B,IAAI,CAAC,mBAAmB,GAAG,KAAK,CAAC;YACjC,OAAO;SACV;QAED,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC;IAC9B,CAAC;8EApRQ,aAAa;oEAAb,aAAa;2BA+DX,qBAAqB;mCACD,cAAc;;;;;8CAtElC;gBACP,SAAS,CAAC,aAAa,EAAE,iBAAiB,EAAE,IAAI,CAAC;gBACjD,SAAS,CAAC,aAAa,EAAE,aAAa,EAAE,IAAI,CAAC;gBAC7C,kBAAkB,CAAC,aAAa,CAAC;aACpC;YC3CD,mCAqBwE;YAXpE,+FAAS,6BAAyB,IAAI,CAAC,IAAC,2EAC/B,0BAAsB,EAAE,yBAAqB,SAAC,wBAAoB,IADnC,gFAEhC,uBAAmB,IAFa,oFAU9B,+BAA2B,IAVG,sGAWL,IAAI,SAAE,4BAAwB,IAXzB;YAV5C,iBAqBwE;YAExE,+BAA8B,gBAAA;YAStB,gGAAS,6BAAyB,KAAK,CAAC,IAAC;YACzC,uBAC6C;YACjD,iBAAS,EAAA;YAEb,8BAA6C,kBAAA;YAgBzC,6FAAW,sBAAkB,IAAC,kFAClB,4BAAwB,IADN,kGAEb,wBAAoB,IAFP;YAflC,iBAiB2C,EAAA;YAG/C,8EAoBc;;YA1EN,+BAAa,mBAAA,gBAAA,2DAAA,2BAAA,0CAAA,4BAAA,0BAAA,4BAAA;YAIb,wDAA0C,gCAAA,8BAAA,wBAAA;YAkBtC,eAAkD;YAAlD,wEAAkD,0CAAA;YAClD,wDAA0C,sGAAA;YAc9C,eAAe;YAAf,6BAAe,4CAAA,8BAAA,sBAAA,2CAAA,6CAAA,4CAAA,4BAAA;YACf,wDAA0C;YAgBrC,eAA4B;YAA5B,8CAA4B;;;uFDb5B,aAAa;cATzB,SAAS;2BACI,UAAU,aAET;oBACP,SAAS,gBAAgB,iBAAiB,EAAE,IAAI,CAAC;oBACjD,SAAS,gBAAgB,aAAa,EAAE,IAAI,CAAC;oBAC7C,kBAAkB,eAAe;iBACpC;qHAiE2C,qBAAqB;kBAAhE,SAAS;mBAAC,qBAAqB;YACgB,KAAK;kBAApD,SAAS;mBAAC,WAAW,EAAE,EAAC,IAAI,EAAE,cAAc,EAAC","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"]}
|