myrta-ui 17.1.47 → 17.1.48
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.
- package/esm2022/lib/components/form/input-date/components/date-calendar/date-calendar.component.mjs +222 -0
- package/esm2022/lib/components/form/input-date/helpers/date-helpers.mjs +70 -0
- package/esm2022/lib/components/form/input-date/input-date.component.mjs +293 -0
- package/esm2022/lib/components/form/input-date/input-date.enum.mjs +7 -0
- package/esm2022/lib/components/form/input-date/input-date.module.mjs +51 -0
- package/esm2022/lib/components/form/input-date-time/input-date-time.component.mjs +3 -3
- package/esm2022/lib/components/form/input-date-time/input-date-time.enum.mjs +7 -7
- package/esm2022/lib/components/form/input-tel/data/all-countries.mjs +2 -2
- package/esm2022/lib/components/form/input-timepicker/input-timepicker.component.mjs +3 -3
- package/esm2022/lib/services/toaster-service/config/index.mjs +3 -2
- package/esm2022/lib/services/toaster-service/toaster-service.service.mjs +1 -1
- package/esm2022/public-api.mjs +3 -1
- package/fesm2022/myrta-ui.mjs +625 -9
- package/fesm2022/myrta-ui.mjs.map +1 -1
- package/lib/components/form/input-date/components/date-calendar/date-calendar.component.d.ts +63 -0
- package/lib/components/form/input-date/helpers/date-helpers.d.ts +14 -0
- package/lib/components/form/input-date/input-date.component.d.ts +65 -0
- package/lib/components/form/input-date/input-date.enum.d.ts +11 -0
- package/lib/components/form/input-date/input-date.module.d.ts +14 -0
- package/lib/components/form/input-date-time/input-date-time.component.d.ts +2 -2
- package/lib/components/form/input-date-time/input-date-time.enum.d.ts +2 -2
- package/lib/services/toaster-service/config/index.d.ts +1 -1
- package/package.json +1 -1
- package/public-api.d.ts +2 -0
|
@@ -0,0 +1,293 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component, EventEmitter, forwardRef, Input, Output, ViewChild } from '@angular/core';
|
|
2
|
+
import { NG_VALUE_ACCESSOR } from '@angular/forms';
|
|
3
|
+
import { adjustInvalidDate, clampDate, getRangeErrorMessage, isDateInRange, isValidDate, parseInputDate, toOutputFormat, formatDate } from './helpers/date-helpers';
|
|
4
|
+
import { ComponentPortal } from '@angular/cdk/portal';
|
|
5
|
+
import { DateCalendarComponent } from './components/date-calendar/date-calendar.component';
|
|
6
|
+
import { v4 as uuidv4 } from 'uuid';
|
|
7
|
+
import { InputDateSizesEnum } from './input-date.enum';
|
|
8
|
+
import { filter, fromEvent } from 'rxjs';
|
|
9
|
+
import { PositionStrategyEnum } from '../../../enums/overlay';
|
|
10
|
+
import * as i0 from "@angular/core";
|
|
11
|
+
import * as i1 from "@angular/cdk/overlay";
|
|
12
|
+
import * as i2 from "ngx-mask";
|
|
13
|
+
import * as i3 from "@angular/forms";
|
|
14
|
+
import * as i4 from "../../error-message/error-message.component";
|
|
15
|
+
import * as i5 from "../../save-state/save-state.component";
|
|
16
|
+
export class InputDateComponent {
|
|
17
|
+
_overlay;
|
|
18
|
+
_detector;
|
|
19
|
+
_elementRef;
|
|
20
|
+
_clickSubscription;
|
|
21
|
+
_overlayRef = null;
|
|
22
|
+
displayValue = '';
|
|
23
|
+
selectedDate = null;
|
|
24
|
+
mask = '';
|
|
25
|
+
errorMessage = null;
|
|
26
|
+
// SAVE STATE
|
|
27
|
+
uuid = uuidv4();
|
|
28
|
+
fields = [];
|
|
29
|
+
format = 'DD.MM.YYYY';
|
|
30
|
+
minDate = null;
|
|
31
|
+
maxDate = null;
|
|
32
|
+
isSilentValidation = true;
|
|
33
|
+
isManualInput = true;
|
|
34
|
+
closeAfterSelect = true;
|
|
35
|
+
required = false;
|
|
36
|
+
size = 'large';
|
|
37
|
+
customClasses = '';
|
|
38
|
+
disabled = false;
|
|
39
|
+
readonly = false;
|
|
40
|
+
placeholder = 'дд.мм.гггг';
|
|
41
|
+
popupPosition = 'bottom-start';
|
|
42
|
+
invalid = false;
|
|
43
|
+
invalidMessage = '';
|
|
44
|
+
checkInvalid = null;
|
|
45
|
+
changed = new EventEmitter();
|
|
46
|
+
modelChange = new EventEmitter();
|
|
47
|
+
blurred = new EventEmitter();
|
|
48
|
+
dateInput;
|
|
49
|
+
onChange = () => {
|
|
50
|
+
};
|
|
51
|
+
onTouched = () => {
|
|
52
|
+
};
|
|
53
|
+
constructor(_overlay, _detector, _elementRef) {
|
|
54
|
+
this._overlay = _overlay;
|
|
55
|
+
this._detector = _detector;
|
|
56
|
+
this._elementRef = _elementRef;
|
|
57
|
+
}
|
|
58
|
+
ngOnInit() {
|
|
59
|
+
this.mask = this.format.replace(/[DMY]/g, '0');
|
|
60
|
+
}
|
|
61
|
+
ngOnDestroy() {
|
|
62
|
+
this._clickSubscription.unsubscribe();
|
|
63
|
+
}
|
|
64
|
+
get checkValidClasses() {
|
|
65
|
+
if (!this.required) {
|
|
66
|
+
return '';
|
|
67
|
+
}
|
|
68
|
+
else {
|
|
69
|
+
return this.checkInvalid === false ? 'mrx-input-checked-success' : this.checkInvalid === true ? 'mrx-input-checked-error' : '';
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
get getClasses() {
|
|
73
|
+
return `${InputDateSizesEnum[this.size]} ${this.customClasses} ${this.checkValidClasses}`;
|
|
74
|
+
}
|
|
75
|
+
get isViewCleanIcon() {
|
|
76
|
+
return !!this.dateInput?.nativeElement.value;
|
|
77
|
+
}
|
|
78
|
+
writeValue(value) {
|
|
79
|
+
this.value = value;
|
|
80
|
+
}
|
|
81
|
+
registerOnChange(fn) {
|
|
82
|
+
this.onChange = fn;
|
|
83
|
+
}
|
|
84
|
+
registerOnTouched(fn) {
|
|
85
|
+
this.onTouched = fn;
|
|
86
|
+
}
|
|
87
|
+
setDisabledState(isDisabled) {
|
|
88
|
+
this.disabled = isDisabled;
|
|
89
|
+
}
|
|
90
|
+
set value(value) {
|
|
91
|
+
const date = parseInputDate(value);
|
|
92
|
+
if (date && isDateInRange(date, this.minDate, this.maxDate)) {
|
|
93
|
+
this.selectedDate = date;
|
|
94
|
+
this.displayValue = formatDate(date, this.format);
|
|
95
|
+
this.errorMessage = null;
|
|
96
|
+
this.updateValue(value);
|
|
97
|
+
}
|
|
98
|
+
else if (this.isSilentValidation && date) {
|
|
99
|
+
const clampedDate = clampDate(date, this.minDate, this.maxDate);
|
|
100
|
+
this.selectedDate = clampedDate;
|
|
101
|
+
this.displayValue = formatDate(clampedDate, this.format);
|
|
102
|
+
this.errorMessage = null;
|
|
103
|
+
const clampedValue = toOutputFormat(clampedDate);
|
|
104
|
+
this.updateValue(clampedValue);
|
|
105
|
+
}
|
|
106
|
+
else {
|
|
107
|
+
this.selectedDate = null;
|
|
108
|
+
this.displayValue = date ? formatDate(date, this.format) : '';
|
|
109
|
+
this.errorMessage = date ? getRangeErrorMessage(date, this.minDate, this.maxDate) : null;
|
|
110
|
+
}
|
|
111
|
+
}
|
|
112
|
+
onInput(event) {
|
|
113
|
+
const inputElement = event.target;
|
|
114
|
+
const inputValue = inputElement.value;
|
|
115
|
+
this.processInput(inputValue);
|
|
116
|
+
}
|
|
117
|
+
processInput(inputValue) {
|
|
118
|
+
this.displayValue = inputValue;
|
|
119
|
+
this.errorMessage = null;
|
|
120
|
+
if (inputValue.length === this.format.length) {
|
|
121
|
+
const separator = this.format.match(/[^DMY]/)?.[0] || '.';
|
|
122
|
+
const regex = new RegExp(`^(\\d{2})${separator}(\\d{2})${separator}(\\d{4})$`);
|
|
123
|
+
const match = inputValue.match(regex);
|
|
124
|
+
if (!match)
|
|
125
|
+
return;
|
|
126
|
+
let day, month, year;
|
|
127
|
+
if (this.format.startsWith('DD')) {
|
|
128
|
+
[day, month, year] = [match[1], match[2], match[3]].map(Number);
|
|
129
|
+
}
|
|
130
|
+
else if (this.format.startsWith('MM')) {
|
|
131
|
+
[month, day, year] = [match[1], match[2], match[3]].map(Number);
|
|
132
|
+
}
|
|
133
|
+
else {
|
|
134
|
+
[year, month, day] = [match[1], match[2], match[3]].map(Number);
|
|
135
|
+
}
|
|
136
|
+
month -= 1;
|
|
137
|
+
let date = new Date(year, month, day);
|
|
138
|
+
if (isValidDate(date) && isDateInRange(date, this.minDate, this.maxDate)) {
|
|
139
|
+
this.selectedDate = date;
|
|
140
|
+
this.value = toOutputFormat(date);
|
|
141
|
+
}
|
|
142
|
+
else {
|
|
143
|
+
const { year: adjYear, month: adjMonth, day: adjDay } = adjustInvalidDate(year, month, day);
|
|
144
|
+
date = new Date(adjYear, adjMonth, adjDay);
|
|
145
|
+
if (isDateInRange(date, this.minDate, this.maxDate)) {
|
|
146
|
+
this.selectedDate = date;
|
|
147
|
+
this.displayValue = formatDate(date, this.format);
|
|
148
|
+
this.value = toOutputFormat(date);
|
|
149
|
+
}
|
|
150
|
+
else if (this.isSilentValidation) {
|
|
151
|
+
const clampedDate = clampDate(date, this.minDate, this.maxDate);
|
|
152
|
+
this.selectedDate = clampedDate;
|
|
153
|
+
this.displayValue = formatDate(clampedDate, this.format);
|
|
154
|
+
this.value = toOutputFormat(clampedDate);
|
|
155
|
+
}
|
|
156
|
+
else {
|
|
157
|
+
this.selectedDate = null;
|
|
158
|
+
this.errorMessage = getRangeErrorMessage(date, this.minDate, this.maxDate);
|
|
159
|
+
}
|
|
160
|
+
}
|
|
161
|
+
}
|
|
162
|
+
}
|
|
163
|
+
onBlur() {
|
|
164
|
+
this.onTouched();
|
|
165
|
+
if (this.displayValue.length > 0 && this.displayValue.length < this.format.length) {
|
|
166
|
+
this.displayValue = '';
|
|
167
|
+
this.selectedDate = null;
|
|
168
|
+
this.value = '';
|
|
169
|
+
this.errorMessage = null;
|
|
170
|
+
}
|
|
171
|
+
}
|
|
172
|
+
openCalendar() {
|
|
173
|
+
if (this.disabled || this._overlayRef)
|
|
174
|
+
return;
|
|
175
|
+
const positionStrategy = this._overlay
|
|
176
|
+
.position()
|
|
177
|
+
.flexibleConnectedTo(this.dateInput)
|
|
178
|
+
.withPositions(PositionStrategyEnum[this.popupPosition]);
|
|
179
|
+
this._overlayRef = this._overlay.create({
|
|
180
|
+
positionStrategy,
|
|
181
|
+
hasBackdrop: false
|
|
182
|
+
});
|
|
183
|
+
const portal = new ComponentPortal(DateCalendarComponent);
|
|
184
|
+
const componentRef = this._overlayRef.attach(portal);
|
|
185
|
+
componentRef.instance.selectedDate = this.selectedDate;
|
|
186
|
+
componentRef.instance.minDate = this.minDate;
|
|
187
|
+
componentRef.instance.maxDate = this.maxDate;
|
|
188
|
+
componentRef.instance.dateSelected.subscribe((date) => this.onDateSelected(date));
|
|
189
|
+
componentRef.instance.close.subscribe(() => this.closeCalendar());
|
|
190
|
+
this._clickSubscription = fromEvent(document, 'click')
|
|
191
|
+
.pipe(filter((event) => {
|
|
192
|
+
const clickTarget = event.target;
|
|
193
|
+
return (!!this._overlayRef &&
|
|
194
|
+
!this._overlayRef.overlayElement.contains(clickTarget) &&
|
|
195
|
+
!this._elementRef.nativeElement.contains(clickTarget));
|
|
196
|
+
}))
|
|
197
|
+
.subscribe(() => this.closeCalendar());
|
|
198
|
+
}
|
|
199
|
+
onDateSelected(date) {
|
|
200
|
+
const clampedDate = clampDate(date, this.minDate, this.maxDate);
|
|
201
|
+
this.selectedDate = clampedDate;
|
|
202
|
+
this.displayValue = formatDate(clampedDate, this.format);
|
|
203
|
+
this.value = toOutputFormat(clampedDate);
|
|
204
|
+
this.errorMessage = null;
|
|
205
|
+
if (this.closeAfterSelect) {
|
|
206
|
+
this.closeCalendar();
|
|
207
|
+
}
|
|
208
|
+
this._detector.detectChanges();
|
|
209
|
+
}
|
|
210
|
+
closeCalendar() {
|
|
211
|
+
if (this._overlayRef) {
|
|
212
|
+
this._overlayRef.dispose();
|
|
213
|
+
this._overlayRef = null;
|
|
214
|
+
}
|
|
215
|
+
this.errorMessage = null;
|
|
216
|
+
}
|
|
217
|
+
clickToIconCalendar() {
|
|
218
|
+
this.openCalendar();
|
|
219
|
+
}
|
|
220
|
+
clickToIconClear() {
|
|
221
|
+
this.value = '';
|
|
222
|
+
this.closeCalendar();
|
|
223
|
+
this.updateValue('');
|
|
224
|
+
}
|
|
225
|
+
updateValue(insideValue) {
|
|
226
|
+
this.changed.emit(insideValue);
|
|
227
|
+
this.modelChange.emit({ value: insideValue, id: this.uuid });
|
|
228
|
+
this.onChange(insideValue);
|
|
229
|
+
this.onTouched();
|
|
230
|
+
}
|
|
231
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: InputDateComponent, deps: [{ token: i1.Overlay }, { token: i0.ChangeDetectorRef }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
232
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: InputDateComponent, selector: "mrx-input-date", inputs: { fields: "fields", format: "format", minDate: "minDate", maxDate: "maxDate", isSilentValidation: "isSilentValidation", isManualInput: "isManualInput", closeAfterSelect: "closeAfterSelect", required: "required", size: "size", customClasses: "customClasses", disabled: "disabled", readonly: "readonly", placeholder: "placeholder", popupPosition: "popupPosition", invalid: "invalid", invalidMessage: "invalidMessage", checkInvalid: "checkInvalid" }, outputs: { changed: "changed", modelChange: "modelChange", blurred: "blurred" }, providers: [
|
|
233
|
+
{
|
|
234
|
+
provide: NG_VALUE_ACCESSOR,
|
|
235
|
+
useExisting: forwardRef(() => InputDateComponent),
|
|
236
|
+
multi: true
|
|
237
|
+
}
|
|
238
|
+
], viewQueries: [{ propertyName: "dateInput", first: true, predicate: ["dateInput"], descendants: true }], ngImport: i0, template: "<div\r\n class=\"mrx-input-date\"\r\n [class.mrx-input-error]=\"invalid\"\r\n [class.mrx-input-readonly]=\"readonly\"\r\n [class]=\"getClasses\"\r\n>\r\n <div class=\"mrx-input-date__wrapper\">\r\n <input\r\n #dateInput\r\n type=\"text\"\r\n autocomplete=\"nope\"\r\n class=\"mrx-input-date__input mrx-input-date__date\"\r\n [ngModel]=\"displayValue\"\r\n [disabled]=\"disabled\"\r\n [readOnly]=\"!isManualInput\"\r\n [mask]=\"mask\"\r\n [leadZeroDateTime]=\"true\"\r\n [dropSpecialCharacters]=\"false\"\r\n [placeholder]=\"placeholder\"\r\n (click)=\"openCalendar()\"\r\n (input)=\"onInput($event)\"\r\n (blur)=\"onBlur()\"\r\n />\r\n\r\n @if (!disabled) {\r\n <div class=\"mrx-input-date__icons\">\r\n @if (isViewCleanIcon) {\r\n <span\r\n class=\"mrx-icon icon-close\"\r\n (click)=\"clickToIconClear()\"\r\n [class.icon-font-16]=\"size === 'small'\"\r\n [class.icon-font-24]=\"size === 'medium' || size === 'large'\"\r\n ></span>\r\n }\r\n\r\n <span\r\n class=\"mrx-icon icon-calendar\"\r\n (click)=\"clickToIconCalendar()\"\r\n [class.icon-font-16]=\"size === 'small'\"\r\n [class.icon-font-24]=\"size === 'medium' || size === 'large'\"\r\n ></span>\r\n </div>\r\n }\r\n </div>\r\n\r\n @if (invalid) {\r\n <mrx-error-message [invalidMessage]=\"invalidMessage\"></mrx-error-message>\r\n } @else {\r\n @if (errorMessage) {\r\n <mrx-error-message [invalidMessage]=\"errorMessage\"></mrx-error-message>\r\n }\r\n }\r\n\r\n <mrx-save-state [id]=\"uuid\" [fields]=\"fields\"></mrx-save-state>\r\n</div>\r\n", styles: [".mrx-input-date{width:100%;position:relative}.mrx-input-date .mrx-input-date__wrapper{position:relative}.mrx-input-date .mrx-input-date__input{border:var(--border-width-default) solid var(--neutral-bg-stroke-default);border-radius:var(--border-radius-1);color:var(--neutral-text-primary);width:100%;transition:outline-width .2s,border .2s}.mrx-input-date .mrx-input-date__input:focus,.mrx-input-date .mrx-input-date__input:active{outline:var(--neutral-bg-island-default) solid var(--border-width-focused)}.mrx-input-date .mrx-input-date__input:hover{border:var(--border-width-default) solid var(--neutral-bg-stroke-hover)}.mrx-input-date .mrx-input-date__input:disabled{background-color:var(--neutral-bg-disabled);color:var(--neutral-text-tertiary)}.mrx-input-date.mrx-input-date-lg .mrx-input-date__input{padding:calc(var(--spacing-3) + var(--spacing-half) - var(--border-width-default)) calc(var(--spacing-4) - var(--border-width-default));font-family:var(--body-md-font-family);font-size:var(--body-md-font-size);font-weight:var(--body-md-font-weight);line-height:var(--body-md-line-height)}.mrx-input-date.mrx-input-date-md .mrx-input-date__input{padding:calc(var(--spacing-2) + var(--spacing-half) - var(--border-width-default)) calc(var(--spacing-3) - var(--border-width-default));font-family:var(--body-md-font-family);font-size:var(--body-md-font-size);font-weight:var(--body-md-font-weight);line-height:var(--body-md-line-height)}.mrx-input-date.mrx-input-date-sm .mrx-input-date__input{padding:calc(var(--spacing-2) - var(--border-width-default)) calc(var(--spacing-2) - var(--border-width-default));font-family:var(--body-sm-font-family);font-size:var(--body-sm-font-size);font-weight:var(--body-sm-font-weight);line-height:var(--body-sm-line-height)}.mrx-input-date.mrx-input-date.mrx-input-error .mrx-input-date__input{border-color:var(--system-bg-controls-negative-default)}.mrx-input-date.mrx-input-date.mrx-input-checked-error .mrx-input-date__input{border-color:var(--system-bg-controls-negative-default);background-color:var(--system-bg-negative-secondary)}.mrx-input-date.mrx-input-date.mrx-input-checked-error .mrx-input-date__input:disabled{background-color:var(--neutral-bg-disabled, #EEF0F4);border-color:var(--neutral-bg-stroke-default)}.mrx-input-date.mrx-input-date.mrx-input-checked-success .mrx-input-date__input{background-color:var(--system-bg-positive-secondary);border-color:var(--system-bg-controls-positive-default)}.mrx-input-date.mrx-input-date.mrx-input-checked-success .mrx-input-date__input:disabled{background-color:var(--neutral-bg-disabled, #EEF0F4);border-color:var(--neutral-bg-stroke-default)}.mrx-input-date.mrx-input-date .mrx-input-date__icons{position:absolute;top:0;right:0;display:flex;align-items:center}.mrx-input-date.mrx-input-date .mrx-input-date__icons-item,.mrx-input-date.mrx-input-date .mrx-input-date__icons .mrx-icon{cursor:pointer}.mrx-input-date.mrx-input-date.mrx-input-date-lg .mrx-icon{margin-top:calc(var(--spacing-3) - var(--border-width-default));margin-right:var(--spacing-3)}.mrx-input-date.mrx-input-date.mrx-input-date-md .mrx-icon{margin-top:calc(var(--spacing-2) - var(--border-width-default));margin-right:var(--spacing-3)}.mrx-input-date.mrx-input-date.mrx-input-date-sm .mrx-icon{margin-top:calc(var(--spacing-2) - var(--border-width-default));margin-right:var(--spacing-2)}\n"], dependencies: [{ kind: "directive", type: i2.NgxMaskDirective, selector: "input[mask], textarea[mask]", inputs: ["mask", "specialCharacters", "patterns", "prefix", "suffix", "thousandSeparator", "decimalMarker", "dropSpecialCharacters", "hiddenInput", "showMaskTyped", "placeHolderCharacter", "shownMaskExpression", "showTemplate", "clearIfNotMatch", "validation", "separatorLimit", "allowNegativeNumbers", "leadZeroDateTime", "leadZero", "triggerOnMaskChange", "apm", "inputTransformFn", "outputTransformFn", "keepCharacterPositions"], outputs: ["maskFilled"], exportAs: ["mask", "ngxMask"] }, { kind: "directive", type: i3.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i4.ErrorMessageComponent, selector: "mrx-error-message", inputs: ["invalid", "invalidMessage", "customClasses"] }, { kind: "component", type: i5.SaveStateComponent, selector: "mrx-save-state", inputs: ["type", "fields", "id"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
239
|
+
}
|
|
240
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: InputDateComponent, decorators: [{
|
|
241
|
+
type: Component,
|
|
242
|
+
args: [{ selector: 'mrx-input-date', changeDetection: ChangeDetectionStrategy.OnPush, providers: [
|
|
243
|
+
{
|
|
244
|
+
provide: NG_VALUE_ACCESSOR,
|
|
245
|
+
useExisting: forwardRef(() => InputDateComponent),
|
|
246
|
+
multi: true
|
|
247
|
+
}
|
|
248
|
+
], template: "<div\r\n class=\"mrx-input-date\"\r\n [class.mrx-input-error]=\"invalid\"\r\n [class.mrx-input-readonly]=\"readonly\"\r\n [class]=\"getClasses\"\r\n>\r\n <div class=\"mrx-input-date__wrapper\">\r\n <input\r\n #dateInput\r\n type=\"text\"\r\n autocomplete=\"nope\"\r\n class=\"mrx-input-date__input mrx-input-date__date\"\r\n [ngModel]=\"displayValue\"\r\n [disabled]=\"disabled\"\r\n [readOnly]=\"!isManualInput\"\r\n [mask]=\"mask\"\r\n [leadZeroDateTime]=\"true\"\r\n [dropSpecialCharacters]=\"false\"\r\n [placeholder]=\"placeholder\"\r\n (click)=\"openCalendar()\"\r\n (input)=\"onInput($event)\"\r\n (blur)=\"onBlur()\"\r\n />\r\n\r\n @if (!disabled) {\r\n <div class=\"mrx-input-date__icons\">\r\n @if (isViewCleanIcon) {\r\n <span\r\n class=\"mrx-icon icon-close\"\r\n (click)=\"clickToIconClear()\"\r\n [class.icon-font-16]=\"size === 'small'\"\r\n [class.icon-font-24]=\"size === 'medium' || size === 'large'\"\r\n ></span>\r\n }\r\n\r\n <span\r\n class=\"mrx-icon icon-calendar\"\r\n (click)=\"clickToIconCalendar()\"\r\n [class.icon-font-16]=\"size === 'small'\"\r\n [class.icon-font-24]=\"size === 'medium' || size === 'large'\"\r\n ></span>\r\n </div>\r\n }\r\n </div>\r\n\r\n @if (invalid) {\r\n <mrx-error-message [invalidMessage]=\"invalidMessage\"></mrx-error-message>\r\n } @else {\r\n @if (errorMessage) {\r\n <mrx-error-message [invalidMessage]=\"errorMessage\"></mrx-error-message>\r\n }\r\n }\r\n\r\n <mrx-save-state [id]=\"uuid\" [fields]=\"fields\"></mrx-save-state>\r\n</div>\r\n", styles: [".mrx-input-date{width:100%;position:relative}.mrx-input-date .mrx-input-date__wrapper{position:relative}.mrx-input-date .mrx-input-date__input{border:var(--border-width-default) solid var(--neutral-bg-stroke-default);border-radius:var(--border-radius-1);color:var(--neutral-text-primary);width:100%;transition:outline-width .2s,border .2s}.mrx-input-date .mrx-input-date__input:focus,.mrx-input-date .mrx-input-date__input:active{outline:var(--neutral-bg-island-default) solid var(--border-width-focused)}.mrx-input-date .mrx-input-date__input:hover{border:var(--border-width-default) solid var(--neutral-bg-stroke-hover)}.mrx-input-date .mrx-input-date__input:disabled{background-color:var(--neutral-bg-disabled);color:var(--neutral-text-tertiary)}.mrx-input-date.mrx-input-date-lg .mrx-input-date__input{padding:calc(var(--spacing-3) + var(--spacing-half) - var(--border-width-default)) calc(var(--spacing-4) - var(--border-width-default));font-family:var(--body-md-font-family);font-size:var(--body-md-font-size);font-weight:var(--body-md-font-weight);line-height:var(--body-md-line-height)}.mrx-input-date.mrx-input-date-md .mrx-input-date__input{padding:calc(var(--spacing-2) + var(--spacing-half) - var(--border-width-default)) calc(var(--spacing-3) - var(--border-width-default));font-family:var(--body-md-font-family);font-size:var(--body-md-font-size);font-weight:var(--body-md-font-weight);line-height:var(--body-md-line-height)}.mrx-input-date.mrx-input-date-sm .mrx-input-date__input{padding:calc(var(--spacing-2) - var(--border-width-default)) calc(var(--spacing-2) - var(--border-width-default));font-family:var(--body-sm-font-family);font-size:var(--body-sm-font-size);font-weight:var(--body-sm-font-weight);line-height:var(--body-sm-line-height)}.mrx-input-date.mrx-input-date.mrx-input-error .mrx-input-date__input{border-color:var(--system-bg-controls-negative-default)}.mrx-input-date.mrx-input-date.mrx-input-checked-error .mrx-input-date__input{border-color:var(--system-bg-controls-negative-default);background-color:var(--system-bg-negative-secondary)}.mrx-input-date.mrx-input-date.mrx-input-checked-error .mrx-input-date__input:disabled{background-color:var(--neutral-bg-disabled, #EEF0F4);border-color:var(--neutral-bg-stroke-default)}.mrx-input-date.mrx-input-date.mrx-input-checked-success .mrx-input-date__input{background-color:var(--system-bg-positive-secondary);border-color:var(--system-bg-controls-positive-default)}.mrx-input-date.mrx-input-date.mrx-input-checked-success .mrx-input-date__input:disabled{background-color:var(--neutral-bg-disabled, #EEF0F4);border-color:var(--neutral-bg-stroke-default)}.mrx-input-date.mrx-input-date .mrx-input-date__icons{position:absolute;top:0;right:0;display:flex;align-items:center}.mrx-input-date.mrx-input-date .mrx-input-date__icons-item,.mrx-input-date.mrx-input-date .mrx-input-date__icons .mrx-icon{cursor:pointer}.mrx-input-date.mrx-input-date.mrx-input-date-lg .mrx-icon{margin-top:calc(var(--spacing-3) - var(--border-width-default));margin-right:var(--spacing-3)}.mrx-input-date.mrx-input-date.mrx-input-date-md .mrx-icon{margin-top:calc(var(--spacing-2) - var(--border-width-default));margin-right:var(--spacing-3)}.mrx-input-date.mrx-input-date.mrx-input-date-sm .mrx-icon{margin-top:calc(var(--spacing-2) - var(--border-width-default));margin-right:var(--spacing-2)}\n"] }]
|
|
249
|
+
}], ctorParameters: () => [{ type: i1.Overlay }, { type: i0.ChangeDetectorRef }, { type: i0.ElementRef }], propDecorators: { fields: [{
|
|
250
|
+
type: Input
|
|
251
|
+
}], format: [{
|
|
252
|
+
type: Input
|
|
253
|
+
}], minDate: [{
|
|
254
|
+
type: Input
|
|
255
|
+
}], maxDate: [{
|
|
256
|
+
type: Input
|
|
257
|
+
}], isSilentValidation: [{
|
|
258
|
+
type: Input
|
|
259
|
+
}], isManualInput: [{
|
|
260
|
+
type: Input
|
|
261
|
+
}], closeAfterSelect: [{
|
|
262
|
+
type: Input
|
|
263
|
+
}], required: [{
|
|
264
|
+
type: Input
|
|
265
|
+
}], size: [{
|
|
266
|
+
type: Input
|
|
267
|
+
}], customClasses: [{
|
|
268
|
+
type: Input
|
|
269
|
+
}], disabled: [{
|
|
270
|
+
type: Input
|
|
271
|
+
}], readonly: [{
|
|
272
|
+
type: Input
|
|
273
|
+
}], placeholder: [{
|
|
274
|
+
type: Input
|
|
275
|
+
}], popupPosition: [{
|
|
276
|
+
type: Input
|
|
277
|
+
}], invalid: [{
|
|
278
|
+
type: Input
|
|
279
|
+
}], invalidMessage: [{
|
|
280
|
+
type: Input
|
|
281
|
+
}], checkInvalid: [{
|
|
282
|
+
type: Input
|
|
283
|
+
}], changed: [{
|
|
284
|
+
type: Output
|
|
285
|
+
}], modelChange: [{
|
|
286
|
+
type: Output
|
|
287
|
+
}], blurred: [{
|
|
288
|
+
type: Output
|
|
289
|
+
}], dateInput: [{
|
|
290
|
+
type: ViewChild,
|
|
291
|
+
args: ['dateInput']
|
|
292
|
+
}] } });
|
|
293
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-date.component.js","sourceRoot":"","sources":["../../../../../../../projects/myrta-ui/src/lib/components/form/input-date/input-date.component.ts","../../../../../../../projects/myrta-ui/src/lib/components/form/input-date/input-date.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectionStrategy, ChangeDetectorRef,\r\n  Component,\r\n  ElementRef,\r\n  EventEmitter,\r\n  forwardRef,\r\n  Input, OnDestroy,\r\n  OnInit,\r\n  Output,\r\n  ViewChild\r\n} from '@angular/core';\r\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\r\nimport {\r\n  adjustInvalidDate,\r\n  clampDate,\r\n  getRangeErrorMessage,\r\n  isDateInRange,\r\n  isValidDate,\r\n  parseInputDate,\r\n  toOutputFormat,\r\n  formatDate\r\n} from './helpers/date-helpers';\r\nimport { ComponentPortal } from '@angular/cdk/portal';\r\nimport { DateCalendarComponent } from './components/date-calendar/date-calendar.component';\r\nimport { Overlay, OverlayRef } from '@angular/cdk/overlay';\r\nimport { v4 as uuidv4 } from 'uuid';\r\nimport { Field } from '../../../services';\r\nimport { InputDateSizesEnum, InputDateSizesTypes, InputDateValueTypes, InputDateValueWithId } from './input-date.enum';\r\nimport { InputDateTimeSizesTypes } from '../input-date-time/input-date-time.enum';\r\nimport { dateModelConstant, timeModelConstant } from '../input-date-time/constants/value-models';\r\nimport { InputDateTimeValueTypes, InputDateTimeValueWithId } from '../input-date-time/models/input-date-time.model';\r\nimport { filter, fromEvent, Subscription } from 'rxjs';\r\nimport { PositionStrategyEnum, PositionType } from '../../../enums/overlay';\r\n\r\n@Component({\r\n  selector: 'mrx-input-date',\r\n  templateUrl: './input-date.component.html',\r\n  styleUrl: './input-date.component.less',\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: forwardRef(() => InputDateComponent),\r\n      multi: true\r\n    }\r\n  ],\r\n})\r\nexport class InputDateComponent implements OnInit, OnDestroy, ControlValueAccessor {\r\n  private _clickSubscription!: Subscription;\r\n  private _overlayRef: OverlayRef | null = null;\r\n\r\n  displayValue: string = '';\r\n  selectedDate: Date | null = null;\r\n  mask: string = '';\r\n  errorMessage: string | null = null;\r\n\r\n  // SAVE STATE\r\n  public uuid: string = uuidv4();\r\n  @Input() public fields: Field[] = [];\r\n\r\n  @Input() public format: string = 'DD.MM.YYYY';\r\n  @Input() public minDate: string | null = null;\r\n  @Input() public maxDate: string | null = null;\r\n  @Input() public isSilentValidation: boolean = true;\r\n  @Input() public isManualInput = true;\r\n  @Input() public closeAfterSelect = true;\r\n  @Input() public required = false;\r\n  @Input() public size: InputDateSizesTypes = 'large';\r\n  @Input() public customClasses = '';\r\n  @Input() public disabled = false;\r\n  @Input() public readonly = false;\r\n  @Input() public placeholder = 'дд.мм.гггг';\r\n  @Input() public popupPosition: PositionType = 'bottom-start';\r\n\r\n  @Input() public invalid = false;\r\n  @Input() public invalidMessage: string | string[] = '';\r\n  @Input() public checkInvalid: true | false | null = null;\r\n\r\n  @Output() public changed: EventEmitter<InputDateTimeValueTypes> = new EventEmitter();\r\n  @Output() public modelChange: EventEmitter<InputDateTimeValueWithId> = new EventEmitter<InputDateTimeValueWithId>();\r\n  @Output() public blurred: EventEmitter<InputDateTimeValueWithId> = new EventEmitter<InputDateTimeValueWithId>();\r\n\r\n  @ViewChild('dateInput') dateInput!: ElementRef;\r\n\r\n  private onChange: (value: string) => void = () => {\r\n  };\r\n  private onTouched: () => void = () => {\r\n  };\r\n\r\n  constructor(\r\n    private _overlay: Overlay,\r\n    private _detector: ChangeDetectorRef,\r\n    private _elementRef: ElementRef\r\n  ) {\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.mask = this.format.replace(/[DMY]/g, '0');\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this._clickSubscription.unsubscribe();\r\n  }\r\n\r\n  public get checkValidClasses(): string {\r\n    if (!this.required) {\r\n      return '';\r\n    } else {\r\n      return this.checkInvalid === false ? 'mrx-input-checked-success' : this.checkInvalid === true ? 'mrx-input-checked-error' : '';\r\n    }\r\n  }\r\n\r\n  public get getClasses(): string {\r\n    return `${InputDateSizesEnum[this.size]} ${this.customClasses} ${this.checkValidClasses}`;\r\n  }\r\n\r\n  public get isViewCleanIcon() {\r\n    return !!this.dateInput?.nativeElement.value;\r\n  }\r\n\r\n  writeValue(value: string): void {\r\n    this.value = value;\r\n  }\r\n\r\n  registerOnChange(fn: (value: string) => void): void {\r\n    this.onChange = fn;\r\n  }\r\n\r\n  registerOnTouched(fn: () => void): void {\r\n    this.onTouched = fn;\r\n  }\r\n\r\n  setDisabledState(isDisabled: boolean): void {\r\n    this.disabled = isDisabled;\r\n  }\r\n\r\n  set value(value: string) {\r\n    const date = parseInputDate(value);\r\n\r\n    if (date && isDateInRange(date, this.minDate, this.maxDate)) {\r\n      this.selectedDate = date;\r\n      this.displayValue = formatDate(date, this.format);\r\n      this.errorMessage = null;\r\n\r\n      this.updateValue(value);\r\n    } else if (this.isSilentValidation && date) {\r\n      const clampedDate = clampDate(date, this.minDate, this.maxDate);\r\n      this.selectedDate = clampedDate;\r\n      this.displayValue = formatDate(clampedDate, this.format);\r\n      this.errorMessage = null;\r\n      const clampedValue = toOutputFormat(clampedDate);\r\n\r\n      this.updateValue(clampedValue);\r\n    } else {\r\n      this.selectedDate = null;\r\n      this.displayValue = date ? formatDate(date, this.format) : '';\r\n      this.errorMessage = date ? getRangeErrorMessage(date, this.minDate, this.maxDate) : null;\r\n    }\r\n  }\r\n\r\n  onInput(event: Event) {\r\n    const inputElement = event.target as HTMLInputElement;\r\n    const inputValue = inputElement.value;\r\n\r\n    this.processInput(inputValue);\r\n  }\r\n\r\n  private processInput(inputValue: string) {\r\n    this.displayValue = inputValue;\r\n    this.errorMessage = null;\r\n\r\n    if (inputValue.length === this.format.length) {\r\n      const separator = this.format.match(/[^DMY]/)?.[0] || '.';\r\n      const regex = new RegExp(`^(\\\\d{2})${separator}(\\\\d{2})${separator}(\\\\d{4})$`);\r\n      const match = inputValue.match(regex);\r\n\r\n      if (!match) return;\r\n\r\n      let day, month, year;\r\n      if (this.format.startsWith('DD')) {\r\n        [day, month, year] = [match[1], match[2], match[3]].map(Number);\r\n      } else if (this.format.startsWith('MM')) {\r\n        [month, day, year] = [match[1], match[2], match[3]].map(Number);\r\n      } else {\r\n        [year, month, day] = [match[1], match[2], match[3]].map(Number);\r\n      }\r\n      month -= 1;\r\n\r\n      let date = new Date(year, month, day);\r\n\r\n      if (isValidDate(date) && isDateInRange(date, this.minDate, this.maxDate)) {\r\n        this.selectedDate = date;\r\n        this.value = toOutputFormat(date);\r\n      } else {\r\n        const {year: adjYear, month: adjMonth, day: adjDay} = adjustInvalidDate(year, month, day);\r\n        date = new Date(adjYear, adjMonth, adjDay);\r\n\r\n        if (isDateInRange(date, this.minDate, this.maxDate)) {\r\n          this.selectedDate = date;\r\n          this.displayValue = formatDate(date, this.format);\r\n          this.value = toOutputFormat(date);\r\n        } else if (this.isSilentValidation) {\r\n          const clampedDate = clampDate(date, this.minDate, this.maxDate);\r\n          this.selectedDate = clampedDate;\r\n          this.displayValue = formatDate(clampedDate, this.format);\r\n          this.value = toOutputFormat(clampedDate);\r\n        } else {\r\n          this.selectedDate = null;\r\n          this.errorMessage = getRangeErrorMessage(date, this.minDate, this.maxDate);\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n  onBlur() {\r\n    this.onTouched();\r\n\r\n    if (this.displayValue.length > 0 && this.displayValue.length < this.format.length) {\r\n      this.displayValue = '';\r\n      this.selectedDate = null;\r\n      this.value = '';\r\n      this.errorMessage = null;\r\n    }\r\n  }\r\n\r\n  openCalendar() {\r\n    if (this.disabled || this._overlayRef) return;\r\n\r\n    const positionStrategy = this._overlay\r\n      .position()\r\n      .flexibleConnectedTo(this.dateInput)\r\n      .withPositions(PositionStrategyEnum[this.popupPosition]);\r\n\r\n    this._overlayRef = this._overlay.create({\r\n      positionStrategy,\r\n      hasBackdrop: false\r\n    });\r\n\r\n    const portal = new ComponentPortal(DateCalendarComponent);\r\n    const componentRef = this._overlayRef.attach(portal);\r\n\r\n    componentRef.instance.selectedDate = this.selectedDate;\r\n    componentRef.instance.minDate = this.minDate;\r\n    componentRef.instance.maxDate = this.maxDate;\r\n    componentRef.instance.dateSelected.subscribe((date: Date) => this.onDateSelected(date));\r\n    componentRef.instance.close.subscribe(() => this.closeCalendar());\r\n\r\n    this._clickSubscription = fromEvent(document, 'click')\r\n      .pipe(\r\n        filter((event: Event) => {\r\n          const clickTarget = event.target as HTMLElement;\r\n\r\n          return (\r\n            !!this._overlayRef &&\r\n            !this._overlayRef.overlayElement.contains(clickTarget) &&\r\n            !this._elementRef.nativeElement.contains(clickTarget)\r\n          );\r\n        })\r\n      )\r\n      .subscribe(() => this.closeCalendar());\r\n  }\r\n\r\n  onDateSelected(date: Date) {\r\n    const clampedDate = clampDate(date, this.minDate, this.maxDate);\r\n\r\n    this.selectedDate = clampedDate;\r\n    this.displayValue = formatDate(clampedDate, this.format);\r\n    this.value = toOutputFormat(clampedDate);\r\n    this.errorMessage = null;\r\n\r\n    if (this.closeAfterSelect) {\r\n      this.closeCalendar();\r\n    }\r\n\r\n    this._detector.detectChanges();\r\n  }\r\n\r\n  closeCalendar() {\r\n    if (this._overlayRef) {\r\n      this._overlayRef.dispose();\r\n      this._overlayRef = null;\r\n    }\r\n    this.errorMessage = null;\r\n  }\r\n\r\n  public clickToIconCalendar(): void {\r\n    this.openCalendar();\r\n  }\r\n\r\n  public clickToIconClear(): void {\r\n    this.value = '';\r\n    this.closeCalendar();\r\n    this.updateValue('');\r\n  }\r\n\r\n  public updateValue(insideValue: InputDateValueTypes) {\r\n    this.changed.emit(insideValue);\r\n    this.modelChange.emit({value: insideValue, id: this.uuid});\r\n    this.onChange(insideValue);\r\n    this.onTouched();\r\n  }\r\n}\r\n","<div\r\n  class=\"mrx-input-date\"\r\n  [class.mrx-input-error]=\"invalid\"\r\n  [class.mrx-input-readonly]=\"readonly\"\r\n  [class]=\"getClasses\"\r\n>\r\n  <div class=\"mrx-input-date__wrapper\">\r\n    <input\r\n      #dateInput\r\n      type=\"text\"\r\n      autocomplete=\"nope\"\r\n      class=\"mrx-input-date__input mrx-input-date__date\"\r\n      [ngModel]=\"displayValue\"\r\n      [disabled]=\"disabled\"\r\n      [readOnly]=\"!isManualInput\"\r\n      [mask]=\"mask\"\r\n      [leadZeroDateTime]=\"true\"\r\n      [dropSpecialCharacters]=\"false\"\r\n      [placeholder]=\"placeholder\"\r\n      (click)=\"openCalendar()\"\r\n      (input)=\"onInput($event)\"\r\n      (blur)=\"onBlur()\"\r\n    />\r\n\r\n    @if (!disabled) {\r\n      <div class=\"mrx-input-date__icons\">\r\n        @if (isViewCleanIcon) {\r\n          <span\r\n            class=\"mrx-icon icon-close\"\r\n            (click)=\"clickToIconClear()\"\r\n            [class.icon-font-16]=\"size === 'small'\"\r\n            [class.icon-font-24]=\"size === 'medium' || size === 'large'\"\r\n          ></span>\r\n        }\r\n\r\n        <span\r\n          class=\"mrx-icon icon-calendar\"\r\n          (click)=\"clickToIconCalendar()\"\r\n          [class.icon-font-16]=\"size === 'small'\"\r\n          [class.icon-font-24]=\"size === 'medium' || size === 'large'\"\r\n        ></span>\r\n      </div>\r\n    }\r\n  </div>\r\n\r\n  @if (invalid) {\r\n    <mrx-error-message [invalidMessage]=\"invalidMessage\"></mrx-error-message>\r\n  } @else {\r\n    @if (errorMessage) {\r\n      <mrx-error-message [invalidMessage]=\"errorMessage\"></mrx-error-message>\r\n    }\r\n  }\r\n\r\n  <mrx-save-state [id]=\"uuid\" [fields]=\"fields\"></mrx-save-state>\r\n</div>\r\n"]}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
export var InputDateSizesEnum;
|
|
2
|
+
(function (InputDateSizesEnum) {
|
|
3
|
+
InputDateSizesEnum["small"] = "mrx-input-date-sm";
|
|
4
|
+
InputDateSizesEnum["medium"] = "mrx-input-date-md";
|
|
5
|
+
InputDateSizesEnum["large"] = "mrx-input-date-lg";
|
|
6
|
+
})(InputDateSizesEnum || (InputDateSizesEnum = {}));
|
|
7
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5wdXQtZGF0ZS5lbnVtLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbXlydGEtdWkvc3JjL2xpYi9jb21wb25lbnRzL2Zvcm0vaW5wdXQtZGF0ZS9pbnB1dC1kYXRlLmVudW0udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsTUFBTSxDQUFOLElBQVksa0JBSVg7QUFKRCxXQUFZLGtCQUFrQjtJQUM1QixpREFBNkIsQ0FBQTtJQUM3QixrREFBOEIsQ0FBQTtJQUM5QixpREFBNkIsQ0FBQTtBQUMvQixDQUFDLEVBSlcsa0JBQWtCLEtBQWxCLGtCQUFrQixRQUk3QiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBlbnVtIElucHV0RGF0ZVNpemVzRW51bSB7XHJcbiAgJ3NtYWxsJyA9ICdtcngtaW5wdXQtZGF0ZS1zbScsXHJcbiAgJ21lZGl1bScgPSAnbXJ4LWlucHV0LWRhdGUtbWQnLFxyXG4gICdsYXJnZScgPSAnbXJ4LWlucHV0LWRhdGUtbGcnLFxyXG59XHJcblxyXG5leHBvcnQgdHlwZSBJbnB1dERhdGVTaXplc1R5cGVzID0gJ3NtYWxsJyB8ICdtZWRpdW0nIHwgJ2xhcmdlJztcclxuXHJcbmV4cG9ydCB0eXBlIElucHV0RGF0ZVZhbHVlVHlwZXMgPSBzdHJpbmc7XHJcblxyXG5leHBvcnQgaW50ZXJmYWNlIElucHV0RGF0ZVZhbHVlV2l0aElkIHtcclxuICB2YWx1ZTogSW5wdXREYXRlVmFsdWVUeXBlcyxcclxuICBpZDogc3RyaW5nXHJcbn1cclxuIl19
|
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
import { NgModule } from '@angular/core';
|
|
2
|
+
import { CommonModule } from '@angular/common';
|
|
3
|
+
import { InputDateComponent } from './input-date.component';
|
|
4
|
+
import { DateCalendarComponent } from './components/date-calendar/date-calendar.component';
|
|
5
|
+
import { NgxMaskDirective, provideNgxMask } from 'ngx-mask';
|
|
6
|
+
import { FormsModule } from '@angular/forms';
|
|
7
|
+
import { ErrorMessageModule } from '../../error-message/error-message.module';
|
|
8
|
+
import { LabelModule } from '../../label/label.module';
|
|
9
|
+
import { SaveStateModule } from '../../save-state/save-state.module';
|
|
10
|
+
import * as i0 from "@angular/core";
|
|
11
|
+
export class InputDateModule {
|
|
12
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: InputDateModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
13
|
+
static ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "17.3.12", ngImport: i0, type: InputDateModule, declarations: [InputDateComponent,
|
|
14
|
+
DateCalendarComponent], imports: [CommonModule,
|
|
15
|
+
NgxMaskDirective,
|
|
16
|
+
FormsModule,
|
|
17
|
+
ErrorMessageModule,
|
|
18
|
+
LabelModule,
|
|
19
|
+
SaveStateModule], exports: [InputDateComponent] });
|
|
20
|
+
static ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: InputDateModule, providers: [
|
|
21
|
+
provideNgxMask(),
|
|
22
|
+
], imports: [CommonModule,
|
|
23
|
+
FormsModule,
|
|
24
|
+
ErrorMessageModule,
|
|
25
|
+
LabelModule,
|
|
26
|
+
SaveStateModule] });
|
|
27
|
+
}
|
|
28
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: InputDateModule, decorators: [{
|
|
29
|
+
type: NgModule,
|
|
30
|
+
args: [{
|
|
31
|
+
declarations: [
|
|
32
|
+
InputDateComponent,
|
|
33
|
+
DateCalendarComponent
|
|
34
|
+
],
|
|
35
|
+
imports: [
|
|
36
|
+
CommonModule,
|
|
37
|
+
NgxMaskDirective,
|
|
38
|
+
FormsModule,
|
|
39
|
+
ErrorMessageModule,
|
|
40
|
+
LabelModule,
|
|
41
|
+
SaveStateModule
|
|
42
|
+
],
|
|
43
|
+
exports: [
|
|
44
|
+
InputDateComponent
|
|
45
|
+
],
|
|
46
|
+
providers: [
|
|
47
|
+
provideNgxMask(),
|
|
48
|
+
]
|
|
49
|
+
}]
|
|
50
|
+
}] });
|
|
51
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5wdXQtZGF0ZS5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9teXJ0YS11aS9zcmMvbGliL2NvbXBvbmVudHMvZm9ybS9pbnB1dC1kYXRlL2lucHV0LWRhdGUubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBQzVELE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLG9EQUFvRCxDQUFDO0FBQzNGLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxjQUFjLEVBQUUsTUFBTSxVQUFVLENBQUM7QUFDNUQsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQzdDLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLDBDQUEwQyxDQUFDO0FBQzlFLE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUN2RCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sb0NBQW9DLENBQUM7O0FBdUJyRSxNQUFNLE9BQU8sZUFBZTt3R0FBZixlQUFlO3lHQUFmLGVBQWUsaUJBbEJ4QixrQkFBa0I7WUFDbEIscUJBQXFCLGFBR3JCLFlBQVk7WUFDWixnQkFBZ0I7WUFDaEIsV0FBVztZQUNYLGtCQUFrQjtZQUNsQixXQUFXO1lBQ1gsZUFBZSxhQUdmLGtCQUFrQjt5R0FNVCxlQUFlLGFBSmY7WUFDVCxjQUFjLEVBQUU7U0FDakIsWUFaQyxZQUFZO1lBRVosV0FBVztZQUNYLGtCQUFrQjtZQUNsQixXQUFXO1lBQ1gsZUFBZTs7NEZBU04sZUFBZTtrQkFwQjNCLFFBQVE7bUJBQUM7b0JBQ1IsWUFBWSxFQUFFO3dCQUNaLGtCQUFrQjt3QkFDbEIscUJBQXFCO3FCQUN0QjtvQkFDRCxPQUFPLEVBQUU7d0JBQ1AsWUFBWTt3QkFDWixnQkFBZ0I7d0JBQ2hCLFdBQVc7d0JBQ1gsa0JBQWtCO3dCQUNsQixXQUFXO3dCQUNYLGVBQWU7cUJBQ2hCO29CQUNELE9BQU8sRUFBRTt3QkFDUCxrQkFBa0I7cUJBQ25CO29CQUNELFNBQVMsRUFBRTt3QkFDVCxjQUFjLEVBQUU7cUJBQ2pCO2lCQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcclxuaW1wb3J0IHsgSW5wdXREYXRlQ29tcG9uZW50IH0gZnJvbSAnLi9pbnB1dC1kYXRlLmNvbXBvbmVudCc7XHJcbmltcG9ydCB7IERhdGVDYWxlbmRhckNvbXBvbmVudCB9IGZyb20gJy4vY29tcG9uZW50cy9kYXRlLWNhbGVuZGFyL2RhdGUtY2FsZW5kYXIuY29tcG9uZW50JztcclxuaW1wb3J0IHsgTmd4TWFza0RpcmVjdGl2ZSwgcHJvdmlkZU5neE1hc2sgfSBmcm9tICduZ3gtbWFzayc7XHJcbmltcG9ydCB7IEZvcm1zTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xyXG5pbXBvcnQgeyBFcnJvck1lc3NhZ2VNb2R1bGUgfSBmcm9tICcuLi8uLi9lcnJvci1tZXNzYWdlL2Vycm9yLW1lc3NhZ2UubW9kdWxlJztcclxuaW1wb3J0IHsgTGFiZWxNb2R1bGUgfSBmcm9tICcuLi8uLi9sYWJlbC9sYWJlbC5tb2R1bGUnO1xyXG5pbXBvcnQgeyBTYXZlU3RhdGVNb2R1bGUgfSBmcm9tICcuLi8uLi9zYXZlLXN0YXRlL3NhdmUtc3RhdGUubW9kdWxlJztcclxuXHJcblxyXG5ATmdNb2R1bGUoe1xyXG4gIGRlY2xhcmF0aW9uczogW1xyXG4gICAgSW5wdXREYXRlQ29tcG9uZW50LFxyXG4gICAgRGF0ZUNhbGVuZGFyQ29tcG9uZW50XHJcbiAgXSxcclxuICBpbXBvcnRzOiBbXHJcbiAgICBDb21tb25Nb2R1bGUsXHJcbiAgICBOZ3hNYXNrRGlyZWN0aXZlLFxyXG4gICAgRm9ybXNNb2R1bGUsXHJcbiAgICBFcnJvck1lc3NhZ2VNb2R1bGUsXHJcbiAgICBMYWJlbE1vZHVsZSxcclxuICAgIFNhdmVTdGF0ZU1vZHVsZVxyXG4gIF0sXHJcbiAgZXhwb3J0czogW1xyXG4gICAgSW5wdXREYXRlQ29tcG9uZW50XHJcbiAgXSxcclxuICBwcm92aWRlcnM6IFtcclxuICAgIHByb3ZpZGVOZ3hNYXNrKCksXHJcbiAgXVxyXG59KVxyXG5leHBvcnQgY2xhc3MgSW5wdXREYXRlTW9kdWxlIHtcclxufVxyXG4iXX0=
|