@litigiovirtual/ius-design-components 1.0.77 → 1.0.78

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.
@@ -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: izquierda abajo, derecha abajo, izquierda arriba, derecha arriba\r\n  overlayPositions: ConnectedPosition[] = [\r\n    { originX: 'start', originY: 'bottom', overlayX: 'start', overlayY: 'top', offsetY: 4 },\r\n    { originX: 'end', originY: 'bottom', overlayX: 'end', overlayY: 'top', offsetY: 4 },\r\n    { originX: 'start', originY: 'top', overlayX: 'start', overlayY: 'bottom', offsetY: -4 },\r\n    { originX: 'end', originY: 'top', overlayX: 'end', overlayY: 'bottom', offsetY: -4 },\r\n  ];\r\n\r\n  scrollStrategy!: ScrollStrategy;\r\n\r\n  constructor(\r\n    private elRef: ElementRef\r\n    // private overlay: Overlay\r\n  ) { }\r\n\r\n  ngOnInit(): void {\r\n    // this.scrollStrategy = this.overlay.scrollStrategies.reposition();\r\n\r\n    this.generateCalendarDays();\r\n    this.updateLabelAndPlaceholder();\r\n  }\r\n\r\n  private updateLabelAndPlaceholder(): void {\r\n    switch (this.mode) {\r\n      case 'date-only':\r\n        this.label = this.label.replace('Fecha y hora', 'Fecha');\r\n        this.placeholder = this.placeholder.replace('fecha y hora', 'fecha');\r\n        break;\r\n      case 'time-only':\r\n        this.label = this.label.replace('Fecha y hora', 'Hora');\r\n        this.placeholder = this.placeholder.replace('fecha y hora', 'hora');\r\n        break;\r\n      case 'date-time':\r\n      default:\r\n        break;\r\n    }\r\n  }\r\n\r\n  toggleCalendar(): void {\r\n    if (this.disabled) return;\r\n    if (!this.calendarOpen) {\r\n      this.calendarView = 'day';\r\n      this.error = false;\r\n      this.focused = true;\r\n      this.calendarOpen = true;\r\n      return;\r\n    }\r\n    this.emitSelection(true);\r\n    this.focused = false;\r\n  }\r\n\r\n  goToToday(): void {\r\n    const now = new Date();\r\n    this.selectedHour = now.getHours() % 12 || 12;\r\n    this.selectedMinute = now.getMinutes();\r\n    this.selectedPeriod = now.getHours() < 12 ? 'AM' : 'PM';\r\n\r\n    this.viewDate = now;\r\n\r\n    this.emitSelection(this.mode !== 'time-only' ? false : true);\r\n  }\r\n\r\n  selectTime(): void {\r\n    if (this.mode === 'time-only') {\r\n      this.emitSelection(true);\r\n    } else {\r\n      this.emitSelection(false);\r\n    }\r\n  }\r\n\r\n  getDisplayValue(): string {\r\n    if (!this.selectedDate) return '';\r\n\r\n    switch (this.mode) {\r\n      case 'date-only':\r\n        return this.selectedDate.toLocaleDateString('es-ES', {\r\n          day: '2-digit',\r\n          month: '2-digit',\r\n          year: 'numeric'\r\n        });\r\n      case 'time-only':\r\n        return this.selectedDate.toLocaleTimeString('es-ES', {\r\n          hour: '2-digit',\r\n          minute: '2-digit',\r\n          hour12: true\r\n        });\r\n      case 'date-time':\r\n      default:\r\n        return this.selectedDate.toLocaleString('es-ES', {\r\n          day: '2-digit',\r\n          month: '2-digit',\r\n          year: 'numeric',\r\n          hour: '2-digit',\r\n          minute: '2-digit',\r\n          hour12: true\r\n        });\r\n    }\r\n  }\r\n\r\n  nextView(view: 'day' | 'month' | 'year'): 'day' | 'month' | 'year' {\r\n    return view === 'day' ? 'month' : view === 'month' ? 'year' : 'day';\r\n  }\r\n\r\n  prev(): void {\r\n    this.shiftViewDate(-1);\r\n    this.generateCalendarDays();\r\n  }\r\n\r\n  next(): void {\r\n    this.shiftViewDate(1);\r\n    this.generateCalendarDays();\r\n  }\r\n\r\n  private shiftViewDate(step: number): void {\r\n    const year = this.viewDate.getFullYear();\r\n    const month = this.viewDate.getMonth();\r\n\r\n    if (this.calendarView === 'day') {\r\n      this.viewDate = new Date(year, month + step, 1);\r\n    } else if (this.calendarView === 'month') {\r\n      this.viewDate = new Date(year + step, month, 1);\r\n    } else {\r\n      this.viewDate = new Date(year + step * 10, month, 1);\r\n    }\r\n  }\r\n\r\n  selectDate(date: Date, open: boolean): void {\r\n    this.viewDate = new Date(date);\r\n    const hour = this.selectedPeriod === 'AM'\r\n      ? this.selectedHour % 12\r\n      : (this.selectedHour % 12) + 12;\r\n\r\n    const selected = new Date(\r\n      date.getFullYear(),\r\n      date.getMonth(),\r\n      date.getDate(),\r\n      hour,\r\n      this.selectedMinute\r\n    );\r\n\r\n    this.selectedDate = selected;\r\n    this.focused = false;\r\n    this.error = false;\r\n\r\n    this.emitSelection(!open);\r\n\r\n    if (open) {\r\n      this.calendarOpen = true;\r\n    }\r\n  }\r\n\r\n\r\n  setMonth(month: number): void {\r\n    this.viewDate.setMonth(month);\r\n    this.calendarView = 'day';\r\n    this.generateCalendarDays();\r\n  }\r\n\r\n  setYear(year: number): void {\r\n    this.viewDate.setFullYear(year);\r\n    this.calendarView = 'month';\r\n    this.generateCalendarDays();\r\n  }\r\n\r\n  getMonthName(index: number): string {\r\n    return this.months[index];\r\n  }\r\n\r\n  getDecadeStart(): number {\r\n    return Math.floor(this.viewDate.getFullYear() / 10) * 10;\r\n  }\r\n\r\n  isSameDate(d1: Date, d2: Date): boolean {\r\n    return d1.getDate() === d2.getDate() &&\r\n      d1.getMonth() === d2.getMonth() &&\r\n      d1.getFullYear() === d2.getFullYear();\r\n  }\r\n\r\n  generateCalendarDays(): void {\r\n    const days: Date[] = [];\r\n    const year = this.viewDate.getFullYear();\r\n    const month = this.viewDate.getMonth();\r\n\r\n    const firstDay = new Date(year, month, 1);\r\n    const offset = firstDay.getDay();\r\n    const startDate = new Date(year, month, 1 - offset);\r\n\r\n    for (let i = 0; i < 42; i++) {\r\n      const date = new Date(startDate);\r\n      date.setDate(startDate.getDate() + i);\r\n      days.push(date);\r\n    }\r\n\r\n    this.calendarDays = days;\r\n  }\r\n\r\n  closeCalendar(): void {\r\n    this.calendarOpen = false;\r\n\r\n    if (!this.selectedDate) {\r\n      this.error = true;\r\n    }\r\n  }\r\n\r\n  @HostListener('document:click', ['$event'])\r\n  handleOutsideClick(event: MouseEvent): void {\r\n    const clickedInside = this.elRef.nativeElement.contains(event.target);\r\n    if (!clickedInside && this.calendarOpen) {\r\n      this.closeCalendar();\r\n    }\r\n  }\r\n\r\n\r\n  private buildSelectedDateFromState(): Date {\r\n    if (this.mode === 'date-only') {\r\n      const base = this.selectedDate ?? this.viewDate;\r\n      return new Date(base.getFullYear(), base.getMonth(), base.getDate(), 0, 0);\r\n    }\r\n\r\n    if (this.mode === 'time-only') {\r\n      const hour = this.selectedPeriod === 'AM' ? this.selectedHour % 12 : (this.selectedHour % 12) + 12;\r\n      const now = new Date();\r\n      return new Date(now.getFullYear(), now.getMonth(), now.getDate(), hour, this.selectedMinute);\r\n    }\r\n    const hour = this.selectedPeriod === 'AM' ? this.selectedHour % 12 : (this.selectedHour % 12) + 12;\r\n    const base = this.viewDate ?? new Date();\r\n    return new Date(base.getFullYear(), base.getMonth(), base.getDate(), hour, this.selectedMinute);\r\n  }\r\n\r\n  private emitSelection(closeCalendar: boolean): void {\r\n    const selected = this.buildSelectedDateFromState();\r\n    this.selectedDate = selected;\r\n\r\n    if (this.mode === 'date-only') {\r\n      const dateString = `${selected.getFullYear()}-${(selected.getMonth() + 1).toString().padStart(2, '0')}-${selected.getDate().toString().padStart(2, '0')}`;\r\n      this.dateSelected.emit(dateString);\r\n    } else if (this.mode === 'time-only') {\r\n      const timeString = `${selected.getHours().toString().padStart(2, '0')}:${selected.getMinutes().toString().padStart(2, '0')}:00`;\r\n      this.dateSelected.emit(timeString);\r\n    } else {\r\n      const dateString = `${selected.getFullYear()}-${(selected.getMonth() + 1).toString().padStart(2, '0')}-${selected.getDate().toString().padStart(2, '0')}T${selected.getHours().toString().padStart(2, '0')}:${selected.getMinutes().toString().padStart(2, '0')}:00`;\r\n      this.dateSelected.emit(dateString);\r\n    }\r\n\r\n    if (closeCalendar) {\r\n      this.calendarOpen = false;\r\n    }\r\n  }\r\n}\r\n","<div class=\"date-picker\" [class.disabled]=\"disabled\">\r\n  <div class=\"text\">\r\n    @if (isRequired) {\r\n    <div class=\"required\"></div>\r\n    }\r\n\r\n    <label class=\"label\">{{ label }}</label>\r\n\r\n    @if (iconHelp) {\r\n      <div class=\"help-icon\">\r\n        <ius-icon-md iconName=\"icon-help\"></ius-icon-md>\r\n      </div>\r\n    }\r\n\r\n    <label class=\"label\">:</label>\r\n  </div>\r\n\r\n  <div class=\"input-wrapper\">\r\n    <!-- Origen del overlay -->\r\n    <div\r\n      class=\"container-textfield\"\r\n      [ngClass]=\"{\r\n        disabled: disabled,\r\n        focused: calendarOpen || focused,\r\n        alert: !calendarOpen && error && !disabled,\r\n        selected: selectedDate\r\n      }\"\r\n      (click)=\"toggleCalendar()\"\r\n      cdkOverlayOrigin #origin=\"cdkOverlayOrigin\"\r\n    >\r\n      <div class=\"input\">\r\n        <input\r\n          [placeholder]=\"placeholder\"\r\n          [value]=\"selectedDate ? getDisplayValue() : ''\"\r\n          readonly\r\n          [disabled]=\"disabled\"\r\n        />\r\n        <div class=\"cnt-icon-right\">\r\n          <ius-icon-md iconName=\"icon-calendar-today\"></ius-icon-md>\r\n        </div>\r\n      </div>\r\n    </div>\r\n\r\n    <!-- ======== OVERLAY (CDK) ======== -->\r\n    <ng-template\r\n      cdkConnectedOverlay\r\n      [cdkConnectedOverlayOpen]=\"calendarOpen\"\r\n      [cdkConnectedOverlayOrigin]=\"origin\"\r\n      [cdkConnectedOverlayPositions]=\"overlayPositions\"\r\n      [cdkConnectedOverlayHasBackdrop]=\"false\"\r\n      [cdkConnectedOverlayPush]=\"true\"\r\n      [cdkConnectedOverlayFlexibleDimensions]=\"false\"\r\n      [cdkConnectedOverlayPanelClass]=\"'calendar-overlay-panel'\"\r\n    >\r\n      <div\r\n        class=\"calendar-overlay\"\r\n        [class.time-only]=\"mode === 'time-only'\"\r\n        [class.date-only]=\"mode === 'date-only'\"\r\n        (click)=\"$event.stopPropagation()\"\r\n      >\r\n        <div class=\"calendar-content\">\r\n          @if (mode !== 'time-only') {\r\n          <div class=\"calendar-side\">\r\n            <div class=\"calendar-header\">\r\n              <ius-button-standard-tertiary\r\n                iconName=\"icon-keyboard-arrow-left\"\r\n                (buttonClicked)=\"prev()\"\r\n              ></ius-button-standard-tertiary>\r\n\r\n              <span (click)=\"calendarView = nextView(calendarView)\">\r\n              @switch (calendarView) { @case ('day') {\r\n              {{ getMonthName(viewDate.getMonth()) }}\r\n              {{ viewDate.getFullYear() }}\r\n              } @case ('month') {\r\n              {{ viewDate.getFullYear() }}\r\n              } @case ('year') {\r\n              {{ getDecadeStart() }}-{{ getDecadeStart() + 9 }}\r\n              } }\r\n              </span>\r\n\r\n              <ius-button-standard-tertiary\r\n                iconName=\"icon-keyboard-arrow-right\"\r\n                (buttonClicked)=\"next()\"\r\n              ></ius-button-standard-tertiary>\r\n            </div>\r\n\r\n            <div class=\"calendar-body\">\r\n            @switch (calendarView) { @case ('day') {\r\n                  <div class=\"grid days\">\r\n              @for (day of dayLabels; track day) {\r\n              <div class=\"header\">{{ day }}</div>\r\n              } @for (date of calendarDays; track date) {\r\n                      <div\r\n                        class=\"cell\"\r\n                [class.selected]=\"\r\n                  selectedDate && isSameDate(date, selectedDate)\r\n                \"\r\n                        [class.out-of-range]=\"date.getMonth() !== viewDate.getMonth()\"\r\n                        (click)=\"selectDate(date, true)\"\r\n                      >\r\n                        {{ date.getDate() }}\r\n                      </div>\r\n                    }\r\n                  </div>\r\n            } @case ('month') {\r\n                  <div class=\"grid months\">\r\n                    @for (m of months; track m; let i = $index) {\r\n                      <div class=\"cell\" (click)=\"setMonth(i)\">{{ m }}</div>\r\n                    }\r\n                  </div>\r\n            } @case ('year') {\r\n                  <div class=\"grid years\">\r\n                    @for (i of yearsArray; track i) {\r\n                      <div\r\n                        class=\"cell\"\r\n                        [class.out-of-range]=\"i === 0 || i === 11\"\r\n                        (click)=\"setYear(getDecadeStart() - 1 + i)\"\r\n                      >\r\n                        {{ getDecadeStart() - 1 + i }}\r\n                      </div>\r\n                    }\r\n                  </div>\r\n            } }\r\n            </div>\r\n          </div>\r\n        } @if (mode !== 'date-only') {\r\n          <div class=\"time-selector\">\r\n            <button class=\"time-title\">\r\n              <span>\r\n                {{ selectedHour | number : \"2.0\" }}:{{\r\n                  selectedMinute === 0 ? \"00\" : (selectedMinute | number : \"2.0\")\r\n                }}\r\n                {{ selectedPeriod }}\r\n              </span>\r\n            </button>\r\n            <ius-simple-divider></ius-simple-divider>\r\n            <div class=\"time-columns\">\r\n              <div class=\"column scrollable\">\r\n                @for (h of hours; track h) {\r\n                <div\r\n                  [class.selected]=\"h === selectedHour\"\r\n                (click)=\"\r\n                  selectedHour = h;\r\n                  mode === 'time-only'\r\n                    ? selectTime()\r\n                    : selectDate(viewDate, true)\r\n                \"\r\n                >\r\n                  {{ h | number : \"2.0\" }}\r\n                </div>\r\n                }\r\n              </div>\r\n              <div class=\"divider\"></div>\r\n              <div class=\"column scrollable\">\r\n                @for (m of minutes; track m) {\r\n                <div\r\n                  [class.selected]=\"m === selectedMinute\"\r\n                (click)=\"\r\n                  selectedMinute = m;\r\n                  mode === 'time-only'\r\n                    ? selectTime()\r\n                    : selectDate(viewDate, true)\r\n                \"\r\n                >\r\n                  {{ m | number : \"2.0\" }}\r\n                </div>\r\n                }\r\n              </div>\r\n              <div class=\"divider\"></div>\r\n              <div class=\"column\">\r\n                <div\r\n                  [class.selected]=\"'AM' === selectedPeriod\"\r\n                (click)=\"\r\n                  selectedPeriod = 'AM';\r\n                  mode === 'time-only'\r\n                    ? selectTime()\r\n                    : selectDate(viewDate, false)\r\n                \"\r\n                >\r\n                  AM\r\n                </div>\r\n                <div\r\n                  [class.selected]=\"'PM' === selectedPeriod\"\r\n                (click)=\"\r\n                  selectedPeriod = 'PM';\r\n                  mode === 'time-only'\r\n                    ? selectTime()\r\n                    : selectDate(viewDate, false)\r\n                \"\r\n                >\r\n                  PM\r\n                </div>\r\n              </div>\r\n            </div>\r\n          </div>\r\n          }\r\n        </div>\r\n\r\n        <ius-simple-divider></ius-simple-divider>\r\n        <button class=\"today\" (click)=\"goToToday()\">\r\n        @if (mode === 'date-only') { Fecha actual } @else if (mode ===\r\n        'time-only') { Hora actual } @else { Fecha y hora actual }\r\n        </button>\r\n      </div>\r\n    </ng-template>\r\n    <!-- ======== /OVERLAY (CDK) ======== -->\r\n  </div>\r\n  @if (helpText && focused && !error) {\r\n  <div class=\"help-text\">\r\n    {{ helpText }}\r\n  </div>\r\n  } @if (helpTextError && error) {\r\n  <div class=\"help-text-error\">\r\n    {{ helpTextError }}\r\n  </div>\r\n  }\r\n</div>\r\n"]}
279
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-hour-picker.component.js","sourceRoot":"","sources":["../../../../../projects/ius-design-components/src/lib/date-hour-picker/date-hour-picker.component.ts","../../../../../projects/ius-design-components/src/lib/date-hour-picker/date-hour-picker.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport { Component, ElementRef, EventEmitter, HostListener, Input, Output } from '@angular/core';\nimport { OverlayModule, ConnectedPosition, ScrollStrategy, Overlay } from '@angular/cdk/overlay';\nimport { IconMdComponent } from '../icon-md/icon-md.component';\nimport { SimpleDividerComponent } from '../simple-divider/simple-divider.component';\nimport { ButtonStandardTertiaryComponent } from '../button-standard-tertiary/button-standard-tertiary.component';\n\n@Component({\n  selector: 'ius-date-hour-picker',\n  standalone: true,\n  imports: [\n    CommonModule,\n    OverlayModule, // ✅ CDK Overlay\n    IconMdComponent,\n    SimpleDividerComponent,\n    ButtonStandardTertiaryComponent,\n  ],\n  templateUrl: './date-hour-picker.component.html',\n  styleUrl: './date-hour-picker.component.scss',\n})\nexport class DateHourPickerComponent {\n  @Input() label = 'Fecha y hora';\n  @Input() placeholder = 'Seleccione una fecha y hora';\n  @Input() error = false;\n  @Input() helpText = '';\n  @Input() helpTextError = '';\n  @Input() disabled = false;\n  @Input() iconHelp = false;\n  @Input() isRequired = true;\n  @Input() mode: 'date-only' | 'time-only' | 'date-time' = 'date-time';\n\n  @Output() dateSelected = new EventEmitter<string>();\n\n  readonly dayLabels = ['Do', 'Lu', 'Ma', 'Mi', 'Ju', 'Vi', 'Sa'];\n  readonly months = ['Ene', 'Feb', 'Mar', 'Abr', 'May', 'Jun', 'Jul', 'Ago', 'Sep', 'Oct', 'Nov', 'Dic'];\n  readonly yearsArray = Array.from({ length: 12 }, (_, i) => i);\n\n  readonly hours = Array.from({ length: 12 }, (_, i) => i + 1); // 01 a 12\n  readonly minutes = Array.from({ length: 60 }, (_, i) => i);   // 00 a 59\n\n  selectedDate: Date | null = null;\n  selectedHour = 1;\n  selectedMinute = 0;\n  selectedPeriod: 'AM' | 'PM' = 'PM';\n\n  viewDate = new Date();\n  calendarOpen = false;\n  focused = false;\n  calendarView: 'day' | 'month' | 'year' = 'day';\n  calendarDays: Date[] = [];\n\n  // Posiciones preferidas del overlay: izquierda abajo, derecha abajo, izquierda arriba, derecha arriba\n  overlayPositions: ConnectedPosition[] = [\n    { originX: 'start', originY: 'bottom', overlayX: 'start', overlayY: 'top', offsetY: 4 },\n    { originX: 'end', originY: 'bottom', overlayX: 'end', overlayY: 'top', offsetY: 4 },\n    { originX: 'start', originY: 'top', overlayX: 'start', overlayY: 'bottom', offsetY: -4 },\n    { originX: 'end', originY: 'top', overlayX: 'end', overlayY: 'bottom', offsetY: -4 },\n  ];\n\n  scrollStrategy!: ScrollStrategy;\n\n  constructor(\n    private elRef: ElementRef\n    // private overlay: Overlay\n  ) { }\n\n  ngOnInit(): void {\n    // this.scrollStrategy = this.overlay.scrollStrategies.reposition();\n\n    this.generateCalendarDays();\n    this.updateLabelAndPlaceholder();\n  }\n\n  private updateLabelAndPlaceholder(): void {\n    switch (this.mode) {\n      case 'date-only':\n        this.label = this.label.replace('Fecha y hora', 'Fecha');\n        this.placeholder = this.placeholder.replace('fecha y hora', 'fecha');\n        break;\n      case 'time-only':\n        this.label = this.label.replace('Fecha y hora', 'Hora');\n        this.placeholder = this.placeholder.replace('fecha y hora', 'hora');\n        break;\n      case 'date-time':\n      default:\n        break;\n    }\n  }\n\n  toggleCalendar(): void {\n    if (this.disabled) return;\n    if (!this.calendarOpen) {\n      this.calendarView = 'day';\n      this.error = false;\n      this.focused = true;\n      this.calendarOpen = true;\n      return;\n    }\n    this.emitSelection(true);\n    this.focused = false;\n  }\n\n  goToToday(): void {\n    const now = new Date();\n    this.selectedHour = now.getHours() % 12 || 12;\n    this.selectedMinute = now.getMinutes();\n    this.selectedPeriod = now.getHours() < 12 ? 'AM' : 'PM';\n\n    this.viewDate = now;\n\n    this.emitSelection(this.mode !== 'time-only' ? false : true);\n  }\n\n  selectTime(): void {\n    if (this.mode === 'time-only') {\n      this.emitSelection(true);\n    } else {\n      this.emitSelection(false);\n    }\n  }\n\n  getDisplayValue(): string {\n    if (!this.selectedDate) return '';\n\n    switch (this.mode) {\n      case 'date-only':\n        return this.selectedDate.toLocaleDateString('es-ES', {\n          day: '2-digit',\n          month: '2-digit',\n          year: 'numeric'\n        });\n      case 'time-only':\n        return this.selectedDate.toLocaleTimeString('es-ES', {\n          hour: '2-digit',\n          minute: '2-digit',\n          hour12: true\n        });\n      case 'date-time':\n      default:\n        return this.selectedDate.toLocaleString('es-ES', {\n          day: '2-digit',\n          month: '2-digit',\n          year: 'numeric',\n          hour: '2-digit',\n          minute: '2-digit',\n          hour12: true\n        });\n    }\n  }\n\n  nextView(view: 'day' | 'month' | 'year'): 'day' | 'month' | 'year' {\n    return view === 'day' ? 'month' : view === 'month' ? 'year' : 'day';\n  }\n\n  prev(): void {\n    this.shiftViewDate(-1);\n    this.generateCalendarDays();\n  }\n\n  next(): void {\n    this.shiftViewDate(1);\n    this.generateCalendarDays();\n  }\n\n  private shiftViewDate(step: number): void {\n    const year = this.viewDate.getFullYear();\n    const month = this.viewDate.getMonth();\n\n    if (this.calendarView === 'day') {\n      this.viewDate = new Date(year, month + step, 1);\n    } else if (this.calendarView === 'month') {\n      this.viewDate = new Date(year + step, month, 1);\n    } else {\n      this.viewDate = new Date(year + step * 10, month, 1);\n    }\n  }\n\n  selectDate(date: Date, open: boolean): void {\n    this.viewDate = new Date(date);\n    const hour = this.selectedPeriod === 'AM'\n      ? this.selectedHour % 12\n      : (this.selectedHour % 12) + 12;\n\n    const selected = new Date(\n      date.getFullYear(),\n      date.getMonth(),\n      date.getDate(),\n      hour,\n      this.selectedMinute\n    );\n\n    this.selectedDate = selected;\n    this.focused = false;\n    this.error = false;\n\n    this.emitSelection(!open);\n\n    if (open) {\n      this.calendarOpen = true;\n    }\n  }\n\n\n  setMonth(month: number): void {\n    this.viewDate.setMonth(month);\n    this.calendarView = 'day';\n    this.generateCalendarDays();\n  }\n\n  setYear(year: number): void {\n    this.viewDate.setFullYear(year);\n    this.calendarView = 'month';\n    this.generateCalendarDays();\n  }\n\n  getMonthName(index: number): string {\n    return this.months[index];\n  }\n\n  getDecadeStart(): number {\n    return Math.floor(this.viewDate.getFullYear() / 10) * 10;\n  }\n\n  isSameDate(d1: Date, d2: Date): boolean {\n    return d1.getDate() === d2.getDate() &&\n      d1.getMonth() === d2.getMonth() &&\n      d1.getFullYear() === d2.getFullYear();\n  }\n\n  generateCalendarDays(): void {\n    const days: Date[] = [];\n    const year = this.viewDate.getFullYear();\n    const month = this.viewDate.getMonth();\n\n    const firstDay = new Date(year, month, 1);\n    const offset = firstDay.getDay();\n    const startDate = new Date(year, month, 1 - offset);\n\n    for (let i = 0; i < 42; i++) {\n      const date = new Date(startDate);\n      date.setDate(startDate.getDate() + i);\n      days.push(date);\n    }\n\n    this.calendarDays = days;\n  }\n\n  closeCalendar(): void {\n    this.calendarOpen = false;\n\n    if (!this.selectedDate) {\n      this.error = true;\n    }\n  }\n\n  @HostListener('document:click', ['$event'])\n  handleOutsideClick(event: MouseEvent): void {\n    const clickedInside = this.elRef.nativeElement.contains(event.target);\n    if (!clickedInside && this.calendarOpen) {\n      this.closeCalendar();\n    }\n  }\n\n\n  private buildSelectedDateFromState(): Date {\n    if (this.mode === 'date-only') {\n      const base = this.selectedDate ?? this.viewDate;\n      return new Date(base.getFullYear(), base.getMonth(), base.getDate(), 0, 0);\n    }\n\n    if (this.mode === 'time-only') {\n      const hour = this.selectedPeriod === 'AM' ? this.selectedHour % 12 : (this.selectedHour % 12) + 12;\n      const now = new Date();\n      return new Date(now.getFullYear(), now.getMonth(), now.getDate(), hour, this.selectedMinute);\n    }\n    const hour = this.selectedPeriod === 'AM' ? this.selectedHour % 12 : (this.selectedHour % 12) + 12;\n    const base = this.viewDate ?? new Date();\n    return new Date(base.getFullYear(), base.getMonth(), base.getDate(), hour, this.selectedMinute);\n  }\n\n  private emitSelection(closeCalendar: boolean): void {\n    const selected = this.buildSelectedDateFromState();\n    this.selectedDate = selected;\n\n    if (this.mode === 'date-only') {\n      const dateString = `${selected.getFullYear()}-${(selected.getMonth() + 1).toString().padStart(2, '0')}-${selected.getDate().toString().padStart(2, '0')}`;\n      this.dateSelected.emit(dateString);\n    } else if (this.mode === 'time-only') {\n      const timeString = `${selected.getHours().toString().padStart(2, '0')}:${selected.getMinutes().toString().padStart(2, '0')}:00`;\n      this.dateSelected.emit(timeString);\n    } else {\n      const dateString = `${selected.getFullYear()}-${(selected.getMonth() + 1).toString().padStart(2, '0')}-${selected.getDate().toString().padStart(2, '0')}T${selected.getHours().toString().padStart(2, '0')}:${selected.getMinutes().toString().padStart(2, '0')}:00`;\n      this.dateSelected.emit(dateString);\n    }\n\n    if (closeCalendar) {\n      this.calendarOpen = false;\n    }\n  }\n}\n","<div class=\"date-picker\" [class.disabled]=\"disabled\">\r\n  <div class=\"text\">\r\n    @if (isRequired) {\r\n    <div class=\"required\"></div>\r\n    }\r\n\r\n    <label class=\"label\">{{ label }}</label>\r\n\r\n    @if (iconHelp) {\r\n      <div class=\"help-icon\">\r\n        <ius-icon-md iconName=\"icon-help\"></ius-icon-md>\r\n      </div>\r\n    }\r\n\r\n    <label class=\"label\">:</label>\r\n  </div>\r\n\r\n  <div class=\"input-wrapper\">\r\n    <!-- Origen del overlay -->\r\n    <div\r\n      class=\"container-textfield\"\r\n      [ngClass]=\"{\r\n        disabled: disabled,\r\n        focused: calendarOpen || focused,\r\n        alert: !calendarOpen && error && !disabled,\r\n        selected: selectedDate\r\n      }\"\r\n      (click)=\"toggleCalendar()\"\r\n      cdkOverlayOrigin #origin=\"cdkOverlayOrigin\"\r\n    >\r\n      <div class=\"input\">\r\n        <input\r\n          [placeholder]=\"placeholder\"\r\n          [value]=\"selectedDate ? getDisplayValue() : ''\"\r\n          readonly\r\n          [disabled]=\"disabled\"\r\n        />\r\n        <div class=\"cnt-icon-right\">\r\n          <ius-icon-md iconName=\"icon-calendar-today\"></ius-icon-md>\r\n        </div>\r\n      </div>\r\n    </div>\r\n\r\n    <!-- ======== OVERLAY (CDK) ======== -->\r\n    <ng-template\r\n      cdkConnectedOverlay\r\n      [cdkConnectedOverlayOpen]=\"calendarOpen\"\r\n      [cdkConnectedOverlayOrigin]=\"origin\"\r\n      [cdkConnectedOverlayPositions]=\"overlayPositions\"\r\n      [cdkConnectedOverlayHasBackdrop]=\"false\"\r\n      [cdkConnectedOverlayPush]=\"true\"\r\n      [cdkConnectedOverlayFlexibleDimensions]=\"false\"\r\n      [cdkConnectedOverlayPanelClass]=\"'calendar-overlay-panel'\"\r\n    >\r\n      <div\r\n        class=\"calendar-overlay\"\r\n        [class.time-only]=\"mode === 'time-only'\"\r\n        [class.date-only]=\"mode === 'date-only'\"\r\n        (click)=\"$event.stopPropagation()\"\r\n      >\r\n        <div class=\"calendar-content\">\r\n          @if (mode !== 'time-only') {\r\n          <div class=\"calendar-side\">\r\n            <div class=\"calendar-header\">\r\n              <ius-button-standard-tertiary\r\n                iconName=\"icon-keyboard-arrow-left\"\r\n                (buttonClicked)=\"prev()\"\r\n              ></ius-button-standard-tertiary>\r\n\r\n              <span (click)=\"calendarView = nextView(calendarView)\">\r\n              @switch (calendarView) { @case ('day') {\r\n              {{ getMonthName(viewDate.getMonth()) }}\r\n              {{ viewDate.getFullYear() }}\r\n              } @case ('month') {\r\n              {{ viewDate.getFullYear() }}\r\n              } @case ('year') {\r\n              {{ getDecadeStart() }}-{{ getDecadeStart() + 9 }}\r\n              } }\r\n              </span>\r\n\r\n              <ius-button-standard-tertiary\r\n                iconName=\"icon-keyboard-arrow-right\"\r\n                (buttonClicked)=\"next()\"\r\n              ></ius-button-standard-tertiary>\r\n            </div>\r\n\r\n            <div class=\"calendar-body\">\r\n            @switch (calendarView) { @case ('day') {\r\n                  <div class=\"grid days\">\r\n              @for (day of dayLabels; track day) {\r\n              <div class=\"header\">{{ day }}</div>\r\n              } @for (date of calendarDays; track date) {\r\n                      <div\r\n                        class=\"cell\"\r\n                [class.selected]=\"\r\n                  selectedDate && isSameDate(date, selectedDate)\r\n                \"\r\n                        [class.out-of-range]=\"date.getMonth() !== viewDate.getMonth()\"\r\n                        (click)=\"selectDate(date, true)\"\r\n                      >\r\n                        {{ date.getDate() }}\r\n                      </div>\r\n                    }\r\n                  </div>\r\n            } @case ('month') {\r\n                  <div class=\"grid months\">\r\n                    @for (m of months; track m; let i = $index) {\r\n                      <div class=\"cell\" (click)=\"setMonth(i)\">{{ m }}</div>\r\n                    }\r\n                  </div>\r\n            } @case ('year') {\r\n                  <div class=\"grid years\">\r\n                    @for (i of yearsArray; track i) {\r\n                      <div\r\n                        class=\"cell\"\r\n                        [class.out-of-range]=\"i === 0 || i === 11\"\r\n                        (click)=\"setYear(getDecadeStart() - 1 + i)\"\r\n                      >\r\n                        {{ getDecadeStart() - 1 + i }}\r\n                      </div>\r\n                    }\r\n                  </div>\r\n            } }\r\n            </div>\r\n          </div>\r\n        } @if (mode !== 'date-only') {\r\n          <div class=\"time-selector\">\r\n            <button class=\"time-title\">\r\n              <span>\r\n                {{ selectedHour | number : \"2.0\" }}:{{\r\n                  selectedMinute === 0 ? \"00\" : (selectedMinute | number : \"2.0\")\r\n                }}\r\n                {{ selectedPeriod }}\r\n              </span>\r\n            </button>\r\n            <ius-simple-divider></ius-simple-divider>\r\n            <div class=\"time-columns\">\r\n              <div class=\"column scrollable\">\r\n                @for (h of hours; track h) {\r\n                <div\r\n                  [class.selected]=\"h === selectedHour\"\r\n                (click)=\"\r\n                  selectedHour = h;\r\n                  mode === 'time-only'\r\n                    ? selectTime()\r\n                    : selectDate(viewDate, true)\r\n                \"\r\n                >\r\n                  {{ h | number : \"2.0\" }}\r\n                </div>\r\n                }\r\n              </div>\r\n              <div class=\"divider\"></div>\r\n              <div class=\"column scrollable\">\r\n                @for (m of minutes; track m) {\r\n                <div\r\n                  [class.selected]=\"m === selectedMinute\"\r\n                (click)=\"\r\n                  selectedMinute = m;\r\n                  mode === 'time-only'\r\n                    ? selectTime()\r\n                    : selectDate(viewDate, true)\r\n                \"\r\n                >\r\n                  {{ m | number : \"2.0\" }}\r\n                </div>\r\n                }\r\n              </div>\r\n              <div class=\"divider\"></div>\r\n              <div class=\"column\">\r\n                <div\r\n                  [class.selected]=\"'AM' === selectedPeriod\"\r\n                (click)=\"\r\n                  selectedPeriod = 'AM';\r\n                  mode === 'time-only'\r\n                    ? selectTime()\r\n                    : selectDate(viewDate, false)\r\n                \"\r\n                >\r\n                  AM\r\n                </div>\r\n                <div\r\n                  [class.selected]=\"'PM' === selectedPeriod\"\r\n                (click)=\"\r\n                  selectedPeriod = 'PM';\r\n                  mode === 'time-only'\r\n                    ? selectTime()\r\n                    : selectDate(viewDate, false)\r\n                \"\r\n                >\r\n                  PM\r\n                </div>\r\n              </div>\r\n            </div>\r\n          </div>\r\n          }\r\n        </div>\r\n\r\n        <ius-simple-divider></ius-simple-divider>\r\n        <button class=\"today\" (click)=\"goToToday()\">\r\n        @if (mode === 'date-only') { Fecha actual } @else if (mode ===\r\n        'time-only') { Hora actual } @else { Fecha y hora actual }\r\n        </button>\r\n      </div>\r\n    </ng-template>\r\n    <!-- ======== /OVERLAY (CDK) ======== -->\r\n  </div>\r\n  @if (helpText && focused && !error) {\r\n  <div class=\"help-text\">\r\n    {{ helpText }}\r\n  </div>\r\n  } @if (helpTextError && error) {\r\n  <div class=\"help-text-error\">\r\n    {{ helpTextError }}\r\n  </div>\r\n  }\r\n</div>\r\n"]}
@@ -1,5 +1,5 @@
1
1
  import { CommonModule } from '@angular/common';
2
- import { Component, EventEmitter, Input, Output, } from '@angular/core';
2
+ import { Component, EventEmitter, HostListener, Input, Output, } from '@angular/core';
3
3
  import * as i0 from "@angular/core";
4
4
  import * as i1 from "@angular/common";
5
5
  export class DropdownUserMenuComponent {
@@ -16,12 +16,19 @@ export class DropdownUserMenuComponent {
16
16
  this.isOpen = !this.isOpen;
17
17
  this.buttonClicked.emit();
18
18
  }
19
+ onClickOutside(event) {
20
+ const target = event.target;
21
+ const container = document.getElementById('userMenu');
22
+ if (container && !container.contains(target)) {
23
+ this.isOpen = false;
24
+ }
25
+ }
19
26
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DropdownUserMenuComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
20
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: DropdownUserMenuComponent, isStandalone: true, selector: "ius-dropdown-user-menu", inputs: { isActive: "isActive", nameUser: "nameUser", logo: "logo", avatar: "avatar", disabled: "disabled" }, outputs: { buttonClicked: "buttonClicked" }, ngImport: i0, template: "<div class=\"dropdown-container\">\r\n <button [disabled]=\"disabled\" (click)=\"onClick()\" class=\"ius-btn\" [ngClass]=\"{ isOpen: isOpen }\">\r\n <img class=\"logo\" [src]=\"logo\" alt=\"lem logo\" />\r\n <span class=\"name\">{{nameUser}}</span>\r\n <img class=\"avatar\" [src]=\"avatar\" alt=\"user avatar\" />\r\n </button>\r\n\r\n @if (isOpen) {\r\n <div class=\"dropdown-menu\">\r\n <ng-content></ng-content>\r\n </div>\r\n }\r\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}.ius-btn{display:inline-flex;padding:8px 12px;align-items:center;gap:8px;border-radius:8px;background-color:#fff;color:#333;border:1px solid #eaeaea;cursor:pointer;font-family:Rubik,sans-serif;font-size:.875rem;font-weight:500;font-style:normal;line-height:20px;letter-spacing:.28px}.ius-btn:hover:not(:disabled){border:1px solid #5892FF;box-shadow:0 1px 3px #0000001f,0 1px 2px #00000014}.ius-btn:active:not(:disabled){border:1px solid #5892FF;background-color:#edf6ff}.ius-btn.isOpen{border:1px solid #eaeaea;box-shadow:0 1px 3px #0000001f,0 1px 2px #00000014;background-color:#fff}.logo{display:flex;width:32px;height:32px;border-radius:100px;justify-content:center;align-items:center;aspect-ratio:1/1;border:.5px solid #f5f5f5}.avatar{display:flex;width:32px;height:32px;border-radius:100px;justify-content:center;align-items:center;aspect-ratio:1/1;border:.5px solid #f5f5f5;background:#fff3}.dropdown-container{position:relative;display:inline-block}.dropdown-menu{position:absolute;top:100%;right:0;z-index:10;margin-top:4px;display:inline-flex;padding:4px;flex-direction:column;justify-content:center;align-items:flex-start;gap:4px;border-radius:8px;background-color:#fff;box-shadow:0 2px 6px #00000024,0 1px 10px #0000001a}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }] }); }
27
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: DropdownUserMenuComponent, isStandalone: true, selector: "ius-dropdown-user-menu", inputs: { isActive: "isActive", nameUser: "nameUser", logo: "logo", avatar: "avatar", disabled: "disabled" }, outputs: { buttonClicked: "buttonClicked" }, host: { listeners: { "document:click": "onClickOutside($event)" } }, ngImport: i0, template: "<div class=\"dropdown-container\" id=\"userMenu\">\r\n <button [disabled]=\"disabled\" (click)=\"onClick()\" class=\"ius-btn\" [ngClass]=\"{ isOpen: isOpen }\">\r\n <img class=\"logo\" [src]=\"logo\" alt=\"lem logo\" />\r\n <span class=\"name\">{{nameUser}}</span>\r\n <img class=\"avatar\" [src]=\"avatar\" alt=\"user avatar\" />\r\n </button>\r\n\r\n @if (isOpen) {\r\n <div class=\"dropdown-menu\">\r\n <ng-content></ng-content>\r\n </div>\r\n }\r\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}.ius-btn{display:inline-flex;padding:8px 12px;align-items:center;gap:8px;border-radius:8px;background-color:#fff;color:#333;border:1px solid #eaeaea;cursor:pointer;font-family:Rubik,sans-serif;font-size:.875rem;font-weight:500;font-style:normal;line-height:20px;letter-spacing:.28px}.ius-btn:hover:not(:disabled){border:1px solid #5892FF;box-shadow:0 1px 3px #0000001f,0 1px 2px #00000014}.ius-btn:active:not(:disabled){border:1px solid #5892FF;background-color:#edf6ff}.ius-btn.isOpen{border:1px solid #eaeaea;box-shadow:0 1px 3px #0000001f,0 1px 2px #00000014;background-color:#fff}.logo{display:flex;width:32px;height:32px;border-radius:100px;justify-content:center;align-items:center;aspect-ratio:1/1;border:.5px solid #f5f5f5}.avatar{display:flex;width:32px;height:32px;border-radius:100px;justify-content:center;align-items:center;aspect-ratio:1/1;border:.5px solid #f5f5f5;background:#fff3}.dropdown-container{position:relative;display:inline-block}.dropdown-menu{position:absolute;top:100%;right:0;z-index:10;margin-top:4px;display:inline-flex;padding:4px;flex-direction:column;justify-content:center;align-items:flex-start;gap:4px;border-radius:8px;background-color:#fff;box-shadow:0 2px 6px #00000024,0 1px 10px #0000001a}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }] }); }
21
28
  }
22
29
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DropdownUserMenuComponent, decorators: [{
23
30
  type: Component,
24
- args: [{ selector: 'ius-dropdown-user-menu', standalone: true, imports: [CommonModule], template: "<div class=\"dropdown-container\">\r\n <button [disabled]=\"disabled\" (click)=\"onClick()\" class=\"ius-btn\" [ngClass]=\"{ isOpen: isOpen }\">\r\n <img class=\"logo\" [src]=\"logo\" alt=\"lem logo\" />\r\n <span class=\"name\">{{nameUser}}</span>\r\n <img class=\"avatar\" [src]=\"avatar\" alt=\"user avatar\" />\r\n </button>\r\n\r\n @if (isOpen) {\r\n <div class=\"dropdown-menu\">\r\n <ng-content></ng-content>\r\n </div>\r\n }\r\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}.ius-btn{display:inline-flex;padding:8px 12px;align-items:center;gap:8px;border-radius:8px;background-color:#fff;color:#333;border:1px solid #eaeaea;cursor:pointer;font-family:Rubik,sans-serif;font-size:.875rem;font-weight:500;font-style:normal;line-height:20px;letter-spacing:.28px}.ius-btn:hover:not(:disabled){border:1px solid #5892FF;box-shadow:0 1px 3px #0000001f,0 1px 2px #00000014}.ius-btn:active:not(:disabled){border:1px solid #5892FF;background-color:#edf6ff}.ius-btn.isOpen{border:1px solid #eaeaea;box-shadow:0 1px 3px #0000001f,0 1px 2px #00000014;background-color:#fff}.logo{display:flex;width:32px;height:32px;border-radius:100px;justify-content:center;align-items:center;aspect-ratio:1/1;border:.5px solid #f5f5f5}.avatar{display:flex;width:32px;height:32px;border-radius:100px;justify-content:center;align-items:center;aspect-ratio:1/1;border:.5px solid #f5f5f5;background:#fff3}.dropdown-container{position:relative;display:inline-block}.dropdown-menu{position:absolute;top:100%;right:0;z-index:10;margin-top:4px;display:inline-flex;padding:4px;flex-direction:column;justify-content:center;align-items:flex-start;gap:4px;border-radius:8px;background-color:#fff;box-shadow:0 2px 6px #00000024,0 1px 10px #0000001a}\n"] }]
31
+ args: [{ selector: 'ius-dropdown-user-menu', standalone: true, imports: [CommonModule], template: "<div class=\"dropdown-container\" id=\"userMenu\">\r\n <button [disabled]=\"disabled\" (click)=\"onClick()\" class=\"ius-btn\" [ngClass]=\"{ isOpen: isOpen }\">\r\n <img class=\"logo\" [src]=\"logo\" alt=\"lem logo\" />\r\n <span class=\"name\">{{nameUser}}</span>\r\n <img class=\"avatar\" [src]=\"avatar\" alt=\"user avatar\" />\r\n </button>\r\n\r\n @if (isOpen) {\r\n <div class=\"dropdown-menu\">\r\n <ng-content></ng-content>\r\n </div>\r\n }\r\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}.ius-btn{display:inline-flex;padding:8px 12px;align-items:center;gap:8px;border-radius:8px;background-color:#fff;color:#333;border:1px solid #eaeaea;cursor:pointer;font-family:Rubik,sans-serif;font-size:.875rem;font-weight:500;font-style:normal;line-height:20px;letter-spacing:.28px}.ius-btn:hover:not(:disabled){border:1px solid #5892FF;box-shadow:0 1px 3px #0000001f,0 1px 2px #00000014}.ius-btn:active:not(:disabled){border:1px solid #5892FF;background-color:#edf6ff}.ius-btn.isOpen{border:1px solid #eaeaea;box-shadow:0 1px 3px #0000001f,0 1px 2px #00000014;background-color:#fff}.logo{display:flex;width:32px;height:32px;border-radius:100px;justify-content:center;align-items:center;aspect-ratio:1/1;border:.5px solid #f5f5f5}.avatar{display:flex;width:32px;height:32px;border-radius:100px;justify-content:center;align-items:center;aspect-ratio:1/1;border:.5px solid #f5f5f5;background:#fff3}.dropdown-container{position:relative;display:inline-block}.dropdown-menu{position:absolute;top:100%;right:0;z-index:10;margin-top:4px;display:inline-flex;padding:4px;flex-direction:column;justify-content:center;align-items:flex-start;gap:4px;border-radius:8px;background-color:#fff;box-shadow:0 2px 6px #00000024,0 1px 10px #0000001a}\n"] }]
25
32
  }], propDecorators: { isActive: [{
26
33
  type: Input
27
34
  }], nameUser: [{
@@ -34,5 +41,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
34
41
  type: Input
35
42
  }], buttonClicked: [{
36
43
  type: Output
44
+ }], onClickOutside: [{
45
+ type: HostListener,
46
+ args: ['document:click', ['$event']]
37
47
  }] } });
38
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHJvcGRvd24tdXNlci1tZW51LmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2l1cy1kZXNpZ24tY29tcG9uZW50cy9zcmMvbGliL2Ryb3Bkb3duLXVzZXItbWVudS9kcm9wZG93bi11c2VyLW1lbnUuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvaXVzLWRlc2lnbi1jb21wb25lbnRzL3NyYy9saWIvZHJvcGRvd24tdXNlci1tZW51L2Ryb3Bkb3duLXVzZXItbWVudS5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUNMLFNBQVMsRUFDVCxZQUFZLEVBQ1osS0FBSyxFQUNMLE1BQU0sR0FDUCxNQUFNLGVBQWUsQ0FBQzs7O0FBV3ZCLE1BQU0sT0FBTyx5QkFBeUI7SUFQdEM7UUFRVyxhQUFRLEdBQUcsS0FBSyxDQUFDO1FBQ2pCLGFBQVEsR0FBRyxFQUFFLENBQUM7UUFDZCxTQUFJLEdBQUcsRUFBRSxDQUFDO1FBQ1YsV0FBTSxHQUFHLEVBQUUsQ0FBQztRQUNaLGFBQVEsR0FBRyxLQUFLLENBQUM7UUFDaEIsa0JBQWEsR0FBdUIsSUFBSSxZQUFZLEVBQUUsQ0FBQztRQUVqRSxXQUFNLEdBQUcsS0FBSyxDQUFDO0tBTWhCO0lBSkMsT0FBTztRQUNMLElBQUksQ0FBQyxNQUFNLEdBQUcsQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDO1FBQzNCLElBQUksQ0FBQyxhQUFhLENBQUMsSUFBSSxFQUFFLENBQUM7SUFDNUIsQ0FBQzsrR0FiVSx5QkFBeUI7bUdBQXpCLHlCQUF5Qiw2T0NqQnRDLHdlQVlNLDhsRkRDTSxZQUFZOzs0RkFJWCx5QkFBeUI7a0JBUHJDLFNBQVM7K0JBQ0Usd0JBQXdCLGNBQ3RCLElBQUksV0FDUCxDQUFDLFlBQVksQ0FBQzs4QkFLZCxRQUFRO3NCQUFoQixLQUFLO2dCQUNHLFFBQVE7c0JBQWhCLEtBQUs7Z0JBQ0csSUFBSTtzQkFBWixLQUFLO2dCQUNHLE1BQU07c0JBQWQsS0FBSztnQkFDRyxRQUFRO3NCQUFoQixLQUFLO2dCQUNJLGFBQWE7c0JBQXRCLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xyXG5pbXBvcnQge1xyXG4gIENvbXBvbmVudCxcclxuICBFdmVudEVtaXR0ZXIsXHJcbiAgSW5wdXQsXHJcbiAgT3V0cHV0LFxyXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBJY29uTWRDb21wb25lbnQgfSBmcm9tIFwiLi4vaWNvbi1tZC9pY29uLW1kLmNvbXBvbmVudFwiO1xyXG5cclxuXHJcbkBDb21wb25lbnQoe1xyXG4gIHNlbGVjdG9yOiAnaXVzLWRyb3Bkb3duLXVzZXItbWVudScsXHJcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcclxuICBpbXBvcnRzOiBbQ29tbW9uTW9kdWxlXSxcclxuICB0ZW1wbGF0ZVVybDogJy4vZHJvcGRvd24tdXNlci1tZW51LmNvbXBvbmVudC5odG1sJyxcclxuICBzdHlsZVVybDogJy4vZHJvcGRvd24tdXNlci1tZW51LmNvbXBvbmVudC5zY3NzJ1xyXG59KVxyXG5leHBvcnQgY2xhc3MgRHJvcGRvd25Vc2VyTWVudUNvbXBvbmVudCB7XHJcbiAgQElucHV0KCkgaXNBY3RpdmUgPSBmYWxzZTtcclxuICBASW5wdXQoKSBuYW1lVXNlciA9ICcnO1xyXG4gIEBJbnB1dCgpIGxvZ28gPSAnJztcclxuICBASW5wdXQoKSBhdmF0YXIgPSAnJztcclxuICBASW5wdXQoKSBkaXNhYmxlZCA9IGZhbHNlO1xyXG4gIEBPdXRwdXQoKSBidXR0b25DbGlja2VkOiBFdmVudEVtaXR0ZXI8dm9pZD4gPSBuZXcgRXZlbnRFbWl0dGVyKCk7XHJcblxyXG4gIGlzT3BlbiA9IGZhbHNlO1xyXG5cclxuICBvbkNsaWNrKCkge1xyXG4gICAgdGhpcy5pc09wZW4gPSAhdGhpcy5pc09wZW47XHJcbiAgICB0aGlzLmJ1dHRvbkNsaWNrZWQuZW1pdCgpO1xyXG4gIH1cclxufVxyXG4iLCI8ZGl2IGNsYXNzPVwiZHJvcGRvd24tY29udGFpbmVyXCI+XHJcbiAgICA8YnV0dG9uIFtkaXNhYmxlZF09XCJkaXNhYmxlZFwiIChjbGljayk9XCJvbkNsaWNrKClcIiBjbGFzcz1cIml1cy1idG5cIiBbbmdDbGFzc109XCJ7IGlzT3BlbjogaXNPcGVuIH1cIj5cclxuICAgICAgICA8aW1nIGNsYXNzPVwibG9nb1wiIFtzcmNdPVwibG9nb1wiIGFsdD1cImxlbSBsb2dvXCIgLz5cclxuICAgICAgICA8c3BhbiBjbGFzcz1cIm5hbWVcIj57e25hbWVVc2VyfX08L3NwYW4+XHJcbiAgICAgICAgPGltZyBjbGFzcz1cImF2YXRhclwiIFtzcmNdPVwiYXZhdGFyXCIgYWx0PVwidXNlciBhdmF0YXJcIiAvPlxyXG4gICAgPC9idXR0b24+XHJcblxyXG4gIEBpZiAoaXNPcGVuKSB7XHJcbiAgICA8ZGl2IGNsYXNzPVwiZHJvcGRvd24tbWVudVwiPlxyXG4gICAgICAgIDxuZy1jb250ZW50PjwvbmctY29udGVudD5cclxuICAgIDwvZGl2PlxyXG4gICAgfVxyXG48L2Rpdj4iXX0=
48
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHJvcGRvd24tdXNlci1tZW51LmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2l1cy1kZXNpZ24tY29tcG9uZW50cy9zcmMvbGliL2Ryb3Bkb3duLXVzZXItbWVudS9kcm9wZG93bi11c2VyLW1lbnUuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvaXVzLWRlc2lnbi1jb21wb25lbnRzL3NyYy9saWIvZHJvcGRvd24tdXNlci1tZW51L2Ryb3Bkb3duLXVzZXItbWVudS5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUNMLFNBQVMsRUFDVCxZQUFZLEVBQ1osWUFBWSxFQUNaLEtBQUssRUFDTCxNQUFNLEdBQ1AsTUFBTSxlQUFlLENBQUM7OztBQVd2QixNQUFNLE9BQU8seUJBQXlCO0lBUHRDO1FBUVcsYUFBUSxHQUFHLEtBQUssQ0FBQztRQUNqQixhQUFRLEdBQUcsRUFBRSxDQUFDO1FBQ2QsU0FBSSxHQUFHLEVBQUUsQ0FBQztRQUNWLFdBQU0sR0FBRyxFQUFFLENBQUM7UUFDWixhQUFRLEdBQUcsS0FBSyxDQUFDO1FBQ2hCLGtCQUFhLEdBQXVCLElBQUksWUFBWSxFQUFFLENBQUM7UUFFakUsV0FBTSxHQUFHLEtBQUssQ0FBQztLQWVoQjtJQWJDLE9BQU87UUFDTCxJQUFJLENBQUMsTUFBTSxHQUFHLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQztRQUMzQixJQUFJLENBQUMsYUFBYSxDQUFDLElBQUksRUFBRSxDQUFDO0lBQzVCLENBQUM7SUFHRCxjQUFjLENBQUMsS0FBWTtRQUN6QixNQUFNLE1BQU0sR0FBRyxLQUFLLENBQUMsTUFBcUIsQ0FBQztRQUMzQyxNQUFNLFNBQVMsR0FBRyxRQUFRLENBQUMsY0FBYyxDQUFDLFVBQVUsQ0FBQyxDQUFDO1FBQ3RELElBQUksU0FBUyxJQUFJLENBQUMsU0FBUyxDQUFDLFFBQVEsQ0FBQyxNQUFNLENBQUMsRUFBRSxDQUFDO1lBQzdDLElBQUksQ0FBQyxNQUFNLEdBQUcsS0FBSyxDQUFDO1FBQ3RCLENBQUM7SUFDSCxDQUFDOytHQXRCVSx5QkFBeUI7bUdBQXpCLHlCQUF5QixrVENsQnRDLHdmQVlNLDhsRkRFTSxZQUFZOzs0RkFJWCx5QkFBeUI7a0JBUHJDLFNBQVM7K0JBQ0Usd0JBQXdCLGNBQ3RCLElBQUksV0FDUCxDQUFDLFlBQVksQ0FBQzs4QkFLZCxRQUFRO3NCQUFoQixLQUFLO2dCQUNHLFFBQVE7c0JBQWhCLEtBQUs7Z0JBQ0csSUFBSTtzQkFBWixLQUFLO2dCQUNHLE1BQU07c0JBQWQsS0FBSztnQkFDRyxRQUFRO3NCQUFoQixLQUFLO2dCQUNJLGFBQWE7c0JBQXRCLE1BQU07Z0JBVVAsY0FBYztzQkFEYixZQUFZO3VCQUFDLGdCQUFnQixFQUFFLENBQUMsUUFBUSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcclxuaW1wb3J0IHtcclxuICBDb21wb25lbnQsXHJcbiAgRXZlbnRFbWl0dGVyLFxyXG4gIEhvc3RMaXN0ZW5lcixcclxuICBJbnB1dCxcclxuICBPdXRwdXQsXHJcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IEljb25NZENvbXBvbmVudCB9IGZyb20gXCIuLi9pY29uLW1kL2ljb24tbWQuY29tcG9uZW50XCI7XHJcblxyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6ICdpdXMtZHJvcGRvd24tdXNlci1tZW51JyxcclxuICBzdGFuZGFsb25lOiB0cnVlLFxyXG4gIGltcG9ydHM6IFtDb21tb25Nb2R1bGVdLFxyXG4gIHRlbXBsYXRlVXJsOiAnLi9kcm9wZG93bi11c2VyLW1lbnUuY29tcG9uZW50Lmh0bWwnLFxyXG4gIHN0eWxlVXJsOiAnLi9kcm9wZG93bi11c2VyLW1lbnUuY29tcG9uZW50LnNjc3MnXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBEcm9wZG93blVzZXJNZW51Q29tcG9uZW50IHtcclxuICBASW5wdXQoKSBpc0FjdGl2ZSA9IGZhbHNlO1xyXG4gIEBJbnB1dCgpIG5hbWVVc2VyID0gJyc7XHJcbiAgQElucHV0KCkgbG9nbyA9ICcnO1xyXG4gIEBJbnB1dCgpIGF2YXRhciA9ICcnO1xyXG4gIEBJbnB1dCgpIGRpc2FibGVkID0gZmFsc2U7XHJcbiAgQE91dHB1dCgpIGJ1dHRvbkNsaWNrZWQ6IEV2ZW50RW1pdHRlcjx2b2lkPiA9IG5ldyBFdmVudEVtaXR0ZXIoKTtcclxuXHJcbiAgaXNPcGVuID0gZmFsc2U7XHJcblxyXG4gIG9uQ2xpY2soKSB7XHJcbiAgICB0aGlzLmlzT3BlbiA9ICF0aGlzLmlzT3BlbjtcclxuICAgIHRoaXMuYnV0dG9uQ2xpY2tlZC5lbWl0KCk7XHJcbiAgfVxyXG5cclxuICBASG9zdExpc3RlbmVyKCdkb2N1bWVudDpjbGljaycsIFsnJGV2ZW50J10pXHJcbiAgb25DbGlja091dHNpZGUoZXZlbnQ6IEV2ZW50KSB7XHJcbiAgICBjb25zdCB0YXJnZXQgPSBldmVudC50YXJnZXQgYXMgSFRNTEVsZW1lbnQ7XHJcbiAgICBjb25zdCBjb250YWluZXIgPSBkb2N1bWVudC5nZXRFbGVtZW50QnlJZCgndXNlck1lbnUnKTtcclxuICAgIGlmIChjb250YWluZXIgJiYgIWNvbnRhaW5lci5jb250YWlucyh0YXJnZXQpKSB7XHJcbiAgICAgIHRoaXMuaXNPcGVuID0gZmFsc2U7XHJcbiAgICB9XHJcbiAgfVxyXG59XHJcbiIsIjxkaXYgY2xhc3M9XCJkcm9wZG93bi1jb250YWluZXJcIiBpZD1cInVzZXJNZW51XCI+XHJcbiAgICA8YnV0dG9uIFtkaXNhYmxlZF09XCJkaXNhYmxlZFwiIChjbGljayk9XCJvbkNsaWNrKClcIiBjbGFzcz1cIml1cy1idG5cIiBbbmdDbGFzc109XCJ7IGlzT3BlbjogaXNPcGVuIH1cIj5cclxuICAgICAgICA8aW1nIGNsYXNzPVwibG9nb1wiIFtzcmNdPVwibG9nb1wiIGFsdD1cImxlbSBsb2dvXCIgLz5cclxuICAgICAgICA8c3BhbiBjbGFzcz1cIm5hbWVcIj57e25hbWVVc2VyfX08L3NwYW4+XHJcbiAgICAgICAgPGltZyBjbGFzcz1cImF2YXRhclwiIFtzcmNdPVwiYXZhdGFyXCIgYWx0PVwidXNlciBhdmF0YXJcIiAvPlxyXG4gICAgPC9idXR0b24+XHJcblxyXG4gIEBpZiAoaXNPcGVuKSB7XHJcbiAgICA8ZGl2IGNsYXNzPVwiZHJvcGRvd24tbWVudVwiPlxyXG4gICAgICAgIDxuZy1jb250ZW50PjwvbmctY29udGVudD5cclxuICAgIDwvZGl2PlxyXG4gICAgfVxyXG48L2Rpdj4iXX0=
@@ -95,11 +95,11 @@ export class InputSelectComponent {
95
95
  event.preventDefault();
96
96
  }
97
97
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: InputSelectComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
98
- 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\">\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 }\" (click)=\"onFocus()\">\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)\" (drop)=\"onDropBlock($event)\" (dragover)=\"onDragOverBlock($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 <div (click)=\"closeList($event)\" style=\"height: 20px;\">\r\n <ius-icon-md iconName=\"icon-keyboard-arrow-up\" class=\"icon-arrows\"></ius-icon-md>\r\n </div>\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>", 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{cursor:default;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"] }] }); }
98
+ 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)\" (drop)=\"onDropBlock($event)\" (dragover)=\"onDragOverBlock($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 <div (click)=\"closeList($event)\" style=\"height: 20px;\">\n <ius-icon-md iconName=\"icon-keyboard-arrow-up\" class=\"icon-arrows\"></ius-icon-md>\n </div>\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{cursor:default;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"] }] }); }
99
99
  }
100
100
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: InputSelectComponent, decorators: [{
101
101
  type: Component,
102
- args: [{ selector: 'ius-input-select', standalone: true, imports: [IconMdComponent, FormsModule, CommonModule], template: "<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 }\" (click)=\"onFocus()\">\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)\" (drop)=\"onDropBlock($event)\" (dragover)=\"onDragOverBlock($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 <div (click)=\"closeList($event)\" style=\"height: 20px;\">\r\n <ius-icon-md iconName=\"icon-keyboard-arrow-up\" class=\"icon-arrows\"></ius-icon-md>\r\n </div>\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>", 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{cursor:default;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"] }]
102
+ 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)\" (drop)=\"onDropBlock($event)\" (dragover)=\"onDragOverBlock($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 <div (click)=\"closeList($event)\" style=\"height: 20px;\">\n <ius-icon-md iconName=\"icon-keyboard-arrow-up\" class=\"icon-arrows\"></ius-icon-md>\n </div>\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{cursor:default;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"] }]
103
103
  }], propDecorators: { componentId: [{
104
104
  type: Input,
105
105
  args: [{ required: true }]
@@ -127,4 +127,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
127
127
  type: HostListener,
128
128
  args: ['document:click', ['$event']]
129
129
  }] } });
130
- //# 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.closeList();\r\n    }\r\n  }\r\n\r\n  closeList(event?: Event): void {\r\n    if (event) {\r\n      event.stopImmediatePropagation();\r\n    }\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  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    if (this.disabled) {\r\n      return;\r\n    }\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  onDropBlock(event: DragEvent) {\r\n    // Evita que se dropee contenido en el input\r\n    event.preventDefault();\r\n  }\r\n\r\n  onDragOverBlock(event: DragEvent) {\r\n    // Evita que se permita arrastrar texto sobre el input\r\n    event.preventDefault();\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    }\" (click)=\"onFocus()\">\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)\" (drop)=\"onDropBlock($event)\" (dragover)=\"onDragOverBlock($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      <div (click)=\"closeList($event)\" style=\"height: 20px;\">\r\n        <ius-icon-md iconName=\"icon-keyboard-arrow-up\" class=\"icon-arrows\"></ius-icon-md>\r\n      </div>\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>"]}
130
+ //# 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.closeList();\n    }\n  }\n\n  closeList(event?: Event): void {\n    if (event) {\n      event.stopImmediatePropagation();\n    }\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  onInput(): void {\n    if (this.selected) {\n      this.selected = false;\n    }\n    this.onChangesValueEvent.emit(this.textInput);\n  }\n\n  onFocus(): void {\n    if (this.disabled) {\n      return;\n    }\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  onDropBlock(event: DragEvent) {\n    // Evita que se dropee contenido en el input\n    event.preventDefault();\n  }\n\n  onDragOverBlock(event: DragEvent) {\n    // Evita que se permita arrastrar texto sobre el input\n    event.preventDefault();\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)\" (drop)=\"onDropBlock($event)\" (dragover)=\"onDragOverBlock($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      <div (click)=\"closeList($event)\" style=\"height: 20px;\">\n        <ius-icon-md iconName=\"icon-keyboard-arrow-up\" class=\"icon-arrows\"></ius-icon-md>\n      </div>\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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoib3B0aW9uLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2l1cy1kZXNpZ24tY29tcG9uZW50cy9zcmMvbGliL29wdGlvbi9vcHRpb24uY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvaXVzLWRlc2lnbi1jb21wb25lbnRzL3NyYy9saWIvb3B0aW9uL29wdGlvbi5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLFlBQVksRUFBRSxLQUFLLEVBQUUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3ZFLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSw4QkFBOEIsQ0FBQzs7QUFTL0QsTUFBTSxPQUFPLGVBQWU7SUFQNUI7UUFTVyxhQUFRLEdBQVksS0FBSyxDQUFDO1FBQzFCLFlBQU8sR0FBWSxLQUFLLENBQUM7UUFDeEIsZ0JBQVcsR0FBRyxJQUFJLFlBQVksRUFBTyxDQUFDO0tBS2pEO0lBSEMsV0FBVztRQUNULElBQUksQ0FBQyxXQUFXLENBQUMsSUFBSSxFQUFFLENBQUM7SUFDMUIsQ0FBQzsrR0FSVSxlQUFlO21HQUFmLGVBQWUscUtDVjVCLG1TQU9TLHlnRURERyxlQUFlOzs0RkFJZCxlQUFlO2tCQVAzQixTQUFTOytCQUNFLFlBQVksY0FDVixJQUFJLFdBQ1AsQ0FBQyxlQUFlLENBQUM7OEJBTWpCLFFBQVE7c0JBQWhCLEtBQUs7Z0JBQ0csT0FBTztzQkFBZixLQUFLO2dCQUNJLFdBQVc7c0JBQXBCLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIEV2ZW50RW1pdHRlciwgSW5wdXQsIE91dHB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBJY29uU21Db21wb25lbnQgfSBmcm9tIFwiLi4vaWNvbi1zbS9pY29uLXNtLmNvbXBvbmVudFwiO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6ICdpdXMtb3B0aW9uJyxcclxuICBzdGFuZGFsb25lOiB0cnVlLFxyXG4gIGltcG9ydHM6IFtJY29uU21Db21wb25lbnRdLFxyXG4gIHRlbXBsYXRlVXJsOiAnLi9vcHRpb24uY29tcG9uZW50Lmh0bWwnLFxyXG4gIHN0eWxlVXJsOiAnLi9vcHRpb24uY29tcG9uZW50LnNjc3MnXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBPcHRpb25Db21wb25lbnQge1xyXG4gIFxyXG4gIEBJbnB1dCgpIGRpc2FibGVkOiBib29sZWFuID0gZmFsc2U7XHJcbiAgQElucHV0KCkgY2hlY2tlZDogYm9vbGVhbiA9IGZhbHNlO1xyXG4gIEBPdXRwdXQoKSBvcHRpb25DbGljayA9IG5ldyBFdmVudEVtaXR0ZXI8YW55PigpO1xyXG5cclxuICBzZWxlY2Npb25hcigpIHtcclxuICAgIHRoaXMub3B0aW9uQ2xpY2suZW1pdCgpO1xyXG4gIH1cclxufVxyXG4iLCI8YnV0dG9uIGNsYXNzPVwiaXVzLWxpc3RcIiBbZGlzYWJsZWRdPVwiZGlzYWJsZWRcIiAoY2xpY2spPVwic2VsZWNjaW9uYXIoKVwiPlxyXG4gICAgPGRpdiBjbGFzcz1cImNvbnRlbnRcIj5cclxuICAgICAgICA8bmctY29udGVudD48L25nLWNvbnRlbnQ+XHJcbiAgICA8L2Rpdj5cclxuICAgIEBpZihjaGVja2VkKXtcclxuICAgIDxpdXMtaWNvbi1zbSBpY29uTmFtZT1cImljb24tY2hlY2stY2lyY2xlXCIgY2xhc3M9XCJpY29uLWNvbG9yXCI+PC9pdXMtaWNvbi1zbT5cclxuICAgIH1cclxuPC9idXR0b24+Il19
26
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoib3B0aW9uLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2l1cy1kZXNpZ24tY29tcG9uZW50cy9zcmMvbGliL29wdGlvbi9vcHRpb24uY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvaXVzLWRlc2lnbi1jb21wb25lbnRzL3NyYy9saWIvb3B0aW9uL29wdGlvbi5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLFlBQVksRUFBRSxLQUFLLEVBQUUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3ZFLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSw4QkFBOEIsQ0FBQzs7QUFTL0QsTUFBTSxPQUFPLGVBQWU7SUFQNUI7UUFTVyxhQUFRLEdBQVksS0FBSyxDQUFDO1FBQzFCLFlBQU8sR0FBWSxLQUFLLENBQUM7UUFDeEIsZ0JBQVcsR0FBRyxJQUFJLFlBQVksRUFBTyxDQUFDO0tBS2pEO0lBSEMsV0FBVztRQUNULElBQUksQ0FBQyxXQUFXLENBQUMsSUFBSSxFQUFFLENBQUM7SUFDMUIsQ0FBQzsrR0FSVSxlQUFlO21HQUFmLGVBQWUscUtDVjVCLG1TQU9TLHlnRURERyxlQUFlOzs0RkFJZCxlQUFlO2tCQVAzQixTQUFTOytCQUNFLFlBQVksY0FDVixJQUFJLFdBQ1AsQ0FBQyxlQUFlLENBQUM7OEJBTWpCLFFBQVE7c0JBQWhCLEtBQUs7Z0JBQ0csT0FBTztzQkFBZixLQUFLO2dCQUNJLFdBQVc7c0JBQXBCLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIEV2ZW50RW1pdHRlciwgSW5wdXQsIE91dHB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgSWNvblNtQ29tcG9uZW50IH0gZnJvbSBcIi4uL2ljb24tc20vaWNvbi1zbS5jb21wb25lbnRcIjtcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnaXVzLW9wdGlvbicsXG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIGltcG9ydHM6IFtJY29uU21Db21wb25lbnRdLFxuICB0ZW1wbGF0ZVVybDogJy4vb3B0aW9uLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmw6ICcuL29wdGlvbi5jb21wb25lbnQuc2Nzcydcbn0pXG5leHBvcnQgY2xhc3MgT3B0aW9uQ29tcG9uZW50IHtcbiAgXG4gIEBJbnB1dCgpIGRpc2FibGVkOiBib29sZWFuID0gZmFsc2U7XG4gIEBJbnB1dCgpIGNoZWNrZWQ6IGJvb2xlYW4gPSBmYWxzZTtcbiAgQE91dHB1dCgpIG9wdGlvbkNsaWNrID0gbmV3IEV2ZW50RW1pdHRlcjxhbnk+KCk7XG5cbiAgc2VsZWNjaW9uYXIoKSB7XG4gICAgdGhpcy5vcHRpb25DbGljay5lbWl0KCk7XG4gIH1cbn1cbiIsIjxidXR0b24gY2xhc3M9XCJpdXMtbGlzdFwiIFtkaXNhYmxlZF09XCJkaXNhYmxlZFwiIChjbGljayk9XCJzZWxlY2Npb25hcigpXCI+XHJcbiAgICA8ZGl2IGNsYXNzPVwiY29udGVudFwiPlxyXG4gICAgICAgIDxuZy1jb250ZW50PjwvbmctY29udGVudD5cclxuICAgIDwvZGl2PlxyXG4gICAgQGlmKGNoZWNrZWQpe1xyXG4gICAgPGl1cy1pY29uLXNtIGljb25OYW1lPVwiaWNvbi1jaGVjay1jaXJjbGVcIiBjbGFzcz1cImljb24tY29sb3JcIj48L2l1cy1pY29uLXNtPlxyXG4gICAgfVxyXG48L2J1dHRvbj4iXX0=