@litigiovirtual/ius-design-components 1.0.44 → 1.0.45
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.
|
@@ -11,20 +11,41 @@ export class DatePickerComponent {
|
|
|
11
11
|
setTimeout(() => this.positionCalendarOverlay(), 0);
|
|
12
12
|
}
|
|
13
13
|
positionCalendarOverlay() {
|
|
14
|
+
if (!this.inputField || !this.calendarOverlay)
|
|
15
|
+
return;
|
|
14
16
|
const inputRect = this.inputField.nativeElement.getBoundingClientRect();
|
|
15
17
|
const overlay = this.calendarOverlay.nativeElement;
|
|
16
18
|
const overlayHeight = overlay.offsetHeight;
|
|
17
19
|
const spaceBelow = window.innerHeight - inputRect.bottom;
|
|
18
20
|
const spaceAbove = inputRect.top;
|
|
19
21
|
let top = inputRect.bottom;
|
|
20
|
-
|
|
22
|
+
let maxHeight = '';
|
|
23
|
+
if (spaceBelow >= overlayHeight) {
|
|
24
|
+
// Mostrar hacia abajo normalmente
|
|
25
|
+
top = inputRect.bottom;
|
|
26
|
+
maxHeight = `${Math.max(spaceBelow - 10, 150)}px`; // mínimo 150px
|
|
27
|
+
}
|
|
28
|
+
else if (spaceAbove >= overlayHeight) {
|
|
21
29
|
// Mostrar hacia arriba
|
|
22
30
|
top = inputRect.top - overlayHeight;
|
|
31
|
+
maxHeight = `${Math.max(spaceAbove - 10, 150)}px`;
|
|
32
|
+
}
|
|
33
|
+
else if (spaceBelow > spaceAbove) {
|
|
34
|
+
// Mostrar hacia abajo pero con scroll interno
|
|
35
|
+
top = inputRect.bottom;
|
|
36
|
+
maxHeight = `${Math.max(spaceBelow - 10, 150)}px`;
|
|
37
|
+
}
|
|
38
|
+
else {
|
|
39
|
+
// Mostrar hacia arriba pero con scroll interno
|
|
40
|
+
top = 10; // margen superior mínimo
|
|
41
|
+
maxHeight = `${Math.max(spaceAbove - 10, 150)}px`;
|
|
23
42
|
}
|
|
24
43
|
overlay.style.position = 'fixed';
|
|
25
44
|
overlay.style.right = '0px';
|
|
26
45
|
overlay.style.top = `${top}px`;
|
|
27
46
|
overlay.style.zIndex = '99999';
|
|
47
|
+
overlay.style.maxHeight = maxHeight;
|
|
48
|
+
overlay.style.overflowY = 'auto';
|
|
28
49
|
}
|
|
29
50
|
constructor(elRef) {
|
|
30
51
|
this.elRef = elRef;
|
|
@@ -187,4 +208,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
187
208
|
type: HostListener,
|
|
188
209
|
args: ['document:click', ['$event']]
|
|
189
210
|
}] } });
|
|
190
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-picker.component.js","sourceRoot":"","sources":["../../../../../projects/ius-design-components/src/lib/date-picker/date-picker.component.ts","../../../../../projects/ius-design-components/src/lib/date-picker/date-picker.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\r\nimport { Component, ElementRef, EventEmitter, HostListener, Input, Output, ViewChild } from '@angular/core';\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-picker',\r\n  standalone: true,\r\n  imports: [\r\n    CommonModule,\r\n    IconMdComponent,\r\n    SimpleDividerComponent,\r\n    ButtonStandardTertiaryComponent,\r\n  ],\r\n  templateUrl: './date-picker.component.html',\r\n  styleUrl: './date-picker.component.scss',\r\n})\r\nexport class DatePickerComponent {\r\n  @Input() label = 'Fecha';\r\n  @Input() placeholder = 'Seleccione una fecha';\r\n  @Input() error = false;\r\n  @Input() iconHelp = false;\r\n  @Input() helpText = '';\r\n  @Input() helpTextError = '';\r\n  @Input() disabled = false;\r\n  @Input() isRequired = true;\r\n\r\n  @Output() dateSelected = new EventEmitter<Date>();\r\n\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  selectedDate: Date | null = null;\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  @ViewChild('calendarOverlay') calendarOverlay!: ElementRef;\r\n  @ViewChild('inputField') inputField!: ElementRef;\r\n\r\n  openCalendar() {\r\n    this.calendarOpen = true;\r\n    setTimeout(() => this.positionCalendarOverlay(), 0);\r\n  }\r\n\r\n  positionCalendarOverlay() {\r\n    const inputRect = this.inputField.nativeElement.getBoundingClientRect();\r\n    const overlay = this.calendarOverlay.nativeElement;\r\n    const overlayHeight = overlay.offsetHeight;\r\n    const spaceBelow = window.innerHeight - inputRect.bottom;\r\n    const spaceAbove = inputRect.top;\r\n\r\n    let top = inputRect.bottom;\r\n    if (spaceBelow < overlayHeight && spaceAbove > overlayHeight) {\r\n      // Mostrar hacia arriba\r\n      top = inputRect.top - overlayHeight;\r\n    }\r\n\r\n    overlay.style.position = 'fixed';\r\n    overlay.style.right = '0px';\r\n    overlay.style.top = `${top}px`;\r\n    overlay.style.zIndex = '99999';\r\n  }\r\n\r\n  constructor(private elRef: ElementRef) { }\r\n\r\n  ngOnInit(): void {\r\n    this.generateCalendarDays();\r\n  }\r\n\r\n  toggleCalendar(): void {\r\n    if (this.disabled) return;\r\n\r\n    if (!this.calendarOpen) {\r\n      this.calendarView = 'day';\r\n      this.error = false;\r\n    }\r\n    this.focused = true;\r\n    this.calendarOpen = !this.calendarOpen;\r\n\r\n    if (this.calendarOpen) {\r\n    setTimeout(() => this.positionCalendarOverlay(), 0);\r\n  }\r\n  }\r\n\r\n  goToToday(): void {\r\n    const today = new Date();\r\n    this.viewDate = today;\r\n    this.selectDate(today);\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 { calendarView, viewDate } = this;\r\n    const year = viewDate.getFullYear();\r\n    const month = viewDate.getMonth();\r\n\r\n    if (calendarView === 'day') {\r\n      this.viewDate = new Date(year, month + step, 1);\r\n    } else if (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): void {\r\n    this.selectedDate = date;\r\n    this.viewDate = new Date(date);\r\n    this.calendarOpen = false;\r\n    this.focused = false;\r\n    this.error = false;\r\n\r\n    this.dateSelected.emit(date);\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\r\n    if (!clickedInside && this.calendarOpen) {\r\n      this.closeCalendar();\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    <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    >\r\n      <div class=\"input\">\r\n        <input #inputField\r\n          [placeholder]=\"placeholder\"\r\n          [value]=\"selectedDate ? (selectedDate | date : 'dd/MM/yyyy') : ''\"\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    @if (calendarOpen) {\r\n    <div #calendarOverlay class=\"calendar-overlay\">\r\n      <div class=\"mes\">\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()) }} {{ 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]=\"selectedDate && isSameDate(date, selectedDate)\"\r\n              [class.out-of-range]=\"date.getMonth() !== viewDate.getMonth()\"\r\n              (click)=\"selectDate(date)\"\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\r\n      <ius-simple-divider></ius-simple-divider>\r\n\r\n      <button class=\"today\" (click)=\"goToToday()\">Fecha actual</button>\r\n    </div>\r\n    }\r\n  </div>\r\n  @if (helpText && focused && !error) {\r\n    <div class=\"help-text\">\r\n      {{helpText}}\r\n    </div>\r\n  }\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"]}
|
|
211
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-picker.component.js","sourceRoot":"","sources":["../../../../../projects/ius-design-components/src/lib/date-picker/date-picker.component.ts","../../../../../projects/ius-design-components/src/lib/date-picker/date-picker.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\r\nimport { Component, ElementRef, EventEmitter, HostListener, Input, Output, ViewChild } from '@angular/core';\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-picker',\r\n  standalone: true,\r\n  imports: [\r\n    CommonModule,\r\n    IconMdComponent,\r\n    SimpleDividerComponent,\r\n    ButtonStandardTertiaryComponent,\r\n  ],\r\n  templateUrl: './date-picker.component.html',\r\n  styleUrl: './date-picker.component.scss',\r\n})\r\nexport class DatePickerComponent {\r\n  @Input() label = 'Fecha';\r\n  @Input() placeholder = 'Seleccione una fecha';\r\n  @Input() error = false;\r\n  @Input() iconHelp = false;\r\n  @Input() helpText = '';\r\n  @Input() helpTextError = '';\r\n  @Input() disabled = false;\r\n  @Input() isRequired = true;\r\n\r\n  @Output() dateSelected = new EventEmitter<Date>();\r\n\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  selectedDate: Date | null = null;\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  @ViewChild('calendarOverlay') calendarOverlay!: ElementRef;\r\n  @ViewChild('inputField') inputField!: ElementRef;\r\n\r\n  openCalendar() {\r\n    this.calendarOpen = true;\r\n    setTimeout(() => this.positionCalendarOverlay(), 0);\r\n  }\r\n\r\n positionCalendarOverlay() {\r\n  if (!this.inputField || !this.calendarOverlay) return;\r\n\r\n  const inputRect = this.inputField.nativeElement.getBoundingClientRect();\r\n  const overlay = this.calendarOverlay.nativeElement;\r\n  const overlayHeight = overlay.offsetHeight;\r\n  const spaceBelow = window.innerHeight - inputRect.bottom;\r\n  const spaceAbove = inputRect.top;\r\n\r\n  let top = inputRect.bottom;\r\n  let maxHeight = '';\r\n\r\n  if (spaceBelow >= overlayHeight) {\r\n    // Mostrar hacia abajo normalmente\r\n    top = inputRect.bottom;\r\n    maxHeight = `${Math.max(spaceBelow - 10, 150)}px`; // mínimo 150px\r\n  } else if (spaceAbove >= overlayHeight) {\r\n    // Mostrar hacia arriba\r\n    top = inputRect.top - overlayHeight;\r\n    maxHeight = `${Math.max(spaceAbove - 10, 150)}px`;\r\n  } else if (spaceBelow > spaceAbove) {\r\n    // Mostrar hacia abajo pero con scroll interno\r\n    top = inputRect.bottom;\r\n    maxHeight = `${Math.max(spaceBelow - 10, 150)}px`;\r\n  } else {\r\n    // Mostrar hacia arriba pero con scroll interno\r\n    top = 10; // margen superior mínimo\r\n    maxHeight = `${Math.max(spaceAbove - 10, 150)}px`;\r\n  }\r\n\r\n  overlay.style.position = 'fixed';\r\n  overlay.style.right = '0px';\r\n  overlay.style.top = `${top}px`;\r\n  overlay.style.zIndex = '99999';\r\n  overlay.style.maxHeight = maxHeight;\r\n  overlay.style.overflowY = 'auto';\r\n}\r\n\r\n  constructor(private elRef: ElementRef) { }\r\n\r\n  ngOnInit(): void {\r\n    this.generateCalendarDays();\r\n  }\r\n\r\n  toggleCalendar(): void {\r\n    if (this.disabled) return;\r\n\r\n    if (!this.calendarOpen) {\r\n      this.calendarView = 'day';\r\n      this.error = false;\r\n    }\r\n    this.focused = true;\r\n    this.calendarOpen = !this.calendarOpen;\r\n\r\n    if (this.calendarOpen) {\r\n    setTimeout(() => this.positionCalendarOverlay(), 0);\r\n  }\r\n  }\r\n\r\n  goToToday(): void {\r\n    const today = new Date();\r\n    this.viewDate = today;\r\n    this.selectDate(today);\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 { calendarView, viewDate } = this;\r\n    const year = viewDate.getFullYear();\r\n    const month = viewDate.getMonth();\r\n\r\n    if (calendarView === 'day') {\r\n      this.viewDate = new Date(year, month + step, 1);\r\n    } else if (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): void {\r\n    this.selectedDate = date;\r\n    this.viewDate = new Date(date);\r\n    this.calendarOpen = false;\r\n    this.focused = false;\r\n    this.error = false;\r\n\r\n    this.dateSelected.emit(date);\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\r\n    if (!clickedInside && this.calendarOpen) {\r\n      this.closeCalendar();\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    <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    >\r\n      <div class=\"input\">\r\n        <input #inputField\r\n          [placeholder]=\"placeholder\"\r\n          [value]=\"selectedDate ? (selectedDate | date : 'dd/MM/yyyy') : ''\"\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    @if (calendarOpen) {\r\n    <div #calendarOverlay class=\"calendar-overlay\">\r\n      <div class=\"mes\">\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()) }} {{ 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]=\"selectedDate && isSameDate(date, selectedDate)\"\r\n              [class.out-of-range]=\"date.getMonth() !== viewDate.getMonth()\"\r\n              (click)=\"selectDate(date)\"\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\r\n      <ius-simple-divider></ius-simple-divider>\r\n\r\n      <button class=\"today\" (click)=\"goToToday()\">Fecha actual</button>\r\n    </div>\r\n    }\r\n  </div>\r\n  @if (helpText && focused && !error) {\r\n    <div class=\"help-text\">\r\n      {{helpText}}\r\n    </div>\r\n  }\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"]}
|
|
@@ -1673,20 +1673,41 @@ class DatePickerComponent {
|
|
|
1673
1673
|
setTimeout(() => this.positionCalendarOverlay(), 0);
|
|
1674
1674
|
}
|
|
1675
1675
|
positionCalendarOverlay() {
|
|
1676
|
+
if (!this.inputField || !this.calendarOverlay)
|
|
1677
|
+
return;
|
|
1676
1678
|
const inputRect = this.inputField.nativeElement.getBoundingClientRect();
|
|
1677
1679
|
const overlay = this.calendarOverlay.nativeElement;
|
|
1678
1680
|
const overlayHeight = overlay.offsetHeight;
|
|
1679
1681
|
const spaceBelow = window.innerHeight - inputRect.bottom;
|
|
1680
1682
|
const spaceAbove = inputRect.top;
|
|
1681
1683
|
let top = inputRect.bottom;
|
|
1682
|
-
|
|
1684
|
+
let maxHeight = '';
|
|
1685
|
+
if (spaceBelow >= overlayHeight) {
|
|
1686
|
+
// Mostrar hacia abajo normalmente
|
|
1687
|
+
top = inputRect.bottom;
|
|
1688
|
+
maxHeight = `${Math.max(spaceBelow - 10, 150)}px`; // mínimo 150px
|
|
1689
|
+
}
|
|
1690
|
+
else if (spaceAbove >= overlayHeight) {
|
|
1683
1691
|
// Mostrar hacia arriba
|
|
1684
1692
|
top = inputRect.top - overlayHeight;
|
|
1693
|
+
maxHeight = `${Math.max(spaceAbove - 10, 150)}px`;
|
|
1694
|
+
}
|
|
1695
|
+
else if (spaceBelow > spaceAbove) {
|
|
1696
|
+
// Mostrar hacia abajo pero con scroll interno
|
|
1697
|
+
top = inputRect.bottom;
|
|
1698
|
+
maxHeight = `${Math.max(spaceBelow - 10, 150)}px`;
|
|
1699
|
+
}
|
|
1700
|
+
else {
|
|
1701
|
+
// Mostrar hacia arriba pero con scroll interno
|
|
1702
|
+
top = 10; // margen superior mínimo
|
|
1703
|
+
maxHeight = `${Math.max(spaceAbove - 10, 150)}px`;
|
|
1685
1704
|
}
|
|
1686
1705
|
overlay.style.position = 'fixed';
|
|
1687
1706
|
overlay.style.right = '0px';
|
|
1688
1707
|
overlay.style.top = `${top}px`;
|
|
1689
1708
|
overlay.style.zIndex = '99999';
|
|
1709
|
+
overlay.style.maxHeight = maxHeight;
|
|
1710
|
+
overlay.style.overflowY = 'auto';
|
|
1690
1711
|
}
|
|
1691
1712
|
constructor(elRef) {
|
|
1692
1713
|
this.elRef = elRef;
|