myrta-ui 1.1.91 → 1.1.92
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/esm2020/lib/components/form/input-date/components/date-calendar/date-calendar.component.mjs +222 -0
- package/esm2020/lib/components/form/input-date/helpers/date-helpers.mjs +70 -0
- package/esm2020/lib/components/form/input-date/input-date.component.mjs +313 -0
- package/esm2020/lib/components/form/input-date/input-date.enum.mjs +7 -0
- package/esm2020/lib/components/form/input-date/input-date.module.mjs +54 -0
- package/esm2020/lib/enums/overlay/index.mjs +78 -0
- package/esm2020/public-api.mjs +5 -2
- package/fesm2015/myrta-ui.mjs +759 -40
- package/fesm2015/myrta-ui.mjs.map +1 -1
- package/fesm2020/myrta-ui.mjs +752 -40
- package/fesm2020/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/enums/overlay/index.d.ts +13 -0
- package/package.json +1 -1
- package/public-api.d.ts +4 -1
package/esm2020/lib/components/form/input-date/components/date-calendar/date-calendar.component.mjs
ADDED
|
@@ -0,0 +1,222 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output } from '@angular/core';
|
|
2
|
+
import { cleanDate } from '../../helpers/date-helpers';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "@angular/common";
|
|
5
|
+
export class DateCalendarComponent {
|
|
6
|
+
constructor(_detector) {
|
|
7
|
+
this._detector = _detector;
|
|
8
|
+
this.selectedDate = null;
|
|
9
|
+
this.dateSelected = new EventEmitter();
|
|
10
|
+
this.close = new EventEmitter();
|
|
11
|
+
this.currentMonth = new Date().getMonth();
|
|
12
|
+
this.currentYear = new Date().getFullYear();
|
|
13
|
+
this.view = 'days';
|
|
14
|
+
this.monthNames = [
|
|
15
|
+
'Январь', 'Февраль', 'Март', 'Апрель', 'Май', 'Июнь',
|
|
16
|
+
'Июль', 'Август', 'Сентябрь', 'Октябрь', 'Ноябрь', 'Декабрь'
|
|
17
|
+
];
|
|
18
|
+
this.daysOfWeek = ['ПН', 'ВТ', 'СР', 'ЧТ', 'ПТ', 'СБ', 'ВС'];
|
|
19
|
+
this.months = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11];
|
|
20
|
+
this._minDate = null;
|
|
21
|
+
this._maxDate = null;
|
|
22
|
+
this._minDateStr = null;
|
|
23
|
+
this._maxDateStr = null;
|
|
24
|
+
this.calendarDaysCache = null;
|
|
25
|
+
}
|
|
26
|
+
ngOnInit() {
|
|
27
|
+
if (this.selectedDate) {
|
|
28
|
+
this.currentMonth = this.selectedDate.getMonth();
|
|
29
|
+
this.currentYear = this.selectedDate.getFullYear();
|
|
30
|
+
}
|
|
31
|
+
this.updateDateBounds();
|
|
32
|
+
}
|
|
33
|
+
set minDate(value) {
|
|
34
|
+
if (this._minDateStr !== value) {
|
|
35
|
+
this._minDateStr = value;
|
|
36
|
+
this.updateDateBounds();
|
|
37
|
+
this._detector.markForCheck();
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
get minDate() {
|
|
41
|
+
return this._minDateStr;
|
|
42
|
+
}
|
|
43
|
+
set maxDate(value) {
|
|
44
|
+
if (this._maxDateStr !== value) {
|
|
45
|
+
this._maxDateStr = value;
|
|
46
|
+
this.updateDateBounds();
|
|
47
|
+
this._detector.markForCheck();
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
get maxDate() {
|
|
51
|
+
return this._maxDateStr;
|
|
52
|
+
}
|
|
53
|
+
updateDateBounds() {
|
|
54
|
+
this._minDate = this._minDateStr ? cleanDate(this._minDateStr) : null;
|
|
55
|
+
this._maxDate = this._maxDateStr ? cleanDate(this._maxDateStr) : null;
|
|
56
|
+
}
|
|
57
|
+
get headerText() {
|
|
58
|
+
switch (this.view) {
|
|
59
|
+
case 'days':
|
|
60
|
+
return `${this.monthNames[this.currentMonth]} ${this.currentYear}`;
|
|
61
|
+
case 'months':
|
|
62
|
+
return `${this.currentYear}`;
|
|
63
|
+
default:
|
|
64
|
+
return 'Выберите год';
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
switchView() {
|
|
68
|
+
this.view = this.view === 'days' ? 'months' : this.view === 'months' ? 'years' : 'days';
|
|
69
|
+
this._detector.markForCheck();
|
|
70
|
+
}
|
|
71
|
+
getCalendarDays() {
|
|
72
|
+
if (this.calendarDaysCache?.month === this.currentMonth && this.calendarDaysCache?.year === this.currentYear) {
|
|
73
|
+
return this.calendarDaysCache.days;
|
|
74
|
+
}
|
|
75
|
+
const daysInMonth = new Date(this.currentYear, this.currentMonth + 1, 0).getDate();
|
|
76
|
+
const prevMonthDays = new Date(this.currentYear, this.currentMonth, 0).getDate();
|
|
77
|
+
const days = [];
|
|
78
|
+
const prevDaysCount = 2;
|
|
79
|
+
const prevMonth = this.currentMonth === 0 ? 11 : this.currentMonth - 1;
|
|
80
|
+
const prevYear = this.currentMonth === 0 ? this.currentYear - 1 : this.currentYear;
|
|
81
|
+
const nextMonth = this.currentMonth === 11 ? 0 : this.currentMonth + 1;
|
|
82
|
+
const nextYear = this.currentMonth === 11 ? this.currentYear + 1 : this.currentYear;
|
|
83
|
+
for (let i = 0; i < prevDaysCount; i++) {
|
|
84
|
+
days.push({ day: prevMonthDays - prevDaysCount + 1 + i, month: prevMonth, year: prevYear });
|
|
85
|
+
}
|
|
86
|
+
for (let i = 1; i <= daysInMonth; i++) {
|
|
87
|
+
days.push({ day: i, month: this.currentMonth, year: this.currentYear });
|
|
88
|
+
}
|
|
89
|
+
const remainingDays = 35 - days.length;
|
|
90
|
+
for (let i = 1; i <= remainingDays; i++) {
|
|
91
|
+
days.push({ day: i, month: nextMonth, year: nextYear });
|
|
92
|
+
}
|
|
93
|
+
this.calendarDaysCache = { month: this.currentMonth, year: this.currentYear, days };
|
|
94
|
+
return days;
|
|
95
|
+
}
|
|
96
|
+
getYears() {
|
|
97
|
+
const centerYear = this.selectedDate?.getFullYear() ?? this.currentYear;
|
|
98
|
+
const startYear = centerYear - 5;
|
|
99
|
+
return Array.from({ length: 12 }, (_, i) => startYear + i);
|
|
100
|
+
}
|
|
101
|
+
isSelected(day) {
|
|
102
|
+
if (!this.selectedDate)
|
|
103
|
+
return false;
|
|
104
|
+
return (day.day === this.selectedDate.getDate() &&
|
|
105
|
+
day.month === this.selectedDate.getMonth() &&
|
|
106
|
+
day.year === this.selectedDate.getFullYear());
|
|
107
|
+
}
|
|
108
|
+
isMonthSelected(month) {
|
|
109
|
+
return this.selectedDate?.getMonth() === month && this.selectedDate?.getFullYear() === this.currentYear;
|
|
110
|
+
}
|
|
111
|
+
isYearSelected(year) {
|
|
112
|
+
return this.selectedDate?.getFullYear() === year;
|
|
113
|
+
}
|
|
114
|
+
isDateEnabled(day) {
|
|
115
|
+
const date = new Date(day.year, day.month, day.day);
|
|
116
|
+
return ((!this._minDate || date >= this._minDate) &&
|
|
117
|
+
(!this._maxDate || date <= this._maxDate));
|
|
118
|
+
}
|
|
119
|
+
isMonthDisabled(month) {
|
|
120
|
+
if (!this._minDate && !this._maxDate)
|
|
121
|
+
return false;
|
|
122
|
+
const startOfMonth = new Date(this.currentYear, month, 1);
|
|
123
|
+
const endOfMonth = new Date(this.currentYear, month + 1, 0);
|
|
124
|
+
return ((!!this._minDate && !isNaN(this._minDate.getTime()) && endOfMonth < this._minDate) ||
|
|
125
|
+
(!!this._maxDate && !isNaN(this._maxDate.getTime()) && startOfMonth > this._maxDate));
|
|
126
|
+
}
|
|
127
|
+
isYearDisabled(year) {
|
|
128
|
+
if (!this._minDate && !this._maxDate)
|
|
129
|
+
return false;
|
|
130
|
+
const minYear = this._minDate && !isNaN(this._minDate.getTime()) ? this._minDate.getFullYear() : null;
|
|
131
|
+
const maxYear = this._maxDate && !isNaN(this._maxDate.getTime()) ? this._maxDate.getFullYear() : null;
|
|
132
|
+
return (minYear !== null && year < minYear) || (maxYear !== null && year > maxYear);
|
|
133
|
+
}
|
|
134
|
+
selectDate(day) {
|
|
135
|
+
if (!this.isDateEnabled(day))
|
|
136
|
+
return;
|
|
137
|
+
const date = new Date(day.year, day.month, day.day);
|
|
138
|
+
this.dateSelected.emit(date);
|
|
139
|
+
const needsUpdate = day.month !== this.currentMonth || day.year !== this.currentYear;
|
|
140
|
+
if (needsUpdate) {
|
|
141
|
+
setTimeout(() => {
|
|
142
|
+
this.currentMonth = day.month;
|
|
143
|
+
this.currentYear = day.year;
|
|
144
|
+
this._detector.markForCheck();
|
|
145
|
+
});
|
|
146
|
+
}
|
|
147
|
+
}
|
|
148
|
+
selectMonth(month) {
|
|
149
|
+
if (this.isMonthDisabled(month))
|
|
150
|
+
return;
|
|
151
|
+
setTimeout(() => {
|
|
152
|
+
this.currentMonth = month;
|
|
153
|
+
this.view = 'days';
|
|
154
|
+
this._detector.markForCheck();
|
|
155
|
+
});
|
|
156
|
+
}
|
|
157
|
+
selectYear(year) {
|
|
158
|
+
if (this.isYearDisabled(year))
|
|
159
|
+
return;
|
|
160
|
+
setTimeout(() => {
|
|
161
|
+
this.currentYear = year;
|
|
162
|
+
this.view = 'months';
|
|
163
|
+
this._detector.markForCheck();
|
|
164
|
+
});
|
|
165
|
+
}
|
|
166
|
+
changeMonth(offset) {
|
|
167
|
+
let newMonth = this.currentMonth + offset;
|
|
168
|
+
let newYear = this.currentYear;
|
|
169
|
+
if (newMonth < 0) {
|
|
170
|
+
newMonth = 11;
|
|
171
|
+
newYear--;
|
|
172
|
+
}
|
|
173
|
+
else if (newMonth > 11) {
|
|
174
|
+
newMonth = 0;
|
|
175
|
+
newYear++;
|
|
176
|
+
}
|
|
177
|
+
this.currentMonth = newMonth;
|
|
178
|
+
this.currentYear = newYear;
|
|
179
|
+
this._detector.markForCheck();
|
|
180
|
+
}
|
|
181
|
+
changeYearRange(offset) {
|
|
182
|
+
this.currentYear += offset * 12;
|
|
183
|
+
this._detector.markForCheck();
|
|
184
|
+
}
|
|
185
|
+
isPreviousMonthDisabled() {
|
|
186
|
+
if (!this._minDate)
|
|
187
|
+
return false;
|
|
188
|
+
return new Date(this.currentYear, this.currentMonth, 0) < this._minDate;
|
|
189
|
+
}
|
|
190
|
+
isNextMonthDisabled() {
|
|
191
|
+
if (!this._maxDate)
|
|
192
|
+
return false;
|
|
193
|
+
return new Date(this.currentYear, this.currentMonth + 1, 1) > this._maxDate;
|
|
194
|
+
}
|
|
195
|
+
isPreviousYearRangeDisabled() {
|
|
196
|
+
if (!this._minDate)
|
|
197
|
+
return false;
|
|
198
|
+
return this.getYears()[0] <= this._minDate.getFullYear();
|
|
199
|
+
}
|
|
200
|
+
isNextYearRangeDisabled() {
|
|
201
|
+
if (!this._maxDate)
|
|
202
|
+
return false;
|
|
203
|
+
return this.getYears()[this.getYears().length - 1] >= this._maxDate.getFullYear();
|
|
204
|
+
}
|
|
205
|
+
}
|
|
206
|
+
DateCalendarComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: DateCalendarComponent, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
207
|
+
DateCalendarComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.4.0", type: DateCalendarComponent, selector: "mrx-date-calendar", inputs: { selectedDate: "selectedDate", minDate: "minDate", maxDate: "maxDate" }, outputs: { dateSelected: "dateSelected", close: "close" }, ngImport: i0, template: "<div class=\"mrx-calendar\">\r\n <div class=\"mrx-calendar-header\">\r\n <button\r\n *ngIf=\"view === 'days'\"\r\n class=\"mrx-calendar-header__chevron\"\r\n [disabled]=\"isPreviousMonthDisabled()\"\r\n (click)=\"changeMonth(-1)\"\r\n >\r\n <span class=\"mrx-icon icon-chevron-left icon-font-16\"></span>\r\n </button>\r\n\r\n <button\r\n *ngIf=\"view === 'years'\"\r\n class=\"mrx-calendar-header__chevron\"\r\n [disabled]=\"isPreviousYearRangeDisabled()\"\r\n (click)=\"changeYearRange(-1)\"\r\n >\r\n <span class=\"mrx-icon icon-chevron-left icon-font-16\"></span>\r\n </button>\r\n\r\n <button class=\"mrx-calendar-header__button\" (click)=\"switchView()\">\r\n {{ headerText }}\r\n </button>\r\n\r\n <button\r\n *ngIf=\"view === 'days'\"\r\n class=\"mrx-calendar-header__chevron\"\r\n [disabled]=\"isNextMonthDisabled()\"\r\n (click)=\"changeMonth(1)\"\r\n >\r\n <span class=\"mrx-icon icon-chevron-right icon-font-16\"></span>\r\n </button>\r\n\r\n <button\r\n *ngIf=\"view === 'years'\"\r\n class=\"mrx-calendar-header__chevron\"\r\n [disabled]=\"isNextYearRangeDisabled()\"\r\n (click)=\"changeYearRange(1)\"\r\n >\r\n <span class=\"mrx-icon icon-chevron-right icon-font-16\"></span>\r\n </button>\r\n </div>\r\n\r\n <div class=\"mrx-calendar-body\">\r\n <ng-container [ngSwitch]=\"view\">\r\n <ng-container *ngSwitchCase=\"'years'\">\r\n <div class=\"mrx-calendar-body__grid mrx-calendar-body__grid--years\">\r\n <div\r\n *ngFor=\"let year of getYears()\"\r\n class=\"mrx-calendar-body__grid__item mrx-calendar-body__grid__item--year\"\r\n [class.selected]=\"isYearSelected(year)\"\r\n [class.disabled]=\"isYearDisabled(year)\"\r\n [class.hoverable]=\"!isYearDisabled(year)\"\r\n (click)=\"selectYear(year)\"\r\n >\r\n {{ year }}\r\n </div>\r\n </div>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'months'\">\r\n <div class=\"mrx-calendar-body__grid mrx-calendar-body__grid--months\">\r\n <div\r\n *ngFor=\"let month of months\"\r\n class=\"mrx-calendar-body__grid__item mrx-calendar-body__grid__item--month\"\r\n [class.selected]=\"isMonthSelected(month)\"\r\n [class.disabled]=\"isMonthDisabled(month)\"\r\n [class.hoverable]=\"!isMonthDisabled(month)\"\r\n (click)=\"selectMonth(month)\"\r\n >\r\n {{ monthNames[month] }}\r\n </div>\r\n </div>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchDefault>\r\n <div class=\"mrx-calendar-body__grid mrx-calendar-body__grid--days\">\r\n <div *ngFor=\"let day of daysOfWeek\" class=\"mrx-calendar-body__grid__label\">\r\n {{ day }}\r\n </div>\r\n\r\n <div\r\n *ngFor=\"let day of getCalendarDays()\"\r\n class=\"mrx-calendar-body__grid__item mrx-calendar-body__grid__item--day\"\r\n [class.selected]=\"isSelected(day)\"\r\n [class.other-month]=\"day.month !== currentMonth\"\r\n [class.disabled]=\"!isDateEnabled(day)\"\r\n [class.hoverable]=\"isDateEnabled(day)\"\r\n (click)=\"selectDate(day)\"\r\n >\r\n {{ day.day }}\r\n </div>\r\n </div>\r\n </ng-container>\r\n </ng-container>\r\n </div>\r\n</div>\r\n", styles: [".mrx-calendar{width:272px;border-radius:4px;background-color:var(--brand-bg-tertiary-default, #FFF);box-shadow:0 1px 4px #3a3a3a4d}.mrx-calendar-header{display:flex;justify-content:space-between;align-items:center;gap:8px;padding:8px 12px;border-bottom:1px solid var(--neutral-bg-divider, #DBDFE5)}.mrx-calendar-header__button{border:none;border-radius:4px;background-color:transparent;padding:6px 12px;text-align:center;flex-grow:1;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);color:var(--neutral-text-primary, #262626);cursor:pointer;transition:background-color .3s}.mrx-calendar-header__button:hover{background-color:var(--brand-bg-tertiary-hover, #EDF5FF)}.mrx-calendar-header__chevron{display:flex;justify-content:center;align-items:center;width:32px;height:32px;border:none;border-radius:4px;background-color:transparent;cursor:pointer;transition:background-color .3s}.mrx-calendar-header__chevron:hover{background-color:var(--brand-bg-tertiary-hover, #EDF5FF)}.mrx-calendar-header__chevron:disabled{cursor:default}.mrx-calendar-header__chevron:disabled:hover{background-color:var(--neutral-bg-island-default, #F8F9FA)}.mrx-calendar-body{padding:8px 12px}.mrx-calendar-body__grid--days{display:grid;grid-template-columns:repeat(7,1fr);grid-gap:4px;gap:4px;text-align:center}.mrx-calendar-body__grid--months{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:8px;gap:8px;text-align:center}.mrx-calendar-body__grid--years{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:8px;gap:8px;text-align:center;max-height:190px;overflow-y:auto}.mrx-calendar-body__grid__label{display:flex;justify-content:center;align-items:center;width:32px;height:32px;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);color:var(--brand-text-accent, #003780)}.mrx-calendar-body__grid__item{display:flex;justify-content:center;align-items:center;border-radius:4px;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);color:var(--neutral-text-primary, #262626);transition:background-color .3s}.mrx-calendar-body__grid__item--day{width:32px;height:32px}.mrx-calendar-body__grid__item--month,.mrx-calendar-body__grid__item--year{height:32px}.mrx-calendar-body__grid__item.hoverable{cursor:pointer}.mrx-calendar-body__grid__item.hoverable:hover{background-color:var(--brand-bg-tertiary-hover, #EDF5FF)}.mrx-calendar-body__grid__item.selected{background-color:var(--brand-bg-primary-default, #2A6AB8);color:var(--neutral-text-inverse, #FFF)}.mrx-calendar-body__grid__item.selected:hover{background-color:var(--brand-bg-primary-hover, #0F54AA)}.mrx-calendar-body__grid__item.other-month{background-color:transparent;color:var(--neutral-text-tertiary, #71767E)}.mrx-calendar-body__grid__item.other-month.selected{background-color:var(--brand-bg-secondary-default, #EDF5FF);color:var(--neutral-text-tertiary, #71767E)}.mrx-calendar-body__grid__item.other-month.selected:hover{background-color:var(--brand-bg-secondary-hover, #BED6F1)}.mrx-calendar-body__grid__item.other-month:hover{background-color:var(--neutral-bg-island-default, #F8F9FA)}.mrx-calendar-body__grid__item.disabled{background-color:transparent;color:var(--neutral-text-tertiary, #71767E)}.mrx-calendar-body__grid__item.disabled:hover{background-color:var(--neutral-bg-island-default, #F8F9FA)}\n"], directives: [{ type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i1.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { type: i1.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i1.NgSwitchDefault, selector: "[ngSwitchDefault]" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
208
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: DateCalendarComponent, decorators: [{
|
|
209
|
+
type: Component,
|
|
210
|
+
args: [{ selector: 'mrx-date-calendar', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"mrx-calendar\">\r\n <div class=\"mrx-calendar-header\">\r\n <button\r\n *ngIf=\"view === 'days'\"\r\n class=\"mrx-calendar-header__chevron\"\r\n [disabled]=\"isPreviousMonthDisabled()\"\r\n (click)=\"changeMonth(-1)\"\r\n >\r\n <span class=\"mrx-icon icon-chevron-left icon-font-16\"></span>\r\n </button>\r\n\r\n <button\r\n *ngIf=\"view === 'years'\"\r\n class=\"mrx-calendar-header__chevron\"\r\n [disabled]=\"isPreviousYearRangeDisabled()\"\r\n (click)=\"changeYearRange(-1)\"\r\n >\r\n <span class=\"mrx-icon icon-chevron-left icon-font-16\"></span>\r\n </button>\r\n\r\n <button class=\"mrx-calendar-header__button\" (click)=\"switchView()\">\r\n {{ headerText }}\r\n </button>\r\n\r\n <button\r\n *ngIf=\"view === 'days'\"\r\n class=\"mrx-calendar-header__chevron\"\r\n [disabled]=\"isNextMonthDisabled()\"\r\n (click)=\"changeMonth(1)\"\r\n >\r\n <span class=\"mrx-icon icon-chevron-right icon-font-16\"></span>\r\n </button>\r\n\r\n <button\r\n *ngIf=\"view === 'years'\"\r\n class=\"mrx-calendar-header__chevron\"\r\n [disabled]=\"isNextYearRangeDisabled()\"\r\n (click)=\"changeYearRange(1)\"\r\n >\r\n <span class=\"mrx-icon icon-chevron-right icon-font-16\"></span>\r\n </button>\r\n </div>\r\n\r\n <div class=\"mrx-calendar-body\">\r\n <ng-container [ngSwitch]=\"view\">\r\n <ng-container *ngSwitchCase=\"'years'\">\r\n <div class=\"mrx-calendar-body__grid mrx-calendar-body__grid--years\">\r\n <div\r\n *ngFor=\"let year of getYears()\"\r\n class=\"mrx-calendar-body__grid__item mrx-calendar-body__grid__item--year\"\r\n [class.selected]=\"isYearSelected(year)\"\r\n [class.disabled]=\"isYearDisabled(year)\"\r\n [class.hoverable]=\"!isYearDisabled(year)\"\r\n (click)=\"selectYear(year)\"\r\n >\r\n {{ year }}\r\n </div>\r\n </div>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'months'\">\r\n <div class=\"mrx-calendar-body__grid mrx-calendar-body__grid--months\">\r\n <div\r\n *ngFor=\"let month of months\"\r\n class=\"mrx-calendar-body__grid__item mrx-calendar-body__grid__item--month\"\r\n [class.selected]=\"isMonthSelected(month)\"\r\n [class.disabled]=\"isMonthDisabled(month)\"\r\n [class.hoverable]=\"!isMonthDisabled(month)\"\r\n (click)=\"selectMonth(month)\"\r\n >\r\n {{ monthNames[month] }}\r\n </div>\r\n </div>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchDefault>\r\n <div class=\"mrx-calendar-body__grid mrx-calendar-body__grid--days\">\r\n <div *ngFor=\"let day of daysOfWeek\" class=\"mrx-calendar-body__grid__label\">\r\n {{ day }}\r\n </div>\r\n\r\n <div\r\n *ngFor=\"let day of getCalendarDays()\"\r\n class=\"mrx-calendar-body__grid__item mrx-calendar-body__grid__item--day\"\r\n [class.selected]=\"isSelected(day)\"\r\n [class.other-month]=\"day.month !== currentMonth\"\r\n [class.disabled]=\"!isDateEnabled(day)\"\r\n [class.hoverable]=\"isDateEnabled(day)\"\r\n (click)=\"selectDate(day)\"\r\n >\r\n {{ day.day }}\r\n </div>\r\n </div>\r\n </ng-container>\r\n </ng-container>\r\n </div>\r\n</div>\r\n", styles: [".mrx-calendar{width:272px;border-radius:4px;background-color:var(--brand-bg-tertiary-default, #FFF);box-shadow:0 1px 4px #3a3a3a4d}.mrx-calendar-header{display:flex;justify-content:space-between;align-items:center;gap:8px;padding:8px 12px;border-bottom:1px solid var(--neutral-bg-divider, #DBDFE5)}.mrx-calendar-header__button{border:none;border-radius:4px;background-color:transparent;padding:6px 12px;text-align:center;flex-grow:1;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);color:var(--neutral-text-primary, #262626);cursor:pointer;transition:background-color .3s}.mrx-calendar-header__button:hover{background-color:var(--brand-bg-tertiary-hover, #EDF5FF)}.mrx-calendar-header__chevron{display:flex;justify-content:center;align-items:center;width:32px;height:32px;border:none;border-radius:4px;background-color:transparent;cursor:pointer;transition:background-color .3s}.mrx-calendar-header__chevron:hover{background-color:var(--brand-bg-tertiary-hover, #EDF5FF)}.mrx-calendar-header__chevron:disabled{cursor:default}.mrx-calendar-header__chevron:disabled:hover{background-color:var(--neutral-bg-island-default, #F8F9FA)}.mrx-calendar-body{padding:8px 12px}.mrx-calendar-body__grid--days{display:grid;grid-template-columns:repeat(7,1fr);grid-gap:4px;gap:4px;text-align:center}.mrx-calendar-body__grid--months{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:8px;gap:8px;text-align:center}.mrx-calendar-body__grid--years{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:8px;gap:8px;text-align:center;max-height:190px;overflow-y:auto}.mrx-calendar-body__grid__label{display:flex;justify-content:center;align-items:center;width:32px;height:32px;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);color:var(--brand-text-accent, #003780)}.mrx-calendar-body__grid__item{display:flex;justify-content:center;align-items:center;border-radius:4px;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);color:var(--neutral-text-primary, #262626);transition:background-color .3s}.mrx-calendar-body__grid__item--day{width:32px;height:32px}.mrx-calendar-body__grid__item--month,.mrx-calendar-body__grid__item--year{height:32px}.mrx-calendar-body__grid__item.hoverable{cursor:pointer}.mrx-calendar-body__grid__item.hoverable:hover{background-color:var(--brand-bg-tertiary-hover, #EDF5FF)}.mrx-calendar-body__grid__item.selected{background-color:var(--brand-bg-primary-default, #2A6AB8);color:var(--neutral-text-inverse, #FFF)}.mrx-calendar-body__grid__item.selected:hover{background-color:var(--brand-bg-primary-hover, #0F54AA)}.mrx-calendar-body__grid__item.other-month{background-color:transparent;color:var(--neutral-text-tertiary, #71767E)}.mrx-calendar-body__grid__item.other-month.selected{background-color:var(--brand-bg-secondary-default, #EDF5FF);color:var(--neutral-text-tertiary, #71767E)}.mrx-calendar-body__grid__item.other-month.selected:hover{background-color:var(--brand-bg-secondary-hover, #BED6F1)}.mrx-calendar-body__grid__item.other-month:hover{background-color:var(--neutral-bg-island-default, #F8F9FA)}.mrx-calendar-body__grid__item.disabled{background-color:transparent;color:var(--neutral-text-tertiary, #71767E)}.mrx-calendar-body__grid__item.disabled:hover{background-color:var(--neutral-bg-island-default, #F8F9FA)}\n"] }]
|
|
211
|
+
}], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }]; }, propDecorators: { selectedDate: [{
|
|
212
|
+
type: Input
|
|
213
|
+
}], dateSelected: [{
|
|
214
|
+
type: Output
|
|
215
|
+
}], close: [{
|
|
216
|
+
type: Output
|
|
217
|
+
}], minDate: [{
|
|
218
|
+
type: Input
|
|
219
|
+
}], maxDate: [{
|
|
220
|
+
type: Input
|
|
221
|
+
}] } });
|
|
222
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-calendar.component.js","sourceRoot":"","sources":["../../../../../../../../../projects/myrta-ui/src/lib/components/form/input-date/components/date-calendar/date-calendar.component.ts","../../../../../../../../../projects/myrta-ui/src/lib/components/form/input-date/components/date-calendar/date-calendar.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectionStrategy,\r\n  ChangeDetectorRef,\r\n  Component,\r\n  EventEmitter,\r\n  Input,\r\n  OnInit,\r\n  Output\r\n} from '@angular/core';\r\nimport { cleanDate } from '../../helpers/date-helpers';\r\n\r\n@Component({\r\n  selector: 'mrx-date-calendar',\r\n  templateUrl: './date-calendar.component.html',\r\n  styleUrls: ['./date-calendar.component.less'],\r\n  changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class DateCalendarComponent implements OnInit {\r\n  @Input() selectedDate: Date | null = null;\r\n  @Output() dateSelected = new EventEmitter<Date>();\r\n  @Output() close = new EventEmitter<void>();\r\n\r\n  currentMonth: number = new Date().getMonth();\r\n  currentYear: number = new Date().getFullYear();\r\n  view: 'days' | 'months' | 'years' = 'days';\r\n  readonly monthNames: string[] = [\r\n    'Январь', 'Февраль', 'Март', 'Апрель', 'Май', 'Июнь',\r\n    'Июль', 'Август', 'Сентябрь', 'Октябрь', 'Ноябрь', 'Декабрь'\r\n  ];\r\n  readonly daysOfWeek: string[] = ['ПН', 'ВТ', 'СР', 'ЧТ', 'ПТ', 'СБ', 'ВС'];\r\n  readonly months: number[] = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11];\r\n\r\n  private _minDate: Date | null = null;\r\n  private _maxDate: Date | null = null;\r\n  private _minDateStr: string | null = null;\r\n  private _maxDateStr: string | null = null;\r\n  private calendarDaysCache: {\r\n    month: number;\r\n    year: number;\r\n    days: { day: number, month: number, year: number }[]\r\n  } | null = null;\r\n\r\n  constructor(private _detector: ChangeDetectorRef) {\r\n  }\r\n\r\n  ngOnInit() {\r\n    if (this.selectedDate) {\r\n      this.currentMonth = this.selectedDate.getMonth();\r\n      this.currentYear = this.selectedDate.getFullYear();\r\n    }\r\n    this.updateDateBounds();\r\n  }\r\n\r\n  @Input()\r\n  set minDate(value: string | null) {\r\n    if (this._minDateStr !== value) {\r\n      this._minDateStr = value;\r\n      this.updateDateBounds();\r\n      this._detector.markForCheck();\r\n    }\r\n  }\r\n\r\n  get minDate(): string | null {\r\n    return this._minDateStr;\r\n  }\r\n\r\n  @Input()\r\n  set maxDate(value: string | null) {\r\n    if (this._maxDateStr !== value) {\r\n      this._maxDateStr = value;\r\n      this.updateDateBounds();\r\n      this._detector.markForCheck();\r\n    }\r\n  }\r\n\r\n  get maxDate(): string | null {\r\n    return this._maxDateStr;\r\n  }\r\n\r\n  private updateDateBounds() {\r\n    this._minDate = this._minDateStr ? cleanDate(this._minDateStr) : null;\r\n    this._maxDate = this._maxDateStr ? cleanDate(this._maxDateStr) : null;\r\n  }\r\n\r\n  get headerText(): string {\r\n    switch (this.view) {\r\n      case 'days':\r\n        return `${this.monthNames[this.currentMonth]} ${this.currentYear}`;\r\n      case 'months':\r\n        return `${this.currentYear}`;\r\n      default:\r\n        return 'Выберите год';\r\n    }\r\n  }\r\n\r\n  switchView() {\r\n    this.view = this.view === 'days' ? 'months' : this.view === 'months' ? 'years' : 'days';\r\n    this._detector.markForCheck();\r\n  }\r\n\r\n  getCalendarDays(): { day: number, month: number, year: number }[] {\r\n    if (this.calendarDaysCache?.month === this.currentMonth && this.calendarDaysCache?.year === this.currentYear) {\r\n      return this.calendarDaysCache.days;\r\n    }\r\n\r\n    const daysInMonth = new Date(this.currentYear, this.currentMonth + 1, 0).getDate();\r\n    const prevMonthDays = new Date(this.currentYear, this.currentMonth, 0).getDate();\r\n\r\n    const days: { day: number, month: number, year: number }[] = [];\r\n    const prevDaysCount = 2;\r\n    const prevMonth = this.currentMonth === 0 ? 11 : this.currentMonth - 1;\r\n    const prevYear = this.currentMonth === 0 ? this.currentYear - 1 : this.currentYear;\r\n    const nextMonth = this.currentMonth === 11 ? 0 : this.currentMonth + 1;\r\n    const nextYear = this.currentMonth === 11 ? this.currentYear + 1 : this.currentYear;\r\n\r\n    for (let i = 0; i < prevDaysCount; i++) {\r\n      days.push({day: prevMonthDays - prevDaysCount + 1 + i, month: prevMonth, year: prevYear});\r\n    }\r\n\r\n    for (let i = 1; i <= daysInMonth; i++) {\r\n      days.push({day: i, month: this.currentMonth, year: this.currentYear});\r\n    }\r\n\r\n    const remainingDays = 35 - days.length;\r\n\r\n    for (let i = 1; i <= remainingDays; i++) {\r\n      days.push({day: i, month: nextMonth, year: nextYear});\r\n    }\r\n\r\n    this.calendarDaysCache = {month: this.currentMonth, year: this.currentYear, days};\r\n    return days;\r\n  }\r\n\r\n  getYears(): number[] {\r\n    const centerYear = this.selectedDate?.getFullYear() ?? this.currentYear;\r\n    const startYear = centerYear - 5;\r\n\r\n    return Array.from({length: 12}, (_, i) => startYear + i);\r\n  }\r\n\r\n  isSelected(day: { day: number, month: number, year: number }): boolean {\r\n    if (!this.selectedDate) return false;\r\n\r\n    return (\r\n      day.day === this.selectedDate.getDate() &&\r\n      day.month === this.selectedDate.getMonth() &&\r\n      day.year === this.selectedDate.getFullYear()\r\n    );\r\n  }\r\n\r\n  isMonthSelected(month: number): boolean {\r\n    return this.selectedDate?.getMonth() === month && this.selectedDate?.getFullYear() === this.currentYear;\r\n  }\r\n\r\n  isYearSelected(year: number): boolean {\r\n    return this.selectedDate?.getFullYear() === year;\r\n  }\r\n\r\n  isDateEnabled(day: { day: number, month: number, year: number }): boolean {\r\n    const date = new Date(day.year, day.month, day.day);\r\n    return (\r\n      (!this._minDate || date >= this._minDate) &&\r\n      (!this._maxDate || date <= this._maxDate)\r\n    );\r\n  }\r\n\r\n  isMonthDisabled(month: number): boolean {\r\n    if (!this._minDate && !this._maxDate) return false;\r\n\r\n    const startOfMonth = new Date(this.currentYear, month, 1);\r\n    const endOfMonth = new Date(this.currentYear, month + 1, 0);\r\n\r\n    return (\r\n      (!!this._minDate && !isNaN(this._minDate.getTime()) && endOfMonth < this._minDate) ||\r\n      (!!this._maxDate && !isNaN(this._maxDate.getTime()) && startOfMonth > this._maxDate)\r\n    );\r\n  }\r\n\r\n  isYearDisabled(year: number): boolean {\r\n    if (!this._minDate && !this._maxDate) return false;\r\n\r\n    const minYear = this._minDate && !isNaN(this._minDate.getTime()) ? this._minDate.getFullYear() : null;\r\n    const maxYear = this._maxDate && !isNaN(this._maxDate.getTime()) ? this._maxDate.getFullYear() : null;\r\n\r\n    return (minYear !== null && year < minYear) || (maxYear !== null && year > maxYear);\r\n  }\r\n\r\n  selectDate(day: { day: number, month: number, year: number }) {\r\n    if (!this.isDateEnabled(day)) return;\r\n\r\n    const date = new Date(day.year, day.month, day.day);\r\n\r\n    this.dateSelected.emit(date);\r\n\r\n    const needsUpdate = day.month !== this.currentMonth || day.year !== this.currentYear;\r\n\r\n    if (needsUpdate) {\r\n      setTimeout(() => {\r\n        this.currentMonth = day.month;\r\n        this.currentYear = day.year;\r\n\r\n        this._detector.markForCheck();\r\n      });\r\n    }\r\n  }\r\n\r\n  selectMonth(month: number) {\r\n    if (this.isMonthDisabled(month)) return;\r\n\r\n    setTimeout(() => {\r\n      this.currentMonth = month;\r\n      this.view = 'days';\r\n\r\n      this._detector.markForCheck();\r\n    });\r\n  }\r\n\r\n  selectYear(year: number) {\r\n    if (this.isYearDisabled(year)) return;\r\n\r\n    setTimeout(() => {\r\n      this.currentYear = year;\r\n      this.view = 'months';\r\n\r\n      this._detector.markForCheck();\r\n    });\r\n  }\r\n\r\n  changeMonth(offset: number) {\r\n    let newMonth = this.currentMonth + offset;\r\n    let newYear = this.currentYear;\r\n\r\n    if (newMonth < 0) {\r\n      newMonth = 11;\r\n      newYear--;\r\n    } else if (newMonth > 11) {\r\n      newMonth = 0;\r\n      newYear++;\r\n    }\r\n\r\n    this.currentMonth = newMonth;\r\n    this.currentYear = newYear;\r\n    this._detector.markForCheck();\r\n  }\r\n\r\n  changeYearRange(offset: number) {\r\n    this.currentYear += offset * 12;\r\n    this._detector.markForCheck();\r\n  }\r\n\r\n  isPreviousMonthDisabled(): boolean {\r\n    if (!this._minDate) return false;\r\n    return new Date(this.currentYear, this.currentMonth, 0) < this._minDate;\r\n  }\r\n\r\n  isNextMonthDisabled(): boolean {\r\n    if (!this._maxDate) return false;\r\n    return new Date(this.currentYear, this.currentMonth + 1, 1) > this._maxDate;\r\n  }\r\n\r\n  isPreviousYearRangeDisabled(): boolean {\r\n    if (!this._minDate) return false;\r\n    return this.getYears()[0] <= this._minDate.getFullYear();\r\n  }\r\n\r\n  isNextYearRangeDisabled(): boolean {\r\n    if (!this._maxDate) return false;\r\n    return this.getYears()[this.getYears().length - 1] >= this._maxDate.getFullYear();\r\n  }\r\n}\r\n","<div class=\"mrx-calendar\">\r\n  <div class=\"mrx-calendar-header\">\r\n    <button\r\n      *ngIf=\"view === 'days'\"\r\n      class=\"mrx-calendar-header__chevron\"\r\n      [disabled]=\"isPreviousMonthDisabled()\"\r\n      (click)=\"changeMonth(-1)\"\r\n    >\r\n      <span class=\"mrx-icon icon-chevron-left icon-font-16\"></span>\r\n    </button>\r\n\r\n    <button\r\n      *ngIf=\"view === 'years'\"\r\n      class=\"mrx-calendar-header__chevron\"\r\n      [disabled]=\"isPreviousYearRangeDisabled()\"\r\n      (click)=\"changeYearRange(-1)\"\r\n    >\r\n      <span class=\"mrx-icon icon-chevron-left icon-font-16\"></span>\r\n    </button>\r\n\r\n    <button class=\"mrx-calendar-header__button\" (click)=\"switchView()\">\r\n      {{ headerText }}\r\n    </button>\r\n\r\n    <button\r\n      *ngIf=\"view === 'days'\"\r\n      class=\"mrx-calendar-header__chevron\"\r\n      [disabled]=\"isNextMonthDisabled()\"\r\n      (click)=\"changeMonth(1)\"\r\n    >\r\n      <span class=\"mrx-icon icon-chevron-right icon-font-16\"></span>\r\n    </button>\r\n\r\n    <button\r\n      *ngIf=\"view === 'years'\"\r\n      class=\"mrx-calendar-header__chevron\"\r\n      [disabled]=\"isNextYearRangeDisabled()\"\r\n      (click)=\"changeYearRange(1)\"\r\n    >\r\n      <span class=\"mrx-icon icon-chevron-right icon-font-16\"></span>\r\n    </button>\r\n  </div>\r\n\r\n  <div class=\"mrx-calendar-body\">\r\n    <ng-container [ngSwitch]=\"view\">\r\n      <ng-container *ngSwitchCase=\"'years'\">\r\n        <div class=\"mrx-calendar-body__grid mrx-calendar-body__grid--years\">\r\n          <div\r\n            *ngFor=\"let year of getYears()\"\r\n            class=\"mrx-calendar-body__grid__item mrx-calendar-body__grid__item--year\"\r\n            [class.selected]=\"isYearSelected(year)\"\r\n            [class.disabled]=\"isYearDisabled(year)\"\r\n            [class.hoverable]=\"!isYearDisabled(year)\"\r\n            (click)=\"selectYear(year)\"\r\n          >\r\n            {{ year }}\r\n          </div>\r\n        </div>\r\n      </ng-container>\r\n\r\n      <ng-container *ngSwitchCase=\"'months'\">\r\n        <div class=\"mrx-calendar-body__grid mrx-calendar-body__grid--months\">\r\n          <div\r\n            *ngFor=\"let month of months\"\r\n            class=\"mrx-calendar-body__grid__item mrx-calendar-body__grid__item--month\"\r\n            [class.selected]=\"isMonthSelected(month)\"\r\n            [class.disabled]=\"isMonthDisabled(month)\"\r\n            [class.hoverable]=\"!isMonthDisabled(month)\"\r\n            (click)=\"selectMonth(month)\"\r\n          >\r\n            {{ monthNames[month] }}\r\n          </div>\r\n        </div>\r\n      </ng-container>\r\n\r\n      <ng-container *ngSwitchDefault>\r\n        <div class=\"mrx-calendar-body__grid mrx-calendar-body__grid--days\">\r\n          <div *ngFor=\"let day of daysOfWeek\" class=\"mrx-calendar-body__grid__label\">\r\n            {{ day }}\r\n          </div>\r\n\r\n          <div\r\n            *ngFor=\"let day of getCalendarDays()\"\r\n            class=\"mrx-calendar-body__grid__item mrx-calendar-body__grid__item--day\"\r\n            [class.selected]=\"isSelected(day)\"\r\n            [class.other-month]=\"day.month !== currentMonth\"\r\n            [class.disabled]=\"!isDateEnabled(day)\"\r\n            [class.hoverable]=\"isDateEnabled(day)\"\r\n            (click)=\"selectDate(day)\"\r\n          >\r\n            {{ day.day }}\r\n          </div>\r\n        </div>\r\n      </ng-container>\r\n    </ng-container>\r\n  </div>\r\n</div>\r\n"]}
|
|
@@ -0,0 +1,70 @@
|
|
|
1
|
+
export function formatDate(date, format) {
|
|
2
|
+
const pad = (n) => n.toString().padStart(2, '0');
|
|
3
|
+
const map = {
|
|
4
|
+
'DD': pad(date.getDate()),
|
|
5
|
+
'MM': pad(date.getMonth() + 1),
|
|
6
|
+
'YYYY': date.getFullYear().toString()
|
|
7
|
+
};
|
|
8
|
+
return format.replace(/DD|MM|YYYY/g, match => map[match]);
|
|
9
|
+
}
|
|
10
|
+
export function toOutputFormat(date) {
|
|
11
|
+
const pad = (n) => n.toString().padStart(2, '0');
|
|
12
|
+
return `${date.getFullYear()}-${pad(date.getMonth() + 1)}-${pad(date.getDate())}`;
|
|
13
|
+
}
|
|
14
|
+
export function isValidDate(date) {
|
|
15
|
+
return date instanceof Date && !isNaN(date.getTime());
|
|
16
|
+
}
|
|
17
|
+
export function getDaysInMonth(year, month) {
|
|
18
|
+
return new Date(year, month + 1, 0).getDate();
|
|
19
|
+
}
|
|
20
|
+
export function isDateInRange(date, minDate, maxDate) {
|
|
21
|
+
const min = minDate ? cleanDate(minDate) : null;
|
|
22
|
+
const max = maxDate ? cleanDate(maxDate) : null;
|
|
23
|
+
return (!min || date >= min) && (!max || date <= max);
|
|
24
|
+
}
|
|
25
|
+
export function clampDate(date, minDate, maxDate) {
|
|
26
|
+
const min = minDate ? cleanDate(minDate) : null;
|
|
27
|
+
const max = maxDate ? cleanDate(maxDate) : null;
|
|
28
|
+
if (min && date < min)
|
|
29
|
+
return new Date(min);
|
|
30
|
+
if (max && date > max)
|
|
31
|
+
return new Date(max);
|
|
32
|
+
return date;
|
|
33
|
+
}
|
|
34
|
+
export function getRangeErrorMessage(date, minDate, maxDate) {
|
|
35
|
+
const min = minDate ? cleanDate(minDate) : null;
|
|
36
|
+
const max = maxDate ? cleanDate(maxDate) : null;
|
|
37
|
+
if (min && date < min)
|
|
38
|
+
return 'Дата меньше минимальной';
|
|
39
|
+
if (max && date > max)
|
|
40
|
+
return 'Дата больше максимальной';
|
|
41
|
+
return '';
|
|
42
|
+
}
|
|
43
|
+
export function parseInputDate(dateStr) {
|
|
44
|
+
if (dateStr) {
|
|
45
|
+
const [year, month, day] = dateStr.split('-').map(Number);
|
|
46
|
+
const date = new Date(year, month - 1, day);
|
|
47
|
+
return isValidDate(date) ? date : null;
|
|
48
|
+
}
|
|
49
|
+
else {
|
|
50
|
+
return null;
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
export function adjustInvalidDate(year, month, day) {
|
|
54
|
+
const maxDays = getDaysInMonth(year, month);
|
|
55
|
+
if (day > maxDays) {
|
|
56
|
+
month += 1;
|
|
57
|
+
if (month > 11) {
|
|
58
|
+
month = 0;
|
|
59
|
+
year += 1;
|
|
60
|
+
}
|
|
61
|
+
day = 1;
|
|
62
|
+
}
|
|
63
|
+
year = Math.min(Math.max(year, 1900), 9999);
|
|
64
|
+
month = Math.min(Math.max(month, 0), 11);
|
|
65
|
+
return { year, month, day };
|
|
66
|
+
}
|
|
67
|
+
export const cleanDate = (date) => {
|
|
68
|
+
return new Date(new Date(date).setHours(0, 0, 0, 0));
|
|
69
|
+
};
|
|
70
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-helpers.js","sourceRoot":"","sources":["../../../../../../../../projects/myrta-ui/src/lib/components/form/input-date/helpers/date-helpers.ts"],"names":[],"mappings":"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","sourcesContent":["export function formatDate(date: Date, format: string): string {\r\n  const pad = (n: number) => n.toString().padStart(2, '0');\r\n  const map: { [key: string]: string } = {\r\n    'DD': pad(date.getDate()),\r\n    'MM': pad(date.getMonth() + 1),\r\n    'YYYY': date.getFullYear().toString()\r\n  };\r\n  return format.replace(/DD|MM|YYYY/g, match => map[match]);\r\n}\r\n\r\nexport function toOutputFormat(date: Date): string {\r\n  const pad = (n: number) => n.toString().padStart(2, '0');\r\n  return `${date.getFullYear()}-${pad(date.getMonth() + 1)}-${pad(date.getDate())}`;\r\n}\r\n\r\nexport function isValidDate(date: Date): boolean {\r\n  return date instanceof Date && !isNaN(date.getTime());\r\n}\r\n\r\nexport function getDaysInMonth(year: number, month: number): number {\r\n  return new Date(year, month + 1, 0).getDate();\r\n}\r\n\r\nexport function isDateInRange(date: Date, minDate: string | null, maxDate: string | null): boolean {\r\n  const min = minDate ? cleanDate(minDate) : null;\r\n  const max = maxDate ? cleanDate(maxDate) : null;\r\n\r\n  return (!min || date >= min) && (!max || date <= max);\r\n}\r\n\r\nexport function clampDate(date: Date, minDate: string | null, maxDate: string | null): Date {\r\n  const min = minDate ? cleanDate(minDate) : null;\r\n  const max = maxDate ? cleanDate(maxDate) : null;\r\n\r\n  if (min && date < min) return new Date(min);\r\n  if (max && date > max) return new Date(max);\r\n\r\n  return date;\r\n}\r\n\r\nexport function getRangeErrorMessage(date: Date, minDate: string | null, maxDate: string | null): string {\r\n  const min = minDate ? cleanDate(minDate) : null;\r\n  const max = maxDate ? cleanDate(maxDate) : null;\r\n\r\n  if (min && date < min) return 'Дата меньше минимальной';\r\n  if (max && date > max) return 'Дата больше максимальной';\r\n\r\n  return '';\r\n}\r\n\r\nexport function parseInputDate(dateStr: string): Date | null {\r\n  if (dateStr) {\r\n    const [year, month, day] = dateStr.split('-').map(Number);\r\n    const date = new Date(year, month - 1, day);\r\n    return isValidDate(date) ? date : null\r\n  } else {\r\n    return null\r\n  }\r\n}\r\n\r\nexport function adjustInvalidDate(year: number, month: number, day: number): { year: number, month: number, day: number } {\r\n  const maxDays = getDaysInMonth(year, month);\r\n  if (day > maxDays) {\r\n    month += 1;\r\n    if (month > 11) {\r\n      month = 0;\r\n      year += 1;\r\n    }\r\n    day = 1;\r\n  }\r\n  year = Math.min(Math.max(year, 1900), 9999);\r\n  month = Math.min(Math.max(month, 0), 11);\r\n  return { year, month, day };\r\n}\r\n\r\nexport const cleanDate = (date: string): Date => {\r\n  return new Date(new Date(date).setHours(0, 0, 0, 0))\r\n}\r\n"]}
|