@wavemaker/app-ng-runtime 11.7.1-next.26361 → 11.7.1-next.26362
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 +16 -34
- app-ng-runtime/components/input/epoch/date/date.component.d.ts +1 -12
- app-ng-runtime/components/input/epoch/date/imaskUtil.d.ts +2 -13
- app-ng-runtime/components/input/epoch/esm2022/date/date.component.mjs +7 -4
- app-ng-runtime/components/input/epoch/esm2022/date/imaskUtil.mjs +11 -32
- app-ng-runtime/components/input/epoch/fesm2022/index.mjs +16 -34
- app-ng-runtime/components/input/epoch/fesm2022/index.mjs.map +1 -1
- app-ng-runtime/package.json +1 -1
|
@@ -1682,36 +1682,16 @@
|
|
|
1682
1682
|
base.registerFormWidget(i1$1.FormWidgetType.DATE, new Map(dateProps));
|
|
1683
1683
|
};
|
|
1684
1684
|
|
|
1685
|
-
|
|
1686
|
-
'January',
|
|
1687
|
-
'February',
|
|
1688
|
-
'March',
|
|
1689
|
-
'April',
|
|
1690
|
-
'May',
|
|
1691
|
-
'June',
|
|
1692
|
-
'July',
|
|
1693
|
-
'August',
|
|
1694
|
-
'September',
|
|
1695
|
-
'October',
|
|
1696
|
-
'November',
|
|
1697
|
-
'December',
|
|
1698
|
-
];
|
|
1699
|
-
function validateTheMaskedDate(format) {
|
|
1685
|
+
function validateTheMaskedDate(format, locale) {
|
|
1700
1686
|
if (format == 'timestamp') {
|
|
1701
|
-
return
|
|
1687
|
+
return false;
|
|
1702
1688
|
}
|
|
1703
1689
|
const modifiedFormat = format.toUpperCase().replace(/E/g, 'd');
|
|
1704
|
-
const parseFn = str => {
|
|
1705
|
-
return moment(str, modifiedFormat).toDate();
|
|
1706
|
-
};
|
|
1707
|
-
const formatFn = date => {
|
|
1708
|
-
return moment(date, modifiedFormat).format(modifiedFormat);
|
|
1709
|
-
};
|
|
1710
1690
|
return {
|
|
1711
1691
|
mask: Date,
|
|
1712
1692
|
pattern: modifiedFormat,
|
|
1713
|
-
format:
|
|
1714
|
-
parse:
|
|
1693
|
+
format: (str) => moment(str, modifiedFormat).toDate(),
|
|
1694
|
+
parse: (str) => { return moment(str, modifiedFormat).toDate(); },
|
|
1715
1695
|
blocks: {
|
|
1716
1696
|
YYYY: {
|
|
1717
1697
|
mask: IMask.MaskedRange,
|
|
@@ -1726,7 +1706,6 @@
|
|
|
1726
1706
|
to: 999,
|
|
1727
1707
|
placeholderChar: 'Y',
|
|
1728
1708
|
maxLength: 3,
|
|
1729
|
-
overwrite: false,
|
|
1730
1709
|
},
|
|
1731
1710
|
YY: {
|
|
1732
1711
|
mask: IMask.MaskedRange,
|
|
@@ -1737,7 +1716,7 @@
|
|
|
1737
1716
|
},
|
|
1738
1717
|
Y: {
|
|
1739
1718
|
mask: IMask.MaskedRange,
|
|
1740
|
-
from:
|
|
1719
|
+
from: 1900,
|
|
1741
1720
|
to: 9999,
|
|
1742
1721
|
placeholderChar: 'Y',
|
|
1743
1722
|
maxLength: 4,
|
|
@@ -1758,13 +1737,13 @@
|
|
|
1758
1737
|
},
|
|
1759
1738
|
MMM: {
|
|
1760
1739
|
mask: IMask.MaskedEnum,
|
|
1761
|
-
enum: Array.from({ length: 12 }, (_, i) => new Date(0, i).toLocaleString(
|
|
1740
|
+
enum: Array.from({ length: 12 }, (_, i) => new Date(0, i).toLocaleString(locale, { month: 'short' })),
|
|
1762
1741
|
placeholderChar: 'M',
|
|
1763
1742
|
maxLength: 3,
|
|
1764
1743
|
},
|
|
1765
1744
|
MMMM: {
|
|
1766
1745
|
mask: IMask.MaskedEnum,
|
|
1767
|
-
enum:
|
|
1746
|
+
enum: Array.from({ length: 12 }, (_, i) => new Date(0, i).toLocaleString(locale, { month: 'long' })),
|
|
1768
1747
|
placeholderChar: "M",
|
|
1769
1748
|
maxLength: 4
|
|
1770
1749
|
},
|
|
@@ -1780,17 +1759,17 @@
|
|
|
1780
1759
|
from: 1,
|
|
1781
1760
|
to: 31,
|
|
1782
1761
|
placeholderChar: 'D',
|
|
1783
|
-
maxLength:
|
|
1762
|
+
maxLength: 2,
|
|
1784
1763
|
},
|
|
1785
1764
|
ddd: {
|
|
1786
1765
|
mask: IMask.MaskedEnum,
|
|
1787
|
-
enum: Array.from({ length: 7 }, (_, i) => new Date(0, 0, i + 1).toLocaleString(
|
|
1766
|
+
enum: Array.from({ length: 7 }, (_, i) => new Date(0, 0, i + 1).toLocaleString(locale, { weekday: 'short' })),
|
|
1788
1767
|
placeholderChar: 'E',
|
|
1789
1768
|
maxLength: 3,
|
|
1790
1769
|
},
|
|
1791
1770
|
dddd: {
|
|
1792
1771
|
mask: IMask.MaskedEnum,
|
|
1793
|
-
enum: Array.from({ length: 7 }, (_, i) => new Date(0, 0, i + 1).toLocaleString(
|
|
1772
|
+
enum: Array.from({ length: 7 }, (_, i) => new Date(0, 0, i + 1).toLocaleString(locale, { weekday: 'long' })),
|
|
1794
1773
|
placeholderChar: 'E',
|
|
1795
1774
|
minLength: 6,
|
|
1796
1775
|
},
|
|
@@ -1844,8 +1823,11 @@
|
|
|
1844
1823
|
return i1$1.getFormattedDate(this.datePipe, this.bsDataValue, this.outputformat, this.timeZone, null, this.isCurrentDate, this) || '';
|
|
1845
1824
|
}
|
|
1846
1825
|
get mask() {
|
|
1826
|
+
if (this.imask) {
|
|
1827
|
+
this.imask.destroyMask();
|
|
1828
|
+
}
|
|
1847
1829
|
if (this.datepattern) {
|
|
1848
|
-
return validateTheMaskedDate(this.datepattern);
|
|
1830
|
+
return validateTheMaskedDate(this.datepattern, this.selectedLocale);
|
|
1849
1831
|
}
|
|
1850
1832
|
else {
|
|
1851
1833
|
return false;
|
|
@@ -1965,7 +1947,7 @@
|
|
|
1965
1947
|
}
|
|
1966
1948
|
onInputFocus($event) {
|
|
1967
1949
|
if (this.imask) {
|
|
1968
|
-
this.imask.maskRef.
|
|
1950
|
+
this.imask.maskRef.updateValue();
|
|
1969
1951
|
}
|
|
1970
1952
|
}
|
|
1971
1953
|
hideDatepickerDropdown() {
|
|
@@ -2043,7 +2025,7 @@
|
|
|
2043
2025
|
this.isEnterPressedOnDateInput = true;
|
|
2044
2026
|
this.bsDatePickerDirective.bsValue = event.target.value ? newVal : '';
|
|
2045
2027
|
if (this.imask) {
|
|
2046
|
-
this.imask.maskRef.
|
|
2028
|
+
this.imask.maskRef.updateValue();
|
|
2047
2029
|
}
|
|
2048
2030
|
}
|
|
2049
2031
|
this.toggleDpDropdown(event);
|
|
@@ -23,19 +23,9 @@ export declare class DateComponent extends BaseDateTimeComponent {
|
|
|
23
23
|
get nativeDisplayValue(): any;
|
|
24
24
|
get datavalue(): any;
|
|
25
25
|
get mask(): false | {
|
|
26
|
-
mask?: undefined;
|
|
27
|
-
pattern?: undefined;
|
|
28
|
-
format?: undefined;
|
|
29
|
-
parse?: undefined;
|
|
30
|
-
blocks?: undefined;
|
|
31
|
-
autofix?: undefined;
|
|
32
|
-
lazy?: undefined;
|
|
33
|
-
overwrite?: undefined;
|
|
34
|
-
skipInvalid?: undefined;
|
|
35
|
-
} | {
|
|
36
26
|
mask: DateConstructor;
|
|
37
27
|
pattern: any;
|
|
38
|
-
format: (
|
|
28
|
+
format: (str: any) => any;
|
|
39
29
|
parse: (str: any) => any;
|
|
40
30
|
blocks: {
|
|
41
31
|
YYYY: {
|
|
@@ -51,7 +41,6 @@ export declare class DateComponent extends BaseDateTimeComponent {
|
|
|
51
41
|
to: number;
|
|
52
42
|
placeholderChar: string;
|
|
53
43
|
maxLength: number;
|
|
54
|
-
overwrite: boolean;
|
|
55
44
|
};
|
|
56
45
|
YY: {
|
|
57
46
|
mask: typeof import("imask/esm/index").MaskedRange;
|
|
@@ -1,17 +1,7 @@
|
|
|
1
|
-
export declare function validateTheMaskedDate(format: any): {
|
|
2
|
-
mask?: undefined;
|
|
3
|
-
pattern?: undefined;
|
|
4
|
-
format?: undefined;
|
|
5
|
-
parse?: undefined;
|
|
6
|
-
blocks?: undefined;
|
|
7
|
-
autofix?: undefined;
|
|
8
|
-
lazy?: undefined;
|
|
9
|
-
overwrite?: undefined;
|
|
10
|
-
skipInvalid?: undefined;
|
|
11
|
-
} | {
|
|
1
|
+
export declare function validateTheMaskedDate(format: any, locale: any): false | {
|
|
12
2
|
mask: DateConstructor;
|
|
13
3
|
pattern: any;
|
|
14
|
-
format: (
|
|
4
|
+
format: (str: any) => any;
|
|
15
5
|
parse: (str: any) => any;
|
|
16
6
|
blocks: {
|
|
17
7
|
YYYY: {
|
|
@@ -27,7 +17,6 @@ export declare function validateTheMaskedDate(format: any): {
|
|
|
27
17
|
to: number;
|
|
28
18
|
placeholderChar: string;
|
|
29
19
|
maxLength: number;
|
|
30
|
-
overwrite: boolean;
|
|
31
20
|
};
|
|
32
21
|
YY: {
|
|
33
22
|
mask: typeof import("imask").MaskedRange;
|
|
@@ -55,8 +55,11 @@ export class DateComponent extends BaseDateTimeComponent {
|
|
|
55
55
|
return getFormattedDate(this.datePipe, this.bsDataValue, this.outputformat, this.timeZone, null, this.isCurrentDate, this) || '';
|
|
56
56
|
}
|
|
57
57
|
get mask() {
|
|
58
|
+
if (this.imask) {
|
|
59
|
+
this.imask.destroyMask();
|
|
60
|
+
}
|
|
58
61
|
if (this.datepattern) {
|
|
59
|
-
return validateTheMaskedDate(this.datepattern);
|
|
62
|
+
return validateTheMaskedDate(this.datepattern, this.selectedLocale);
|
|
60
63
|
}
|
|
61
64
|
else {
|
|
62
65
|
return false;
|
|
@@ -176,7 +179,7 @@ export class DateComponent extends BaseDateTimeComponent {
|
|
|
176
179
|
}
|
|
177
180
|
onInputFocus($event) {
|
|
178
181
|
if (this.imask) {
|
|
179
|
-
this.imask.maskRef.
|
|
182
|
+
this.imask.maskRef.updateValue();
|
|
180
183
|
}
|
|
181
184
|
}
|
|
182
185
|
hideDatepickerDropdown() {
|
|
@@ -254,7 +257,7 @@ export class DateComponent extends BaseDateTimeComponent {
|
|
|
254
257
|
this.isEnterPressedOnDateInput = true;
|
|
255
258
|
this.bsDatePickerDirective.bsValue = event.target.value ? newVal : '';
|
|
256
259
|
if (this.imask) {
|
|
257
|
-
this.imask.maskRef.
|
|
260
|
+
this.imask.maskRef.updateValue();
|
|
258
261
|
}
|
|
259
262
|
}
|
|
260
263
|
this.toggleDpDropdown(event);
|
|
@@ -334,4 +337,4 @@ export class DateComponent extends BaseDateTimeComponent {
|
|
|
334
337
|
type: ViewChild,
|
|
335
338
|
args: ['dateInput', { read: IMaskDirective }]
|
|
336
339
|
}] }); })();
|
|
337
|
-
//# 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 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    @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        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            if (this.imask) {\n                this.imask.maskRef.updateValue();\n            }\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"]}
|
|
340
|
+
//# 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.imask) {\n            this.imask.destroyMask();\n        }\n        if (this.datepattern) {\n           return validateTheMaskedDate(this.datepattern, this.selectedLocale);\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    @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        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            if (this.imask) {\n                this.imask.maskRef.updateValue();\n            }\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.updateValue();\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.updateValue();\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"]}
|
|
@@ -1,34 +1,14 @@
|
|
|
1
1
|
import IMask from "imask";
|
|
2
|
-
|
|
3
|
-
'January',
|
|
4
|
-
'February',
|
|
5
|
-
'March',
|
|
6
|
-
'April',
|
|
7
|
-
'May',
|
|
8
|
-
'June',
|
|
9
|
-
'July',
|
|
10
|
-
'August',
|
|
11
|
-
'September',
|
|
12
|
-
'October',
|
|
13
|
-
'November',
|
|
14
|
-
'December',
|
|
15
|
-
];
|
|
16
|
-
export function validateTheMaskedDate(format) {
|
|
2
|
+
export function validateTheMaskedDate(format, locale) {
|
|
17
3
|
if (format == 'timestamp') {
|
|
18
|
-
return
|
|
4
|
+
return false;
|
|
19
5
|
}
|
|
20
6
|
const modifiedFormat = format.toUpperCase().replace(/E/g, 'd');
|
|
21
|
-
const parseFn = str => {
|
|
22
|
-
return moment(str, modifiedFormat).toDate();
|
|
23
|
-
};
|
|
24
|
-
const formatFn = date => {
|
|
25
|
-
return moment(date, modifiedFormat).format(modifiedFormat);
|
|
26
|
-
};
|
|
27
7
|
return {
|
|
28
8
|
mask: Date,
|
|
29
9
|
pattern: modifiedFormat,
|
|
30
|
-
format:
|
|
31
|
-
parse:
|
|
10
|
+
format: (str) => moment(str, modifiedFormat).toDate(),
|
|
11
|
+
parse: (str) => { return moment(str, modifiedFormat).toDate(); },
|
|
32
12
|
blocks: {
|
|
33
13
|
YYYY: {
|
|
34
14
|
mask: IMask.MaskedRange,
|
|
@@ -43,7 +23,6 @@ export function validateTheMaskedDate(format) {
|
|
|
43
23
|
to: 999,
|
|
44
24
|
placeholderChar: 'Y',
|
|
45
25
|
maxLength: 3,
|
|
46
|
-
overwrite: false,
|
|
47
26
|
},
|
|
48
27
|
YY: {
|
|
49
28
|
mask: IMask.MaskedRange,
|
|
@@ -54,7 +33,7 @@ export function validateTheMaskedDate(format) {
|
|
|
54
33
|
},
|
|
55
34
|
Y: {
|
|
56
35
|
mask: IMask.MaskedRange,
|
|
57
|
-
from:
|
|
36
|
+
from: 1900,
|
|
58
37
|
to: 9999,
|
|
59
38
|
placeholderChar: 'Y',
|
|
60
39
|
maxLength: 4,
|
|
@@ -75,13 +54,13 @@ export function validateTheMaskedDate(format) {
|
|
|
75
54
|
},
|
|
76
55
|
MMM: {
|
|
77
56
|
mask: IMask.MaskedEnum,
|
|
78
|
-
enum: Array.from({ length: 12 }, (_, i) => new Date(0, i).toLocaleString(
|
|
57
|
+
enum: Array.from({ length: 12 }, (_, i) => new Date(0, i).toLocaleString(locale, { month: 'short' })),
|
|
79
58
|
placeholderChar: 'M',
|
|
80
59
|
maxLength: 3,
|
|
81
60
|
},
|
|
82
61
|
MMMM: {
|
|
83
62
|
mask: IMask.MaskedEnum,
|
|
84
|
-
enum:
|
|
63
|
+
enum: Array.from({ length: 12 }, (_, i) => new Date(0, i).toLocaleString(locale, { month: 'long' })),
|
|
85
64
|
placeholderChar: "M",
|
|
86
65
|
maxLength: 4
|
|
87
66
|
},
|
|
@@ -97,17 +76,17 @@ export function validateTheMaskedDate(format) {
|
|
|
97
76
|
from: 1,
|
|
98
77
|
to: 31,
|
|
99
78
|
placeholderChar: 'D',
|
|
100
|
-
maxLength:
|
|
79
|
+
maxLength: 2,
|
|
101
80
|
},
|
|
102
81
|
ddd: {
|
|
103
82
|
mask: IMask.MaskedEnum,
|
|
104
|
-
enum: Array.from({ length: 7 }, (_, i) => new Date(0, 0, i + 1).toLocaleString(
|
|
83
|
+
enum: Array.from({ length: 7 }, (_, i) => new Date(0, 0, i + 1).toLocaleString(locale, { weekday: 'short' })),
|
|
105
84
|
placeholderChar: 'E',
|
|
106
85
|
maxLength: 3,
|
|
107
86
|
},
|
|
108
87
|
dddd: {
|
|
109
88
|
mask: IMask.MaskedEnum,
|
|
110
|
-
enum: Array.from({ length: 7 }, (_, i) => new Date(0, 0, i + 1).toLocaleString(
|
|
89
|
+
enum: Array.from({ length: 7 }, (_, i) => new Date(0, 0, i + 1).toLocaleString(locale, { weekday: 'long' })),
|
|
111
90
|
placeholderChar: 'E',
|
|
112
91
|
minLength: 6,
|
|
113
92
|
},
|
|
@@ -118,4 +97,4 @@ export function validateTheMaskedDate(format) {
|
|
|
118
97
|
skipInvalid: true
|
|
119
98
|
};
|
|
120
99
|
}
|
|
121
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
100
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"imaskUtil.js","sourceRoot":"","sources":["../../../../../../projects/components/widgets/input/epoch/src/date/imaskUtil.ts"],"names":[],"mappings":"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","sourcesContent":["import IMask from \"imask\";\ndeclare const moment;\n\nexport function validateTheMaskedDate (format, locale)  {\n    if(format == 'timestamp') {\n        return false;\n    }\n    const modifiedFormat = format.toUpperCase().replace(/E/g, 'd');\n    return {\n        mask: Date,\n        pattern: modifiedFormat,\n        format: (str) => moment(str, modifiedFormat).toDate(),\n        parse: (str) => {return moment(str, modifiedFormat).toDate();},\n\n        blocks: {\n            YYYY: {\n                mask: IMask.MaskedRange,\n                    from: 1900,\n                    to: 9999,\n                    placeholderChar:'Y',\n                maxLength: 4,\n            },\n            YYY: {\n                mask: IMask.MaskedRange,\n                from: 900,\n                to: 999,\n                placeholderChar:'Y',\n                maxLength: 3,\n            },\n            YY: {\n                mask: IMask.MaskedRange,\n                from: 0,\n                to: 99,\n                placeholderChar:'Y',\n                maxLength: 2,\n            },\n            Y: {\n                mask: IMask.MaskedRange,\n                from: 1900,\n                to: 9999,\n                placeholderChar:'Y',\n                maxLength: 4,\n            },\n            M: {\n                mask: IMask.MaskedRange,\n                from: 1,\n                to: 12,\n                placeholderChar:'M',\n                maxLength: 2,\n            },\n            MM: {\n                mask: IMask.MaskedRange,\n                from: 1,\n                to: 12,\n                placeholderChar:'M',\n                maxLength: 2,\n            },\n            MMM: {\n                mask: IMask.MaskedEnum,\n                enum: Array.from({ length: 12 }, (_, i) =>\n                    new Date(0, i).toLocaleString(locale, { month: 'short' })\n                ),\n                placeholderChar:'M',\n                maxLength: 3,\n            },\n            MMMM: {\n                mask: IMask.MaskedEnum,\n               enum: Array.from({ length: 12 }, (_, i) =>\n                    new Date(0, i).toLocaleString(locale, { month: 'long' })\n                ),\n                placeholderChar: \"M\",\n                maxLength: 4\n            },\n            DD: {\n                mask: IMask.MaskedRange,\n                from: 1,\n                to: 31,\n                placeholderChar:'D',\n                maxLength: 2,\n            },\n            D: {\n                mask: IMask.MaskedRange,\n                from: 1,\n                to: 31,\n                placeholderChar:'D',\n                maxLength: 2,\n            },\n            ddd: {\n                mask: IMask.MaskedEnum,\n                enum: Array.from({ length: 7 }, (_, i) =>\n                    new Date(0, 0, i + 1).toLocaleString(locale, { weekday: 'short' })\n                ),\n                placeholderChar:'E',\n                maxLength: 3,\n            },\n            dddd: {\n                mask: IMask.MaskedEnum,\n                enum: Array.from({ length: 7 }, (_, i) =>\n                    new Date(0, 0, i + 1).toLocaleString(locale, { weekday: 'long' })\n                ),\n                placeholderChar:'E',\n                minLength: 6,\n            },\n    },\n        autofix: true,\n        lazy: false,\n        overwrite: true,\n        skipInvalid: true\n\n    }\n}\n\n\n\n\n\n\n\n\n\n\n\n"]}
|
|
@@ -1670,36 +1670,16 @@ const registerProps$2 = () => {
|
|
|
1670
1670
|
registerFormWidget(FormWidgetType.DATE, new Map(dateProps));
|
|
1671
1671
|
};
|
|
1672
1672
|
|
|
1673
|
-
|
|
1674
|
-
'January',
|
|
1675
|
-
'February',
|
|
1676
|
-
'March',
|
|
1677
|
-
'April',
|
|
1678
|
-
'May',
|
|
1679
|
-
'June',
|
|
1680
|
-
'July',
|
|
1681
|
-
'August',
|
|
1682
|
-
'September',
|
|
1683
|
-
'October',
|
|
1684
|
-
'November',
|
|
1685
|
-
'December',
|
|
1686
|
-
];
|
|
1687
|
-
function validateTheMaskedDate(format) {
|
|
1673
|
+
function validateTheMaskedDate(format, locale) {
|
|
1688
1674
|
if (format == 'timestamp') {
|
|
1689
|
-
return
|
|
1675
|
+
return false;
|
|
1690
1676
|
}
|
|
1691
1677
|
const modifiedFormat = format.toUpperCase().replace(/E/g, 'd');
|
|
1692
|
-
const parseFn = str => {
|
|
1693
|
-
return moment(str, modifiedFormat).toDate();
|
|
1694
|
-
};
|
|
1695
|
-
const formatFn = date => {
|
|
1696
|
-
return moment(date, modifiedFormat).format(modifiedFormat);
|
|
1697
|
-
};
|
|
1698
1678
|
return {
|
|
1699
1679
|
mask: Date,
|
|
1700
1680
|
pattern: modifiedFormat,
|
|
1701
|
-
format:
|
|
1702
|
-
parse:
|
|
1681
|
+
format: (str) => moment(str, modifiedFormat).toDate(),
|
|
1682
|
+
parse: (str) => { return moment(str, modifiedFormat).toDate(); },
|
|
1703
1683
|
blocks: {
|
|
1704
1684
|
YYYY: {
|
|
1705
1685
|
mask: IMask.MaskedRange,
|
|
@@ -1714,7 +1694,6 @@ function validateTheMaskedDate(format) {
|
|
|
1714
1694
|
to: 999,
|
|
1715
1695
|
placeholderChar: 'Y',
|
|
1716
1696
|
maxLength: 3,
|
|
1717
|
-
overwrite: false,
|
|
1718
1697
|
},
|
|
1719
1698
|
YY: {
|
|
1720
1699
|
mask: IMask.MaskedRange,
|
|
@@ -1725,7 +1704,7 @@ function validateTheMaskedDate(format) {
|
|
|
1725
1704
|
},
|
|
1726
1705
|
Y: {
|
|
1727
1706
|
mask: IMask.MaskedRange,
|
|
1728
|
-
from:
|
|
1707
|
+
from: 1900,
|
|
1729
1708
|
to: 9999,
|
|
1730
1709
|
placeholderChar: 'Y',
|
|
1731
1710
|
maxLength: 4,
|
|
@@ -1746,13 +1725,13 @@ function validateTheMaskedDate(format) {
|
|
|
1746
1725
|
},
|
|
1747
1726
|
MMM: {
|
|
1748
1727
|
mask: IMask.MaskedEnum,
|
|
1749
|
-
enum: Array.from({ length: 12 }, (_, i) => new Date(0, i).toLocaleString(
|
|
1728
|
+
enum: Array.from({ length: 12 }, (_, i) => new Date(0, i).toLocaleString(locale, { month: 'short' })),
|
|
1750
1729
|
placeholderChar: 'M',
|
|
1751
1730
|
maxLength: 3,
|
|
1752
1731
|
},
|
|
1753
1732
|
MMMM: {
|
|
1754
1733
|
mask: IMask.MaskedEnum,
|
|
1755
|
-
enum:
|
|
1734
|
+
enum: Array.from({ length: 12 }, (_, i) => new Date(0, i).toLocaleString(locale, { month: 'long' })),
|
|
1756
1735
|
placeholderChar: "M",
|
|
1757
1736
|
maxLength: 4
|
|
1758
1737
|
},
|
|
@@ -1768,17 +1747,17 @@ function validateTheMaskedDate(format) {
|
|
|
1768
1747
|
from: 1,
|
|
1769
1748
|
to: 31,
|
|
1770
1749
|
placeholderChar: 'D',
|
|
1771
|
-
maxLength:
|
|
1750
|
+
maxLength: 2,
|
|
1772
1751
|
},
|
|
1773
1752
|
ddd: {
|
|
1774
1753
|
mask: IMask.MaskedEnum,
|
|
1775
|
-
enum: Array.from({ length: 7 }, (_, i) => new Date(0, 0, i + 1).toLocaleString(
|
|
1754
|
+
enum: Array.from({ length: 7 }, (_, i) => new Date(0, 0, i + 1).toLocaleString(locale, { weekday: 'short' })),
|
|
1776
1755
|
placeholderChar: 'E',
|
|
1777
1756
|
maxLength: 3,
|
|
1778
1757
|
},
|
|
1779
1758
|
dddd: {
|
|
1780
1759
|
mask: IMask.MaskedEnum,
|
|
1781
|
-
enum: Array.from({ length: 7 }, (_, i) => new Date(0, 0, i + 1).toLocaleString(
|
|
1760
|
+
enum: Array.from({ length: 7 }, (_, i) => new Date(0, 0, i + 1).toLocaleString(locale, { weekday: 'long' })),
|
|
1782
1761
|
placeholderChar: 'E',
|
|
1783
1762
|
minLength: 6,
|
|
1784
1763
|
},
|
|
@@ -1832,8 +1811,11 @@ class DateComponent extends BaseDateTimeComponent {
|
|
|
1832
1811
|
return getFormattedDate(this.datePipe, this.bsDataValue, this.outputformat, this.timeZone, null, this.isCurrentDate, this) || '';
|
|
1833
1812
|
}
|
|
1834
1813
|
get mask() {
|
|
1814
|
+
if (this.imask) {
|
|
1815
|
+
this.imask.destroyMask();
|
|
1816
|
+
}
|
|
1835
1817
|
if (this.datepattern) {
|
|
1836
|
-
return validateTheMaskedDate(this.datepattern);
|
|
1818
|
+
return validateTheMaskedDate(this.datepattern, this.selectedLocale);
|
|
1837
1819
|
}
|
|
1838
1820
|
else {
|
|
1839
1821
|
return false;
|
|
@@ -1953,7 +1935,7 @@ class DateComponent extends BaseDateTimeComponent {
|
|
|
1953
1935
|
}
|
|
1954
1936
|
onInputFocus($event) {
|
|
1955
1937
|
if (this.imask) {
|
|
1956
|
-
this.imask.maskRef.
|
|
1938
|
+
this.imask.maskRef.updateValue();
|
|
1957
1939
|
}
|
|
1958
1940
|
}
|
|
1959
1941
|
hideDatepickerDropdown() {
|
|
@@ -2031,7 +2013,7 @@ class DateComponent extends BaseDateTimeComponent {
|
|
|
2031
2013
|
this.isEnterPressedOnDateInput = true;
|
|
2032
2014
|
this.bsDatePickerDirective.bsValue = event.target.value ? newVal : '';
|
|
2033
2015
|
if (this.imask) {
|
|
2034
|
-
this.imask.maskRef.
|
|
2016
|
+
this.imask.maskRef.updateValue();
|
|
2035
2017
|
}
|
|
2036
2018
|
}
|
|
2037
2019
|
this.toggleDpDropdown(event);
|