lib-portal-angular 0.0.69 → 0.0.70

Sign up to get free protection for your applications and to get access to all the features.
@@ -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 "lucide-angular";
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'; // Suporte para diferentes idiomas
13
- this.useTime = false; // Propriedade para definir se inclui hora
14
- this.initialDate = null; // Propriedade para receber a data inicial
15
- this.dateChange = new EventEmitter();
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.initialDate) {
51
- // Se a initialDate for fornecida, usamos ela
52
- this.updateCalendar(this.initialDate);
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
- // Caso contrário, usamos a data atual
56
- const today = new Date();
57
- this.selectedDate = today;
58
- this.inputDate = this.formatDateForDisplay(today);
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
- // Método para atualizar o calendário com a data passada
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
- // Verifica se a data é válida
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.dateChange.emit(this.inputDate); // Emite a nova data
77
- this.invalidDate = false; // Remove o status de data inválida
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; // Marca a data como inválida
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
- // Validação para obrigar a hora quando useTime for verdadeiro
89
- if (this.useTime) {
90
- // Se a entrada não tiver o comprimento correto para data + hora
91
- if (this.inputDate.length < 16) {
92
- this.invalidDate = true;
93
- this.dateChange.emit('Data ou hora inválida');
94
- return;
95
- }
96
- }
97
- // Somente validar a hora se o campo useTime estiver ativo e o formato estiver correto
98
- if (this.useTime && this.inputDate.length >= 14) {
99
- const [datePart, timePart] = this.inputDate.split(' ');
100
- if (timePart) {
101
- const [hourStr, minuteStr] = timePart.split(':');
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 if (minute < 0 || minute > 59 || isNaN(minute)) {
120
+ else {
111
121
  this.invalidDate = true;
112
- this.dateChange.emit('Hora inválida');
113
- return;
114
122
  }
115
- else {
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
- // Emitir a data quando for válida
121
- if ((this.useTime && this.inputDate.length === 16) || (!this.useTime && this.inputDate.length === 10)) {
122
- if (this.validateDate(this.inputDate)) {
123
- this.invalidDate = false;
124
- const parsedDate = this.parseDate(this.inputDate);
125
- // Verificar se parsedDate não é nulo antes de acessar suas propriedades
126
- if (parsedDate !== null) {
127
- this.currentYear = parsedDate.getFullYear();
128
- this.currentMonth = parsedDate.getMonth();
129
- this.selectedDate = parsedDate;
130
- // Formatar a data para dd/MM/yyyy - HH:mm
131
- const formattedDate = this.formatDateForEmit(parsedDate);
132
- this.dateChange.emit(formattedDate); // Emite a data válida com o hífen
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
- console.log('Data inválida passada para o componente.');
136
- this.dateChange.emit('Data inválida');
209
+ this.selectedStartDate.setHours(0, 0);
210
+ this.startTime = '00:00';
137
211
  }
212
+ this.isSelectingStart = false;
138
213
  }
139
214
  else {
140
- this.invalidDate = true;
141
- this.dateChange.emit('Data inválida'); // Emite o evento com mensagem de erro
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
- // Formatar a data e hora com hífen
146
- formatDateForEmit(date) {
147
- const day = date.getDate().toString().padStart(2, '0');
148
- const month = (date.getMonth() + 1).toString().padStart(2, '0');
149
- const year = date.getFullYear();
150
- let formattedDate = `${day}/${month}/${year}`;
151
- if (this.useTime) {
152
- const hours = date.getHours().toString().padStart(2, '0');
153
- const minutes = date.getMinutes().toString().padStart(2, '0');
154
- // Adiciona o hífen entre a data e a hora
155
- formattedDate += ` - ${hours}:${minutes}`;
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
- // Limita os dígitos com base no uso de hora
162
- const maxLength = this.useTime ? 12 : 8;
163
- if (digitsOnly.length > maxLength) {
164
- digitsOnly = digitsOnly.substring(0, maxLength);
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
- let day = digitsOnly.substring(0, 2);
167
- let month = digitsOnly.substring(2, 4);
168
- let year = digitsOnly.substring(4, 8);
169
- let hour = digitsOnly.substring(8, 10);
170
- let minute = digitsOnly.substring(10, 12);
171
- let maskedDate = `${day}/${month}/${year}`;
172
- if (this.useTime && hour && minute) {
173
- maskedDate += ` ${hour}:${minute}`;
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; // Hora ou minuto inválidos
326
+ return false;
198
327
  }
199
328
  }
200
329
  return true;
201
330
  }
202
- parseDate(dateStr) {
203
- const [datePart, timePart] = dateStr.split(' ');
204
- const [day, month, year] = datePart.split('/').map(Number);
205
- if (!day || !month || !year) {
206
- return null;
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
- const date = new Date(year, month - 1, day);
209
- if (this.useTime && timePart) {
210
- const [hour, minute] = timePart.split(':').map(Number);
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
- toggleCalendar() {
228
- this.isCalendarVisible = !this.isCalendarVisible;
229
- }
230
- selectDate(day) {
231
- const date = new Date(this.currentYear, this.currentMonth, day);
232
- this.inputDate = this.formatDateForDisplay(date);
233
- this.selectedDate = date; // Armazena a data selecionada
234
- this.dateChange.emit(this.inputDate); // Emite a data selecionada ao clicar no calendário
235
- this.isCalendarVisible = false; // Fecha o calendário após a seleção
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
- handleKeyPress(event) {
238
- const charCode = event.key.charCodeAt(0);
239
- if (charCode < 48 || charCode > 57) {
240
- event.preventDefault();
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
- if (this.inputDate.replace(/\D/g, '').length >= (this.useTime ? 12 : 8)) {
243
- event.preventDefault();
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(); // Dia da semana do primeiro dia do mês
248
- const totalDaysInMonth = new Date(this.currentYear, this.currentMonth + 1, 0).getDate(); // Total de dias no mês
249
- const daysArray = Array.from({ length: totalDaysInMonth }, (_, i) => i + 1); // Array com todos os dias do mês
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]; // Retorna os dias vazios seguidos pelos dias do mês
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 (selectedDay === day &&
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 (today.getFullYear() === this.currentYear &&
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: { dateChange: "dateChange" }, 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]=\"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 <!-- \u00CDcone de calend\u00E1rio dentro do input -->\n <lucide-icon name=\"calendar\" class=\"calendar-icon\"></lucide-icon>\n </div>\n\n <!-- Mensagem de erro estilo bal\u00E3ozinho -->\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\u00E1lidos -->\n {{ day ? day : \"\" }}\n <!-- Exibe o dia se for v\u00E1lido, sen\u00E3o exibe vazio -->\n </span>\n </div>\n </div>\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}.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}.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}\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: "component", type: i2.LucideAngularComponent, selector: "lucide-angular, lucide-icon, i-lucide, span-lucide", inputs: ["class", "name", "img", "color", "absoluteStrokeWidth", "size", "strokeWidth"] }] }); }
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()\">&#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\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 <!-- \u00CDcone de calend\u00E1rio dentro do input -->\n <lucide-icon name=\"calendar\" class=\"calendar-icon\"></lucide-icon>\n </div>\n\n <!-- Mensagem de erro estilo bal\u00E3ozinho -->\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\u00E1lidos -->\n {{ day ? day : \"\" }}\n <!-- Exibe o dia se for v\u00E1lido, sen\u00E3o exibe vazio -->\n </span>\n </div>\n </div>\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}.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}.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}\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()\">&#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\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
- }], dateChange: [{
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"]}