@litigiovirtual/ius-design-components 1.0.62 → 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.
- package/esm2022/lib/date-hour-picker/date-hour-picker.component.mjs +6 -6
- package/esm2022/lib/input-select/input-select.component.mjs +3 -3
- package/esm2022/lib/option/option.component.mjs +1 -1
- package/fesm2022/litigiovirtual-ius-design-components.mjs +7 -7
- package/fesm2022/litigiovirtual-ius-design-components.mjs.map +1 -1
- package/package.json +1 -1
|
@@ -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:
|
|
39
|
+
// Posiciones preferidas del overlay: izquierda abajo, derecha abajo, izquierda arriba, derecha arriba
|
|
40
40
|
this.overlayPositions = [
|
|
41
|
-
{ originX: '
|
|
42
|
-
{ originX: 'end', originY: 'bottom', overlayX: '
|
|
43
|
-
{ originX: '
|
|
44
|
-
{ originX: '
|
|
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":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,SAAS,EAAc,YAAY,EAAE,YAAY,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AACjG,OAAO,EAAE,aAAa,EAA8C,MAAM,sBAAsB,CAAC;AACjG,OAAO,EAAE,eAAe,EAAE,MAAM,8BAA8B,CAAC;AAC/D,OAAO,EAAE,sBAAsB,EAAE,MAAM,4CAA4C,CAAC;AACpF,OAAO,EAAE,+BAA+B,EAAE,MAAM,gEAAgE,CAAC;;;;AAejH,MAAM,OAAO,uBAAuB;IAyClC,YACU,KAAiB;IACzB,2BAA2B;;QADnB,UAAK,GAAL,KAAK,CAAY;QAzClB,UAAK,GAAG,cAAc,CAAC;QACvB,gBAAW,GAAG,6BAA6B,CAAC;QAC5C,UAAK,GAAG,KAAK,CAAC;QACd,aAAQ,GAAG,EAAE,CAAC;QACd,kBAAa,GAAG,EAAE,CAAC;QACnB,aAAQ,GAAG,KAAK,CAAC;QACjB,aAAQ,GAAG,KAAK,CAAC;QACjB,eAAU,GAAG,IAAI,CAAC;QAClB,SAAI,GAA4C,WAAW,CAAC;QAE3D,iBAAY,GAAG,IAAI,YAAY,EAAU,CAAC;QAE3C,cAAS,GAAG,CAAC,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC;QACvD,WAAM,GAAG,CAAC,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,CAAC,CAAC;QAC9F,eAAU,GAAG,KAAK,CAAC,IAAI,CAAC,EAAE,MAAM,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC;QAErD,UAAK,GAAG,KAAK,CAAC,IAAI,CAAC,EAAE,MAAM,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,UAAU;QAC/D,YAAO,GAAG,KAAK,CAAC,IAAI,CAAC,EAAE,MAAM,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,CAAG,UAAU;QAExE,iBAAY,GAAgB,IAAI,CAAC;QACjC,iBAAY,GAAG,CAAC,CAAC;QACjB,mBAAc,GAAG,CAAC,CAAC;QACnB,mBAAc,GAAgB,IAAI,CAAC;QAEnC,aAAQ,GAAG,IAAI,IAAI,EAAE,CAAC;QACtB,iBAAY,GAAG,KAAK,CAAC;QACrB,YAAO,GAAG,KAAK,CAAC;QAChB,iBAAY,GAA6B,KAAK,CAAC;QAC/C,iBAAY,GAAW,EAAE,CAAC;QAE1B,sGAAsG;QACtG,qBAAgB,GAAwB;YACtC,EAAE,OAAO,EAAE,OAAO,EAAE,OAAO,EAAE,QAAQ,EAAE,QAAQ,EAAE,OAAO,EAAE,QAAQ,EAAE,KAAK,EAAE,OAAO,EAAE,CAAC,EAAE;YACvF,EAAE,OAAO,EAAE,KAAK,EAAE,OAAO,EAAE,QAAQ,EAAE,QAAQ,EAAE,KAAK,EAAE,QAAQ,EAAE,KAAK,EAAE,OAAO,EAAE,CAAC,EAAE;YACnF,EAAE,OAAO,EAAE,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,QAAQ,EAAE,OAAO,EAAE,QAAQ,EAAE,QAAQ,EAAE,OAAO,EAAE,CAAC,CAAC,EAAE;YACxF,EAAE,OAAO,EAAE,KAAK,EAAE,OAAO,EAAE,KAAK,EAAE,QAAQ,EAAE,KAAK,EAAE,QAAQ,EAAE,QAAQ,EAAE,OAAO,EAAE,CAAC,CAAC,EAAE;SACrF,CAAC;IAOE,CAAC;IAEL,QAAQ;QACN,oEAAoE;QAEpE,IAAI,CAAC,oBAAoB,EAAE,CAAC;QAC5B,IAAI,CAAC,yBAAyB,EAAE,CAAC;IACnC,CAAC;IAEO,yBAAyB;QAC/B,QAAQ,IAAI,CAAC,IAAI,EAAE,CAAC;YAClB,KAAK,WAAW;gBACd,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,cAAc,EAAE,OAAO,CAAC,CAAC;gBACzD,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,cAAc,EAAE,OAAO,CAAC,CAAC;gBACrE,MAAM;YACR,KAAK,WAAW;gBACd,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,cAAc,EAAE,MAAM,CAAC,CAAC;gBACxD,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,cAAc,EAAE,MAAM,CAAC,CAAC;gBACpE,MAAM;YACR,KAAK,WAAW,CAAC;YACjB;gBACE,MAAM;QACV,CAAC;IACH,CAAC;IAED,cAAc;QACZ,IAAI,IAAI,CAAC,QAAQ;YAAE,OAAO;QAC1B,IAAI,CAAC,IAAI,CAAC,YAAY,EAAE,CAAC;YACvB,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC;YAC1B,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;YACnB,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;YACpB,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;YACzB,OAAO;QACT,CAAC;QACD,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC;QACzB,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;IACvB,CAAC;IAED,SAAS;QACP,MAAM,GAAG,GAAG,IAAI,IAAI,EAAE,CAAC;QACvB,IAAI,CAAC,YAAY,GAAG,GAAG,CAAC,QAAQ,EAAE,GAAG,EAAE,IAAI,EAAE,CAAC;QAC9C,IAAI,CAAC,cAAc,GAAG,GAAG,CAAC,UAAU,EAAE,CAAC;QACvC,IAAI,CAAC,cAAc,GAAG,GAAG,CAAC,QAAQ,EAAE,GAAG,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC;QAExD,IAAI,CAAC,QAAQ,GAAG,GAAG,CAAC;QAEpB,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,IAAI,KAAK,WAAW,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC;IAC/D,CAAC;IAED,UAAU;QACR,IAAI,IAAI,CAAC,IAAI,KAAK,WAAW,EAAE,CAAC;YAC9B,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC;QAC3B,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;QAC5B,CAAC;IACH,CAAC;IAED,eAAe;QACb,IAAI,CAAC,IAAI,CAAC,YAAY;YAAE,OAAO,EAAE,CAAC;QAElC,QAAQ,IAAI,CAAC,IAAI,EAAE,CAAC;YAClB,KAAK,WAAW;gBACd,OAAO,IAAI,CAAC,YAAY,CAAC,kBAAkB,CAAC,OAAO,EAAE;oBACnD,GAAG,EAAE,SAAS;oBACd,KAAK,EAAE,SAAS;oBAChB,IAAI,EAAE,SAAS;iBAChB,CAAC,CAAC;YACL,KAAK,WAAW;gBACd,OAAO,IAAI,CAAC,YAAY,CAAC,kBAAkB,CAAC,OAAO,EAAE;oBACnD,IAAI,EAAE,SAAS;oBACf,MAAM,EAAE,SAAS;oBACjB,MAAM,EAAE,IAAI;iBACb,CAAC,CAAC;YACL,KAAK,WAAW,CAAC;YACjB;gBACE,OAAO,IAAI,CAAC,YAAY,CAAC,cAAc,CAAC,OAAO,EAAE;oBAC/C,GAAG,EAAE,SAAS;oBACd,KAAK,EAAE,SAAS;oBAChB,IAAI,EAAE,SAAS;oBACf,IAAI,EAAE,SAAS;oBACf,MAAM,EAAE,SAAS;oBACjB,MAAM,EAAE,IAAI;iBACb,CAAC,CAAC;QACP,CAAC;IACH,CAAC;IAED,QAAQ,CAAC,IAA8B;QACrC,OAAO,IAAI,KAAK,KAAK,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,KAAK,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC;IACtE,CAAC;IAED,IAAI;QACF,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC,CAAC;QACvB,IAAI,CAAC,oBAAoB,EAAE,CAAC;IAC9B,CAAC;IAED,IAAI;QACF,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC;QACtB,IAAI,CAAC,oBAAoB,EAAE,CAAC;IAC9B,CAAC;IAEO,aAAa,CAAC,IAAY;QAChC,MAAM,IAAI,GAAG,IAAI,CAAC,QAAQ,CAAC,WAAW,EAAE,CAAC;QACzC,MAAM,KAAK,GAAG,IAAI,CAAC,QAAQ,CAAC,QAAQ,EAAE,CAAC;QAEvC,IAAI,IAAI,CAAC,YAAY,KAAK,KAAK,EAAE,CAAC;YAChC,IAAI,CAAC,QAAQ,GAAG,IAAI,IAAI,CAAC,IAAI,EAAE,KAAK,GAAG,IAAI,EAAE,CAAC,CAAC,CAAC;QAClD,CAAC;aAAM,IAAI,IAAI,CAAC,YAAY,KAAK,OAAO,EAAE,CAAC;YACzC,IAAI,CAAC,QAAQ,GAAG,IAAI,IAAI,CAAC,IAAI,GAAG,IAAI,EAAE,KAAK,EAAE,CAAC,CAAC,CAAC;QAClD,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,QAAQ,GAAG,IAAI,IAAI,CAAC,IAAI,GAAG,IAAI,GAAG,EAAE,EAAE,KAAK,EAAE,CAAC,CAAC,CAAC;QACvD,CAAC;IACH,CAAC;IAED,UAAU,CAAC,IAAU,EAAE,IAAa;QAClC,IAAI,CAAC,QAAQ,GAAG,IAAI,IAAI,CAAC,IAAI,CAAC,CAAC;QAC/B,MAAM,IAAI,GAAG,IAAI,CAAC,cAAc,KAAK,IAAI;YACvC,CAAC,CAAC,IAAI,CAAC,YAAY,GAAG,EAAE;YACxB,CAAC,CAAC,CAAC,IAAI,CAAC,YAAY,GAAG,EAAE,CAAC,GAAG,EAAE,CAAC;QAElC,MAAM,QAAQ,GAAG,IAAI,IAAI,CACvB,IAAI,CAAC,WAAW,EAAE,EAClB,IAAI,CAAC,QAAQ,EAAE,EACf,IAAI,CAAC,OAAO,EAAE,EACd,IAAI,EACJ,IAAI,CAAC,cAAc,CACpB,CAAC;QAEF,IAAI,CAAC,YAAY,GAAG,QAAQ,CAAC;QAC7B,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;QACrB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QAEnB,IAAI,CAAC,aAAa,CAAC,CAAC,IAAI,CAAC,CAAC;QAE1B,IAAI,IAAI,EAAE,CAAC;YACT,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;QAC3B,CAAC;IACH,CAAC;IAGD,QAAQ,CAAC,KAAa;QACpB,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;QAC9B,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC;QAC1B,IAAI,CAAC,oBAAoB,EAAE,CAAC;IAC9B,CAAC;IAED,OAAO,CAAC,IAAY;QAClB,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;QAChC,IAAI,CAAC,YAAY,GAAG,OAAO,CAAC;QAC5B,IAAI,CAAC,oBAAoB,EAAE,CAAC;IAC9B,CAAC;IAED,YAAY,CAAC,KAAa;QACxB,OAAO,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;IAC5B,CAAC;IAED,cAAc;QACZ,OAAO,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,QAAQ,CAAC,WAAW,EAAE,GAAG,EAAE,CAAC,GAAG,EAAE,CAAC;IAC3D,CAAC;IAED,UAAU,CAAC,EAAQ,EAAE,EAAQ;QAC3B,OAAO,EAAE,CAAC,OAAO,EAAE,KAAK,EAAE,CAAC,OAAO,EAAE;YAClC,EAAE,CAAC,QAAQ,EAAE,KAAK,EAAE,CAAC,QAAQ,EAAE;YAC/B,EAAE,CAAC,WAAW,EAAE,KAAK,EAAE,CAAC,WAAW,EAAE,CAAC;IAC1C,CAAC;IAED,oBAAoB;QAClB,MAAM,IAAI,GAAW,EAAE,CAAC;QACxB,MAAM,IAAI,GAAG,IAAI,CAAC,QAAQ,CAAC,WAAW,EAAE,CAAC;QACzC,MAAM,KAAK,GAAG,IAAI,CAAC,QAAQ,CAAC,QAAQ,EAAE,CAAC;QAEvC,MAAM,QAAQ,GAAG,IAAI,IAAI,CAAC,IAAI,EAAE,KAAK,EAAE,CAAC,CAAC,CAAC;QAC1C,MAAM,MAAM,GAAG,QAAQ,CAAC,MAAM,EAAE,CAAC;QACjC,MAAM,SAAS,GAAG,IAAI,IAAI,CAAC,IAAI,EAAE,KAAK,EAAE,CAAC,GAAG,MAAM,CAAC,CAAC;QAEpD,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC;YAC5B,MAAM,IAAI,GAAG,IAAI,IAAI,CAAC,SAAS,CAAC,CAAC;YACjC,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC,OAAO,EAAE,GAAG,CAAC,CAAC,CAAC;YACtC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAClB,CAAC;QAED,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;IAC3B,CAAC;IAED,aAAa;QACX,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC;QAE1B,IAAI,CAAC,IAAI,CAAC,YAAY,EAAE,CAAC;YACvB,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC;QACpB,CAAC;IACH,CAAC;IAGD,kBAAkB,CAAC,KAAiB;QAClC,MAAM,aAAa,GAAG,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,QAAQ,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;QACtE,IAAI,CAAC,aAAa,IAAI,IAAI,CAAC,YAAY,EAAE,CAAC;YACxC,IAAI,CAAC,aAAa,EAAE,CAAC;QACvB,CAAC;IACH,CAAC;IAGO,0BAA0B;QAChC,IAAI,IAAI,CAAC,IAAI,KAAK,WAAW,EAAE,CAAC;YAC9B,MAAM,IAAI,GAAG,IAAI,CAAC,YAAY,IAAI,IAAI,CAAC,QAAQ,CAAC;YAChD,OAAO,IAAI,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,EAAE,IAAI,CAAC,QAAQ,EAAE,EAAE,IAAI,CAAC,OAAO,EAAE,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;QAC7E,CAAC;QAED,IAAI,IAAI,CAAC,IAAI,KAAK,WAAW,EAAE,CAAC;YAC9B,MAAM,IAAI,GAAG,IAAI,CAAC,cAAc,KAAK,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,YAAY,GAAG,EAAE,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,YAAY,GAAG,EAAE,CAAC,GAAG,EAAE,CAAC;YACnG,MAAM,GAAG,GAAG,IAAI,IAAI,EAAE,CAAC;YACvB,OAAO,IAAI,IAAI,CAAC,GAAG,CAAC,WAAW,EAAE,EAAE,GAAG,CAAC,QAAQ,EAAE,EAAE,GAAG,CAAC,OAAO,EAAE,EAAE,IAAI,EAAE,IAAI,CAAC,cAAc,CAAC,CAAC;QAC/F,CAAC;QACD,MAAM,IAAI,GAAG,IAAI,CAAC,cAAc,KAAK,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,YAAY,GAAG,EAAE,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,YAAY,GAAG,EAAE,CAAC,GAAG,EAAE,CAAC;QACnG,MAAM,IAAI,GAAG,IAAI,CAAC,QAAQ,IAAI,IAAI,IAAI,EAAE,CAAC;QACzC,OAAO,IAAI,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,EAAE,IAAI,CAAC,QAAQ,EAAE,EAAE,IAAI,CAAC,OAAO,EAAE,EAAE,IAAI,EAAE,IAAI,CAAC,cAAc,CAAC,CAAC;IAClG,CAAC;IAEO,aAAa,CAAC,aAAsB;QAC1C,MAAM,QAAQ,GAAG,IAAI,CAAC,0BAA0B,EAAE,CAAC;QACnD,IAAI,CAAC,YAAY,GAAG,QAAQ,CAAC;QAE7B,IAAI,IAAI,CAAC,IAAI,KAAK,WAAW,EAAE,CAAC;YAC9B,MAAM,UAAU,GAAG,GAAG,QAAQ,CAAC,WAAW,EAAE,IAAI,CAAC,QAAQ,CAAC,QAAQ,EAAE,GAAG,CAAC,CAAC,CAAC,QAAQ,EAAE,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC,IAAI,QAAQ,CAAC,OAAO,EAAE,CAAC,QAAQ,EAAE,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC,EAAE,CAAC;YAC1J,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QACrC,CAAC;aAAM,IAAI,IAAI,CAAC,IAAI,KAAK,WAAW,EAAE,CAAC;YACrC,MAAM,UAAU,GAAG,GAAG,QAAQ,CAAC,QAAQ,EAAE,CAAC,QAAQ,EAAE,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC,IAAI,QAAQ,CAAC,UAAU,EAAE,CAAC,QAAQ,EAAE,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC,KAAK,CAAC;YAChI,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QACrC,CAAC;aAAM,CAAC;YACN,MAAM,UAAU,GAAG,GAAG,QAAQ,CAAC,WAAW,EAAE,IAAI,CAAC,QAAQ,CAAC,QAAQ,EAAE,GAAG,CAAC,CAAC,CAAC,QAAQ,EAAE,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC,IAAI,QAAQ,CAAC,OAAO,EAAE,CAAC,QAAQ,EAAE,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC,IAAI,QAAQ,CAAC,QAAQ,EAAE,CAAC,QAAQ,EAAE,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC,IAAI,QAAQ,CAAC,UAAU,EAAE,CAAC,QAAQ,EAAE,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC,KAAK,CAAC;YACrQ,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QACrC,CAAC;QAED,IAAI,aAAa,EAAE,CAAC;YAClB,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC;QAC5B,CAAC;IACH,CAAC;+GAtRU,uBAAuB;mGAAvB,uBAAuB,sZCpBpC,yzPAyNA,uiQD9MI,YAAY,oLACZ,aAAa,2rCAAE,gBAAgB;gBAC/B,eAAe,uFACf,sBAAsB,+DACtB,+BAA+B;;4FAKtB,uBAAuB;kBAbnC,SAAS;+BACE,sBAAsB,cACpB,IAAI,WACP;wBACP,YAAY;wBACZ,aAAa,EAAE,gBAAgB;wBAC/B,eAAe;wBACf,sBAAsB;wBACtB,+BAA+B;qBAChC;+EAKQ,KAAK;sBAAb,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACG,KAAK;sBAAb,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,aAAa;sBAArB,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBAEI,YAAY;sBAArB,MAAM;gBAiOP,kBAAkB;sBADjB,YAAY;uBAAC,gBAAgB,EAAE,CAAC,QAAQ,CAAC","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"]}
|
|
@@ -78,11 +78,11 @@ export class InputSelectComponent {
|
|
|
78
78
|
this.isAlertText = false;
|
|
79
79
|
}
|
|
80
80
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: InputSelectComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
81
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: InputSelectComponent, isStandalone: true, selector: "ius-input-select", inputs: { componentId: "componentId", required: "required", disabled: "disabled", showHelpText: "showHelpText", labelSuperior: "labelSuperior", labelInferior: "labelInferior", labelInput: "labelInput", iconInput: "iconInput", textInput: "textInput" }, outputs: { onChangesValueEvent: "onChangesValueEvent", onAddText: "onAddText" }, host: { listeners: { "document:click": "onClickOutside($event)" } }, ngImport: i0, template: "<div class=\"container-general\" [id]=\"componentId\">\
|
|
81
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: InputSelectComponent, isStandalone: true, selector: "ius-input-select", inputs: { componentId: "componentId", required: "required", disabled: "disabled", showHelpText: "showHelpText", labelSuperior: "labelSuperior", labelInferior: "labelInferior", labelInput: "labelInput", iconInput: "iconInput", textInput: "textInput" }, outputs: { onChangesValueEvent: "onChangesValueEvent", onAddText: "onAddText" }, host: { listeners: { "document:click": "onClickOutside($event)" } }, ngImport: i0, template: "<div class=\"container-general\" [id]=\"componentId\">\n @if (labelSuperior) {\n <div class=\"container-label-sup\" [ngClass]=\"{\n 'disabled': disabled\n }\">\n @if(!disabled && required){\n <div class=\"icon-dot\"></div>\n }\n <span class=\"\">{{labelSuperior}}</span>\n @if(!disabled && showHelpText){\n <ius-icon-md iconName=\"icon-help\" class=\"icon-color-help\"></ius-icon-md>\n }\n <span>:</span>\n </div>\n }\n <div class=\"container-textfield\" [ngClass]=\"{\n 'disabled': disabled,\n 'focused': isFocused,\n 'alert': !isFocused && isAlertText && !disabled\n }\" (click)=\"onFocus()\">\n @if (iconInput) {\n <ius-icon-md [iconName]=\"iconInput\" class=\"icon-color\"></ius-icon-md>\n }\n <input type=\"text\" [(ngModel)]=\"textInput\" [placeholder]=\"labelInput\" [disabled]=\"disabled\" (input)=\"onInput()\"\n (focus)=\"onFocus()\" (blur)=\"onBlur()\" (keypress)=\"onKeyPress($event)\">\n <div class=\"cnt-icon-right\">\n @if(!showList){\n <ius-icon-md iconName=\"icon-keyboard-arrow-down\" class=\"icon-arrows\"></ius-icon-md>\n }@else{\n <ius-icon-md iconName=\"icon-keyboard-arrow-up\" class=\"icon-arrows\"></ius-icon-md>\n }\n </div>\n </div>\n @if (labelInferior && isFocused) {\n <span class=\"label-inf\">{{labelInferior}}</span>\n }\n @if (labelInferior && !isFocused && isAlertText) {\n <span class=\"label-inf\" [ngClass]=\"{\n 'alert': !isFocused && isAlertText && !disabled\n }\">{{labelInferior}}</span>\n }\n @if (showList) {\n <div class=\"container-list scrollable-small\">\n <div (click)=\"onSelectOption()\">\n <ng-content selector=\"ius-option\"></ng-content>\n </div>\n </div>\n }\n</div>", styles: [".h1{font-family:Roboto,sans-serif;font-size:2.375rem;font-weight:500;line-height:46px}.h2{font-family:Roboto,sans-serif;font-size:1.875rem;font-weight:700;line-height:38px}.h3{font-family:Roboto,sans-serif;font-size:1.5rem;font-weight:500;line-height:32px}.h4{font-family:Roboto,sans-serif;font-size:1.25rem;font-weight:700;line-height:26px}.h5{font-family:Roboto,sans-serif;font-size:1.125rem;font-weight:500;line-height:24px;letter-spacing:.18px}.label-large{font-family:Roboto,sans-serif;font-size:1rem;font-weight:500;line-height:22px}.body-large{font-family:Rubik,sans-serif;font-size:1rem;font-weight:400;line-height:22px}.label-base{font-family:Rubik,sans-serif;font-size:.875rem;font-weight:500;line-height:20px;letter-spacing:.28px}.body-base{font-family:Rubik,sans-serif;font-size:.875rem;font-weight:400;line-height:20px;font-style:italic;letter-spacing:.28px}.body-sm{font-family:Rubik,sans-serif;font-size:.75rem;font-weight:400;line-height:16px;letter-spacing:.28px}.body-sm-italic{font-family:Rubik,sans-serif;font-size:.75rem;font-weight:400;line-height:16px;font-style:italic;letter-spacing:.28px}.caption-sm{font-family:Rubik,sans-serif;font-size:.75rem;font-weight:500;line-height:16px;letter-spacing:.28px}.caption-sm-italic{font-family:Rubik,sans-serif;font-size:.75rem;font-weight:500;line-height:16px;font-style:italic;letter-spacing:.28px}.container-general{position:relative;height:100%}.container-textfield{display:flex;padding:10px 12px;justify-content:center;align-items:flex-start;gap:4px;cursor:pointer;border:1px solid #f5f5f5;border-radius:8px;background:#f5f5f5;font-family:Rubik,sans-serif;font-size:.875rem;font-weight:400;line-height:20px;letter-spacing:.28px}.container-textfield:hover:not(.disabled):not(.focused):not(.alert){background:#edf6ff}.container-textfield.focused{border:1px solid #0581BC;background:#edf6ff}.container-textfield.disabled{background:#f5f5f5}.container-textfield.disabled .icon-color,.container-textfield.disabled .icon-arrows,.container-textfield.disabled input{color:#bfbfbf}.container-textfield.disabled input::placeholder{color:#bfbfbf;opacity:1}.container-textfield.alert{border:1px solid #DB2E2A;background:#fff4f0}.container-textfield .icon-arrows{pointer-events:none}.container-textfield .icon-arrows svg{pointer-events:none}.icon-color{color:#595959}.icon-arrows{color:#333}input{display:flex;align-items:center;flex:1 0 0;border:none;outline:none;background-color:transparent;font-family:Rubik,sans-serif;font-size:.875rem;font-weight:400;line-height:20px;letter-spacing:.28px}.cnt-icon-right{display:flex;align-items:center;justify-content:center;background:none;padding:0;color:#333}.container-label-sup{display:flex;align-items:center;gap:4px;margin-bottom:8px;color:#333;font-family:Roboto,sans-serif;font-size:.875rem;font-weight:500;line-height:20px;letter-spacing:.28px}.container-label-sup.disabled{color:#bfbfbf}.icon-dot{display:flex;align-items:center;width:4px;height:4px;aspect-ratio:1/1;background-color:#db2e2a;border-radius:100px}.icon-color-help{color:#8c8c8c}.label-inf{display:flex;position:absolute;margin-top:4px;color:#595959;font-family:Roboto,sans-serif;font-size:.75rem;font-style:italic;font-weight:500;line-height:16px;letter-spacing:.24px}.label-inf.alert{color:#931224}.container-list{position:absolute;max-height:144px;width:100%;display:flex;flex-direction:column;margin-top:4px;border-radius:8px;background:#fff;box-shadow:0 2px 6px #00000024,0 1px 10px #0000001a;z-index:1000;overflow-y:auto}.scrollable-small::-webkit-scrollbar{-webkit-appearance:none}.scrollable-small::-webkit-scrollbar:vertical{width:4px;height:32px;padding-top:2px;padding-bottom:2px}.scrollable-small::-webkit-scrollbar:horizontal{height:5px;padding-top:2px;padding-bottom:2px}.scrollable-small::-webkit-scrollbar-thumb{background-color:#08a6db;border-radius:4px}\n"], dependencies: [{ kind: "component", type: IconMdComponent, selector: "ius-icon-md", inputs: ["iconName", "color"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i1.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: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }] }); }
|
|
82
82
|
}
|
|
83
83
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: InputSelectComponent, decorators: [{
|
|
84
84
|
type: Component,
|
|
85
|
-
args: [{ selector: 'ius-input-select', standalone: true, imports: [IconMdComponent, FormsModule, CommonModule], template: "<div class=\"container-general\" [id]=\"componentId\">\
|
|
85
|
+
args: [{ selector: 'ius-input-select', standalone: true, imports: [IconMdComponent, FormsModule, CommonModule], template: "<div class=\"container-general\" [id]=\"componentId\">\n @if (labelSuperior) {\n <div class=\"container-label-sup\" [ngClass]=\"{\n 'disabled': disabled\n }\">\n @if(!disabled && required){\n <div class=\"icon-dot\"></div>\n }\n <span class=\"\">{{labelSuperior}}</span>\n @if(!disabled && showHelpText){\n <ius-icon-md iconName=\"icon-help\" class=\"icon-color-help\"></ius-icon-md>\n }\n <span>:</span>\n </div>\n }\n <div class=\"container-textfield\" [ngClass]=\"{\n 'disabled': disabled,\n 'focused': isFocused,\n 'alert': !isFocused && isAlertText && !disabled\n }\" (click)=\"onFocus()\">\n @if (iconInput) {\n <ius-icon-md [iconName]=\"iconInput\" class=\"icon-color\"></ius-icon-md>\n }\n <input type=\"text\" [(ngModel)]=\"textInput\" [placeholder]=\"labelInput\" [disabled]=\"disabled\" (input)=\"onInput()\"\n (focus)=\"onFocus()\" (blur)=\"onBlur()\" (keypress)=\"onKeyPress($event)\">\n <div class=\"cnt-icon-right\">\n @if(!showList){\n <ius-icon-md iconName=\"icon-keyboard-arrow-down\" class=\"icon-arrows\"></ius-icon-md>\n }@else{\n <ius-icon-md iconName=\"icon-keyboard-arrow-up\" class=\"icon-arrows\"></ius-icon-md>\n }\n </div>\n </div>\n @if (labelInferior && isFocused) {\n <span class=\"label-inf\">{{labelInferior}}</span>\n }\n @if (labelInferior && !isFocused && isAlertText) {\n <span class=\"label-inf\" [ngClass]=\"{\n 'alert': !isFocused && isAlertText && !disabled\n }\">{{labelInferior}}</span>\n }\n @if (showList) {\n <div class=\"container-list scrollable-small\">\n <div (click)=\"onSelectOption()\">\n <ng-content selector=\"ius-option\"></ng-content>\n </div>\n </div>\n }\n</div>", styles: [".h1{font-family:Roboto,sans-serif;font-size:2.375rem;font-weight:500;line-height:46px}.h2{font-family:Roboto,sans-serif;font-size:1.875rem;font-weight:700;line-height:38px}.h3{font-family:Roboto,sans-serif;font-size:1.5rem;font-weight:500;line-height:32px}.h4{font-family:Roboto,sans-serif;font-size:1.25rem;font-weight:700;line-height:26px}.h5{font-family:Roboto,sans-serif;font-size:1.125rem;font-weight:500;line-height:24px;letter-spacing:.18px}.label-large{font-family:Roboto,sans-serif;font-size:1rem;font-weight:500;line-height:22px}.body-large{font-family:Rubik,sans-serif;font-size:1rem;font-weight:400;line-height:22px}.label-base{font-family:Rubik,sans-serif;font-size:.875rem;font-weight:500;line-height:20px;letter-spacing:.28px}.body-base{font-family:Rubik,sans-serif;font-size:.875rem;font-weight:400;line-height:20px;font-style:italic;letter-spacing:.28px}.body-sm{font-family:Rubik,sans-serif;font-size:.75rem;font-weight:400;line-height:16px;letter-spacing:.28px}.body-sm-italic{font-family:Rubik,sans-serif;font-size:.75rem;font-weight:400;line-height:16px;font-style:italic;letter-spacing:.28px}.caption-sm{font-family:Rubik,sans-serif;font-size:.75rem;font-weight:500;line-height:16px;letter-spacing:.28px}.caption-sm-italic{font-family:Rubik,sans-serif;font-size:.75rem;font-weight:500;line-height:16px;font-style:italic;letter-spacing:.28px}.container-general{position:relative;height:100%}.container-textfield{display:flex;padding:10px 12px;justify-content:center;align-items:flex-start;gap:4px;cursor:pointer;border:1px solid #f5f5f5;border-radius:8px;background:#f5f5f5;font-family:Rubik,sans-serif;font-size:.875rem;font-weight:400;line-height:20px;letter-spacing:.28px}.container-textfield:hover:not(.disabled):not(.focused):not(.alert){background:#edf6ff}.container-textfield.focused{border:1px solid #0581BC;background:#edf6ff}.container-textfield.disabled{background:#f5f5f5}.container-textfield.disabled .icon-color,.container-textfield.disabled .icon-arrows,.container-textfield.disabled input{color:#bfbfbf}.container-textfield.disabled input::placeholder{color:#bfbfbf;opacity:1}.container-textfield.alert{border:1px solid #DB2E2A;background:#fff4f0}.container-textfield .icon-arrows{pointer-events:none}.container-textfield .icon-arrows svg{pointer-events:none}.icon-color{color:#595959}.icon-arrows{color:#333}input{display:flex;align-items:center;flex:1 0 0;border:none;outline:none;background-color:transparent;font-family:Rubik,sans-serif;font-size:.875rem;font-weight:400;line-height:20px;letter-spacing:.28px}.cnt-icon-right{display:flex;align-items:center;justify-content:center;background:none;padding:0;color:#333}.container-label-sup{display:flex;align-items:center;gap:4px;margin-bottom:8px;color:#333;font-family:Roboto,sans-serif;font-size:.875rem;font-weight:500;line-height:20px;letter-spacing:.28px}.container-label-sup.disabled{color:#bfbfbf}.icon-dot{display:flex;align-items:center;width:4px;height:4px;aspect-ratio:1/1;background-color:#db2e2a;border-radius:100px}.icon-color-help{color:#8c8c8c}.label-inf{display:flex;position:absolute;margin-top:4px;color:#595959;font-family:Roboto,sans-serif;font-size:.75rem;font-style:italic;font-weight:500;line-height:16px;letter-spacing:.24px}.label-inf.alert{color:#931224}.container-list{position:absolute;max-height:144px;width:100%;display:flex;flex-direction:column;margin-top:4px;border-radius:8px;background:#fff;box-shadow:0 2px 6px #00000024,0 1px 10px #0000001a;z-index:1000;overflow-y:auto}.scrollable-small::-webkit-scrollbar{-webkit-appearance:none}.scrollable-small::-webkit-scrollbar:vertical{width:4px;height:32px;padding-top:2px;padding-bottom:2px}.scrollable-small::-webkit-scrollbar:horizontal{height:5px;padding-top:2px;padding-bottom:2px}.scrollable-small::-webkit-scrollbar-thumb{background-color:#08a6db;border-radius:4px}\n"] }]
|
|
86
86
|
}], propDecorators: { componentId: [{
|
|
87
87
|
type: Input,
|
|
88
88
|
args: [{ required: true }]
|
|
@@ -110,4 +110,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
110
110
|
type: HostListener,
|
|
111
111
|
args: ['document:click', ['$event']]
|
|
112
112
|
}] } });
|
|
113
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-select.component.js","sourceRoot":"","sources":["../../../../../projects/ius-design-components/src/lib/input-select/input-select.component.ts","../../../../../projects/ius-design-components/src/lib/input-select/input-select.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, HostListener, Input, Output} from '@angular/core';\r\nimport { IconMdComponent } from '../icon-md/icon-md.component';\r\nimport { CommonModule } from '@angular/common';\r\nimport { FormsModule } from '@angular/forms';\r\n\r\n@Component({\r\n  selector: 'ius-input-select',\r\n  standalone: true,\r\n  imports: [IconMdComponent, FormsModule, CommonModule],\r\n  templateUrl: './input-select.component.html',\r\n  styleUrl: './input-select.component.scss',\r\n})\r\nexport class InputSelectComponent {\r\n \r\n  isFocused: boolean = false;\r\n  isAlertText: boolean = false;\r\n  showList: boolean = false;\r\n  hasClickedInside: boolean = false; //Bandera para detectar que ya dieron el primer click en el componente\r\n  selected: boolean = false;\r\n\r\n  @Input({ required: true }) componentId: string = ''; //Debe mandar un componenteID para llamar el input varias veces\r\n  @Input() required = false;\r\n  @Input() disabled = false;\r\n  @Input() showHelpText = false;\r\n\r\n  @Input() labelSuperior?: string;\r\n  @Input() labelInferior?: string;\r\n  @Input() labelInput?: string;\r\n  @Input() iconInput?: string;\r\n\r\n  @Input() textInput?: string = '';\r\n\r\n  @Output() onChangesValueEvent = new EventEmitter<any>();\r\n  @Output() onAddText = new EventEmitter<string>();\r\n\r\n  //Esta funcion permite que el se cierre el listado si el usuario da click en otro lado fuera del componente\r\n  @HostListener('document:click', ['$event'])\r\n  onClickOutside(event: Event) {\r\n    if (!this.hasClickedInside) {\r\n      return;\r\n    }\r\n    const target = event.target as HTMLElement;\r\n    const container = document.getElementById(this.componentId);\r\n    if (container && !container.contains(target)) {\r\n      this.isFocused = false;\r\n      this.showList = false;\r\n      if (!this.selected && !this.showList) {\r\n        this.isAlertText = true;\r\n      } else {\r\n        this.isAlertText = false;\r\n      }\r\n    }\r\n  }\r\n\r\n  onInput(): void {\r\n    if (this.selected) {\r\n      this.selected = false;\r\n    }\r\n    this.onChangesValueEvent.emit(this.textInput);\r\n  }\r\n\r\n  onFocus(): void {\r\n    this.isFocused = true;\r\n    this.showList = true;\r\n    this.hasClickedInside = true;\r\n  }\r\n\r\n  onBlur(): void {\r\n    this.isFocused = false;\r\n    if (this.required && !this.selected) {\r\n      if (this.textInput === '') {\r\n        this.isAlertText = true;\r\n      } else {\r\n        this.isAlertText = false;\r\n      }\r\n    }\r\n  }\r\n\r\n  onKeyPress(event: KeyboardEvent): void {\r\n    if (event.key === 'Enter') {\r\n      this.addText();\r\n    }\r\n  }\r\n\r\n  addText(): void {\r\n    if (this.textInput!.trim() !== '') {\r\n      this.onAddText.emit(this.textInput);\r\n      this.textInput = '';\r\n    }\r\n  }\r\n\r\n  onSelectOption() {\r\n    this.selected = true;\r\n    this.isFocused = false;\r\n    this.showList = false;\r\n    this.isAlertText = false;\r\n  }\r\n}\r\n","<div class=\"container-general\" [id]=\"componentId\">\r\n  @if (labelSuperior) {\r\n  <div class=\"container-label-sup\" [ngClass]=\"{\r\n        'disabled': disabled\r\n    }\">\r\n    @if(!disabled && required){\r\n    <div class=\"icon-dot\"></div>\r\n    }\r\n    <span class=\"\">{{labelSuperior}}</span>\r\n    @if(!disabled && showHelpText){\r\n    <ius-icon-md iconName=\"icon-help\" class=\"icon-color-help\"></ius-icon-md>\r\n    }\r\n    <span>:</span>\r\n  </div>\r\n  }\r\n  <div class=\"container-textfield\" [ngClass]=\"{\r\n        'disabled': disabled,\r\n        'focused': isFocused,\r\n        'alert': !isFocused && isAlertText && !disabled\r\n    }\">\r\n    @if (iconInput) {\r\n    <ius-icon-md [iconName]=\"iconInput\" class=\"icon-color\"></ius-icon-md>\r\n    }\r\n    <input type=\"text\" [(ngModel)]=\"textInput\" [placeholder]=\"labelInput\" [disabled]=\"disabled\" (input)=\"onInput()\"\r\n      (focus)=\"onFocus()\" (blur)=\"onBlur()\" (keypress)=\"onKeyPress($event)\">\r\n    <div class=\"cnt-icon-right\">\r\n      @if(!showList){\r\n      <ius-icon-md iconName=\"icon-keyboard-arrow-down\" class=\"icon-arrows\"></ius-icon-md>\r\n      }@else{\r\n      <ius-icon-md iconName=\"icon-keyboard-arrow-up\" class=\"icon-arrows\"></ius-icon-md>\r\n      }\r\n    </div>\r\n  </div>\r\n  @if (labelInferior && isFocused) {\r\n  <span class=\"label-inf\">{{labelInferior}}</span>\r\n  }\r\n  @if (labelInferior && !isFocused && isAlertText) {\r\n  <span class=\"label-inf\" [ngClass]=\"{\r\n        'alert': !isFocused && isAlertText && !disabled\r\n    }\">{{labelInferior}}</span>\r\n  }\r\n  @if (showList) {\r\n  <div class=\"container-list scrollable-small\">\r\n    <div (click)=\"onSelectOption()\">\r\n      <ng-content selector=\"ius-option\"></ng-content>\r\n    </div>\r\n  </div>\r\n  }\r\n</div>"]}
|
|
113
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-select.component.js","sourceRoot":"","sources":["../../../../../projects/ius-design-components/src/lib/input-select/input-select.component.ts","../../../../../projects/ius-design-components/src/lib/input-select/input-select.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, HostListener, Input, Output} from '@angular/core';\nimport { IconMdComponent } from '../icon-md/icon-md.component';\nimport { CommonModule } from '@angular/common';\nimport { FormsModule } from '@angular/forms';\n\n@Component({\n  selector: 'ius-input-select',\n  standalone: true,\n  imports: [IconMdComponent, FormsModule, CommonModule],\n  templateUrl: './input-select.component.html',\n  styleUrl: './input-select.component.scss',\n})\nexport class InputSelectComponent {\n \n  isFocused: boolean = false;\n  isAlertText: boolean = false;\n  showList: boolean = false;\n  hasClickedInside: boolean = false; //Bandera para detectar que ya dieron el primer click en el componente\n  selected: boolean = false;\n\n  @Input({ required: true }) componentId: string = ''; //Debe mandar un componenteID para llamar el input varias veces\n  @Input() required = false;\n  @Input() disabled = false;\n  @Input() showHelpText = false;\n\n  @Input() labelSuperior?: string;\n  @Input() labelInferior?: string;\n  @Input() labelInput?: string;\n  @Input() iconInput?: string;\n\n  @Input() textInput?: string = '';\n\n  @Output() onChangesValueEvent = new EventEmitter<any>();\n  @Output() onAddText = new EventEmitter<string>();\n\n  //Esta funcion permite que el se cierre el listado si el usuario da click en otro lado fuera del componente\n  @HostListener('document:click', ['$event'])\n  onClickOutside(event: Event) {\n    if (!this.hasClickedInside) {\n      return;\n    }\n    const target = event.target as HTMLElement;\n    const container = document.getElementById(this.componentId);\n    if (container && !container.contains(target)) {\n      this.isFocused = false;\n      this.showList = false;\n      if (!this.selected && !this.showList) {\n        this.isAlertText = true;\n      } else {\n        this.isAlertText = false;\n      }\n    }\n  }\n\n  onInput(): void {\n    if (this.selected) {\n      this.selected = false;\n    }\n    this.onChangesValueEvent.emit(this.textInput);\n  }\n\n  onFocus(): void {\n    this.isFocused = true;\n    this.showList = true;\n    this.hasClickedInside = true;\n  }\n\n  onBlur(): void {\n    this.isFocused = false;\n    if (this.required && !this.selected) {\n      if (this.textInput === '') {\n        this.isAlertText = true;\n      } else {\n        this.isAlertText = false;\n      }\n    }\n  }\n\n  onKeyPress(event: KeyboardEvent): void {\n    if (event.key === 'Enter') {\n      this.addText();\n    }\n  }\n\n  addText(): void {\n    if (this.textInput!.trim() !== '') {\n      this.onAddText.emit(this.textInput);\n      this.textInput = '';\n    }\n  }\n\n  onSelectOption() {\n    this.selected = true;\n    this.isFocused = false;\n    this.showList = false;\n    this.isAlertText = false;\n  }\n}\n","<div class=\"container-general\" [id]=\"componentId\">\n  @if (labelSuperior) {\n  <div class=\"container-label-sup\" [ngClass]=\"{\n        'disabled': disabled\n    }\">\n    @if(!disabled && required){\n    <div class=\"icon-dot\"></div>\n    }\n    <span class=\"\">{{labelSuperior}}</span>\n    @if(!disabled && showHelpText){\n    <ius-icon-md iconName=\"icon-help\" class=\"icon-color-help\"></ius-icon-md>\n    }\n    <span>:</span>\n  </div>\n  }\n  <div class=\"container-textfield\" [ngClass]=\"{\n        'disabled': disabled,\n        'focused': isFocused,\n        'alert': !isFocused && isAlertText && !disabled\n    }\" (click)=\"onFocus()\">\n    @if (iconInput) {\n    <ius-icon-md [iconName]=\"iconInput\" class=\"icon-color\"></ius-icon-md>\n    }\n    <input type=\"text\" [(ngModel)]=\"textInput\" [placeholder]=\"labelInput\" [disabled]=\"disabled\" (input)=\"onInput()\"\n      (focus)=\"onFocus()\" (blur)=\"onBlur()\" (keypress)=\"onKeyPress($event)\">\n    <div class=\"cnt-icon-right\">\n      @if(!showList){\n      <ius-icon-md iconName=\"icon-keyboard-arrow-down\" class=\"icon-arrows\"></ius-icon-md>\n      }@else{\n      <ius-icon-md iconName=\"icon-keyboard-arrow-up\" class=\"icon-arrows\"></ius-icon-md>\n      }\n    </div>\n  </div>\n  @if (labelInferior && isFocused) {\n  <span class=\"label-inf\">{{labelInferior}}</span>\n  }\n  @if (labelInferior && !isFocused && isAlertText) {\n  <span class=\"label-inf\" [ngClass]=\"{\n        'alert': !isFocused && isAlertText && !disabled\n    }\">{{labelInferior}}</span>\n  }\n  @if (showList) {\n  <div class=\"container-list scrollable-small\">\n    <div (click)=\"onSelectOption()\">\n      <ng-content selector=\"ius-option\"></ng-content>\n    </div>\n  </div>\n  }\n</div>"]}
|
|
@@ -23,4 +23,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
23
23
|
}], optionClick: [{
|
|
24
24
|
type: Output
|
|
25
25
|
}] } });
|
|
26
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
26
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoib3B0aW9uLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2l1cy1kZXNpZ24tY29tcG9uZW50cy9zcmMvbGliL29wdGlvbi9vcHRpb24uY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvaXVzLWRlc2lnbi1jb21wb25lbnRzL3NyYy9saWIvb3B0aW9uL29wdGlvbi5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLFlBQVksRUFBRSxLQUFLLEVBQUUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3ZFLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSw4QkFBOEIsQ0FBQzs7QUFTL0QsTUFBTSxPQUFPLGVBQWU7SUFQNUI7UUFTVyxhQUFRLEdBQVksS0FBSyxDQUFDO1FBQzFCLFlBQU8sR0FBWSxLQUFLLENBQUM7UUFDeEIsZ0JBQVcsR0FBRyxJQUFJLFlBQVksRUFBTyxDQUFDO0tBS2pEO0lBSEMsV0FBVztRQUNULElBQUksQ0FBQyxXQUFXLENBQUMsSUFBSSxFQUFFLENBQUM7SUFDMUIsQ0FBQzsrR0FSVSxlQUFlO21HQUFmLGVBQWUscUtDVjVCLG1TQU9TLHlnRURERyxlQUFlOzs0RkFJZCxlQUFlO2tCQVAzQixTQUFTOytCQUNFLFlBQVksY0FDVixJQUFJLFdBQ1AsQ0FBQyxlQUFlLENBQUM7OEJBTWpCLFFBQVE7c0JBQWhCLEtBQUs7Z0JBQ0csT0FBTztzQkFBZixLQUFLO2dCQUNJLFdBQVc7c0JBQXBCLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIEV2ZW50RW1pdHRlciwgSW5wdXQsIE91dHB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgSWNvblNtQ29tcG9uZW50IH0gZnJvbSBcIi4uL2ljb24tc20vaWNvbi1zbS5jb21wb25lbnRcIjtcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnaXVzLW9wdGlvbicsXG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIGltcG9ydHM6IFtJY29uU21Db21wb25lbnRdLFxuICB0ZW1wbGF0ZVVybDogJy4vb3B0aW9uLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmw6ICcuL29wdGlvbi5jb21wb25lbnQuc2Nzcydcbn0pXG5leHBvcnQgY2xhc3MgT3B0aW9uQ29tcG9uZW50IHtcbiAgXG4gIEBJbnB1dCgpIGRpc2FibGVkOiBib29sZWFuID0gZmFsc2U7XG4gIEBJbnB1dCgpIGNoZWNrZWQ6IGJvb2xlYW4gPSBmYWxzZTtcbiAgQE91dHB1dCgpIG9wdGlvbkNsaWNrID0gbmV3IEV2ZW50RW1pdHRlcjxhbnk+KCk7XG5cbiAgc2VsZWNjaW9uYXIoKSB7XG4gICAgdGhpcy5vcHRpb25DbGljay5lbWl0KCk7XG4gIH1cbn1cbiIsIjxidXR0b24gY2xhc3M9XCJpdXMtbGlzdFwiIFtkaXNhYmxlZF09XCJkaXNhYmxlZFwiIChjbGljayk9XCJzZWxlY2Npb25hcigpXCI+XHJcbiAgICA8ZGl2IGNsYXNzPVwiY29udGVudFwiPlxyXG4gICAgICAgIDxuZy1jb250ZW50PjwvbmctY29udGVudD5cclxuICAgIDwvZGl2PlxyXG4gICAgQGlmKGNoZWNrZWQpe1xyXG4gICAgPGl1cy1pY29uLXNtIGljb25OYW1lPVwiaWNvbi1jaGVjay1jaXJjbGVcIiBjbGFzcz1cImljb24tY29sb3JcIj48L2l1cy1pY29uLXNtPlxyXG4gICAgfVxyXG48L2J1dHRvbj4iXX0=
|
|
@@ -1891,12 +1891,12 @@ class DateHourPickerComponent {
|
|
|
1891
1891
|
this.focused = false;
|
|
1892
1892
|
this.calendarView = 'day';
|
|
1893
1893
|
this.calendarDays = [];
|
|
1894
|
-
// Posiciones preferidas del overlay:
|
|
1894
|
+
// Posiciones preferidas del overlay: izquierda abajo, derecha abajo, izquierda arriba, derecha arriba
|
|
1895
1895
|
this.overlayPositions = [
|
|
1896
|
-
{ originX: '
|
|
1897
|
-
{ originX: 'end', originY: 'bottom', overlayX: '
|
|
1898
|
-
{ originX: '
|
|
1899
|
-
{ originX: '
|
|
1896
|
+
{ originX: 'start', originY: 'bottom', overlayX: 'start', overlayY: 'top', offsetY: 4 },
|
|
1897
|
+
{ originX: 'end', originY: 'bottom', overlayX: 'end', overlayY: 'top', offsetY: 4 },
|
|
1898
|
+
{ originX: 'start', originY: 'top', overlayX: 'start', overlayY: 'bottom', offsetY: -4 },
|
|
1899
|
+
{ originX: 'end', originY: 'top', overlayX: 'end', overlayY: 'bottom', offsetY: -4 },
|
|
1900
1900
|
];
|
|
1901
1901
|
}
|
|
1902
1902
|
ngOnInit() {
|
|
@@ -2404,11 +2404,11 @@ class InputSelectComponent {
|
|
|
2404
2404
|
this.isAlertText = false;
|
|
2405
2405
|
}
|
|
2406
2406
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: InputSelectComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
2407
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: InputSelectComponent, isStandalone: true, selector: "ius-input-select", inputs: { componentId: "componentId", required: "required", disabled: "disabled", showHelpText: "showHelpText", labelSuperior: "labelSuperior", labelInferior: "labelInferior", labelInput: "labelInput", iconInput: "iconInput", textInput: "textInput" }, outputs: { onChangesValueEvent: "onChangesValueEvent", onAddText: "onAddText" }, host: { listeners: { "document:click": "onClickOutside($event)" } }, ngImport: i0, template: "<div class=\"container-general\" [id]=\"componentId\">\
|
|
2407
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: InputSelectComponent, isStandalone: true, selector: "ius-input-select", inputs: { componentId: "componentId", required: "required", disabled: "disabled", showHelpText: "showHelpText", labelSuperior: "labelSuperior", labelInferior: "labelInferior", labelInput: "labelInput", iconInput: "iconInput", textInput: "textInput" }, outputs: { onChangesValueEvent: "onChangesValueEvent", onAddText: "onAddText" }, host: { listeners: { "document:click": "onClickOutside($event)" } }, ngImport: i0, template: "<div class=\"container-general\" [id]=\"componentId\">\n @if (labelSuperior) {\n <div class=\"container-label-sup\" [ngClass]=\"{\n 'disabled': disabled\n }\">\n @if(!disabled && required){\n <div class=\"icon-dot\"></div>\n }\n <span class=\"\">{{labelSuperior}}</span>\n @if(!disabled && showHelpText){\n <ius-icon-md iconName=\"icon-help\" class=\"icon-color-help\"></ius-icon-md>\n }\n <span>:</span>\n </div>\n }\n <div class=\"container-textfield\" [ngClass]=\"{\n 'disabled': disabled,\n 'focused': isFocused,\n 'alert': !isFocused && isAlertText && !disabled\n }\" (click)=\"onFocus()\">\n @if (iconInput) {\n <ius-icon-md [iconName]=\"iconInput\" class=\"icon-color\"></ius-icon-md>\n }\n <input type=\"text\" [(ngModel)]=\"textInput\" [placeholder]=\"labelInput\" [disabled]=\"disabled\" (input)=\"onInput()\"\n (focus)=\"onFocus()\" (blur)=\"onBlur()\" (keypress)=\"onKeyPress($event)\">\n <div class=\"cnt-icon-right\">\n @if(!showList){\n <ius-icon-md iconName=\"icon-keyboard-arrow-down\" class=\"icon-arrows\"></ius-icon-md>\n }@else{\n <ius-icon-md iconName=\"icon-keyboard-arrow-up\" class=\"icon-arrows\"></ius-icon-md>\n }\n </div>\n </div>\n @if (labelInferior && isFocused) {\n <span class=\"label-inf\">{{labelInferior}}</span>\n }\n @if (labelInferior && !isFocused && isAlertText) {\n <span class=\"label-inf\" [ngClass]=\"{\n 'alert': !isFocused && isAlertText && !disabled\n }\">{{labelInferior}}</span>\n }\n @if (showList) {\n <div class=\"container-list scrollable-small\">\n <div (click)=\"onSelectOption()\">\n <ng-content selector=\"ius-option\"></ng-content>\n </div>\n </div>\n }\n</div>", styles: [".h1{font-family:Roboto,sans-serif;font-size:2.375rem;font-weight:500;line-height:46px}.h2{font-family:Roboto,sans-serif;font-size:1.875rem;font-weight:700;line-height:38px}.h3{font-family:Roboto,sans-serif;font-size:1.5rem;font-weight:500;line-height:32px}.h4{font-family:Roboto,sans-serif;font-size:1.25rem;font-weight:700;line-height:26px}.h5{font-family:Roboto,sans-serif;font-size:1.125rem;font-weight:500;line-height:24px;letter-spacing:.18px}.label-large{font-family:Roboto,sans-serif;font-size:1rem;font-weight:500;line-height:22px}.body-large{font-family:Rubik,sans-serif;font-size:1rem;font-weight:400;line-height:22px}.label-base{font-family:Rubik,sans-serif;font-size:.875rem;font-weight:500;line-height:20px;letter-spacing:.28px}.body-base{font-family:Rubik,sans-serif;font-size:.875rem;font-weight:400;line-height:20px;font-style:italic;letter-spacing:.28px}.body-sm{font-family:Rubik,sans-serif;font-size:.75rem;font-weight:400;line-height:16px;letter-spacing:.28px}.body-sm-italic{font-family:Rubik,sans-serif;font-size:.75rem;font-weight:400;line-height:16px;font-style:italic;letter-spacing:.28px}.caption-sm{font-family:Rubik,sans-serif;font-size:.75rem;font-weight:500;line-height:16px;letter-spacing:.28px}.caption-sm-italic{font-family:Rubik,sans-serif;font-size:.75rem;font-weight:500;line-height:16px;font-style:italic;letter-spacing:.28px}.container-general{position:relative;height:100%}.container-textfield{display:flex;padding:10px 12px;justify-content:center;align-items:flex-start;gap:4px;cursor:pointer;border:1px solid #f5f5f5;border-radius:8px;background:#f5f5f5;font-family:Rubik,sans-serif;font-size:.875rem;font-weight:400;line-height:20px;letter-spacing:.28px}.container-textfield:hover:not(.disabled):not(.focused):not(.alert){background:#edf6ff}.container-textfield.focused{border:1px solid #0581BC;background:#edf6ff}.container-textfield.disabled{background:#f5f5f5}.container-textfield.disabled .icon-color,.container-textfield.disabled .icon-arrows,.container-textfield.disabled input{color:#bfbfbf}.container-textfield.disabled input::placeholder{color:#bfbfbf;opacity:1}.container-textfield.alert{border:1px solid #DB2E2A;background:#fff4f0}.container-textfield .icon-arrows{pointer-events:none}.container-textfield .icon-arrows svg{pointer-events:none}.icon-color{color:#595959}.icon-arrows{color:#333}input{display:flex;align-items:center;flex:1 0 0;border:none;outline:none;background-color:transparent;font-family:Rubik,sans-serif;font-size:.875rem;font-weight:400;line-height:20px;letter-spacing:.28px}.cnt-icon-right{display:flex;align-items:center;justify-content:center;background:none;padding:0;color:#333}.container-label-sup{display:flex;align-items:center;gap:4px;margin-bottom:8px;color:#333;font-family:Roboto,sans-serif;font-size:.875rem;font-weight:500;line-height:20px;letter-spacing:.28px}.container-label-sup.disabled{color:#bfbfbf}.icon-dot{display:flex;align-items:center;width:4px;height:4px;aspect-ratio:1/1;background-color:#db2e2a;border-radius:100px}.icon-color-help{color:#8c8c8c}.label-inf{display:flex;position:absolute;margin-top:4px;color:#595959;font-family:Roboto,sans-serif;font-size:.75rem;font-style:italic;font-weight:500;line-height:16px;letter-spacing:.24px}.label-inf.alert{color:#931224}.container-list{position:absolute;max-height:144px;width:100%;display:flex;flex-direction:column;margin-top:4px;border-radius:8px;background:#fff;box-shadow:0 2px 6px #00000024,0 1px 10px #0000001a;z-index:1000;overflow-y:auto}.scrollable-small::-webkit-scrollbar{-webkit-appearance:none}.scrollable-small::-webkit-scrollbar:vertical{width:4px;height:32px;padding-top:2px;padding-bottom:2px}.scrollable-small::-webkit-scrollbar:horizontal{height:5px;padding-top:2px;padding-bottom:2px}.scrollable-small::-webkit-scrollbar-thumb{background-color:#08a6db;border-radius:4px}\n"], dependencies: [{ kind: "component", type: IconMdComponent, selector: "ius-icon-md", inputs: ["iconName", "color"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i1$2.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: i1$2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1$2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1$1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }] }); }
|
|
2408
2408
|
}
|
|
2409
2409
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: InputSelectComponent, decorators: [{
|
|
2410
2410
|
type: Component,
|
|
2411
|
-
args: [{ selector: 'ius-input-select', standalone: true, imports: [IconMdComponent, FormsModule, CommonModule], template: "<div class=\"container-general\" [id]=\"componentId\">\
|
|
2411
|
+
args: [{ selector: 'ius-input-select', standalone: true, imports: [IconMdComponent, FormsModule, CommonModule], template: "<div class=\"container-general\" [id]=\"componentId\">\n @if (labelSuperior) {\n <div class=\"container-label-sup\" [ngClass]=\"{\n 'disabled': disabled\n }\">\n @if(!disabled && required){\n <div class=\"icon-dot\"></div>\n }\n <span class=\"\">{{labelSuperior}}</span>\n @if(!disabled && showHelpText){\n <ius-icon-md iconName=\"icon-help\" class=\"icon-color-help\"></ius-icon-md>\n }\n <span>:</span>\n </div>\n }\n <div class=\"container-textfield\" [ngClass]=\"{\n 'disabled': disabled,\n 'focused': isFocused,\n 'alert': !isFocused && isAlertText && !disabled\n }\" (click)=\"onFocus()\">\n @if (iconInput) {\n <ius-icon-md [iconName]=\"iconInput\" class=\"icon-color\"></ius-icon-md>\n }\n <input type=\"text\" [(ngModel)]=\"textInput\" [placeholder]=\"labelInput\" [disabled]=\"disabled\" (input)=\"onInput()\"\n (focus)=\"onFocus()\" (blur)=\"onBlur()\" (keypress)=\"onKeyPress($event)\">\n <div class=\"cnt-icon-right\">\n @if(!showList){\n <ius-icon-md iconName=\"icon-keyboard-arrow-down\" class=\"icon-arrows\"></ius-icon-md>\n }@else{\n <ius-icon-md iconName=\"icon-keyboard-arrow-up\" class=\"icon-arrows\"></ius-icon-md>\n }\n </div>\n </div>\n @if (labelInferior && isFocused) {\n <span class=\"label-inf\">{{labelInferior}}</span>\n }\n @if (labelInferior && !isFocused && isAlertText) {\n <span class=\"label-inf\" [ngClass]=\"{\n 'alert': !isFocused && isAlertText && !disabled\n }\">{{labelInferior}}</span>\n }\n @if (showList) {\n <div class=\"container-list scrollable-small\">\n <div (click)=\"onSelectOption()\">\n <ng-content selector=\"ius-option\"></ng-content>\n </div>\n </div>\n }\n</div>", styles: [".h1{font-family:Roboto,sans-serif;font-size:2.375rem;font-weight:500;line-height:46px}.h2{font-family:Roboto,sans-serif;font-size:1.875rem;font-weight:700;line-height:38px}.h3{font-family:Roboto,sans-serif;font-size:1.5rem;font-weight:500;line-height:32px}.h4{font-family:Roboto,sans-serif;font-size:1.25rem;font-weight:700;line-height:26px}.h5{font-family:Roboto,sans-serif;font-size:1.125rem;font-weight:500;line-height:24px;letter-spacing:.18px}.label-large{font-family:Roboto,sans-serif;font-size:1rem;font-weight:500;line-height:22px}.body-large{font-family:Rubik,sans-serif;font-size:1rem;font-weight:400;line-height:22px}.label-base{font-family:Rubik,sans-serif;font-size:.875rem;font-weight:500;line-height:20px;letter-spacing:.28px}.body-base{font-family:Rubik,sans-serif;font-size:.875rem;font-weight:400;line-height:20px;font-style:italic;letter-spacing:.28px}.body-sm{font-family:Rubik,sans-serif;font-size:.75rem;font-weight:400;line-height:16px;letter-spacing:.28px}.body-sm-italic{font-family:Rubik,sans-serif;font-size:.75rem;font-weight:400;line-height:16px;font-style:italic;letter-spacing:.28px}.caption-sm{font-family:Rubik,sans-serif;font-size:.75rem;font-weight:500;line-height:16px;letter-spacing:.28px}.caption-sm-italic{font-family:Rubik,sans-serif;font-size:.75rem;font-weight:500;line-height:16px;font-style:italic;letter-spacing:.28px}.container-general{position:relative;height:100%}.container-textfield{display:flex;padding:10px 12px;justify-content:center;align-items:flex-start;gap:4px;cursor:pointer;border:1px solid #f5f5f5;border-radius:8px;background:#f5f5f5;font-family:Rubik,sans-serif;font-size:.875rem;font-weight:400;line-height:20px;letter-spacing:.28px}.container-textfield:hover:not(.disabled):not(.focused):not(.alert){background:#edf6ff}.container-textfield.focused{border:1px solid #0581BC;background:#edf6ff}.container-textfield.disabled{background:#f5f5f5}.container-textfield.disabled .icon-color,.container-textfield.disabled .icon-arrows,.container-textfield.disabled input{color:#bfbfbf}.container-textfield.disabled input::placeholder{color:#bfbfbf;opacity:1}.container-textfield.alert{border:1px solid #DB2E2A;background:#fff4f0}.container-textfield .icon-arrows{pointer-events:none}.container-textfield .icon-arrows svg{pointer-events:none}.icon-color{color:#595959}.icon-arrows{color:#333}input{display:flex;align-items:center;flex:1 0 0;border:none;outline:none;background-color:transparent;font-family:Rubik,sans-serif;font-size:.875rem;font-weight:400;line-height:20px;letter-spacing:.28px}.cnt-icon-right{display:flex;align-items:center;justify-content:center;background:none;padding:0;color:#333}.container-label-sup{display:flex;align-items:center;gap:4px;margin-bottom:8px;color:#333;font-family:Roboto,sans-serif;font-size:.875rem;font-weight:500;line-height:20px;letter-spacing:.28px}.container-label-sup.disabled{color:#bfbfbf}.icon-dot{display:flex;align-items:center;width:4px;height:4px;aspect-ratio:1/1;background-color:#db2e2a;border-radius:100px}.icon-color-help{color:#8c8c8c}.label-inf{display:flex;position:absolute;margin-top:4px;color:#595959;font-family:Roboto,sans-serif;font-size:.75rem;font-style:italic;font-weight:500;line-height:16px;letter-spacing:.24px}.label-inf.alert{color:#931224}.container-list{position:absolute;max-height:144px;width:100%;display:flex;flex-direction:column;margin-top:4px;border-radius:8px;background:#fff;box-shadow:0 2px 6px #00000024,0 1px 10px #0000001a;z-index:1000;overflow-y:auto}.scrollable-small::-webkit-scrollbar{-webkit-appearance:none}.scrollable-small::-webkit-scrollbar:vertical{width:4px;height:32px;padding-top:2px;padding-bottom:2px}.scrollable-small::-webkit-scrollbar:horizontal{height:5px;padding-top:2px;padding-bottom:2px}.scrollable-small::-webkit-scrollbar-thumb{background-color:#08a6db;border-radius:4px}\n"] }]
|
|
2412
2412
|
}], propDecorators: { componentId: [{
|
|
2413
2413
|
type: Input,
|
|
2414
2414
|
args: [{ required: true }]
|