@litigiovirtual/ius-design-components 1.0.61 → 1.0.63

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -36,12 +36,12 @@ export class DateHourPickerComponent {
36
36
  this.focused = false;
37
37
  this.calendarView = 'day';
38
38
  this.calendarDays = [];
39
- // Posiciones preferidas del overlay: alineado a la derecha del input
39
+ // Posiciones preferidas del overlay: izquierda abajo, derecha abajo, izquierda arriba, derecha arriba
40
40
  this.overlayPositions = [
41
- { originX: 'end', originY: 'bottom', overlayX: 'end', overlayY: 'top', offsetY: 8 },
42
- { originX: 'end', originY: 'bottom', overlayX: 'start', overlayY: 'top', offsetY: 8 },
43
- { originX: 'center', originY: 'bottom', overlayX: 'center', overlayY: 'top', offsetY: 8 },
44
- { originX: 'start', originY: 'bottom', overlayX: 'start', overlayY: 'top', offsetY: 8 },
41
+ { originX: 'start', originY: 'bottom', overlayX: 'start', overlayY: 'top', offsetY: 4 },
42
+ { originX: 'end', originY: 'bottom', overlayX: 'end', overlayY: 'top', offsetY: 4 },
43
+ { originX: 'start', originY: 'top', overlayX: 'start', overlayY: 'bottom', offsetY: -4 },
44
+ { originX: 'end', originY: 'top', overlayX: 'end', overlayY: 'bottom', offsetY: -4 },
45
45
  ];
46
46
  }
47
47
  ngOnInit() {
@@ -276,4 +276,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
276
276
  type: HostListener,
277
277
  args: ['document:click', ['$event']]
278
278
  }] } });
279
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-hour-picker.component.js","sourceRoot":"","sources":["../../../../../projects/ius-design-components/src/lib/date-hour-picker/date-hour-picker.component.ts","../../../../../projects/ius-design-components/src/lib/date-hour-picker/date-hour-picker.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\r\nimport { Component, ElementRef, EventEmitter, HostListener, Input, Output } from '@angular/core';\r\nimport { OverlayModule, ConnectedPosition, ScrollStrategy, Overlay } from '@angular/cdk/overlay';\r\nimport { IconMdComponent } from '../icon-md/icon-md.component';\r\nimport { SimpleDividerComponent } from '../simple-divider/simple-divider.component';\r\nimport { ButtonStandardTertiaryComponent } from '../button-standard-tertiary/button-standard-tertiary.component';\r\n\r\n@Component({\r\n  selector: 'ius-date-hour-picker',\r\n  standalone: true,\r\n  imports: [\r\n    CommonModule,\r\n    OverlayModule, // ✅ CDK Overlay\r\n    IconMdComponent,\r\n    SimpleDividerComponent,\r\n    ButtonStandardTertiaryComponent,\r\n  ],\r\n  templateUrl: './date-hour-picker.component.html',\r\n  styleUrl: './date-hour-picker.component.scss',\r\n})\r\nexport class DateHourPickerComponent {\r\n  @Input() label = 'Fecha y hora';\r\n  @Input() placeholder = 'Seleccione una fecha y hora';\r\n  @Input() error = false;\r\n  @Input() helpText = '';\r\n  @Input() helpTextError = '';\r\n  @Input() disabled = false;\r\n  @Input() iconHelp = false;\r\n  @Input() isRequired = true;\r\n  @Input() mode: 'date-only' | 'time-only' | 'date-time' = 'date-time';\r\n\r\n  @Output() dateSelected = new EventEmitter<string>();\r\n\r\n  readonly dayLabels = ['Do', 'Lu', 'Ma', 'Mi', 'Ju', 'Vi', 'Sa'];\r\n  readonly months = ['Ene', 'Feb', 'Mar', 'Abr', 'May', 'Jun', 'Jul', 'Ago', 'Sep', 'Oct', 'Nov', 'Dic'];\r\n  readonly yearsArray = Array.from({ length: 12 }, (_, i) => i);\r\n\r\n  readonly hours = Array.from({ length: 12 }, (_, i) => i + 1); // 01 a 12\r\n  readonly minutes = Array.from({ length: 60 }, (_, i) => i);   // 00 a 59\r\n\r\n  selectedDate: Date | null = null;\r\n  selectedHour = 1;\r\n  selectedMinute = 0;\r\n  selectedPeriod: 'AM' | 'PM' = 'PM';\r\n\r\n  viewDate = new Date();\r\n  calendarOpen = false;\r\n  focused = false;\r\n  calendarView: 'day' | 'month' | 'year' = 'day';\r\n  calendarDays: Date[] = [];\r\n\r\n  // Posiciones preferidas del overlay: alineado a la derecha del input\r\n  overlayPositions: ConnectedPosition[] = [\r\n    { originX: 'end', originY: 'bottom', overlayX: 'end', overlayY: 'top', offsetY: 8 },\r\n    { originX: 'end', originY: 'bottom', overlayX: 'start', overlayY: 'top', offsetY: 8 },\r\n    { originX: 'center', originY: 'bottom', overlayX: 'center', overlayY: 'top', offsetY: 8 },\r\n    { originX: 'start', originY: 'bottom', overlayX: 'start', overlayY: 'top', offsetY: 8 },\r\n  ];\r\n\r\n  scrollStrategy!: ScrollStrategy;\r\n\r\n  constructor(\r\n    private elRef: ElementRef\r\n    // private overlay: Overlay\r\n  ) { }\r\n\r\n  ngOnInit(): void {\r\n    // this.scrollStrategy = this.overlay.scrollStrategies.reposition();\r\n\r\n    this.generateCalendarDays();\r\n    this.updateLabelAndPlaceholder();\r\n  }\r\n\r\n  private updateLabelAndPlaceholder(): void {\r\n    switch (this.mode) {\r\n      case 'date-only':\r\n        this.label = this.label.replace('Fecha y hora', 'Fecha');\r\n        this.placeholder = this.placeholder.replace('fecha y hora', 'fecha');\r\n        break;\r\n      case 'time-only':\r\n        this.label = this.label.replace('Fecha y hora', 'Hora');\r\n        this.placeholder = this.placeholder.replace('fecha y hora', 'hora');\r\n        break;\r\n      case 'date-time':\r\n      default:\r\n        break;\r\n    }\r\n  }\r\n\r\n  toggleCalendar(): void {\r\n    if (this.disabled) return;\r\n    if (!this.calendarOpen) {\r\n      this.calendarView = 'day';\r\n      this.error = false;\r\n      this.focused = true;\r\n      this.calendarOpen = true;\r\n      return;\r\n    }\r\n    this.emitSelection(true);\r\n    this.focused = false;\r\n  }\r\n\r\n  goToToday(): void {\r\n    const now = new Date();\r\n    this.selectedHour = now.getHours() % 12 || 12;\r\n    this.selectedMinute = now.getMinutes();\r\n    this.selectedPeriod = now.getHours() < 12 ? 'AM' : 'PM';\r\n\r\n    this.viewDate = now;\r\n\r\n    this.emitSelection(this.mode !== 'time-only' ? false : true);\r\n  }\r\n\r\n  selectTime(): void {\r\n    if (this.mode === 'time-only') {\r\n      this.emitSelection(true);\r\n    } else {\r\n      this.emitSelection(false);\r\n    }\r\n  }\r\n\r\n  getDisplayValue(): string {\r\n    if (!this.selectedDate) return '';\r\n\r\n    switch (this.mode) {\r\n      case 'date-only':\r\n        return this.selectedDate.toLocaleDateString('es-ES', {\r\n          day: '2-digit',\r\n          month: '2-digit',\r\n          year: 'numeric'\r\n        });\r\n      case 'time-only':\r\n        return this.selectedDate.toLocaleTimeString('es-ES', {\r\n          hour: '2-digit',\r\n          minute: '2-digit',\r\n          hour12: true\r\n        });\r\n      case 'date-time':\r\n      default:\r\n        return this.selectedDate.toLocaleString('es-ES', {\r\n          day: '2-digit',\r\n          month: '2-digit',\r\n          year: 'numeric',\r\n          hour: '2-digit',\r\n          minute: '2-digit',\r\n          hour12: true\r\n        });\r\n    }\r\n  }\r\n\r\n  nextView(view: 'day' | 'month' | 'year'): 'day' | 'month' | 'year' {\r\n    return view === 'day' ? 'month' : view === 'month' ? 'year' : 'day';\r\n  }\r\n\r\n  prev(): void {\r\n    this.shiftViewDate(-1);\r\n    this.generateCalendarDays();\r\n  }\r\n\r\n  next(): void {\r\n    this.shiftViewDate(1);\r\n    this.generateCalendarDays();\r\n  }\r\n\r\n  private shiftViewDate(step: number): void {\r\n    const year = this.viewDate.getFullYear();\r\n    const month = this.viewDate.getMonth();\r\n\r\n    if (this.calendarView === 'day') {\r\n      this.viewDate = new Date(year, month + step, 1);\r\n    } else if (this.calendarView === 'month') {\r\n      this.viewDate = new Date(year + step, month, 1);\r\n    } else {\r\n      this.viewDate = new Date(year + step * 10, month, 1);\r\n    }\r\n  }\r\n\r\n  selectDate(date: Date, open: boolean): void {\r\n    this.viewDate = new Date(date);\r\n    const hour = this.selectedPeriod === 'AM'\r\n      ? this.selectedHour % 12\r\n      : (this.selectedHour % 12) + 12;\r\n\r\n    const selected = new Date(\r\n      date.getFullYear(),\r\n      date.getMonth(),\r\n      date.getDate(),\r\n      hour,\r\n      this.selectedMinute\r\n    );\r\n\r\n    this.selectedDate = selected;\r\n    this.focused = false;\r\n    this.error = false;\r\n\r\n    this.emitSelection(!open);\r\n\r\n    if (open) {\r\n      this.calendarOpen = true;\r\n    }\r\n  }\r\n\r\n\r\n  setMonth(month: number): void {\r\n    this.viewDate.setMonth(month);\r\n    this.calendarView = 'day';\r\n    this.generateCalendarDays();\r\n  }\r\n\r\n  setYear(year: number): void {\r\n    this.viewDate.setFullYear(year);\r\n    this.calendarView = 'month';\r\n    this.generateCalendarDays();\r\n  }\r\n\r\n  getMonthName(index: number): string {\r\n    return this.months[index];\r\n  }\r\n\r\n  getDecadeStart(): number {\r\n    return Math.floor(this.viewDate.getFullYear() / 10) * 10;\r\n  }\r\n\r\n  isSameDate(d1: Date, d2: Date): boolean {\r\n    return d1.getDate() === d2.getDate() &&\r\n      d1.getMonth() === d2.getMonth() &&\r\n      d1.getFullYear() === d2.getFullYear();\r\n  }\r\n\r\n  generateCalendarDays(): void {\r\n    const days: Date[] = [];\r\n    const year = this.viewDate.getFullYear();\r\n    const month = this.viewDate.getMonth();\r\n\r\n    const firstDay = new Date(year, month, 1);\r\n    const offset = firstDay.getDay();\r\n    const startDate = new Date(year, month, 1 - offset);\r\n\r\n    for (let i = 0; i < 42; i++) {\r\n      const date = new Date(startDate);\r\n      date.setDate(startDate.getDate() + i);\r\n      days.push(date);\r\n    }\r\n\r\n    this.calendarDays = days;\r\n  }\r\n\r\n  closeCalendar(): void {\r\n    this.calendarOpen = false;\r\n\r\n    if (!this.selectedDate) {\r\n      this.error = true;\r\n    }\r\n  }\r\n\r\n  @HostListener('document:click', ['$event'])\r\n  handleOutsideClick(event: MouseEvent): void {\r\n    const clickedInside = this.elRef.nativeElement.contains(event.target);\r\n    if (!clickedInside && this.calendarOpen) {\r\n      this.closeCalendar();\r\n    }\r\n  }\r\n\r\n\r\n  private buildSelectedDateFromState(): Date {\r\n    if (this.mode === 'date-only') {\r\n      const base = this.selectedDate ?? this.viewDate;\r\n      return new Date(base.getFullYear(), base.getMonth(), base.getDate(), 0, 0);\r\n    }\r\n\r\n    if (this.mode === 'time-only') {\r\n      const hour = this.selectedPeriod === 'AM' ? this.selectedHour % 12 : (this.selectedHour % 12) + 12;\r\n      const now = new Date();\r\n      return new Date(now.getFullYear(), now.getMonth(), now.getDate(), hour, this.selectedMinute);\r\n    }\r\n    const hour = this.selectedPeriod === 'AM' ? this.selectedHour % 12 : (this.selectedHour % 12) + 12;\r\n    const base = this.viewDate ?? new Date();\r\n    return new Date(base.getFullYear(), base.getMonth(), base.getDate(), hour, this.selectedMinute);\r\n  }\r\n\r\n  private emitSelection(closeCalendar: boolean): void {\r\n    const selected = this.buildSelectedDateFromState();\r\n    this.selectedDate = selected;\r\n\r\n    if (this.mode === 'date-only') {\r\n      const dateString = `${selected.getFullYear()}-${(selected.getMonth() + 1).toString().padStart(2, '0')}-${selected.getDate().toString().padStart(2, '0')}`;\r\n      this.dateSelected.emit(dateString);\r\n    } else if (this.mode === 'time-only') {\r\n      const timeString = `${selected.getHours().toString().padStart(2, '0')}:${selected.getMinutes().toString().padStart(2, '0')}:00`;\r\n      this.dateSelected.emit(timeString);\r\n    } else {\r\n      const dateString = `${selected.getFullYear()}-${(selected.getMonth() + 1).toString().padStart(2, '0')}-${selected.getDate().toString().padStart(2, '0')}T${selected.getHours().toString().padStart(2, '0')}:${selected.getMinutes().toString().padStart(2, '0')}:00`;\r\n      this.dateSelected.emit(dateString);\r\n    }\r\n\r\n    if (closeCalendar) {\r\n      this.calendarOpen = false;\r\n    }\r\n  }\r\n}\r\n","<div class=\"date-picker\" [class.disabled]=\"disabled\">\r\n  <div class=\"text\">\r\n    @if (isRequired) {\r\n    <div class=\"required\"></div>\r\n    }\r\n\r\n    <label class=\"label\">{{ label }}</label>\r\n\r\n    @if (iconHelp) {\r\n      <div class=\"help-icon\">\r\n        <ius-icon-md iconName=\"icon-help\"></ius-icon-md>\r\n      </div>\r\n    }\r\n\r\n    <label class=\"label\">:</label>\r\n  </div>\r\n\r\n  <div class=\"input-wrapper\">\r\n    <!-- Origen del overlay -->\r\n    <div\r\n      class=\"container-textfield\"\r\n      [ngClass]=\"{\r\n        disabled: disabled,\r\n        focused: calendarOpen || focused,\r\n        alert: !calendarOpen && error && !disabled,\r\n        selected: selectedDate\r\n      }\"\r\n      (click)=\"toggleCalendar()\"\r\n      cdkOverlayOrigin #origin=\"cdkOverlayOrigin\"\r\n    >\r\n      <div class=\"input\">\r\n        <input\r\n          [placeholder]=\"placeholder\"\r\n          [value]=\"selectedDate ? getDisplayValue() : ''\"\r\n          readonly\r\n          [disabled]=\"disabled\"\r\n        />\r\n        <div class=\"cnt-icon-right\">\r\n          <ius-icon-md iconName=\"icon-calendar-today\"></ius-icon-md>\r\n        </div>\r\n      </div>\r\n    </div>\r\n\r\n    <!-- ======== OVERLAY (CDK) ======== -->\r\n    <ng-template\r\n      cdkConnectedOverlay\r\n      [cdkConnectedOverlayOpen]=\"calendarOpen\"\r\n      [cdkConnectedOverlayOrigin]=\"origin\"\r\n      [cdkConnectedOverlayPositions]=\"overlayPositions\"\r\n      [cdkConnectedOverlayHasBackdrop]=\"false\"\r\n      [cdkConnectedOverlayPush]=\"true\"\r\n      [cdkConnectedOverlayFlexibleDimensions]=\"false\"\r\n      [cdkConnectedOverlayPanelClass]=\"'calendar-overlay-panel'\"\r\n    >\r\n      <div\r\n        class=\"calendar-overlay\"\r\n        [class.time-only]=\"mode === 'time-only'\"\r\n        [class.date-only]=\"mode === 'date-only'\"\r\n        (click)=\"$event.stopPropagation()\"\r\n      >\r\n        <div class=\"calendar-content\">\r\n          @if (mode !== 'time-only') {\r\n          <div class=\"calendar-side\">\r\n            <div class=\"calendar-header\">\r\n              <ius-button-standard-tertiary\r\n                iconName=\"icon-keyboard-arrow-left\"\r\n                (buttonClicked)=\"prev()\"\r\n              ></ius-button-standard-tertiary>\r\n\r\n              <span (click)=\"calendarView = nextView(calendarView)\">\r\n              @switch (calendarView) { @case ('day') {\r\n              {{ getMonthName(viewDate.getMonth()) }}\r\n              {{ viewDate.getFullYear() }}\r\n              } @case ('month') {\r\n              {{ viewDate.getFullYear() }}\r\n              } @case ('year') {\r\n              {{ getDecadeStart() }}-{{ getDecadeStart() + 9 }}\r\n              } }\r\n              </span>\r\n\r\n              <ius-button-standard-tertiary\r\n                iconName=\"icon-keyboard-arrow-right\"\r\n                (buttonClicked)=\"next()\"\r\n              ></ius-button-standard-tertiary>\r\n            </div>\r\n\r\n            <div class=\"calendar-body\">\r\n            @switch (calendarView) { @case ('day') {\r\n                  <div class=\"grid days\">\r\n              @for (day of dayLabels; track day) {\r\n              <div class=\"header\">{{ day }}</div>\r\n              } @for (date of calendarDays; track date) {\r\n                      <div\r\n                        class=\"cell\"\r\n                [class.selected]=\"\r\n                  selectedDate && isSameDate(date, selectedDate)\r\n                \"\r\n                        [class.out-of-range]=\"date.getMonth() !== viewDate.getMonth()\"\r\n                        (click)=\"selectDate(date, true)\"\r\n                      >\r\n                        {{ date.getDate() }}\r\n                      </div>\r\n                    }\r\n                  </div>\r\n            } @case ('month') {\r\n                  <div class=\"grid months\">\r\n                    @for (m of months; track m; let i = $index) {\r\n                      <div class=\"cell\" (click)=\"setMonth(i)\">{{ m }}</div>\r\n                    }\r\n                  </div>\r\n            } @case ('year') {\r\n                  <div class=\"grid years\">\r\n                    @for (i of yearsArray; track i) {\r\n                      <div\r\n                        class=\"cell\"\r\n                        [class.out-of-range]=\"i === 0 || i === 11\"\r\n                        (click)=\"setYear(getDecadeStart() - 1 + i)\"\r\n                      >\r\n                        {{ getDecadeStart() - 1 + i }}\r\n                      </div>\r\n                    }\r\n                  </div>\r\n            } }\r\n            </div>\r\n          </div>\r\n        } @if (mode !== 'date-only') {\r\n          <div class=\"time-selector\">\r\n            <button class=\"time-title\">\r\n              <span>\r\n                {{ selectedHour | number : \"2.0\" }}:{{\r\n                  selectedMinute === 0 ? \"00\" : (selectedMinute | number : \"2.0\")\r\n                }}\r\n                {{ selectedPeriod }}\r\n              </span>\r\n            </button>\r\n            <ius-simple-divider></ius-simple-divider>\r\n            <div class=\"time-columns\">\r\n              <div class=\"column scrollable\">\r\n                @for (h of hours; track h) {\r\n                <div\r\n                  [class.selected]=\"h === selectedHour\"\r\n                (click)=\"\r\n                  selectedHour = h;\r\n                  mode === 'time-only'\r\n                    ? selectTime()\r\n                    : selectDate(viewDate, true)\r\n                \"\r\n                >\r\n                  {{ h | number : \"2.0\" }}\r\n                </div>\r\n                }\r\n              </div>\r\n              <div class=\"divider\"></div>\r\n              <div class=\"column scrollable\">\r\n                @for (m of minutes; track m) {\r\n                <div\r\n                  [class.selected]=\"m === selectedMinute\"\r\n                (click)=\"\r\n                  selectedMinute = m;\r\n                  mode === 'time-only'\r\n                    ? selectTime()\r\n                    : selectDate(viewDate, true)\r\n                \"\r\n                >\r\n                  {{ m | number : \"2.0\" }}\r\n                </div>\r\n                }\r\n              </div>\r\n              <div class=\"divider\"></div>\r\n              <div class=\"column\">\r\n                <div\r\n                  [class.selected]=\"'AM' === selectedPeriod\"\r\n                (click)=\"\r\n                  selectedPeriod = 'AM';\r\n                  mode === 'time-only'\r\n                    ? selectTime()\r\n                    : selectDate(viewDate, false)\r\n                \"\r\n                >\r\n                  AM\r\n                </div>\r\n                <div\r\n                  [class.selected]=\"'PM' === selectedPeriod\"\r\n                (click)=\"\r\n                  selectedPeriod = 'PM';\r\n                  mode === 'time-only'\r\n                    ? selectTime()\r\n                    : selectDate(viewDate, false)\r\n                \"\r\n                >\r\n                  PM\r\n                </div>\r\n              </div>\r\n            </div>\r\n          </div>\r\n          }\r\n        </div>\r\n\r\n        <ius-simple-divider></ius-simple-divider>\r\n        <button class=\"today\" (click)=\"goToToday()\">\r\n        @if (mode === 'date-only') { Fecha actual } @else if (mode ===\r\n        'time-only') { Hora actual } @else { Fecha y hora actual }\r\n        </button>\r\n      </div>\r\n    </ng-template>\r\n    <!-- ======== /OVERLAY (CDK) ======== -->\r\n  </div>\r\n  @if (helpText && focused && !error) {\r\n  <div class=\"help-text\">\r\n    {{ helpText }}\r\n  </div>\r\n  } @if (helpTextError && error) {\r\n  <div class=\"help-text-error\">\r\n    {{ helpTextError }}\r\n  </div>\r\n  }\r\n</div>\r\n"]}
279
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-hour-picker.component.js","sourceRoot":"","sources":["../../../../../projects/ius-design-components/src/lib/date-hour-picker/date-hour-picker.component.ts","../../../../../projects/ius-design-components/src/lib/date-hour-picker/date-hour-picker.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport { Component, ElementRef, EventEmitter, HostListener, Input, Output } from '@angular/core';\nimport { OverlayModule, ConnectedPosition, ScrollStrategy, Overlay } from '@angular/cdk/overlay';\nimport { IconMdComponent } from '../icon-md/icon-md.component';\nimport { SimpleDividerComponent } from '../simple-divider/simple-divider.component';\nimport { ButtonStandardTertiaryComponent } from '../button-standard-tertiary/button-standard-tertiary.component';\n\n@Component({\n  selector: 'ius-date-hour-picker',\n  standalone: true,\n  imports: [\n    CommonModule,\n    OverlayModule, // ✅ CDK Overlay\n    IconMdComponent,\n    SimpleDividerComponent,\n    ButtonStandardTertiaryComponent,\n  ],\n  templateUrl: './date-hour-picker.component.html',\n  styleUrl: './date-hour-picker.component.scss',\n})\nexport class DateHourPickerComponent {\n  @Input() label = 'Fecha y hora';\n  @Input() placeholder = 'Seleccione una fecha y hora';\n  @Input() error = false;\n  @Input() helpText = '';\n  @Input() helpTextError = '';\n  @Input() disabled = false;\n  @Input() iconHelp = false;\n  @Input() isRequired = true;\n  @Input() mode: 'date-only' | 'time-only' | 'date-time' = 'date-time';\n\n  @Output() dateSelected = new EventEmitter<string>();\n\n  readonly dayLabels = ['Do', 'Lu', 'Ma', 'Mi', 'Ju', 'Vi', 'Sa'];\n  readonly months = ['Ene', 'Feb', 'Mar', 'Abr', 'May', 'Jun', 'Jul', 'Ago', 'Sep', 'Oct', 'Nov', 'Dic'];\n  readonly yearsArray = Array.from({ length: 12 }, (_, i) => i);\n\n  readonly hours = Array.from({ length: 12 }, (_, i) => i + 1); // 01 a 12\n  readonly minutes = Array.from({ length: 60 }, (_, i) => i);   // 00 a 59\n\n  selectedDate: Date | null = null;\n  selectedHour = 1;\n  selectedMinute = 0;\n  selectedPeriod: 'AM' | 'PM' = 'PM';\n\n  viewDate = new Date();\n  calendarOpen = false;\n  focused = false;\n  calendarView: 'day' | 'month' | 'year' = 'day';\n  calendarDays: Date[] = [];\n\n  // Posiciones preferidas del overlay: izquierda abajo, derecha abajo, izquierda arriba, derecha arriba\n  overlayPositions: ConnectedPosition[] = [\n    { originX: 'start', originY: 'bottom', overlayX: 'start', overlayY: 'top', offsetY: 4 },\n    { originX: 'end', originY: 'bottom', overlayX: 'end', overlayY: 'top', offsetY: 4 },\n    { originX: 'start', originY: 'top', overlayX: 'start', overlayY: 'bottom', offsetY: -4 },\n    { originX: 'end', originY: 'top', overlayX: 'end', overlayY: 'bottom', offsetY: -4 },\n  ];\n\n  scrollStrategy!: ScrollStrategy;\n\n  constructor(\n    private elRef: ElementRef\n    // private overlay: Overlay\n  ) { }\n\n  ngOnInit(): void {\n    // this.scrollStrategy = this.overlay.scrollStrategies.reposition();\n\n    this.generateCalendarDays();\n    this.updateLabelAndPlaceholder();\n  }\n\n  private updateLabelAndPlaceholder(): void {\n    switch (this.mode) {\n      case 'date-only':\n        this.label = this.label.replace('Fecha y hora', 'Fecha');\n        this.placeholder = this.placeholder.replace('fecha y hora', 'fecha');\n        break;\n      case 'time-only':\n        this.label = this.label.replace('Fecha y hora', 'Hora');\n        this.placeholder = this.placeholder.replace('fecha y hora', 'hora');\n        break;\n      case 'date-time':\n      default:\n        break;\n    }\n  }\n\n  toggleCalendar(): void {\n    if (this.disabled) return;\n    if (!this.calendarOpen) {\n      this.calendarView = 'day';\n      this.error = false;\n      this.focused = true;\n      this.calendarOpen = true;\n      return;\n    }\n    this.emitSelection(true);\n    this.focused = false;\n  }\n\n  goToToday(): void {\n    const now = new Date();\n    this.selectedHour = now.getHours() % 12 || 12;\n    this.selectedMinute = now.getMinutes();\n    this.selectedPeriod = now.getHours() < 12 ? 'AM' : 'PM';\n\n    this.viewDate = now;\n\n    this.emitSelection(this.mode !== 'time-only' ? false : true);\n  }\n\n  selectTime(): void {\n    if (this.mode === 'time-only') {\n      this.emitSelection(true);\n    } else {\n      this.emitSelection(false);\n    }\n  }\n\n  getDisplayValue(): string {\n    if (!this.selectedDate) return '';\n\n    switch (this.mode) {\n      case 'date-only':\n        return this.selectedDate.toLocaleDateString('es-ES', {\n          day: '2-digit',\n          month: '2-digit',\n          year: 'numeric'\n        });\n      case 'time-only':\n        return this.selectedDate.toLocaleTimeString('es-ES', {\n          hour: '2-digit',\n          minute: '2-digit',\n          hour12: true\n        });\n      case 'date-time':\n      default:\n        return this.selectedDate.toLocaleString('es-ES', {\n          day: '2-digit',\n          month: '2-digit',\n          year: 'numeric',\n          hour: '2-digit',\n          minute: '2-digit',\n          hour12: true\n        });\n    }\n  }\n\n  nextView(view: 'day' | 'month' | 'year'): 'day' | 'month' | 'year' {\n    return view === 'day' ? 'month' : view === 'month' ? 'year' : 'day';\n  }\n\n  prev(): void {\n    this.shiftViewDate(-1);\n    this.generateCalendarDays();\n  }\n\n  next(): void {\n    this.shiftViewDate(1);\n    this.generateCalendarDays();\n  }\n\n  private shiftViewDate(step: number): void {\n    const year = this.viewDate.getFullYear();\n    const month = this.viewDate.getMonth();\n\n    if (this.calendarView === 'day') {\n      this.viewDate = new Date(year, month + step, 1);\n    } else if (this.calendarView === 'month') {\n      this.viewDate = new Date(year + step, month, 1);\n    } else {\n      this.viewDate = new Date(year + step * 10, month, 1);\n    }\n  }\n\n  selectDate(date: Date, open: boolean): void {\n    this.viewDate = new Date(date);\n    const hour = this.selectedPeriod === 'AM'\n      ? this.selectedHour % 12\n      : (this.selectedHour % 12) + 12;\n\n    const selected = new Date(\n      date.getFullYear(),\n      date.getMonth(),\n      date.getDate(),\n      hour,\n      this.selectedMinute\n    );\n\n    this.selectedDate = selected;\n    this.focused = false;\n    this.error = false;\n\n    this.emitSelection(!open);\n\n    if (open) {\n      this.calendarOpen = true;\n    }\n  }\n\n\n  setMonth(month: number): void {\n    this.viewDate.setMonth(month);\n    this.calendarView = 'day';\n    this.generateCalendarDays();\n  }\n\n  setYear(year: number): void {\n    this.viewDate.setFullYear(year);\n    this.calendarView = 'month';\n    this.generateCalendarDays();\n  }\n\n  getMonthName(index: number): string {\n    return this.months[index];\n  }\n\n  getDecadeStart(): number {\n    return Math.floor(this.viewDate.getFullYear() / 10) * 10;\n  }\n\n  isSameDate(d1: Date, d2: Date): boolean {\n    return d1.getDate() === d2.getDate() &&\n      d1.getMonth() === d2.getMonth() &&\n      d1.getFullYear() === d2.getFullYear();\n  }\n\n  generateCalendarDays(): void {\n    const days: Date[] = [];\n    const year = this.viewDate.getFullYear();\n    const month = this.viewDate.getMonth();\n\n    const firstDay = new Date(year, month, 1);\n    const offset = firstDay.getDay();\n    const startDate = new Date(year, month, 1 - offset);\n\n    for (let i = 0; i < 42; i++) {\n      const date = new Date(startDate);\n      date.setDate(startDate.getDate() + i);\n      days.push(date);\n    }\n\n    this.calendarDays = days;\n  }\n\n  closeCalendar(): void {\n    this.calendarOpen = false;\n\n    if (!this.selectedDate) {\n      this.error = true;\n    }\n  }\n\n  @HostListener('document:click', ['$event'])\n  handleOutsideClick(event: MouseEvent): void {\n    const clickedInside = this.elRef.nativeElement.contains(event.target);\n    if (!clickedInside && this.calendarOpen) {\n      this.closeCalendar();\n    }\n  }\n\n\n  private buildSelectedDateFromState(): Date {\n    if (this.mode === 'date-only') {\n      const base = this.selectedDate ?? this.viewDate;\n      return new Date(base.getFullYear(), base.getMonth(), base.getDate(), 0, 0);\n    }\n\n    if (this.mode === 'time-only') {\n      const hour = this.selectedPeriod === 'AM' ? this.selectedHour % 12 : (this.selectedHour % 12) + 12;\n      const now = new Date();\n      return new Date(now.getFullYear(), now.getMonth(), now.getDate(), hour, this.selectedMinute);\n    }\n    const hour = this.selectedPeriod === 'AM' ? this.selectedHour % 12 : (this.selectedHour % 12) + 12;\n    const base = this.viewDate ?? new Date();\n    return new Date(base.getFullYear(), base.getMonth(), base.getDate(), hour, this.selectedMinute);\n  }\n\n  private emitSelection(closeCalendar: boolean): void {\n    const selected = this.buildSelectedDateFromState();\n    this.selectedDate = selected;\n\n    if (this.mode === 'date-only') {\n      const dateString = `${selected.getFullYear()}-${(selected.getMonth() + 1).toString().padStart(2, '0')}-${selected.getDate().toString().padStart(2, '0')}`;\n      this.dateSelected.emit(dateString);\n    } else if (this.mode === 'time-only') {\n      const timeString = `${selected.getHours().toString().padStart(2, '0')}:${selected.getMinutes().toString().padStart(2, '0')}:00`;\n      this.dateSelected.emit(timeString);\n    } else {\n      const dateString = `${selected.getFullYear()}-${(selected.getMonth() + 1).toString().padStart(2, '0')}-${selected.getDate().toString().padStart(2, '0')}T${selected.getHours().toString().padStart(2, '0')}:${selected.getMinutes().toString().padStart(2, '0')}:00`;\n      this.dateSelected.emit(dateString);\n    }\n\n    if (closeCalendar) {\n      this.calendarOpen = false;\n    }\n  }\n}\n","<div class=\"date-picker\" [class.disabled]=\"disabled\">\r\n  <div class=\"text\">\r\n    @if (isRequired) {\r\n    <div class=\"required\"></div>\r\n    }\r\n\r\n    <label class=\"label\">{{ label }}</label>\r\n\r\n    @if (iconHelp) {\r\n      <div class=\"help-icon\">\r\n        <ius-icon-md iconName=\"icon-help\"></ius-icon-md>\r\n      </div>\r\n    }\r\n\r\n    <label class=\"label\">:</label>\r\n  </div>\r\n\r\n  <div class=\"input-wrapper\">\r\n    <!-- Origen del overlay -->\r\n    <div\r\n      class=\"container-textfield\"\r\n      [ngClass]=\"{\r\n        disabled: disabled,\r\n        focused: calendarOpen || focused,\r\n        alert: !calendarOpen && error && !disabled,\r\n        selected: selectedDate\r\n      }\"\r\n      (click)=\"toggleCalendar()\"\r\n      cdkOverlayOrigin #origin=\"cdkOverlayOrigin\"\r\n    >\r\n      <div class=\"input\">\r\n        <input\r\n          [placeholder]=\"placeholder\"\r\n          [value]=\"selectedDate ? getDisplayValue() : ''\"\r\n          readonly\r\n          [disabled]=\"disabled\"\r\n        />\r\n        <div class=\"cnt-icon-right\">\r\n          <ius-icon-md iconName=\"icon-calendar-today\"></ius-icon-md>\r\n        </div>\r\n      </div>\r\n    </div>\r\n\r\n    <!-- ======== OVERLAY (CDK) ======== -->\r\n    <ng-template\r\n      cdkConnectedOverlay\r\n      [cdkConnectedOverlayOpen]=\"calendarOpen\"\r\n      [cdkConnectedOverlayOrigin]=\"origin\"\r\n      [cdkConnectedOverlayPositions]=\"overlayPositions\"\r\n      [cdkConnectedOverlayHasBackdrop]=\"false\"\r\n      [cdkConnectedOverlayPush]=\"true\"\r\n      [cdkConnectedOverlayFlexibleDimensions]=\"false\"\r\n      [cdkConnectedOverlayPanelClass]=\"'calendar-overlay-panel'\"\r\n    >\r\n      <div\r\n        class=\"calendar-overlay\"\r\n        [class.time-only]=\"mode === 'time-only'\"\r\n        [class.date-only]=\"mode === 'date-only'\"\r\n        (click)=\"$event.stopPropagation()\"\r\n      >\r\n        <div class=\"calendar-content\">\r\n          @if (mode !== 'time-only') {\r\n          <div class=\"calendar-side\">\r\n            <div class=\"calendar-header\">\r\n              <ius-button-standard-tertiary\r\n                iconName=\"icon-keyboard-arrow-left\"\r\n                (buttonClicked)=\"prev()\"\r\n              ></ius-button-standard-tertiary>\r\n\r\n              <span (click)=\"calendarView = nextView(calendarView)\">\r\n              @switch (calendarView) { @case ('day') {\r\n              {{ getMonthName(viewDate.getMonth()) }}\r\n              {{ viewDate.getFullYear() }}\r\n              } @case ('month') {\r\n              {{ viewDate.getFullYear() }}\r\n              } @case ('year') {\r\n              {{ getDecadeStart() }}-{{ getDecadeStart() + 9 }}\r\n              } }\r\n              </span>\r\n\r\n              <ius-button-standard-tertiary\r\n                iconName=\"icon-keyboard-arrow-right\"\r\n                (buttonClicked)=\"next()\"\r\n              ></ius-button-standard-tertiary>\r\n            </div>\r\n\r\n            <div class=\"calendar-body\">\r\n            @switch (calendarView) { @case ('day') {\r\n                  <div class=\"grid days\">\r\n              @for (day of dayLabels; track day) {\r\n              <div class=\"header\">{{ day }}</div>\r\n              } @for (date of calendarDays; track date) {\r\n                      <div\r\n                        class=\"cell\"\r\n                [class.selected]=\"\r\n                  selectedDate && isSameDate(date, selectedDate)\r\n                \"\r\n                        [class.out-of-range]=\"date.getMonth() !== viewDate.getMonth()\"\r\n                        (click)=\"selectDate(date, true)\"\r\n                      >\r\n                        {{ date.getDate() }}\r\n                      </div>\r\n                    }\r\n                  </div>\r\n            } @case ('month') {\r\n                  <div class=\"grid months\">\r\n                    @for (m of months; track m; let i = $index) {\r\n                      <div class=\"cell\" (click)=\"setMonth(i)\">{{ m }}</div>\r\n                    }\r\n                  </div>\r\n            } @case ('year') {\r\n                  <div class=\"grid years\">\r\n                    @for (i of yearsArray; track i) {\r\n                      <div\r\n                        class=\"cell\"\r\n                        [class.out-of-range]=\"i === 0 || i === 11\"\r\n                        (click)=\"setYear(getDecadeStart() - 1 + i)\"\r\n                      >\r\n                        {{ getDecadeStart() - 1 + i }}\r\n                      </div>\r\n                    }\r\n                  </div>\r\n            } }\r\n            </div>\r\n          </div>\r\n        } @if (mode !== 'date-only') {\r\n          <div class=\"time-selector\">\r\n            <button class=\"time-title\">\r\n              <span>\r\n                {{ selectedHour | number : \"2.0\" }}:{{\r\n                  selectedMinute === 0 ? \"00\" : (selectedMinute | number : \"2.0\")\r\n                }}\r\n                {{ selectedPeriod }}\r\n              </span>\r\n            </button>\r\n            <ius-simple-divider></ius-simple-divider>\r\n            <div class=\"time-columns\">\r\n              <div class=\"column scrollable\">\r\n                @for (h of hours; track h) {\r\n                <div\r\n                  [class.selected]=\"h === selectedHour\"\r\n                (click)=\"\r\n                  selectedHour = h;\r\n                  mode === 'time-only'\r\n                    ? selectTime()\r\n                    : selectDate(viewDate, true)\r\n                \"\r\n                >\r\n                  {{ h | number : \"2.0\" }}\r\n                </div>\r\n                }\r\n              </div>\r\n              <div class=\"divider\"></div>\r\n              <div class=\"column scrollable\">\r\n                @for (m of minutes; track m) {\r\n                <div\r\n                  [class.selected]=\"m === selectedMinute\"\r\n                (click)=\"\r\n                  selectedMinute = m;\r\n                  mode === 'time-only'\r\n                    ? selectTime()\r\n                    : selectDate(viewDate, true)\r\n                \"\r\n                >\r\n                  {{ m | number : \"2.0\" }}\r\n                </div>\r\n                }\r\n              </div>\r\n              <div class=\"divider\"></div>\r\n              <div class=\"column\">\r\n                <div\r\n                  [class.selected]=\"'AM' === selectedPeriod\"\r\n                (click)=\"\r\n                  selectedPeriod = 'AM';\r\n                  mode === 'time-only'\r\n                    ? selectTime()\r\n                    : selectDate(viewDate, false)\r\n                \"\r\n                >\r\n                  AM\r\n                </div>\r\n                <div\r\n                  [class.selected]=\"'PM' === selectedPeriod\"\r\n                (click)=\"\r\n                  selectedPeriod = 'PM';\r\n                  mode === 'time-only'\r\n                    ? selectTime()\r\n                    : selectDate(viewDate, false)\r\n                \"\r\n                >\r\n                  PM\r\n                </div>\r\n              </div>\r\n            </div>\r\n          </div>\r\n          }\r\n        </div>\r\n\r\n        <ius-simple-divider></ius-simple-divider>\r\n        <button class=\"today\" (click)=\"goToToday()\">\r\n        @if (mode === 'date-only') { Fecha actual } @else if (mode ===\r\n        'time-only') { Hora actual } @else { Fecha y hora actual }\r\n        </button>\r\n      </div>\r\n    </ng-template>\r\n    <!-- ======== /OVERLAY (CDK) ======== -->\r\n  </div>\r\n  @if (helpText && focused && !error) {\r\n  <div class=\"help-text\">\r\n    {{ helpText }}\r\n  </div>\r\n  } @if (helpTextError && error) {\r\n  <div class=\"help-text-error\">\r\n    {{ helpTextError }}\r\n  </div>\r\n  }\r\n</div>\r\n"]}