lib-portal-angular 0.0.68 → 0.0.70
Sign up to get free protection for your applications and to get access to all the features.
- package/esm2022/lib/components/calendar-argenta/calendar-argenta.component.mjs +328 -165
- package/esm2022/lib/components/components.module.mjs +13 -8
- package/esm2022/lib/components/json-viewer/json-viewer.component.mjs +9 -3
- package/esm2022/lib/components/modal/modal.component.mjs +40 -0
- package/esm2022/public-api.mjs +2 -1
- package/fesm2022/lib-portal-angular.mjs +391 -183
- package/fesm2022/lib-portal-angular.mjs.map +1 -1
- package/lib/components/calendar-argenta/calendar-argenta.component.d.ts +30 -11
- package/lib/components/components.module.d.ts +6 -5
- package/lib/components/json-viewer/json-viewer.component.d.ts +4 -1
- package/lib/components/modal/modal.component.d.ts +18 -0
- package/package.json +1 -1
- package/public-api.d.ts +1 -0
@@ -1,7 +1,8 @@
|
|
1
1
|
import { Component, Input, Output, EventEmitter } from '@angular/core';
|
2
2
|
import * as i0 from "@angular/core";
|
3
3
|
import * as i1 from "@angular/common";
|
4
|
-
import * as i2 from "
|
4
|
+
import * as i2 from "@angular/forms";
|
5
|
+
import * as i3 from "lucide-angular";
|
5
6
|
export class CalendarArgentaComponent {
|
6
7
|
constructor() {
|
7
8
|
this.id = 'argenta-calendar';
|
@@ -9,54 +10,73 @@ export class CalendarArgentaComponent {
|
|
9
10
|
this.label = 'Select a date';
|
10
11
|
this.minDate = null;
|
11
12
|
this.maxDate = null;
|
12
|
-
this.locale = 'pt';
|
13
|
-
this.useTime = false; //
|
14
|
-
this.initialDate = null; //
|
15
|
-
this.
|
13
|
+
this.locale = 'pt';
|
14
|
+
this.useTime = false; // Incluir ou não a hora
|
15
|
+
this.initialDate = null; // Data inicial no modo de data única
|
16
|
+
this.rangeMode = false; // Ativa o modo de intervalo de datas
|
17
|
+
this.startDate = null; // Data de início do intervalo
|
18
|
+
this.endDate = null; // Data de fim do intervalo
|
19
|
+
this.closeButtonLabel = 'Fechar'; // Texto do botão de fechar
|
20
|
+
this.rangeChange = new EventEmitter(); // Evento que emite data única ou intervalo
|
16
21
|
this.currentYear = new Date().getFullYear();
|
17
22
|
this.currentMonth = new Date().getMonth();
|
18
23
|
this.selectedDate = null;
|
24
|
+
this.selectedStartDate = null;
|
25
|
+
this.selectedEndDate = null;
|
19
26
|
this.isCalendarVisible = false;
|
20
27
|
this.inputDate = '';
|
21
28
|
this.invalidDate = false;
|
29
|
+
this.isSelectingStart = true; // Controla se estamos selecionando a data inicial ou final
|
30
|
+
this.startTime = '';
|
31
|
+
this.endTime = '';
|
32
|
+
this.selectedTime = '';
|
22
33
|
this.locales = {
|
23
34
|
en: {
|
24
35
|
months: [
|
25
|
-
'January', 'February', 'March', 'April', 'May', 'June', 'July',
|
26
|
-
'August', 'September', 'October', 'November', 'December'
|
36
|
+
'January', 'February', 'March', 'April', 'May', 'June', 'July', 'August', 'September', 'October', 'November', 'December'
|
27
37
|
],
|
28
38
|
daysOfWeek: ['Su', 'Mo', 'Tu', 'We', 'Th', 'Fr', 'Sa'],
|
29
|
-
invalidDateMessage: 'Invalid date. Please enter a date in the format dd/MM/yyyy'
|
39
|
+
invalidDateMessage: 'Invalid date. Please enter a date in the format dd/MM/yyyy',
|
40
|
+
startTimeLabel: 'Start Time',
|
41
|
+
endTimeLabel: 'End Time',
|
30
42
|
},
|
31
43
|
pt: {
|
32
44
|
months: [
|
33
|
-
'Janeiro', 'Fevereiro', 'Março', 'Abril', 'Maio', 'Junho', 'Julho',
|
34
|
-
'Agosto', 'Setembro', 'Outubro', 'Novembro', 'Dezembro'
|
45
|
+
'Janeiro', 'Fevereiro', 'Março', 'Abril', 'Maio', 'Junho', 'Julho', 'Agosto', 'Setembro', 'Outubro', 'Novembro', 'Dezembro'
|
35
46
|
],
|
36
47
|
daysOfWeek: ['Dom', 'Seg', 'Ter', 'Qua', 'Qui', 'Sex', 'Sáb'],
|
37
|
-
invalidDateMessage: 'Data inválida. Por favor, insira uma data no formato dd/MM/yyyy'
|
48
|
+
invalidDateMessage: 'Data inválida. Por favor, insira uma data no formato dd/MM/yyyy',
|
49
|
+
startTimeLabel: 'Hora de Início',
|
50
|
+
endTimeLabel: 'Hora de Fim',
|
38
51
|
},
|
39
52
|
es: {
|
40
53
|
months: [
|
41
|
-
'Enero', 'Febrero', 'Marzo', 'Abril', 'Mayo', 'Junio', 'Julio',
|
42
|
-
'Agosto', 'Septiembre', 'Octubre', 'Noviembre', 'Diciembre'
|
54
|
+
'Enero', 'Febrero', 'Marzo', 'Abril', 'Mayo', 'Junio', 'Julio', 'Agosto', 'Septiembre', 'Octubre', 'Noviembre', 'Diciembre'
|
43
55
|
],
|
44
56
|
daysOfWeek: ['Do', 'Lu', 'Ma', 'Mi', 'Ju', 'Vi', 'Sá'],
|
45
|
-
invalidDateMessage: 'Fecha inválida. Por favor, ingrese una fecha en el formato dd/MM/yyyy'
|
57
|
+
invalidDateMessage: 'Fecha inválida. Por favor, ingrese una fecha en el formato dd/MM/yyyy',
|
58
|
+
startTimeLabel: 'Hora de Inicio',
|
59
|
+
endTimeLabel: 'Hora de Fin',
|
46
60
|
}
|
47
61
|
};
|
48
62
|
}
|
49
63
|
ngOnInit() {
|
50
|
-
if (this.
|
51
|
-
|
52
|
-
|
64
|
+
if (this.rangeMode) {
|
65
|
+
if (this.startDate) {
|
66
|
+
this.selectedStartDate = this.parseDate(this.startDate);
|
67
|
+
this.startTime = this.formatTimeForDisplay(this.selectedStartDate);
|
68
|
+
}
|
69
|
+
if (this.endDate) {
|
70
|
+
this.selectedEndDate = this.parseDate(this.endDate);
|
71
|
+
this.endTime = this.formatTimeForDisplay(this.selectedEndDate);
|
72
|
+
}
|
73
|
+
this.updateInputForRange(); // Atualiza o input no modo range com horas
|
53
74
|
}
|
54
75
|
else {
|
55
|
-
|
56
|
-
|
57
|
-
|
58
|
-
|
59
|
-
this.dateChange.emit(this.inputDate); // Emite a data inicial
|
76
|
+
if (this.initialDate) {
|
77
|
+
this.updateCalendar(this.initialDate); // Atualiza o input único com a data inicial
|
78
|
+
this.selectedTime = this.formatTimeForDisplay(this.selectedDate);
|
79
|
+
}
|
60
80
|
}
|
61
81
|
}
|
62
82
|
ngOnChanges(changes) {
|
@@ -64,123 +84,233 @@ export class CalendarArgentaComponent {
|
|
64
84
|
this.updateCalendar(changes['initialDate'].currentValue);
|
65
85
|
}
|
66
86
|
}
|
67
|
-
//
|
87
|
+
// Atualiza o calendário para exibir a data única e a hora
|
68
88
|
updateCalendar(dateString) {
|
69
89
|
const parsedDate = this.parseDate(dateString);
|
70
|
-
|
71
|
-
if (parsedDate !== null && this.validateDate(dateString)) {
|
90
|
+
if (parsedDate && this.validateDate(dateString)) {
|
72
91
|
this.selectedDate = parsedDate;
|
73
92
|
this.currentYear = parsedDate.getFullYear();
|
74
93
|
this.currentMonth = parsedDate.getMonth();
|
75
|
-
this.inputDate = this.formatDateForDisplay(parsedDate);
|
76
|
-
this.
|
77
|
-
this.invalidDate = false;
|
94
|
+
this.inputDate = this.formatDateForDisplay(parsedDate); // Inclui a hora no input principal
|
95
|
+
this.emitSingleOrRange(); // Emite data única ou intervalo
|
96
|
+
this.invalidDate = false;
|
78
97
|
}
|
79
98
|
else {
|
80
|
-
this.invalidDate = true;
|
81
|
-
this.dateChange.emit('Data ou hora inválida'); // Emite mensagem de erro
|
82
|
-
console.log('Data ou hora inválida passada para o componente');
|
99
|
+
this.invalidDate = true;
|
83
100
|
}
|
84
101
|
}
|
85
102
|
onInputChange(event) {
|
86
103
|
const inputValue = event.target.value;
|
87
104
|
this.inputDate = this.applyDateMask(inputValue);
|
88
|
-
|
89
|
-
|
90
|
-
|
91
|
-
|
92
|
-
|
93
|
-
this.
|
94
|
-
|
95
|
-
|
96
|
-
|
97
|
-
|
98
|
-
|
99
|
-
|
100
|
-
|
101
|
-
|
102
|
-
const hour = Number(hourStr);
|
103
|
-
const minute = Number(minuteStr);
|
104
|
-
// Corrige somente se a hora/minuto forem inválidos
|
105
|
-
if (hour < 0 || hour > 23 || isNaN(hour)) {
|
106
|
-
this.invalidDate = true;
|
107
|
-
this.dateChange.emit('Hora inválida');
|
108
|
-
return;
|
105
|
+
if (this.rangeMode) {
|
106
|
+
const dateParts = this.inputDate.split(' - ');
|
107
|
+
if (dateParts.length === 2) {
|
108
|
+
const [startDate, endDate] = dateParts;
|
109
|
+
// Valida as duas partes do intervalo
|
110
|
+
if (this.validateDate(startDate) && this.validateDate(endDate)) {
|
111
|
+
this.invalidDate = false;
|
112
|
+
const parsedStartDate = this.parseDate(startDate);
|
113
|
+
const parsedEndDate = this.parseDate(endDate);
|
114
|
+
if (parsedStartDate && parsedEndDate) {
|
115
|
+
this.selectedStartDate = parsedStartDate;
|
116
|
+
this.selectedEndDate = parsedEndDate;
|
117
|
+
this.emitSingleOrRange(); // Emite o intervalo atualizado
|
118
|
+
}
|
109
119
|
}
|
110
|
-
else
|
120
|
+
else {
|
111
121
|
this.invalidDate = true;
|
112
|
-
this.dateChange.emit('Hora inválida');
|
113
|
-
return;
|
114
122
|
}
|
115
|
-
|
123
|
+
}
|
124
|
+
}
|
125
|
+
else {
|
126
|
+
// Valida data única
|
127
|
+
if ((this.useTime && this.inputDate.length === 16) || (!this.useTime && this.inputDate.length === 10)) {
|
128
|
+
if (this.validateDate(this.inputDate)) {
|
116
129
|
this.invalidDate = false;
|
130
|
+
const parsedDate = this.parseDate(this.inputDate);
|
131
|
+
if (parsedDate) {
|
132
|
+
this.selectedDate = parsedDate;
|
133
|
+
this.emitSingleOrRange(); // Emite a data única atualizada
|
134
|
+
}
|
135
|
+
}
|
136
|
+
else {
|
137
|
+
this.invalidDate = true;
|
117
138
|
}
|
118
139
|
}
|
119
140
|
}
|
120
|
-
|
121
|
-
|
122
|
-
|
123
|
-
|
124
|
-
|
125
|
-
|
126
|
-
|
127
|
-
|
128
|
-
|
129
|
-
|
130
|
-
|
131
|
-
|
132
|
-
|
141
|
+
}
|
142
|
+
// Atualiza o input no modo intervalo
|
143
|
+
updateInputForRange() {
|
144
|
+
if (this.selectedStartDate && this.selectedEndDate) {
|
145
|
+
const formattedStart = this.formatDateForDisplay(this.selectedStartDate);
|
146
|
+
const formattedEnd = this.formatDateForDisplay(this.selectedEndDate);
|
147
|
+
this.inputDate = `${formattedStart} - ${formattedEnd}`;
|
148
|
+
}
|
149
|
+
else if (this.selectedStartDate) {
|
150
|
+
this.inputDate = this.formatDateForDisplay(this.selectedStartDate);
|
151
|
+
}
|
152
|
+
}
|
153
|
+
/// Emite data única ou intervalo, incluindo horas
|
154
|
+
emitSingleOrRange() {
|
155
|
+
if (this.rangeMode) {
|
156
|
+
const formattedStart = this.selectedStartDate ? this.formatDateForDisplay(this.selectedStartDate) : '';
|
157
|
+
const formattedEnd = this.selectedEndDate ? this.formatDateForDisplay(this.selectedEndDate) : '';
|
158
|
+
this.inputDate = `${formattedStart} - ${formattedEnd}`; // Atualiza o input principal com o range e horas
|
159
|
+
this.rangeChange.emit({ start: formattedStart, end: formattedEnd });
|
160
|
+
}
|
161
|
+
else {
|
162
|
+
const formattedDate = this.selectedDate ? this.formatDateForDisplay(this.selectedDate) : '';
|
163
|
+
this.inputDate = formattedDate; // Atualiza o input principal com a data única e hora
|
164
|
+
this.rangeChange.emit({ start: formattedDate, end: '' });
|
165
|
+
}
|
166
|
+
}
|
167
|
+
// Função para tratar mudanças nas horas
|
168
|
+
onTimeChange(type) {
|
169
|
+
if (type === 'start') {
|
170
|
+
if (this.selectedStartDate) {
|
171
|
+
const [hours, minutes] = this.startTime ? this.startTime.split(':') : ['00', '00'];
|
172
|
+
this.selectedStartDate.setHours(+hours, +minutes);
|
173
|
+
}
|
174
|
+
}
|
175
|
+
else if (type === 'end') {
|
176
|
+
if (this.selectedEndDate) {
|
177
|
+
const [hours, minutes] = this.endTime ? this.endTime.split(':') : ['00', '00'];
|
178
|
+
this.selectedEndDate.setHours(+hours, +minutes);
|
179
|
+
}
|
180
|
+
}
|
181
|
+
else if (type === 'single') {
|
182
|
+
if (this.selectedDate) {
|
183
|
+
const [hours, minutes] = this.selectedTime ? this.selectedTime.split(':') : ['00', '00'];
|
184
|
+
this.selectedDate.setHours(+hours, +minutes);
|
185
|
+
}
|
186
|
+
}
|
187
|
+
this.emitSingleOrRange(); // Atualiza o valor no input principal
|
188
|
+
}
|
189
|
+
// Função para formatação da hora no input de hora
|
190
|
+
formatTimeForDisplay(date) {
|
191
|
+
if (!date)
|
192
|
+
return '';
|
193
|
+
const hours = date.getHours().toString().padStart(2, '0');
|
194
|
+
const minutes = date.getMinutes().toString().padStart(2, '0');
|
195
|
+
return `${hours}:${minutes}`;
|
196
|
+
}
|
197
|
+
// Método para selecionar uma data no calendário
|
198
|
+
selectDate(day) {
|
199
|
+
const date = new Date(this.currentYear, this.currentMonth, day);
|
200
|
+
if (this.rangeMode) {
|
201
|
+
// Lógica para rangeMode
|
202
|
+
if (this.isSelectingStart) {
|
203
|
+
this.selectedStartDate = date;
|
204
|
+
if (this.startTime) {
|
205
|
+
const [hours, minutes] = this.startTime.split(':');
|
206
|
+
this.selectedStartDate.setHours(+hours, +minutes);
|
133
207
|
}
|
134
208
|
else {
|
135
|
-
|
136
|
-
this.
|
209
|
+
this.selectedStartDate.setHours(0, 0);
|
210
|
+
this.startTime = '00:00';
|
137
211
|
}
|
212
|
+
this.isSelectingStart = false;
|
138
213
|
}
|
139
214
|
else {
|
140
|
-
this.
|
141
|
-
this.
|
215
|
+
this.selectedEndDate = date;
|
216
|
+
if (this.endTime) {
|
217
|
+
const [hours, minutes] = this.endTime.split(':');
|
218
|
+
this.selectedEndDate.setHours(+hours, +minutes);
|
219
|
+
}
|
220
|
+
else {
|
221
|
+
this.selectedEndDate.setHours(0, 0);
|
222
|
+
this.endTime = '00:00';
|
223
|
+
}
|
224
|
+
this.isSelectingStart = true;
|
225
|
+
this.emitSingleOrRange();
|
142
226
|
}
|
227
|
+
this.updateInputForRange();
|
228
|
+
// O calendário só será fechado ao clicar no botão "Fechar"
|
143
229
|
}
|
144
|
-
|
145
|
-
|
146
|
-
|
147
|
-
|
148
|
-
|
149
|
-
|
150
|
-
|
151
|
-
|
152
|
-
|
153
|
-
|
154
|
-
|
155
|
-
|
230
|
+
else {
|
231
|
+
// Lógica para quando não está em rangeMode
|
232
|
+
this.selectedDate = date;
|
233
|
+
if (this.selectedTime) {
|
234
|
+
const [hours, minutes] = this.selectedTime.split(':');
|
235
|
+
this.selectedDate.setHours(+hours, +minutes);
|
236
|
+
}
|
237
|
+
else {
|
238
|
+
this.selectedDate.setHours(0, 0);
|
239
|
+
this.selectedTime = '00:00';
|
240
|
+
}
|
241
|
+
this.inputDate = this.formatDateForDisplay(date);
|
242
|
+
this.emitSingleOrRange();
|
243
|
+
// **Fechar o calendário apenas se `useTime` for false**
|
244
|
+
if (!this.useTime) {
|
245
|
+
this.isCalendarVisible = false; // Fecha o calendário automaticamente se `useTime` for false
|
246
|
+
}
|
247
|
+
// Se `useTime` for true, o calendário permanece aberto para inserir a hora
|
156
248
|
}
|
157
|
-
return formattedDate;
|
158
249
|
}
|
159
250
|
applyDateMask(inputValue) {
|
251
|
+
// Remove qualquer caractere que não seja numérico
|
160
252
|
let digitsOnly = inputValue.replace(/\D/g, '');
|
161
|
-
|
162
|
-
|
163
|
-
|
164
|
-
|
253
|
+
if (this.rangeMode) {
|
254
|
+
const maxLength = this.useTime ? 28 : 17; // Ajusta o comprimento máximo para intervalo com ou sem tempo
|
255
|
+
// Certifica-se de que a entrada não excede o comprimento permitido
|
256
|
+
if (digitsOnly.length > maxLength) {
|
257
|
+
digitsOnly = digitsOnly.substring(0, maxLength);
|
258
|
+
}
|
259
|
+
// Primeiro intervalo (start date)
|
260
|
+
let day1 = digitsOnly.substring(0, 2);
|
261
|
+
let month1 = digitsOnly.substring(2, 4);
|
262
|
+
let year1 = digitsOnly.substring(4, 8);
|
263
|
+
let hour1 = digitsOnly.substring(8, 10);
|
264
|
+
let minute1 = digitsOnly.substring(10, 12);
|
265
|
+
// Cria a data formatada para a primeira parte (start date)
|
266
|
+
let maskedDate = `${day1}/${month1}/${year1}`;
|
267
|
+
if (this.useTime && hour1 && minute1) {
|
268
|
+
maskedDate += ` ${hour1}:${minute1}`;
|
269
|
+
}
|
270
|
+
// Adiciona o separador ' - ' se houver dados para o segundo intervalo
|
271
|
+
if (digitsOnly.length > 12) {
|
272
|
+
maskedDate += ' - ';
|
273
|
+
}
|
274
|
+
// Segundo intervalo (end date)
|
275
|
+
let day2 = digitsOnly.substring(12, 14);
|
276
|
+
let month2 = digitsOnly.substring(14, 16);
|
277
|
+
let year2 = digitsOnly.substring(16, 20);
|
278
|
+
let hour2 = digitsOnly.substring(20, 22);
|
279
|
+
let minute2 = digitsOnly.substring(22, 24);
|
280
|
+
let endDatePart = `${day2}/${month2}/${year2}`;
|
281
|
+
if (this.useTime && hour2 && minute2) {
|
282
|
+
endDatePart += ` ${hour2}:${minute2}`;
|
283
|
+
}
|
284
|
+
// Adiciona a segunda parte (end date) ao input, se aplicável
|
285
|
+
if (digitsOnly.length > 12) {
|
286
|
+
maskedDate += endDatePart;
|
287
|
+
}
|
288
|
+
return maskedDate;
|
165
289
|
}
|
166
|
-
|
167
|
-
|
168
|
-
|
169
|
-
|
170
|
-
|
171
|
-
|
172
|
-
|
173
|
-
|
290
|
+
else {
|
291
|
+
const maxLength = this.useTime ? 16 : 10;
|
292
|
+
if (digitsOnly.length > maxLength) {
|
293
|
+
digitsOnly = digitsOnly.substring(0, maxLength);
|
294
|
+
}
|
295
|
+
let day = digitsOnly.substring(0, 2);
|
296
|
+
let month = digitsOnly.substring(2, 4);
|
297
|
+
let year = digitsOnly.substring(4, 8);
|
298
|
+
let hour = digitsOnly.substring(8, 10);
|
299
|
+
let minute = digitsOnly.substring(10, 12);
|
300
|
+
let maskedDate = `${day}/${month}/${year}`;
|
301
|
+
if (this.useTime && hour && minute) {
|
302
|
+
maskedDate += ` ${hour}:${minute}`;
|
303
|
+
}
|
304
|
+
return maskedDate;
|
174
305
|
}
|
175
|
-
return maskedDate;
|
176
306
|
}
|
307
|
+
// Validação da data
|
177
308
|
validateDate(inputValue) {
|
178
309
|
const [datePart, timePart] = inputValue.split(' ');
|
179
310
|
const [dayStr, monthStr, yearStr] = datePart.split('/');
|
180
311
|
const day = Number(dayStr);
|
181
312
|
const month = Number(monthStr);
|
182
313
|
const year = Number(yearStr);
|
183
|
-
// Validação de data
|
184
314
|
if (month < 1 || month > 12 || yearStr.length !== 4 || isNaN(year)) {
|
185
315
|
return false;
|
186
316
|
}
|
@@ -188,30 +318,36 @@ export class CalendarArgentaComponent {
|
|
188
318
|
if (day < 1 || day > lastDayOfMonth) {
|
189
319
|
return false;
|
190
320
|
}
|
191
|
-
// Validação de hora
|
192
321
|
if (this.useTime && timePart) {
|
193
322
|
const [hourStr, minuteStr] = timePart.split(':');
|
194
323
|
const hour = Number(hourStr);
|
195
324
|
const minute = Number(minuteStr);
|
196
325
|
if (hour < 0 || hour > 23 || minute < 0 || minute > 59 || isNaN(hour) || isNaN(minute)) {
|
197
|
-
return false;
|
326
|
+
return false;
|
198
327
|
}
|
199
328
|
}
|
200
329
|
return true;
|
201
330
|
}
|
202
|
-
|
203
|
-
const
|
204
|
-
|
205
|
-
if (
|
206
|
-
|
331
|
+
handleKeyPress(event) {
|
332
|
+
const charCode = event.key.charCodeAt(0);
|
333
|
+
// Permitir apenas números e barra "/"
|
334
|
+
if ((charCode < 48 || charCode > 57) && charCode !== 47) {
|
335
|
+
event.preventDefault(); // Bloqueia a inserção de caracteres não permitidos
|
207
336
|
}
|
208
|
-
|
209
|
-
if (this.useTime
|
210
|
-
|
211
|
-
date.setHours(hour || 0, minute || 0);
|
337
|
+
// Limita o tamanho da entrada conforme o tipo de dado (com ou sem hora)
|
338
|
+
if (this.inputDate.replace(/\D/g, '').length >= (this.useTime ? 12 : 8)) {
|
339
|
+
event.preventDefault(); // Limita o número de caracteres permitidos
|
212
340
|
}
|
213
|
-
return date;
|
214
341
|
}
|
342
|
+
// Fecha o calendário
|
343
|
+
closeCalendar() {
|
344
|
+
this.isCalendarVisible = false;
|
345
|
+
}
|
346
|
+
// Alterna a visibilidade do calendário
|
347
|
+
toggleCalendar() {
|
348
|
+
this.isCalendarVisible = !this.isCalendarVisible;
|
349
|
+
}
|
350
|
+
// Formata a data e hora para exibição no input principal
|
215
351
|
formatDateForDisplay(date) {
|
216
352
|
const day = date.getDate().toString().padStart(2, '0');
|
217
353
|
const month = (date.getMonth() + 1).toString().padStart(2, '0');
|
@@ -224,72 +360,56 @@ export class CalendarArgentaComponent {
|
|
224
360
|
}
|
225
361
|
return formattedDate;
|
226
362
|
}
|
227
|
-
|
228
|
-
|
229
|
-
|
230
|
-
|
231
|
-
const
|
232
|
-
|
233
|
-
this.
|
234
|
-
|
235
|
-
|
363
|
+
// Formata a data para emitir no evento
|
364
|
+
formatDateForEmit(date) {
|
365
|
+
const day = date.getDate().toString().padStart(2, '0');
|
366
|
+
const month = (date.getMonth() + 1).toString().padStart(2, '0');
|
367
|
+
const year = date.getFullYear();
|
368
|
+
let formattedDate = `${day}/${month}/${year}`;
|
369
|
+
if (this.useTime) {
|
370
|
+
const hours = date.getHours().toString().padStart(2, '0');
|
371
|
+
const minutes = date.getMinutes().toString().padStart(2, '0');
|
372
|
+
formattedDate += ` - ${hours}:${minutes}`;
|
373
|
+
}
|
374
|
+
return formattedDate;
|
236
375
|
}
|
237
|
-
|
238
|
-
|
239
|
-
|
240
|
-
|
376
|
+
// Função para parsing de string para Date
|
377
|
+
parseDate(dateStr) {
|
378
|
+
const [datePart, timePart] = dateStr.split(' ');
|
379
|
+
const [day, month, year] = datePart.split('/').map(Number);
|
380
|
+
if (!day || !month || !year) {
|
381
|
+
return null;
|
241
382
|
}
|
242
|
-
|
243
|
-
|
383
|
+
const date = new Date(year, month - 1, day);
|
384
|
+
if (this.useTime && timePart) {
|
385
|
+
const [hour, minute] = timePart.split(':').map(Number);
|
386
|
+
date.setHours(hour || 0, minute || 0);
|
244
387
|
}
|
388
|
+
return date;
|
245
389
|
}
|
390
|
+
// Gera a lista de dias no mês atual
|
246
391
|
get daysInMonth() {
|
247
|
-
const firstDayOfMonth = new Date(this.currentYear, this.currentMonth, 1).getDay();
|
248
|
-
const totalDaysInMonth = new Date(this.currentYear, this.currentMonth + 1, 0).getDate();
|
249
|
-
const daysArray = Array.from({ length: totalDaysInMonth }, (_, i) => i + 1);
|
392
|
+
const firstDayOfMonth = new Date(this.currentYear, this.currentMonth, 1).getDay();
|
393
|
+
const totalDaysInMonth = new Date(this.currentYear, this.currentMonth + 1, 0).getDate();
|
394
|
+
const daysArray = Array.from({ length: totalDaysInMonth }, (_, i) => i + 1);
|
250
395
|
const leadingEmptyDays = Array(firstDayOfMonth).fill(null); // Dias vazios antes do primeiro dia do mês
|
251
|
-
return [...leadingEmptyDays, ...daysArray];
|
252
|
-
}
|
253
|
-
get months() {
|
254
|
-
return this.locales[this.locale]?.months || this.locales['en'].months;
|
255
|
-
}
|
256
|
-
get daysOfWeek() {
|
257
|
-
return this.locales[this.locale]?.daysOfWeek || this.locales['en'].daysOfWeek;
|
258
|
-
}
|
259
|
-
prevMonth() {
|
260
|
-
if (this.currentMonth === 0) {
|
261
|
-
this.currentMonth = 11;
|
262
|
-
this.currentYear--;
|
263
|
-
}
|
264
|
-
else {
|
265
|
-
this.currentMonth--;
|
266
|
-
}
|
267
|
-
}
|
268
|
-
nextMonth() {
|
269
|
-
if (this.currentMonth === 11) {
|
270
|
-
this.currentMonth = 0;
|
271
|
-
this.currentYear++;
|
272
|
-
}
|
273
|
-
else {
|
274
|
-
this.currentMonth++;
|
275
|
-
}
|
396
|
+
return [...leadingEmptyDays, ...daysArray];
|
276
397
|
}
|
398
|
+
// Verifica se um dia está selecionado
|
277
399
|
isSelected(day) {
|
278
400
|
if (!this.selectedDate)
|
279
401
|
return false;
|
280
402
|
const selectedDay = this.selectedDate.getDate();
|
281
403
|
const selectedMonth = this.selectedDate.getMonth();
|
282
404
|
const selectedYear = this.selectedDate.getFullYear();
|
283
|
-
return
|
284
|
-
selectedMonth === this.currentMonth &&
|
285
|
-
selectedYear === this.currentYear);
|
405
|
+
return selectedDay === day && selectedMonth === this.currentMonth && selectedYear === this.currentYear;
|
286
406
|
}
|
407
|
+
// Verifica se o dia é hoje
|
287
408
|
isToday(day) {
|
288
409
|
const today = new Date();
|
289
|
-
return
|
290
|
-
today.getMonth() === this.currentMonth &&
|
291
|
-
today.getDate() === day);
|
410
|
+
return today.getFullYear() === this.currentYear && today.getMonth() === this.currentMonth && today.getDate() === day;
|
292
411
|
}
|
412
|
+
// Verifica se a data está desabilitada
|
293
413
|
isDateDisabled(day) {
|
294
414
|
const date = new Date(this.currentYear, this.currentMonth, day);
|
295
415
|
if (this.minDate && date < this.minDate)
|
@@ -298,12 +418,47 @@ export class CalendarArgentaComponent {
|
|
298
418
|
return true;
|
299
419
|
return false;
|
300
420
|
}
|
421
|
+
// Verifica se um dia está no intervalo selecionado
|
422
|
+
isInRange(day) {
|
423
|
+
if (!this.selectedStartDate || !this.selectedEndDate)
|
424
|
+
return false;
|
425
|
+
const date = new Date(this.currentYear, this.currentMonth, day);
|
426
|
+
return date >= this.selectedStartDate && date <= this.selectedEndDate;
|
427
|
+
}
|
428
|
+
// Avança para o próximo mês
|
429
|
+
nextMonth() {
|
430
|
+
if (this.currentMonth === 11) {
|
431
|
+
this.currentMonth = 0;
|
432
|
+
this.currentYear++;
|
433
|
+
}
|
434
|
+
else {
|
435
|
+
this.currentMonth++;
|
436
|
+
}
|
437
|
+
}
|
438
|
+
// Retrocede para o mês anterior
|
439
|
+
prevMonth() {
|
440
|
+
if (this.currentMonth === 0) {
|
441
|
+
this.currentMonth = 11;
|
442
|
+
this.currentYear--;
|
443
|
+
}
|
444
|
+
else {
|
445
|
+
this.currentMonth--;
|
446
|
+
}
|
447
|
+
}
|
448
|
+
// Retorna a lista de meses de acordo com o locale
|
449
|
+
get months() {
|
450
|
+
return this.locales[this.locale]?.months || this.locales['en'].months;
|
451
|
+
}
|
452
|
+
// Retorna a lista de dias da semana de acordo com o locale
|
453
|
+
get daysOfWeek() {
|
454
|
+
return this.locales[this.locale]?.daysOfWeek || this.locales['en'].daysOfWeek;
|
455
|
+
}
|
301
456
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: CalendarArgentaComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
302
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: CalendarArgentaComponent, selector: "argenta-calendar", inputs: { id: "id", placeholder: "placeholder", label: "label", minDate: "minDate", maxDate: "maxDate", locale: "locale", useTime: "useTime", initialDate: "initialDate" }, outputs: {
|
457
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: CalendarArgentaComponent, selector: "argenta-calendar", inputs: { id: "id", placeholder: "placeholder", label: "label", minDate: "minDate", maxDate: "maxDate", locale: "locale", useTime: "useTime", initialDate: "initialDate", rangeMode: "rangeMode", startDate: "startDate", endDate: "endDate", closeButtonLabel: "closeButtonLabel" }, outputs: { rangeChange: "rangeChange" }, usesOnChanges: true, ngImport: i0, template: "<div class=\"form-group\">\n <label [for]=\"id\" [ngClass]=\"'label-styles'\">{{ label }}</label>\n <div class=\"input-wrapper\">\n <input\n id=\"{{ id }}\"\n type=\"text\"\n class=\"custom-input\"\n [attr.placeholder]=\"rangeMode && useTime ? 'dd/MM/yyyy HH:mm - dd/MM/yyyy HH:mm' : \n rangeMode && !useTime ? 'dd/MM/yyyy - dd/MM/yyyy' :(!rangeMode && useTime ? 'dd/MM/yyyy HH:mm' : 'dd/MM/yyyy')\"\n [value]=\"inputDate\"\n (input)=\"onInputChange($event)\"\n (keypress)=\"handleKeyPress($event)\"\n (click)=\"toggleCalendar()\"\n />\n <lucide-icon name=\"calendar\" class=\"calendar-icon\"></lucide-icon>\n </div>\n\n <div *ngIf=\"invalidDate\" class=\"error-message\">\n {{ locales[locale].invalidDateMessage }}\n <span *ngIf=\"useTime\"> HH:mm.</span>\n </div>\n\n <div class=\"calendar-wrapper\">\n <div class=\"calendar-container\" [ngClass]=\"{ open: isCalendarVisible }\">\n <div class=\"calendar\">\n <div class=\"calendar-header\">\n <button (click)=\"prevMonth()\">‹</button>\n <span>{{ months[currentMonth] }} {{ currentYear }}</span>\n <button (click)=\"nextMonth()\">›</button>\n </div>\n\n <div class=\"calendar-body\">\n <div class=\"calendar-day-names\">\n <span *ngFor=\"let day of daysOfWeek\">{{ day }}</span>\n </div>\n\n <div class=\"calendar-days\">\n <span\n *ngFor=\"let day of daysInMonth; let i = index\"\n [class.today]=\"isToday(day)\"\n [class.selected]=\"isSelected(day)\"\n [class.in-range]=\"isInRange(day)\"\n [class.disabled]=\"isDateDisabled(day)\"\n (click)=\"day ? selectDate(day) : null\"\n >\n {{ day ? day : \"\" }}\n </span>\n </div>\n </div>\n\n <!-- Inputs para inser\u00E7\u00E3o das horas -->\n <div *ngIf=\"useTime\" class=\"time-inputs\">\n <!-- Campo de hora de in\u00EDcio -->\n <div *ngIf=\"rangeMode\" class=\"time-input\">\n <label>{{ locales[locale]?.startTimeLabel || 'Hora de In\u00EDcio' }}</label> <!-- Usando tradu\u00E7\u00E3o -->\n <input type=\"time\" [(ngModel)]=\"startTime\" (change)=\"onTimeChange('start')\" />\n </div>\n\n <!-- Campo de hora de fim -->\n <div *ngIf=\"rangeMode\" class=\"time-input\">\n <label>{{ locales[locale]?.endTimeLabel || 'Hora de Fim' }}</label> <!-- Usando tradu\u00E7\u00E3o -->\n <input type=\"time\" [(ngModel)]=\"endTime\" (change)=\"onTimeChange('end')\" />\n </div>\n\n <!-- Campo de hora \u00FAnica (se n\u00E3o for range) -->\n <div *ngIf=\"!rangeMode\" class=\"time-input\">\n <label>{{ locales[locale]?.startTimeLabel || 'Hora' }}</label> <!-- Usando o label de in\u00EDcio -->\n <input type=\"time\" [(ngModel)]=\"selectedTime\" (change)=\"onTimeChange('single')\" />\n </div>\n </div>\n\n <!-- Bot\u00E3o de fechar o calend\u00E1rio -->\n <button class=\"close-button\" (click)=\"closeCalendar()\">{{ closeButtonLabel }}</button>\n </div>\n </div>\n </div>\n</div>\n", styles: ["@charset \"UTF-8\";@import\"https://fonts.googleapis.com/css2?family=Inter:wght@400;700&display=swap\";body{font-family:Inter,sans-serif}.calendar-container{overflow:hidden;max-height:0;transition:max-height .4s ease;position:absolute;top:100%;left:0;z-index:9999;background-color:#fff;box-shadow:0 4px 12px #0000001a;width:auto;max-width:none}.calendar-wrapper{position:relative}@media (max-width: 300px){.calendar-container{width:100vw;left:0}}.calendar-container.open{max-height:500px}.calendar{display:inline-block;border:1px solid #ccc;border-radius:8px;padding:10px;width:450px;font-family:Inter,Arial,sans-serif;transition:max-height .4s ease;background-color:#f5f5f5}.calendar .calendar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;font-weight:700}.calendar .calendar-header button{background-color:#00444c;color:#fff;border:none;padding:8px 12px;cursor:pointer;border-radius:8px;font-size:1.2rem;transition:background-color .2s}.calendar .calendar-header button:hover{background-color:#2ca58d}.calendar .calendar-header span{font-size:1.4rem;color:#00444c;text-align:center;flex-grow:1}.calendar .calendar-body{display:grid;grid-template-columns:repeat(7,1fr);gap:7px}.calendar .calendar-body .calendar-day-names{display:contents}.calendar .calendar-body .calendar-day-names span{text-align:center;font-weight:700;margin-bottom:5px;font-size:.9rem}.calendar .calendar-body .calendar-day-names span:nth-child(1){color:#ff8080}.calendar .calendar-body .calendar-day-names span:nth-child(7){color:#555}.calendar .calendar-body .calendar-days{display:contents}.calendar .calendar-body .calendar-days span{display:flex;justify-content:center;align-items:center;margin:1px;padding:10px;height:45px;width:45px;cursor:pointer;border-radius:50%;transition:background-color .2s,color .2s ease}.calendar .calendar-body .calendar-days span.today{background-color:#2ca58d;color:#fff}.calendar .calendar-body .calendar-days span.selected{background-color:#00444c;color:#fff}.calendar .calendar-body .calendar-days span.disabled{background-color:#e9ecef;color:#999;cursor:not-allowed}.calendar .calendar-body .calendar-days span:hover:not(.disabled){background-color:#2ca58d;color:#fff}.custom-input{font-family:Inter,Arial,sans-serif;color:#333;font-size:.9rem;height:46px;padding:.5rem .75rem;border:1px solid #ccc;border-radius:4px;width:100%;box-sizing:border-box}.custom-input::placeholder{font-size:14px;color:#d3d3d3}.label-styles{font-weight:400;font-family:Inter,Arial,sans-serif;font-size:16px;line-height:19.36px;text-align:left;margin-top:1rem;margin-bottom:.5rem}.error-message{position:relative;background-color:#ff8080;color:#fff;padding:10px;border-radius:8px;font-size:.9rem;max-width:250px;margin-top:5px}.error-message:after{content:\"\";position:absolute;top:100%;left:20px;border-width:10px;border-style:solid;border-color:#ff8080 transparent transparent transparent}.input-wrapper{position:relative;display:inline-block;width:100%}.input-wrapper .custom-input{width:100%;padding-right:40px;box-sizing:border-box}.input-wrapper .calendar-icon{position:absolute;top:50%;right:10px;transform:translateY(-50%);pointer-events:none;color:#b8b8b8}.calendar-days{display:contents}.calendar-days span{display:flex;justify-content:center;align-items:center;margin:1px;padding:10px;height:45px;width:45px;cursor:pointer;border-radius:50%;transition:background-color .2s,color .2s ease}.calendar-days span.today{background-color:#2ca58d;color:#fff;text-decoration:underline}.calendar-days span.selected{background-color:#00444c;color:#fff}.calendar-days span.in-range{background-color:#fd9;color:#000}.calendar-days span.disabled{background-color:#e9ecef;color:#999;cursor:not-allowed}.calendar-days span:hover:not(.disabled){background-color:#2ca58d;color:#fff}.calendar-body{position:relative}.close-button{float:right;margin-top:10px;background-color:#fff3cd;color:#383838;border:none;padding:6px 12px;cursor:pointer;border-radius:20px;font-size:12px;font-weight:500;transition:all .2s ease}.close-button:hover{background-color:#e9ebec;box-shadow:0 2px 4px #00000026}.close-button:active{transform:translateY(1px)}.time-inputs{display:flex;justify-content:space-between;margin-top:10px}.time-input{display:flex;flex-direction:column;width:45%}.time-input label{font-size:.9rem;margin-bottom:5px}.time-input input{padding:8px;font-size:.9rem;border:1px solid #ccc;border-radius:4px}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.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: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i3.LucideAngularComponent, selector: "lucide-angular, lucide-icon, i-lucide, span-lucide", inputs: ["class", "name", "img", "color", "absoluteStrokeWidth", "size", "strokeWidth"] }] }); }
|
303
458
|
}
|
304
459
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: CalendarArgentaComponent, decorators: [{
|
305
460
|
type: Component,
|
306
|
-
args: [{ selector: 'argenta-calendar', template: "<div class=\"form-group\">\n <label [for]=\"id\" [ngClass]=\"'label-styles'\">{{ label }}</label>\n <div class=\"input-wrapper\">\n <input\n id=\"{{ id }}\"\n type=\"text\"\n class=\"custom-input\"\n [attr.placeholder]=\"useTime ? 'dd/MM/yyyy HH:mm' : 'dd/MM/yyyy'\"\n [value]=\"inputDate\"\n (input)=\"onInputChange($event)\"\n (keypress)=\"handleKeyPress($event)\"\n (click)=\"toggleCalendar()\"\n />\n
|
461
|
+
args: [{ selector: 'argenta-calendar', template: "<div class=\"form-group\">\n <label [for]=\"id\" [ngClass]=\"'label-styles'\">{{ label }}</label>\n <div class=\"input-wrapper\">\n <input\n id=\"{{ id }}\"\n type=\"text\"\n class=\"custom-input\"\n [attr.placeholder]=\"rangeMode && useTime ? 'dd/MM/yyyy HH:mm - dd/MM/yyyy HH:mm' : \n rangeMode && !useTime ? 'dd/MM/yyyy - dd/MM/yyyy' :(!rangeMode && useTime ? 'dd/MM/yyyy HH:mm' : 'dd/MM/yyyy')\"\n [value]=\"inputDate\"\n (input)=\"onInputChange($event)\"\n (keypress)=\"handleKeyPress($event)\"\n (click)=\"toggleCalendar()\"\n />\n <lucide-icon name=\"calendar\" class=\"calendar-icon\"></lucide-icon>\n </div>\n\n <div *ngIf=\"invalidDate\" class=\"error-message\">\n {{ locales[locale].invalidDateMessage }}\n <span *ngIf=\"useTime\"> HH:mm.</span>\n </div>\n\n <div class=\"calendar-wrapper\">\n <div class=\"calendar-container\" [ngClass]=\"{ open: isCalendarVisible }\">\n <div class=\"calendar\">\n <div class=\"calendar-header\">\n <button (click)=\"prevMonth()\">‹</button>\n <span>{{ months[currentMonth] }} {{ currentYear }}</span>\n <button (click)=\"nextMonth()\">›</button>\n </div>\n\n <div class=\"calendar-body\">\n <div class=\"calendar-day-names\">\n <span *ngFor=\"let day of daysOfWeek\">{{ day }}</span>\n </div>\n\n <div class=\"calendar-days\">\n <span\n *ngFor=\"let day of daysInMonth; let i = index\"\n [class.today]=\"isToday(day)\"\n [class.selected]=\"isSelected(day)\"\n [class.in-range]=\"isInRange(day)\"\n [class.disabled]=\"isDateDisabled(day)\"\n (click)=\"day ? selectDate(day) : null\"\n >\n {{ day ? day : \"\" }}\n </span>\n </div>\n </div>\n\n <!-- Inputs para inser\u00E7\u00E3o das horas -->\n <div *ngIf=\"useTime\" class=\"time-inputs\">\n <!-- Campo de hora de in\u00EDcio -->\n <div *ngIf=\"rangeMode\" class=\"time-input\">\n <label>{{ locales[locale]?.startTimeLabel || 'Hora de In\u00EDcio' }}</label> <!-- Usando tradu\u00E7\u00E3o -->\n <input type=\"time\" [(ngModel)]=\"startTime\" (change)=\"onTimeChange('start')\" />\n </div>\n\n <!-- Campo de hora de fim -->\n <div *ngIf=\"rangeMode\" class=\"time-input\">\n <label>{{ locales[locale]?.endTimeLabel || 'Hora de Fim' }}</label> <!-- Usando tradu\u00E7\u00E3o -->\n <input type=\"time\" [(ngModel)]=\"endTime\" (change)=\"onTimeChange('end')\" />\n </div>\n\n <!-- Campo de hora \u00FAnica (se n\u00E3o for range) -->\n <div *ngIf=\"!rangeMode\" class=\"time-input\">\n <label>{{ locales[locale]?.startTimeLabel || 'Hora' }}</label> <!-- Usando o label de in\u00EDcio -->\n <input type=\"time\" [(ngModel)]=\"selectedTime\" (change)=\"onTimeChange('single')\" />\n </div>\n </div>\n\n <!-- Bot\u00E3o de fechar o calend\u00E1rio -->\n <button class=\"close-button\" (click)=\"closeCalendar()\">{{ closeButtonLabel }}</button>\n </div>\n </div>\n </div>\n</div>\n", styles: ["@charset \"UTF-8\";@import\"https://fonts.googleapis.com/css2?family=Inter:wght@400;700&display=swap\";body{font-family:Inter,sans-serif}.calendar-container{overflow:hidden;max-height:0;transition:max-height .4s ease;position:absolute;top:100%;left:0;z-index:9999;background-color:#fff;box-shadow:0 4px 12px #0000001a;width:auto;max-width:none}.calendar-wrapper{position:relative}@media (max-width: 300px){.calendar-container{width:100vw;left:0}}.calendar-container.open{max-height:500px}.calendar{display:inline-block;border:1px solid #ccc;border-radius:8px;padding:10px;width:450px;font-family:Inter,Arial,sans-serif;transition:max-height .4s ease;background-color:#f5f5f5}.calendar .calendar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;font-weight:700}.calendar .calendar-header button{background-color:#00444c;color:#fff;border:none;padding:8px 12px;cursor:pointer;border-radius:8px;font-size:1.2rem;transition:background-color .2s}.calendar .calendar-header button:hover{background-color:#2ca58d}.calendar .calendar-header span{font-size:1.4rem;color:#00444c;text-align:center;flex-grow:1}.calendar .calendar-body{display:grid;grid-template-columns:repeat(7,1fr);gap:7px}.calendar .calendar-body .calendar-day-names{display:contents}.calendar .calendar-body .calendar-day-names span{text-align:center;font-weight:700;margin-bottom:5px;font-size:.9rem}.calendar .calendar-body .calendar-day-names span:nth-child(1){color:#ff8080}.calendar .calendar-body .calendar-day-names span:nth-child(7){color:#555}.calendar .calendar-body .calendar-days{display:contents}.calendar .calendar-body .calendar-days span{display:flex;justify-content:center;align-items:center;margin:1px;padding:10px;height:45px;width:45px;cursor:pointer;border-radius:50%;transition:background-color .2s,color .2s ease}.calendar .calendar-body .calendar-days span.today{background-color:#2ca58d;color:#fff}.calendar .calendar-body .calendar-days span.selected{background-color:#00444c;color:#fff}.calendar .calendar-body .calendar-days span.disabled{background-color:#e9ecef;color:#999;cursor:not-allowed}.calendar .calendar-body .calendar-days span:hover:not(.disabled){background-color:#2ca58d;color:#fff}.custom-input{font-family:Inter,Arial,sans-serif;color:#333;font-size:.9rem;height:46px;padding:.5rem .75rem;border:1px solid #ccc;border-radius:4px;width:100%;box-sizing:border-box}.custom-input::placeholder{font-size:14px;color:#d3d3d3}.label-styles{font-weight:400;font-family:Inter,Arial,sans-serif;font-size:16px;line-height:19.36px;text-align:left;margin-top:1rem;margin-bottom:.5rem}.error-message{position:relative;background-color:#ff8080;color:#fff;padding:10px;border-radius:8px;font-size:.9rem;max-width:250px;margin-top:5px}.error-message:after{content:\"\";position:absolute;top:100%;left:20px;border-width:10px;border-style:solid;border-color:#ff8080 transparent transparent transparent}.input-wrapper{position:relative;display:inline-block;width:100%}.input-wrapper .custom-input{width:100%;padding-right:40px;box-sizing:border-box}.input-wrapper .calendar-icon{position:absolute;top:50%;right:10px;transform:translateY(-50%);pointer-events:none;color:#b8b8b8}.calendar-days{display:contents}.calendar-days span{display:flex;justify-content:center;align-items:center;margin:1px;padding:10px;height:45px;width:45px;cursor:pointer;border-radius:50%;transition:background-color .2s,color .2s ease}.calendar-days span.today{background-color:#2ca58d;color:#fff;text-decoration:underline}.calendar-days span.selected{background-color:#00444c;color:#fff}.calendar-days span.in-range{background-color:#fd9;color:#000}.calendar-days span.disabled{background-color:#e9ecef;color:#999;cursor:not-allowed}.calendar-days span:hover:not(.disabled){background-color:#2ca58d;color:#fff}.calendar-body{position:relative}.close-button{float:right;margin-top:10px;background-color:#fff3cd;color:#383838;border:none;padding:6px 12px;cursor:pointer;border-radius:20px;font-size:12px;font-weight:500;transition:all .2s ease}.close-button:hover{background-color:#e9ebec;box-shadow:0 2px 4px #00000026}.close-button:active{transform:translateY(1px)}.time-inputs{display:flex;justify-content:space-between;margin-top:10px}.time-input{display:flex;flex-direction:column;width:45%}.time-input label{font-size:.9rem;margin-bottom:5px}.time-input input{padding:8px;font-size:.9rem;border:1px solid #ccc;border-radius:4px}\n"] }]
|
307
462
|
}], propDecorators: { id: [{
|
308
463
|
type: Input
|
309
464
|
}], placeholder: [{
|
@@ -320,7 +475,15 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
320
475
|
type: Input
|
321
476
|
}], initialDate: [{
|
322
477
|
type: Input
|
323
|
-
}],
|
478
|
+
}], rangeMode: [{
|
479
|
+
type: Input
|
480
|
+
}], startDate: [{
|
481
|
+
type: Input
|
482
|
+
}], endDate: [{
|
483
|
+
type: Input
|
484
|
+
}], closeButtonLabel: [{
|
485
|
+
type: Input
|
486
|
+
}], rangeChange: [{
|
324
487
|
type: Output
|
325
488
|
}] } });
|
326
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"calendar-argenta.component.js","sourceRoot":"","sources":["../../../../../../projects/lib-portal-angular/src/lib/components/calendar-argenta/calendar-argenta.component.ts","../../../../../../projects/lib-portal-angular/src/lib/components/calendar-argenta/calendar-argenta.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, Output, EventEmitter, OnInit, OnChanges, SimpleChanges } from '@angular/core';\n\n@Component({\n    selector: 'argenta-calendar',\n    templateUrl: './calendar-argenta.component.html',\n    styleUrls: ['./calendar-argenta.component.scss'],\n})\nexport class CalendarArgentaComponent implements OnInit, OnChanges {\n    @Input() id: string = 'argenta-calendar';\n    @Input() placeholder: string = 'Select a date';\n    @Input() label: string = 'Select a date';\n    @Input() minDate: Date | null = null;\n    @Input() maxDate: Date | null = null;\n    @Input() locale: string = 'pt'; // Suporte para diferentes idiomas\n    @Input() useTime: boolean = false; // Propriedade para definir se inclui hora\n    @Input() initialDate: string | null = null; // Propriedade para receber a data inicial\n    @Output() dateChange = new EventEmitter<string>();\n\n    currentYear: number = new Date().getFullYear();\n    currentMonth: number = new Date().getMonth();\n    selectedDate: Date | null = null;\n    isCalendarVisible: boolean = false;\n    inputDate: string = '';\n    invalidDate: boolean = false;\n\n    locales: any = {\n        en: {\n            months: [\n                'January', 'February', 'March', 'April', 'May', 'June', 'July',\n                'August', 'September', 'October', 'November', 'December'\n            ],\n            daysOfWeek: ['Su', 'Mo', 'Tu', 'We', 'Th', 'Fr', 'Sa'],\n            invalidDateMessage: 'Invalid date. Please enter a date in the format dd/MM/yyyy'\n        },\n        pt: {\n            months: [\n                'Janeiro', 'Fevereiro', 'Março', 'Abril', 'Maio', 'Junho', 'Julho',\n                'Agosto', 'Setembro', 'Outubro', 'Novembro', 'Dezembro'\n            ],\n            daysOfWeek: ['Dom', 'Seg', 'Ter', 'Qua', 'Qui', 'Sex', 'Sáb'],\n            invalidDateMessage: 'Data inválida. Por favor, insira uma data no formato dd/MM/yyyy'\n        },\n        es: {\n            months: [\n                'Enero', 'Febrero', 'Marzo', 'Abril', 'Mayo', 'Junio', 'Julio',\n                'Agosto', 'Septiembre', 'Octubre', 'Noviembre', 'Diciembre'\n            ],\n            daysOfWeek: ['Do', 'Lu', 'Ma', 'Mi', 'Ju', 'Vi', 'Sá'],\n            invalidDateMessage: 'Fecha inválida. Por favor, ingrese una fecha en el formato dd/MM/yyyy'\n        }\n    };\n\n    ngOnInit(): void {\n        if (this.initialDate) {\n            // Se a initialDate for fornecida, usamos ela\n            this.updateCalendar(this.initialDate);\n        } else {\n            // Caso contrário, usamos a data atual\n            const today = new Date();\n            this.selectedDate = today;\n            this.inputDate = this.formatDateForDisplay(today);\n            this.dateChange.emit(this.inputDate); // Emite a data inicial\n        }\n    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        if (changes['initialDate'] && changes['initialDate'].currentValue) {\n            this.updateCalendar(changes['initialDate'].currentValue);\n        }\n    }\n\n    // Método para atualizar o calendário com a data passada\n    updateCalendar(dateString: string): void {\n        const parsedDate = this.parseDate(dateString);\n\n        // Verifica se a data é válida\n        if (parsedDate !== null && this.validateDate(dateString)) {\n            this.selectedDate = parsedDate;\n            this.currentYear = parsedDate.getFullYear();\n            this.currentMonth = parsedDate.getMonth();\n            this.inputDate = this.formatDateForDisplay(parsedDate);\n            this.dateChange.emit(this.inputDate); // Emite a nova data\n            this.invalidDate = false; // Remove o status de data inválida\n        } else {\n            this.invalidDate = true; // Marca a data como inválida\n            this.dateChange.emit('Data ou hora inválida'); // Emite mensagem de erro\n            console.log('Data ou hora inválida passada para o componente');\n        }\n    }\n\n    onInputChange(event: any): void {\n        const inputValue = event.target.value;\n        this.inputDate = this.applyDateMask(inputValue);\n\n        // Validação para obrigar a hora quando useTime for verdadeiro\n        if (this.useTime) {\n            // Se a entrada não tiver o comprimento correto para data + hora\n            if (this.inputDate.length < 16) {\n                this.invalidDate = true;\n                this.dateChange.emit('Data ou hora inválida');\n                return;\n            }\n        }\n\n        // Somente validar a hora se o campo useTime estiver ativo e o formato estiver correto\n        if (this.useTime && this.inputDate.length >= 14) {\n            const [datePart, timePart] = this.inputDate.split(' ');\n            if (timePart) {\n                const [hourStr, minuteStr] = timePart.split(':');\n                const hour = Number(hourStr);\n                const minute = Number(minuteStr);\n\n                // Corrige somente se a hora/minuto forem inválidos\n                if (hour < 0 || hour > 23 || isNaN(hour)) {\n                    this.invalidDate = true;\n                    this.dateChange.emit('Hora inválida');\n                    return;\n                } else if (minute < 0 || minute > 59 || isNaN(minute)) {\n                    this.invalidDate = true;\n                    this.dateChange.emit('Hora inválida');\n                    return;\n                } else {\n                    this.invalidDate = false;\n                }\n            }\n        }\n\n        // Emitir a data quando for válida\n        if ((this.useTime && this.inputDate.length === 16) || (!this.useTime && this.inputDate.length === 10)) {\n            if (this.validateDate(this.inputDate)) {\n                this.invalidDate = false;\n                const parsedDate = this.parseDate(this.inputDate);\n\n                // Verificar se parsedDate não é nulo antes de acessar suas propriedades\n                if (parsedDate !== null) {\n                    this.currentYear = parsedDate.getFullYear();\n                    this.currentMonth = parsedDate.getMonth();\n                    this.selectedDate = parsedDate;\n\n                    // Formatar a data para dd/MM/yyyy - HH:mm\n                    const formattedDate = this.formatDateForEmit(parsedDate);\n\n                    this.dateChange.emit(formattedDate); // Emite a data válida com o hífen\n                } else {\n                    console.log('Data inválida passada para o componente.');\n                    this.dateChange.emit('Data inválida');\n                }\n            } else {\n                this.invalidDate = true;\n                this.dateChange.emit('Data inválida'); // Emite o evento com mensagem de erro\n            }\n        }\n    }\n\n    // Formatar a data e hora com hífen\n    formatDateForEmit(date: Date): string {\n        const day = date.getDate().toString().padStart(2, '0');\n        const month = (date.getMonth() + 1).toString().padStart(2, '0');\n        const year = date.getFullYear();\n\n        let formattedDate = `${day}/${month}/${year}`;\n\n        if (this.useTime) {\n            const hours = date.getHours().toString().padStart(2, '0');\n            const minutes = date.getMinutes().toString().padStart(2, '0');\n            // Adiciona o hífen entre a data e a hora\n            formattedDate += ` - ${hours}:${minutes}`;\n        }\n\n        return formattedDate;\n    }\n\n    applyDateMask(inputValue: string): string {\n        let digitsOnly = inputValue.replace(/\\D/g, '');\n\n        // Limita os dígitos com base no uso de hora\n        const maxLength = this.useTime ? 12 : 8;\n        if (digitsOnly.length > maxLength) {\n            digitsOnly = digitsOnly.substring(0, maxLength);\n        }\n\n        let day = digitsOnly.substring(0, 2);\n        let month = digitsOnly.substring(2, 4);\n        let year = digitsOnly.substring(4, 8);\n        let hour = digitsOnly.substring(8, 10);\n        let minute = digitsOnly.substring(10, 12);\n\n        let maskedDate = `${day}/${month}/${year}`;\n        if (this.useTime && hour && minute) {\n            maskedDate += ` ${hour}:${minute}`;\n        }\n\n        return maskedDate;\n    }\n\n    validateDate(inputValue: string): boolean {\n        const [datePart, timePart] = inputValue.split(' ');\n        const [dayStr, monthStr, yearStr] = datePart.split('/');\n        const day = Number(dayStr);\n        const month = Number(monthStr);\n        const year = Number(yearStr);\n\n        // Validação de data\n        if (month < 1 || month > 12 || yearStr.length !== 4 || isNaN(year)) {\n            return false;\n        }\n\n        const lastDayOfMonth = new Date(year, month, 0).getDate();\n        if (day < 1 || day > lastDayOfMonth) {\n            return false;\n        }\n\n        // Validação de hora\n        if (this.useTime && timePart) {\n            const [hourStr, minuteStr] = timePart.split(':');\n            const hour = Number(hourStr);\n            const minute = Number(minuteStr);\n\n            if (hour < 0 || hour > 23 || minute < 0 || minute > 59 || isNaN(hour) || isNaN(minute)) {\n                return false; // Hora ou minuto inválidos\n            }\n        }\n\n        return true;\n    }\n\n    parseDate(dateStr: string): Date | null {\n        const [datePart, timePart] = dateStr.split(' ');\n        const [day, month, year] = datePart.split('/').map(Number);\n        if (!day || !month || !year) {\n            return null;\n        }\n\n        const date = new Date(year, month - 1, day);\n        if (this.useTime && timePart) {\n            const [hour, minute] = timePart.split(':').map(Number);\n            date.setHours(hour || 0, minute || 0);\n        }\n        return date;\n    }\n\n    formatDateForDisplay(date: Date): string {\n        const day = date.getDate().toString().padStart(2, '0');\n        const month = (date.getMonth() + 1).toString().padStart(2, '0');\n        const year = date.getFullYear();\n        let formattedDate = `${day}/${month}/${year}`;\n\n        if (this.useTime) {\n            const hours = date.getHours().toString().padStart(2, '0');\n            const minutes = date.getMinutes().toString().padStart(2, '0');\n            formattedDate += ` ${hours}:${minutes}`;\n        }\n\n        return formattedDate;\n    }\n\n    toggleCalendar(): void {\n        this.isCalendarVisible = !this.isCalendarVisible;\n    }\n\n    selectDate(day: number): void {\n        const date = new Date(this.currentYear, this.currentMonth, day);\n        this.inputDate = this.formatDateForDisplay(date);\n        this.selectedDate = date; // Armazena a data selecionada\n        this.dateChange.emit(this.inputDate); // Emite a data selecionada ao clicar no calendário\n        this.isCalendarVisible = false; // Fecha o calendário após a seleção\n    }\n\n    handleKeyPress(event: KeyboardEvent): void {\n        const charCode = event.key.charCodeAt(0);\n\n        if (charCode < 48 || charCode > 57) {\n            event.preventDefault();\n        }\n\n        if (this.inputDate.replace(/\\D/g, '').length >= (this.useTime ? 12 : 8)) {\n            event.preventDefault();\n        }\n    }\n\n    get daysInMonth(): any[] {\n        const firstDayOfMonth = new Date(this.currentYear, this.currentMonth, 1).getDay(); // Dia da semana do primeiro dia do mês\n        const totalDaysInMonth = new Date(this.currentYear, this.currentMonth + 1, 0).getDate(); // Total de dias no mês\n\n        const daysArray = Array.from({ length: totalDaysInMonth }, (_, i) => i + 1); // Array com todos os dias do mês\n\n        const leadingEmptyDays = Array(firstDayOfMonth).fill(null); // Dias vazios antes do primeiro dia do mês\n\n        return [...leadingEmptyDays, ...daysArray]; // Retorna os dias vazios seguidos pelos dias do mês\n    }\n\n\n\n    get months(): string[] {\n        return this.locales[this.locale]?.months || this.locales['en'].months;\n    }\n\n    get daysOfWeek(): string[] {\n        return this.locales[this.locale]?.daysOfWeek || this.locales['en'].daysOfWeek;\n    }\n\n    prevMonth(): void {\n        if (this.currentMonth === 0) {\n            this.currentMonth = 11;\n            this.currentYear--;\n        } else {\n            this.currentMonth--;\n        }\n    }\n\n    nextMonth(): void {\n        if (this.currentMonth === 11) {\n            this.currentMonth = 0;\n            this.currentYear++;\n        } else {\n            this.currentMonth++;\n        }\n    }\n\n    isSelected(day: number): boolean {\n        if (!this.selectedDate) return false;\n        const selectedDay = this.selectedDate.getDate();\n        const selectedMonth = this.selectedDate.getMonth();\n        const selectedYear = this.selectedDate.getFullYear();\n\n        return (\n            selectedDay === day &&\n            selectedMonth === this.currentMonth &&\n            selectedYear === this.currentYear\n        );\n    }\n\n    isToday(day: number): boolean {\n        const today = new Date();\n        return (\n            today.getFullYear() === this.currentYear &&\n            today.getMonth() === this.currentMonth &&\n            today.getDate() === day\n        );\n    }\n\n    isDateDisabled(day: number): boolean {\n        const date = new Date(this.currentYear, this.currentMonth, day);\n        if (this.minDate && date < this.minDate) return true;\n        if (this.maxDate && date > this.maxDate) return true;\n        return false;\n    }\n}\n","<div class=\"form-group\">\n  <label [for]=\"id\" [ngClass]=\"'label-styles'\">{{ label }}</label>\n  <div class=\"input-wrapper\">\n    <input\n      id=\"{{ id }}\"\n      type=\"text\"\n      class=\"custom-input\"\n      [attr.placeholder]=\"useTime ? 'dd/MM/yyyy HH:mm' : 'dd/MM/yyyy'\"\n      [value]=\"inputDate\"\n      (input)=\"onInputChange($event)\"\n      (keypress)=\"handleKeyPress($event)\"\n      (click)=\"toggleCalendar()\"\n    />\n    <!-- Ícone de calendário dentro do input -->\n    <lucide-icon name=\"calendar\" class=\"calendar-icon\"></lucide-icon>\n  </div>\n\n  <!-- Mensagem de erro estilo balãozinho -->\n  <div *ngIf=\"invalidDate\" class=\"error-message\">\n    {{ locales[locale].invalidDateMessage }}\n    <!-- Mostra a parte de 'HH:mm' apenas se useTime for verdadeiro -->\n    <span *ngIf=\"useTime\"> HH:mm.</span>\n  </div>\n\n  <div class=\"calendar-wrapper\">\n    <div class=\"calendar-container\" [ngClass]=\"{ open: isCalendarVisible }\">\n      <div class=\"calendar\">\n        <div class=\"calendar-header\">\n          <button (click)=\"prevMonth()\">&#8249;</button>\n          <span>{{ months[currentMonth] }} {{ currentYear }}</span>\n          <button (click)=\"nextMonth()\">&#8250;</button>\n        </div>\n\n        <div class=\"calendar-body\">\n          <div class=\"calendar-day-names\">\n            <span *ngFor=\"let day of daysOfWeek\">{{ day }}</span>\n          </div>\n\n          <div class=\"calendar-days\">\n            <span\n              *ngFor=\"let day of daysInMonth; let i = index\"\n              [class.today]=\"isToday(day)\"\n              [class.selected]=\"isSelected(day)\"\n              [class.disabled]=\"isDateDisabled(day)\"\n              (click)=\"day ? selectDate(day) : null\"\n            >\n              <!-- Somente permite clique em dias válidos -->\n              {{ day ? day : \"\" }}\n              <!-- Exibe o dia se for válido, senão exibe vazio -->\n            </span>\n          </div>\n        </div>\n      </div>\n    </div>\n  </div>\n</div>\n"]}
|
489
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"calendar-argenta.component.js","sourceRoot":"","sources":["../../../../../../projects/lib-portal-angular/src/lib/components/calendar-argenta/calendar-argenta.component.ts","../../../../../../projects/lib-portal-angular/src/lib/components/calendar-argenta/calendar-argenta.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, Output, EventEmitter, OnInit, OnChanges, SimpleChanges } from '@angular/core';\n\n@Component({\n    selector: 'argenta-calendar',\n    templateUrl: './calendar-argenta.component.html',\n    styleUrls: ['./calendar-argenta.component.scss'],\n})\nexport class CalendarArgentaComponent implements OnInit, OnChanges {\n    @Input() id: string = 'argenta-calendar';\n    @Input() placeholder: string = 'Select a date';\n    @Input() label: string = 'Select a date';\n    @Input() minDate: Date | null = null;\n    @Input() maxDate: Date | null = null;\n    @Input() locale: string = 'pt';\n    @Input() useTime: boolean = false; // Incluir ou não a hora\n    @Input() initialDate: string | null = null; // Data inicial no modo de data única\n    @Input() rangeMode: boolean = false; // Ativa o modo de intervalo de datas\n    @Input() startDate: string | null = null; // Data de início do intervalo\n    @Input() endDate: string | null = null; // Data de fim do intervalo\n    @Input() closeButtonLabel: string = 'Fechar'; // Texto do botão de fechar\n    @Output() rangeChange = new EventEmitter<{ start: string, end: string }>(); // Evento que emite data única ou intervalo\n\n    currentYear: number = new Date().getFullYear();\n    currentMonth: number = new Date().getMonth();\n    selectedDate: Date | null = null;\n    selectedStartDate: Date | null = null;\n    selectedEndDate: Date | null = null;\n    isCalendarVisible: boolean = false;\n    inputDate: string = '';\n    invalidDate: boolean = false;\n    isSelectingStart: boolean = true; // Controla se estamos selecionando a data inicial ou final\n    startTime: string = '';\n    endTime: string = '';\n    selectedTime: string = '';\n\n    locales: any = {\n        en: {\n            months: [\n                'January', 'February', 'March', 'April', 'May', 'June', 'July', 'August', 'September', 'October', 'November', 'December'\n            ],\n            daysOfWeek: ['Su', 'Mo', 'Tu', 'We', 'Th', 'Fr', 'Sa'],\n            invalidDateMessage: 'Invalid date. Please enter a date in the format dd/MM/yyyy',\n            startTimeLabel: 'Start Time', \n            endTimeLabel: 'End Time',\n        },\n        pt: {\n            months: [\n                'Janeiro', 'Fevereiro', 'Março', 'Abril', 'Maio', 'Junho', 'Julho', 'Agosto', 'Setembro', 'Outubro', 'Novembro', 'Dezembro'\n            ],\n            daysOfWeek: ['Dom', 'Seg', 'Ter', 'Qua', 'Qui', 'Sex', 'Sáb'],\n            invalidDateMessage: 'Data inválida. Por favor, insira uma data no formato dd/MM/yyyy',\n            startTimeLabel: 'Hora de Início', \n            endTimeLabel: 'Hora de Fim',\n        },\n        es: {\n            months: [\n                'Enero', 'Febrero', 'Marzo', 'Abril', 'Mayo', 'Junio', 'Julio', 'Agosto', 'Septiembre', 'Octubre', 'Noviembre', 'Diciembre'\n            ],\n            daysOfWeek: ['Do', 'Lu', 'Ma', 'Mi', 'Ju', 'Vi', 'Sá'],\n            invalidDateMessage: 'Fecha inválida. Por favor, ingrese una fecha en el formato dd/MM/yyyy',\n            startTimeLabel: 'Hora de Inicio',  \n            endTimeLabel: 'Hora de Fin', \n        }\n    };\n\n    ngOnInit(): void {\n        if (this.rangeMode) {\n            if (this.startDate) {\n                this.selectedStartDate = this.parseDate(this.startDate);\n                this.startTime = this.formatTimeForDisplay(this.selectedStartDate);\n            }\n            if (this.endDate) {\n                this.selectedEndDate = this.parseDate(this.endDate);\n                this.endTime = this.formatTimeForDisplay(this.selectedEndDate);\n            }\n            this.updateInputForRange(); // Atualiza o input no modo range com horas\n        } else {\n            if (this.initialDate) {\n                this.updateCalendar(this.initialDate); // Atualiza o input único com a data inicial\n                this.selectedTime = this.formatTimeForDisplay(this.selectedDate);\n            }\n        }\n    }\n    \n\n    ngOnChanges(changes: SimpleChanges): void {\n        if (changes['initialDate'] && changes['initialDate'].currentValue) {\n            this.updateCalendar(changes['initialDate'].currentValue);\n        }\n    }\n\n    // Atualiza o calendário para exibir a data única e a hora\n    updateCalendar(dateString: string): void {\n        const parsedDate = this.parseDate(dateString);\n        if (parsedDate && this.validateDate(dateString)) {\n            this.selectedDate = parsedDate;\n            this.currentYear = parsedDate.getFullYear();\n            this.currentMonth = parsedDate.getMonth();\n            this.inputDate = this.formatDateForDisplay(parsedDate); // Inclui a hora no input principal\n            this.emitSingleOrRange();  // Emite data única ou intervalo\n            this.invalidDate = false;\n        } else {\n            this.invalidDate = true;\n        }\n    }\n\n    onInputChange(event: any): void {\n        const inputValue = event.target.value;\n        this.inputDate = this.applyDateMask(inputValue);\n\n        if (this.rangeMode) {\n            const dateParts = this.inputDate.split(' - ');\n            if (dateParts.length === 2) {\n                const [startDate, endDate] = dateParts;\n\n                // Valida as duas partes do intervalo\n                if (this.validateDate(startDate) && this.validateDate(endDate)) {\n                    this.invalidDate = false;\n                    const parsedStartDate = this.parseDate(startDate);\n                    const parsedEndDate = this.parseDate(endDate);\n\n                    if (parsedStartDate && parsedEndDate) {\n                        this.selectedStartDate = parsedStartDate;\n                        this.selectedEndDate = parsedEndDate;\n                        this.emitSingleOrRange(); // Emite o intervalo atualizado\n                    }\n                } else {\n                    this.invalidDate = true;\n                }\n            }\n        } else {\n            // Valida data única\n            if ((this.useTime && this.inputDate.length === 16) || (!this.useTime && this.inputDate.length === 10)) {\n                if (this.validateDate(this.inputDate)) {\n                    this.invalidDate = false;\n                    const parsedDate = this.parseDate(this.inputDate);\n                    if (parsedDate) {\n                        this.selectedDate = parsedDate;\n                        this.emitSingleOrRange(); // Emite a data única atualizada\n                    }\n                } else {\n                    this.invalidDate = true;\n                }\n            }\n        }\n    }\n\n\n    // Atualiza o input no modo intervalo\n    updateInputForRange(): void {\n        if (this.selectedStartDate && this.selectedEndDate) {\n            const formattedStart = this.formatDateForDisplay(this.selectedStartDate);\n            const formattedEnd = this.formatDateForDisplay(this.selectedEndDate);\n            this.inputDate = `${formattedStart} - ${formattedEnd}`;\n        } else if (this.selectedStartDate) {\n            this.inputDate = this.formatDateForDisplay(this.selectedStartDate);\n        }\n    }\n\n\n    /// Emite data única ou intervalo, incluindo horas\n    emitSingleOrRange(): void {\n        if (this.rangeMode) {\n            const formattedStart = this.selectedStartDate ? this.formatDateForDisplay(this.selectedStartDate) : '';\n            const formattedEnd = this.selectedEndDate ? this.formatDateForDisplay(this.selectedEndDate) : '';\n            this.inputDate = `${formattedStart} - ${formattedEnd}`; // Atualiza o input principal com o range e horas\n            this.rangeChange.emit({ start: formattedStart, end: formattedEnd });\n        } else {\n            const formattedDate = this.selectedDate ? this.formatDateForDisplay(this.selectedDate) : '';\n            this.inputDate = formattedDate; // Atualiza o input principal com a data única e hora\n            this.rangeChange.emit({ start: formattedDate, end: '' });\n        }\n    }\n    // Função para tratar mudanças nas horas\n    onTimeChange(type: string): void {\n        if (type === 'start') {\n            if (this.selectedStartDate) {\n                const [hours, minutes] = this.startTime ? this.startTime.split(':') : ['00', '00'];\n                this.selectedStartDate.setHours(+hours, +minutes);\n            }\n        } else if (type === 'end') {\n            if (this.selectedEndDate) {\n                const [hours, minutes] = this.endTime ? this.endTime.split(':') : ['00', '00'];\n                this.selectedEndDate.setHours(+hours, +minutes);\n            }\n        } else if (type === 'single') {\n            if (this.selectedDate) {\n                const [hours, minutes] = this.selectedTime ? this.selectedTime.split(':') : ['00', '00'];\n                this.selectedDate.setHours(+hours, +minutes);\n            }\n        }\n        this.emitSingleOrRange(); // Atualiza o valor no input principal\n    }\n\n\n\n    // Função para formatação da hora no input de hora\n    formatTimeForDisplay(date: Date | null): string {\n        if (!date) return '';\n        const hours = date.getHours().toString().padStart(2, '0');\n        const minutes = date.getMinutes().toString().padStart(2, '0');\n        return `${hours}:${minutes}`;\n    }\n\n\n    // Método para selecionar uma data no calendário\n    selectDate(day: number): void {\n        const date = new Date(this.currentYear, this.currentMonth, day);\n\n        if (this.rangeMode) {\n            // Lógica para rangeMode\n            if (this.isSelectingStart) {\n                this.selectedStartDate = date;\n                if (this.startTime) {\n                    const [hours, minutes] = this.startTime.split(':');\n                    this.selectedStartDate.setHours(+hours, +minutes);\n                } else {\n                    this.selectedStartDate.setHours(0, 0);\n                    this.startTime = '00:00';\n                }\n                this.isSelectingStart = false;\n            } else {\n                this.selectedEndDate = date;\n                if (this.endTime) {\n                    const [hours, minutes] = this.endTime.split(':');\n                    this.selectedEndDate.setHours(+hours, +minutes);\n                } else {\n                    this.selectedEndDate.setHours(0, 0);\n                    this.endTime = '00:00';\n                }\n                this.isSelectingStart = true;\n                this.emitSingleOrRange();\n            }\n            this.updateInputForRange();\n            // O calendário só será fechado ao clicar no botão \"Fechar\"\n        } else {\n            // Lógica para quando não está em rangeMode\n            this.selectedDate = date;\n            if (this.selectedTime) {\n                const [hours, minutes] = this.selectedTime.split(':');\n                this.selectedDate.setHours(+hours, +minutes);\n            } else {\n                this.selectedDate.setHours(0, 0);\n                this.selectedTime = '00:00';\n            }\n            this.inputDate = this.formatDateForDisplay(date);\n            this.emitSingleOrRange();\n\n            // **Fechar o calendário apenas se `useTime` for false**\n            if (!this.useTime) {\n                this.isCalendarVisible = false; // Fecha o calendário automaticamente se `useTime` for false\n            }\n            // Se `useTime` for true, o calendário permanece aberto para inserir a hora\n        }\n    }\n\n\n\n    applyDateMask(inputValue: string): string {\n        // Remove qualquer caractere que não seja numérico\n        let digitsOnly = inputValue.replace(/\\D/g, '');\n\n        if (this.rangeMode) {\n            const maxLength = this.useTime ? 28 : 17; // Ajusta o comprimento máximo para intervalo com ou sem tempo\n\n            // Certifica-se de que a entrada não excede o comprimento permitido\n            if (digitsOnly.length > maxLength) {\n                digitsOnly = digitsOnly.substring(0, maxLength);\n            }\n\n            // Primeiro intervalo (start date)\n            let day1 = digitsOnly.substring(0, 2);\n            let month1 = digitsOnly.substring(2, 4);\n            let year1 = digitsOnly.substring(4, 8);\n            let hour1 = digitsOnly.substring(8, 10);\n            let minute1 = digitsOnly.substring(10, 12);\n\n            // Cria a data formatada para a primeira parte (start date)\n            let maskedDate = `${day1}/${month1}/${year1}`;\n            if (this.useTime && hour1 && minute1) {\n                maskedDate += ` ${hour1}:${minute1}`;\n            }\n\n            // Adiciona o separador ' - ' se houver dados para o segundo intervalo\n            if (digitsOnly.length > 12) {\n                maskedDate += ' - ';\n            }\n\n            // Segundo intervalo (end date)\n            let day2 = digitsOnly.substring(12, 14);\n            let month2 = digitsOnly.substring(14, 16);\n            let year2 = digitsOnly.substring(16, 20);\n            let hour2 = digitsOnly.substring(20, 22);\n            let minute2 = digitsOnly.substring(22, 24);\n\n            let endDatePart = `${day2}/${month2}/${year2}`;\n            if (this.useTime && hour2 && minute2) {\n                endDatePart += ` ${hour2}:${minute2}`;\n            }\n\n            // Adiciona a segunda parte (end date) ao input, se aplicável\n            if (digitsOnly.length > 12) {\n                maskedDate += endDatePart;\n            }\n\n            return maskedDate;\n        } else {\n            const maxLength = this.useTime ? 16 : 10;\n            if (digitsOnly.length > maxLength) {\n                digitsOnly = digitsOnly.substring(0, maxLength);\n            }\n\n            let day = digitsOnly.substring(0, 2);\n            let month = digitsOnly.substring(2, 4);\n            let year = digitsOnly.substring(4, 8);\n            let hour = digitsOnly.substring(8, 10);\n            let minute = digitsOnly.substring(10, 12);\n\n            let maskedDate = `${day}/${month}/${year}`;\n            if (this.useTime && hour && minute) {\n                maskedDate += ` ${hour}:${minute}`;\n            }\n\n            return maskedDate;\n        }\n    }\n\n\n\n    // Validação da data\n    validateDate(inputValue: string): boolean {\n        const [datePart, timePart] = inputValue.split(' ');\n        const [dayStr, monthStr, yearStr] = datePart.split('/');\n        const day = Number(dayStr);\n        const month = Number(monthStr);\n        const year = Number(yearStr);\n\n        if (month < 1 || month > 12 || yearStr.length !== 4 || isNaN(year)) {\n            return false;\n        }\n\n        const lastDayOfMonth = new Date(year, month, 0).getDate();\n        if (day < 1 || day > lastDayOfMonth) {\n            return false;\n        }\n\n        if (this.useTime && timePart) {\n            const [hourStr, minuteStr] = timePart.split(':');\n            const hour = Number(hourStr);\n            const minute = Number(minuteStr);\n            if (hour < 0 || hour > 23 || minute < 0 || minute > 59 || isNaN(hour) || isNaN(minute)) {\n                return false;\n            }\n        }\n\n        return true;\n    }\n\n    handleKeyPress(event: KeyboardEvent): void {\n        const charCode = event.key.charCodeAt(0);\n\n        // Permitir apenas números e barra \"/\"\n        if ((charCode < 48 || charCode > 57) && charCode !== 47) {\n            event.preventDefault(); // Bloqueia a inserção de caracteres não permitidos\n        }\n\n        // Limita o tamanho da entrada conforme o tipo de dado (com ou sem hora)\n        if (this.inputDate.replace(/\\D/g, '').length >= (this.useTime ? 12 : 8)) {\n            event.preventDefault(); // Limita o número de caracteres permitidos\n        }\n    }\n\n\n    // Fecha o calendário\n    closeCalendar(): void {\n        this.isCalendarVisible = false;\n    }\n\n    // Alterna a visibilidade do calendário\n    toggleCalendar(): void {\n        this.isCalendarVisible = !this.isCalendarVisible;\n    }\n\n    // Formata a data e hora para exibição no input principal\n    formatDateForDisplay(date: Date): string {\n        const day = date.getDate().toString().padStart(2, '0');\n        const month = (date.getMonth() + 1).toString().padStart(2, '0');\n        const year = date.getFullYear();\n        let formattedDate = `${day}/${month}/${year}`;\n\n        if (this.useTime) {\n            const hours = date.getHours().toString().padStart(2, '0');\n            const minutes = date.getMinutes().toString().padStart(2, '0');\n            formattedDate += ` ${hours}:${minutes}`;\n        }\n\n        return formattedDate;\n    }\n\n\n    // Formata a data para emitir no evento\n    formatDateForEmit(date: Date): string {\n        const day = date.getDate().toString().padStart(2, '0');\n        const month = (date.getMonth() + 1).toString().padStart(2, '0');\n        const year = date.getFullYear();\n        let formattedDate = `${day}/${month}/${year}`;\n        if (this.useTime) {\n            const hours = date.getHours().toString().padStart(2, '0');\n            const minutes = date.getMinutes().toString().padStart(2, '0');\n            formattedDate += ` - ${hours}:${minutes}`;\n        }\n        return formattedDate;\n    }\n\n    // Função para parsing de string para Date\n    parseDate(dateStr: string): Date | null {\n        const [datePart, timePart] = dateStr.split(' ');\n        const [day, month, year] = datePart.split('/').map(Number);\n        if (!day || !month || !year) {\n            return null;\n        }\n\n        const date = new Date(year, month - 1, day);\n        if (this.useTime && timePart) {\n            const [hour, minute] = timePart.split(':').map(Number);\n            date.setHours(hour || 0, minute || 0);\n        }\n        return date;\n    }\n\n    // Gera a lista de dias no mês atual\n    get daysInMonth(): any[] {\n        const firstDayOfMonth = new Date(this.currentYear, this.currentMonth, 1).getDay();\n        const totalDaysInMonth = new Date(this.currentYear, this.currentMonth + 1, 0).getDate();\n        const daysArray = Array.from({ length: totalDaysInMonth }, (_, i) => i + 1);\n        const leadingEmptyDays = Array(firstDayOfMonth).fill(null); // Dias vazios antes do primeiro dia do mês\n        return [...leadingEmptyDays, ...daysArray];\n    }\n\n    // Verifica se um dia está selecionado\n    isSelected(day: number): boolean {\n        if (!this.selectedDate) return false;\n        const selectedDay = this.selectedDate.getDate();\n        const selectedMonth = this.selectedDate.getMonth();\n        const selectedYear = this.selectedDate.getFullYear();\n        return selectedDay === day && selectedMonth === this.currentMonth && selectedYear === this.currentYear;\n    }\n\n    // Verifica se o dia é hoje\n    isToday(day: number): boolean {\n        const today = new Date();\n        return today.getFullYear() === this.currentYear && today.getMonth() === this.currentMonth && today.getDate() === day;\n    }\n\n    // Verifica se a data está desabilitada\n    isDateDisabled(day: number): boolean {\n        const date = new Date(this.currentYear, this.currentMonth, day);\n        if (this.minDate && date < this.minDate) return true;\n        if (this.maxDate && date > this.maxDate) return true;\n        return false;\n    }\n\n    // Verifica se um dia está no intervalo selecionado\n    isInRange(day: number): boolean {\n        if (!this.selectedStartDate || !this.selectedEndDate) return false;\n        const date = new Date(this.currentYear, this.currentMonth, day);\n        return date >= this.selectedStartDate && date <= this.selectedEndDate;\n    }\n\n    // Avança para o próximo mês\n    nextMonth(): void {\n        if (this.currentMonth === 11) {\n            this.currentMonth = 0;\n            this.currentYear++;\n        } else {\n            this.currentMonth++;\n        }\n    }\n\n    // Retrocede para o mês anterior\n    prevMonth(): void {\n        if (this.currentMonth === 0) {\n            this.currentMonth = 11;\n            this.currentYear--;\n        } else {\n            this.currentMonth--;\n        }\n    }\n\n    // Retorna a lista de meses de acordo com o locale\n    get months(): string[] {\n        return this.locales[this.locale]?.months || this.locales['en'].months;\n    }\n\n    // Retorna a lista de dias da semana de acordo com o locale\n    get daysOfWeek(): string[] {\n        return this.locales[this.locale]?.daysOfWeek || this.locales['en'].daysOfWeek;\n    }\n\n    \n\n}\n","<div class=\"form-group\">\n  <label [for]=\"id\" [ngClass]=\"'label-styles'\">{{ label }}</label>\n  <div class=\"input-wrapper\">\n    <input\n      id=\"{{ id }}\"\n      type=\"text\"\n      class=\"custom-input\"\n      [attr.placeholder]=\"rangeMode && useTime ? 'dd/MM/yyyy HH:mm - dd/MM/yyyy HH:mm' : \n      rangeMode && !useTime ? 'dd/MM/yyyy - dd/MM/yyyy' :(!rangeMode && useTime ? 'dd/MM/yyyy HH:mm' : 'dd/MM/yyyy')\"\n      [value]=\"inputDate\"\n      (input)=\"onInputChange($event)\"\n      (keypress)=\"handleKeyPress($event)\"\n      (click)=\"toggleCalendar()\"\n    />\n    <lucide-icon name=\"calendar\" class=\"calendar-icon\"></lucide-icon>\n  </div>\n\n  <div *ngIf=\"invalidDate\" class=\"error-message\">\n    {{ locales[locale].invalidDateMessage }}\n    <span *ngIf=\"useTime\"> HH:mm.</span>\n  </div>\n\n  <div class=\"calendar-wrapper\">\n    <div class=\"calendar-container\" [ngClass]=\"{ open: isCalendarVisible }\">\n      <div class=\"calendar\">\n        <div class=\"calendar-header\">\n          <button (click)=\"prevMonth()\">&#8249;</button>\n          <span>{{ months[currentMonth] }} {{ currentYear }}</span>\n          <button (click)=\"nextMonth()\">&#8250;</button>\n        </div>\n\n        <div class=\"calendar-body\">\n          <div class=\"calendar-day-names\">\n            <span *ngFor=\"let day of daysOfWeek\">{{ day }}</span>\n          </div>\n\n          <div class=\"calendar-days\">\n            <span\n              *ngFor=\"let day of daysInMonth; let i = index\"\n              [class.today]=\"isToday(day)\"\n              [class.selected]=\"isSelected(day)\"\n              [class.in-range]=\"isInRange(day)\"\n              [class.disabled]=\"isDateDisabled(day)\"\n              (click)=\"day ? selectDate(day) : null\"\n            >\n              {{ day ? day : \"\" }}\n            </span>\n          </div>\n        </div>\n\n        <!-- Inputs para inserção das horas -->\n        <div *ngIf=\"useTime\" class=\"time-inputs\">\n          <!-- Campo de hora de início -->\n          <div *ngIf=\"rangeMode\" class=\"time-input\">\n            <label>{{ locales[locale]?.startTimeLabel || 'Hora de Início' }}</label> <!-- Usando tradução -->\n            <input type=\"time\" [(ngModel)]=\"startTime\" (change)=\"onTimeChange('start')\" />\n          </div>\n\n          <!-- Campo de hora de fim -->\n          <div *ngIf=\"rangeMode\" class=\"time-input\">\n            <label>{{ locales[locale]?.endTimeLabel || 'Hora de Fim' }}</label> <!-- Usando tradução -->\n            <input type=\"time\" [(ngModel)]=\"endTime\" (change)=\"onTimeChange('end')\" />\n          </div>\n\n          <!-- Campo de hora única (se não for range) -->\n          <div *ngIf=\"!rangeMode\" class=\"time-input\">\n            <label>{{ locales[locale]?.startTimeLabel || 'Hora' }}</label> <!-- Usando o label de início -->\n            <input type=\"time\" [(ngModel)]=\"selectedTime\" (change)=\"onTimeChange('single')\" />\n          </div>\n        </div>\n\n        <!-- Botão de fechar o calendário -->\n        <button class=\"close-button\" (click)=\"closeCalendar()\">{{ closeButtonLabel }}</button>\n      </div>\n    </div>\n  </div>\n</div>\n"]}
|