valtech-components 2.0.598 → 2.0.600

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.
@@ -5,6 +5,7 @@ import { IonButton, IonSpinner, IonTextarea, } from '@ionic/angular/standalone';
5
5
  import { FeedbackService } from '../../../services/feedback/feedback.service';
6
6
  import { ToastService } from '../../../services/toast.service';
7
7
  import { I18nService } from '../../../services/i18n';
8
+ import { AuthService } from '../../../services/auth/auth.service';
8
9
  import * as i0 from "@angular/core";
9
10
  /**
10
11
  * Componente para reacciones de contenido con emojis.
@@ -25,6 +26,7 @@ export class ContentReactionComponent {
25
26
  this.feedbackService = inject(FeedbackService);
26
27
  this.toast = inject(ToastService);
27
28
  this.i18n = inject(I18nService);
29
+ this.auth = inject(AuthService, { optional: true });
28
30
  this.props = {};
29
31
  this.reactionSubmit = new EventEmitter();
30
32
  this.reactionChange = new EventEmitter();
@@ -128,12 +130,22 @@ export class ContentReactionComponent {
128
130
  return;
129
131
  this.state.update((s) => ({ ...s, isLoading: true, error: null }));
130
132
  try {
131
- await this.feedbackService.createReaction(props.entityRef, currentState.selectedValue, currentState.comment || undefined);
133
+ // Determinar si usar endpoint anónimo o autenticado
134
+ const isAuthenticated = this.auth?.isAuthenticated() ?? false;
135
+ const useAnonymous = this.props.allowAnonymous && !isAuthenticated;
136
+ if (useAnonymous) {
137
+ // Usar endpoint anónimo (público)
138
+ await this.feedbackService.createAnonymousReaction(props.entityRef, currentState.selectedValue, currentState.comment || undefined);
139
+ }
140
+ else {
141
+ // Usar endpoint autenticado
142
+ await this.feedbackService.createReaction(props.entityRef, currentState.selectedValue, currentState.comment || undefined);
143
+ }
132
144
  this.state.update((s) => ({
133
145
  ...s,
134
146
  isLoading: false,
135
147
  isSubmitted: true,
136
- hadPreviousReaction: true,
148
+ hadPreviousReaction: !useAnonymous, // Solo para autenticados
137
149
  }));
138
150
  this.reactionSubmit.emit({
139
151
  value: currentState.selectedValue,
@@ -203,4 +215,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
203
215
  }], reactionChange: [{
204
216
  type: Output
205
217
  }] } });
206
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"content-reaction.component.js","sourceRoot":"","sources":["../../../../../../../src/lib/components/molecules/content-reaction/content-reaction.component.ts","../../../../../../../src/lib/components/molecules/content-reaction/content-reaction.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  inject,\n  Input,\n  Output,\n  EventEmitter,\n  OnInit,\n  OnChanges,\n  SimpleChanges,\n  signal,\n  computed,\n} from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { FormsModule } from '@angular/forms';\nimport {\n  IonButton,\n  IonSpinner,\n  IonTextarea,\n} from '@ionic/angular/standalone';\nimport { FeedbackService } from '../../../services/feedback/feedback.service';\nimport { ReactionValue } from '../../../services/feedback/types';\nimport { ToastService } from '../../../services/toast.service';\nimport { I18nService } from '../../../services/i18n';\nimport {\n  ContentReactionMetadata,\n  ContentReactionState,\n  ReactionSubmitEvent,\n  ReactionChangeEvent,\n} from './types';\n\n/**\n * Componente para reacciones de contenido con emojis.\n *\n * @example\n * ```html\n * <val-content-reaction\n *   [props]=\"{\n *     entityRef: { entityType: 'article', entityId: 'art-123' },\n *     question: '¿Te fue útil este artículo?'\n *   }\"\n *   (reactionSubmit)=\"onReactionSubmit($event)\"\n * />\n * ```\n */\n@Component({\n  selector: 'val-content-reaction',\n  standalone: true,\n  imports: [CommonModule, FormsModule, IonButton, IonSpinner, IonTextarea],\n  templateUrl: './content-reaction.component.html',\n  styleUrls: ['./content-reaction.component.scss'],\n})\nexport class ContentReactionComponent implements OnInit, OnChanges {\n  private feedbackService = inject(FeedbackService);\n  private toast = inject(ToastService);\n  private i18n = inject(I18nService);\n\n  @Input() props: Partial<ContentReactionMetadata> = {};\n  @Output() reactionSubmit = new EventEmitter<ReactionSubmitEvent>();\n  @Output() reactionChange = new EventEmitter<ReactionChangeEvent>();\n\n  // Estado reactivo\n  state = signal<ContentReactionState>({\n    selectedValue: null,\n    comment: '',\n    isLoading: false,\n    isSubmitted: false,\n    hadPreviousReaction: false,\n    error: null,\n  });\n\n  // Valores por defecto\n  readonly defaultEmojis: [string, string, string] = ['😞', '😐', '😊'];\n  readonly defaultLabels: [string, string, string] = [\n    'No me ayudó',\n    'Regular',\n    'Muy útil',\n  ];\n  readonly reactionValues: ReactionValue[] = ['negative', 'neutral', 'positive'];\n\n  // Computed properties\n  resolvedProps = computed(() => ({\n    entityRef: this.props.entityRef!,\n    question: this.props.question || this.t('question'),\n    showComment: this.props.showComment ?? true,\n    commentPlaceholder: this.props.commentPlaceholder || this.t('commentPlaceholder'),\n    maxCommentLength: this.props.maxCommentLength ?? 500,\n    emojis: this.props.emojis || this.defaultEmojis,\n    emojiLabels: this.props.emojiLabels || this.defaultLabels,\n    showThankYou: this.props.showThankYou ?? true,\n    thankYouMessage: this.props.thankYouMessage || this.t('thankYou'),\n    disabled: this.props.disabled ?? false,\n    readonly: this.props.readonly ?? false,\n  }));\n\n  showCommentField = computed(\n    () =>\n      this.state().selectedValue !== null && this.resolvedProps().showComment\n  );\n\n  canSubmit = computed(\n    () => this.state().selectedValue !== null && !this.state().isLoading\n  );\n\n  ngOnInit() {\n    this.loadPreviousReaction();\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (changes['props'] && !changes['props'].firstChange) {\n      this.loadPreviousReaction();\n    }\n  }\n\n  private async loadPreviousReaction(): Promise<void> {\n    if (!this.props.entityRef) return;\n\n    // Si hay initialValue, usarlo directamente sin consultar\n    if (this.props.initialValue) {\n      this.state.update((s) => ({\n        ...s,\n        selectedValue: this.props.initialValue!,\n        hadPreviousReaction: true,\n        isLoading: false,\n        isSubmitted: true,\n      }));\n      return;\n    }\n\n    // Si skipInitialCheck está activo, no consultar\n    if (this.props.skipInitialCheck) {\n      return;\n    }\n\n    this.state.update((s) => ({ ...s, isLoading: true, error: null }));\n\n    try {\n      const check = await this.feedbackService.checkFeedback(\n        this.props.entityRef.entityType,\n        this.props.entityRef.entityId\n      );\n\n      if (check.hasFeedback && check.reactionValue) {\n        this.state.update((s) => ({\n          ...s,\n          selectedValue: check.reactionValue!,\n          hadPreviousReaction: true,\n          isLoading: false,\n          isSubmitted: true,\n        }));\n      } else {\n        this.state.update((s) => ({ ...s, isLoading: false }));\n      }\n    } catch (error) {\n      console.error('Error loading previous reaction:', error);\n      this.state.update((s) => ({ ...s, isLoading: false }));\n    }\n  }\n\n  selectReaction(value: ReactionValue): void {\n    if (this.resolvedProps().disabled || this.resolvedProps().readonly) return;\n\n    const previousValue = this.state().selectedValue;\n\n    this.state.update((s) => ({\n      ...s,\n      selectedValue: value,\n      isSubmitted: false,\n      error: null,\n    }));\n\n    this.reactionChange.emit({ value, previousValue });\n  }\n\n  async submitReaction(): Promise<void> {\n    const currentState = this.state();\n    const props = this.resolvedProps();\n\n    if (!currentState.selectedValue || props.disabled) return;\n\n    this.state.update((s) => ({ ...s, isLoading: true, error: null }));\n\n    try {\n      await this.feedbackService.createReaction(\n        props.entityRef,\n        currentState.selectedValue,\n        currentState.comment || undefined\n      );\n\n      this.state.update((s) => ({\n        ...s,\n        isLoading: false,\n        isSubmitted: true,\n        hadPreviousReaction: true,\n      }));\n\n      this.reactionSubmit.emit({\n        value: currentState.selectedValue,\n        comment: currentState.comment || undefined,\n        entityRef: props.entityRef,\n        isUpdate: currentState.hadPreviousReaction,\n      });\n\n      if (props.showThankYou) {\n        this.toast.show({\n          message: props.thankYouMessage,\n          duration: 2000,\n          position: 'bottom',\n          color: 'success',\n        });\n      }\n    } catch (error) {\n      console.error('Error submitting reaction:', error);\n      this.state.update((s) => ({\n        ...s,\n        isLoading: false,\n        error: this.t('errorSubmitting'),\n      }));\n\n      this.toast.show({\n        message: this.t('errorSubmitting'),\n        duration: 3000,\n        position: 'bottom',\n        color: 'danger',\n      });\n    }\n  }\n\n  updateComment(event: CustomEvent): void {\n    const value = event.detail.value || '';\n    this.state.update((s) => ({ ...s, comment: value }));\n  }\n\n  getEmoji(index: number): string {\n    return this.resolvedProps().emojis[index];\n  }\n\n  getEmojiLabel(index: number): string {\n    return this.resolvedProps().emojiLabels[index];\n  }\n\n  isSelected(value: ReactionValue): boolean {\n    return this.state().selectedValue === value;\n  }\n\n  t(key: string): string {\n    const translations: Record<string, string> = {\n      question: '¿Te resultó útil este contenido?',\n      commentPlaceholder: 'Cuéntanos más (opcional)...',\n      submit: 'Enviar opinión',\n      update: 'Actualizar opinión',\n      thankYou: '¡Gracias por tu opinión!',\n      submitted: 'Tu opinión ha sido registrada',\n      errorSubmitting: 'Error al enviar. Intenta de nuevo.',\n    };\n    return this.i18n.t(key, 'ContentReaction') || translations[key] || key;\n  }\n}\n","<div\n  class=\"content-reaction\"\n  [class.disabled]=\"resolvedProps().disabled\"\n  [class.readonly]=\"resolvedProps().readonly\"\n>\n  <!-- Loading inicial -->\n  @if (state().isLoading && !state().selectedValue) {\n    <div class=\"loading-container\">\n      <ion-spinner name=\"crescent\"></ion-spinner>\n    </div>\n  } @else {\n    <!-- Pregunta -->\n    <p class=\"question\">{{ resolvedProps().question }}</p>\n\n    <!-- Emojis -->\n    <div class=\"emoji-container\">\n      @for (value of reactionValues; track value; let i = $index) {\n        <button\n          type=\"button\"\n          class=\"emoji-button\"\n          [class.selected]=\"isSelected(value)\"\n          [class.negative]=\"value === 'negative' && isSelected(value)\"\n          [class.neutral]=\"value === 'neutral' && isSelected(value)\"\n          [class.positive]=\"value === 'positive' && isSelected(value)\"\n          [attr.aria-label]=\"getEmojiLabel(i)\"\n          [attr.aria-pressed]=\"isSelected(value)\"\n          [disabled]=\"resolvedProps().disabled || resolvedProps().readonly\"\n          (click)=\"selectReaction(value)\"\n        >\n          <span class=\"emoji\">{{ getEmoji(i) }}</span>\n        </button>\n      }\n    </div>\n\n    <!-- Campo de comentario (solo si hay selección) -->\n    @if (showCommentField()) {\n      <div class=\"comment-section\">\n        <ion-textarea\n          [value]=\"state().comment\"\n          [placeholder]=\"resolvedProps().commentPlaceholder\"\n          [maxlength]=\"resolvedProps().maxCommentLength\"\n          [disabled]=\"resolvedProps().disabled\"\n          [rows]=\"3\"\n          class=\"comment-textarea\"\n          (ionInput)=\"updateComment($event)\"\n        ></ion-textarea>\n        <span class=\"char-count\">\n          {{ state().comment.length }}/{{ resolvedProps().maxCommentLength }}\n        </span>\n      </div>\n    }\n\n    <!-- Botón de envío -->\n    @if (state().selectedValue && !state().isSubmitted) {\n      <ion-button\n        expand=\"block\"\n        [disabled]=\"!canSubmit()\"\n        (click)=\"submitReaction()\"\n        class=\"submit-button\"\n      >\n        @if (state().isLoading) {\n          <ion-spinner name=\"crescent\"></ion-spinner>\n        } @else {\n          {{ state().hadPreviousReaction ? t('update') : t('submit') }}\n        }\n      </ion-button>\n    }\n\n    <!-- Mensaje de confirmación -->\n    @if (state().isSubmitted) {\n      <p class=\"submitted-message\">\n        {{ t('submitted') }}\n      </p>\n    }\n\n    <!-- Error -->\n    @if (state().error) {\n      <p class=\"error-message\">{{ state().error }}</p>\n    }\n  }\n</div>\n"]}
218
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"content-reaction.component.js","sourceRoot":"","sources":["../../../../../../../src/lib/components/molecules/content-reaction/content-reaction.component.ts","../../../../../../../src/lib/components/molecules/content-reaction/content-reaction.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  inject,\n  Input,\n  Output,\n  EventEmitter,\n  OnInit,\n  OnChanges,\n  SimpleChanges,\n  signal,\n  computed,\n} from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { FormsModule } from '@angular/forms';\nimport {\n  IonButton,\n  IonSpinner,\n  IonTextarea,\n} from '@ionic/angular/standalone';\nimport { FeedbackService } from '../../../services/feedback/feedback.service';\nimport { ReactionValue } from '../../../services/feedback/types';\nimport { ToastService } from '../../../services/toast.service';\nimport { I18nService } from '../../../services/i18n';\nimport { AuthService } from '../../../services/auth/auth.service';\nimport {\n  ContentReactionMetadata,\n  ContentReactionState,\n  ReactionSubmitEvent,\n  ReactionChangeEvent,\n} from './types';\n\n/**\n * Componente para reacciones de contenido con emojis.\n *\n * @example\n * ```html\n * <val-content-reaction\n *   [props]=\"{\n *     entityRef: { entityType: 'article', entityId: 'art-123' },\n *     question: '¿Te fue útil este artículo?'\n *   }\"\n *   (reactionSubmit)=\"onReactionSubmit($event)\"\n * />\n * ```\n */\n@Component({\n  selector: 'val-content-reaction',\n  standalone: true,\n  imports: [CommonModule, FormsModule, IonButton, IonSpinner, IonTextarea],\n  templateUrl: './content-reaction.component.html',\n  styleUrls: ['./content-reaction.component.scss'],\n})\nexport class ContentReactionComponent implements OnInit, OnChanges {\n  private feedbackService = inject(FeedbackService);\n  private toast = inject(ToastService);\n  private i18n = inject(I18nService);\n  private auth = inject(AuthService, { optional: true });\n\n  @Input() props: Partial<ContentReactionMetadata> = {};\n  @Output() reactionSubmit = new EventEmitter<ReactionSubmitEvent>();\n  @Output() reactionChange = new EventEmitter<ReactionChangeEvent>();\n\n  // Estado reactivo\n  state = signal<ContentReactionState>({\n    selectedValue: null,\n    comment: '',\n    isLoading: false,\n    isSubmitted: false,\n    hadPreviousReaction: false,\n    error: null,\n  });\n\n  // Valores por defecto\n  readonly defaultEmojis: [string, string, string] = ['😞', '😐', '😊'];\n  readonly defaultLabels: [string, string, string] = [\n    'No me ayudó',\n    'Regular',\n    'Muy útil',\n  ];\n  readonly reactionValues: ReactionValue[] = ['negative', 'neutral', 'positive'];\n\n  // Computed properties\n  resolvedProps = computed(() => ({\n    entityRef: this.props.entityRef!,\n    question: this.props.question || this.t('question'),\n    showComment: this.props.showComment ?? true,\n    commentPlaceholder: this.props.commentPlaceholder || this.t('commentPlaceholder'),\n    maxCommentLength: this.props.maxCommentLength ?? 500,\n    emojis: this.props.emojis || this.defaultEmojis,\n    emojiLabels: this.props.emojiLabels || this.defaultLabels,\n    showThankYou: this.props.showThankYou ?? true,\n    thankYouMessage: this.props.thankYouMessage || this.t('thankYou'),\n    disabled: this.props.disabled ?? false,\n    readonly: this.props.readonly ?? false,\n  }));\n\n  showCommentField = computed(\n    () =>\n      this.state().selectedValue !== null && this.resolvedProps().showComment\n  );\n\n  canSubmit = computed(\n    () => this.state().selectedValue !== null && !this.state().isLoading\n  );\n\n  ngOnInit() {\n    this.loadPreviousReaction();\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (changes['props'] && !changes['props'].firstChange) {\n      this.loadPreviousReaction();\n    }\n  }\n\n  private async loadPreviousReaction(): Promise<void> {\n    if (!this.props.entityRef) return;\n\n    // Si hay initialValue, usarlo directamente sin consultar\n    if (this.props.initialValue) {\n      this.state.update((s) => ({\n        ...s,\n        selectedValue: this.props.initialValue!,\n        hadPreviousReaction: true,\n        isLoading: false,\n        isSubmitted: true,\n      }));\n      return;\n    }\n\n    // Si skipInitialCheck está activo, no consultar\n    if (this.props.skipInitialCheck) {\n      return;\n    }\n\n    this.state.update((s) => ({ ...s, isLoading: true, error: null }));\n\n    try {\n      const check = await this.feedbackService.checkFeedback(\n        this.props.entityRef.entityType,\n        this.props.entityRef.entityId\n      );\n\n      if (check.hasFeedback && check.reactionValue) {\n        this.state.update((s) => ({\n          ...s,\n          selectedValue: check.reactionValue!,\n          hadPreviousReaction: true,\n          isLoading: false,\n          isSubmitted: true,\n        }));\n      } else {\n        this.state.update((s) => ({ ...s, isLoading: false }));\n      }\n    } catch (error) {\n      console.error('Error loading previous reaction:', error);\n      this.state.update((s) => ({ ...s, isLoading: false }));\n    }\n  }\n\n  selectReaction(value: ReactionValue): void {\n    if (this.resolvedProps().disabled || this.resolvedProps().readonly) return;\n\n    const previousValue = this.state().selectedValue;\n\n    this.state.update((s) => ({\n      ...s,\n      selectedValue: value,\n      isSubmitted: false,\n      error: null,\n    }));\n\n    this.reactionChange.emit({ value, previousValue });\n  }\n\n  async submitReaction(): Promise<void> {\n    const currentState = this.state();\n    const props = this.resolvedProps();\n\n    if (!currentState.selectedValue || props.disabled) return;\n\n    this.state.update((s) => ({ ...s, isLoading: true, error: null }));\n\n    try {\n      // Determinar si usar endpoint anónimo o autenticado\n      const isAuthenticated = this.auth?.isAuthenticated() ?? false;\n      const useAnonymous = this.props.allowAnonymous && !isAuthenticated;\n\n      if (useAnonymous) {\n        // Usar endpoint anónimo (público)\n        await this.feedbackService.createAnonymousReaction(\n          props.entityRef,\n          currentState.selectedValue,\n          currentState.comment || undefined\n        );\n      } else {\n        // Usar endpoint autenticado\n        await this.feedbackService.createReaction(\n          props.entityRef,\n          currentState.selectedValue,\n          currentState.comment || undefined\n        );\n      }\n\n      this.state.update((s) => ({\n        ...s,\n        isLoading: false,\n        isSubmitted: true,\n        hadPreviousReaction: !useAnonymous, // Solo para autenticados\n      }));\n\n      this.reactionSubmit.emit({\n        value: currentState.selectedValue,\n        comment: currentState.comment || undefined,\n        entityRef: props.entityRef,\n        isUpdate: currentState.hadPreviousReaction,\n      });\n\n      if (props.showThankYou) {\n        this.toast.show({\n          message: props.thankYouMessage,\n          duration: 2000,\n          position: 'bottom',\n          color: 'success',\n        });\n      }\n    } catch (error) {\n      console.error('Error submitting reaction:', error);\n      this.state.update((s) => ({\n        ...s,\n        isLoading: false,\n        error: this.t('errorSubmitting'),\n      }));\n\n      this.toast.show({\n        message: this.t('errorSubmitting'),\n        duration: 3000,\n        position: 'bottom',\n        color: 'danger',\n      });\n    }\n  }\n\n  updateComment(event: CustomEvent): void {\n    const value = event.detail.value || '';\n    this.state.update((s) => ({ ...s, comment: value }));\n  }\n\n  getEmoji(index: number): string {\n    return this.resolvedProps().emojis[index];\n  }\n\n  getEmojiLabel(index: number): string {\n    return this.resolvedProps().emojiLabels[index];\n  }\n\n  isSelected(value: ReactionValue): boolean {\n    return this.state().selectedValue === value;\n  }\n\n  t(key: string): string {\n    const translations: Record<string, string> = {\n      question: '¿Te resultó útil este contenido?',\n      commentPlaceholder: 'Cuéntanos más (opcional)...',\n      submit: 'Enviar opinión',\n      update: 'Actualizar opinión',\n      thankYou: '¡Gracias por tu opinión!',\n      submitted: 'Tu opinión ha sido registrada',\n      errorSubmitting: 'Error al enviar. Intenta de nuevo.',\n    };\n    return this.i18n.t(key, 'ContentReaction') || translations[key] || key;\n  }\n}\n","<div\n  class=\"content-reaction\"\n  [class.disabled]=\"resolvedProps().disabled\"\n  [class.readonly]=\"resolvedProps().readonly\"\n>\n  <!-- Loading inicial -->\n  @if (state().isLoading && !state().selectedValue) {\n    <div class=\"loading-container\">\n      <ion-spinner name=\"crescent\"></ion-spinner>\n    </div>\n  } @else {\n    <!-- Pregunta -->\n    <p class=\"question\">{{ resolvedProps().question }}</p>\n\n    <!-- Emojis -->\n    <div class=\"emoji-container\">\n      @for (value of reactionValues; track value; let i = $index) {\n        <button\n          type=\"button\"\n          class=\"emoji-button\"\n          [class.selected]=\"isSelected(value)\"\n          [class.negative]=\"value === 'negative' && isSelected(value)\"\n          [class.neutral]=\"value === 'neutral' && isSelected(value)\"\n          [class.positive]=\"value === 'positive' && isSelected(value)\"\n          [attr.aria-label]=\"getEmojiLabel(i)\"\n          [attr.aria-pressed]=\"isSelected(value)\"\n          [disabled]=\"resolvedProps().disabled || resolvedProps().readonly\"\n          (click)=\"selectReaction(value)\"\n        >\n          <span class=\"emoji\">{{ getEmoji(i) }}</span>\n        </button>\n      }\n    </div>\n\n    <!-- Campo de comentario (solo si hay selección) -->\n    @if (showCommentField()) {\n      <div class=\"comment-section\">\n        <ion-textarea\n          [value]=\"state().comment\"\n          [placeholder]=\"resolvedProps().commentPlaceholder\"\n          [maxlength]=\"resolvedProps().maxCommentLength\"\n          [disabled]=\"resolvedProps().disabled\"\n          [rows]=\"3\"\n          class=\"comment-textarea\"\n          (ionInput)=\"updateComment($event)\"\n        ></ion-textarea>\n        <span class=\"char-count\">\n          {{ state().comment.length }}/{{ resolvedProps().maxCommentLength }}\n        </span>\n      </div>\n    }\n\n    <!-- Botón de envío -->\n    @if (state().selectedValue && !state().isSubmitted) {\n      <ion-button\n        expand=\"block\"\n        [disabled]=\"!canSubmit()\"\n        (click)=\"submitReaction()\"\n        class=\"submit-button\"\n      >\n        @if (state().isLoading) {\n          <ion-spinner name=\"crescent\"></ion-spinner>\n        } @else {\n          {{ state().hadPreviousReaction ? t('update') : t('submit') }}\n        }\n      </ion-button>\n    }\n\n    <!-- Mensaje de confirmación -->\n    @if (state().isSubmitted) {\n      <p class=\"submitted-message\">\n        {{ t('submitted') }}\n      </p>\n    }\n\n    <!-- Error -->\n    @if (state().error) {\n      <p class=\"error-message\">{{ state().error }}</p>\n    }\n  }\n</div>\n"]}
@@ -1,2 +1,2 @@
1
1
  export {};
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9zcmMvbGliL2NvbXBvbmVudHMvbW9sZWN1bGVzL2NvbnRlbnQtcmVhY3Rpb24vdHlwZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEVudGl0eVJlZiwgUmVhY3Rpb25WYWx1ZSB9IGZyb20gJy4uLy4uLy4uL3NlcnZpY2VzL2ZlZWRiYWNrL3R5cGVzJztcblxuLyoqXG4gKiBDb25maWd1cmFjacOzbiBkZWwgY29tcG9uZW50ZSBjb250ZW50LXJlYWN0aW9uLlxuICovXG5leHBvcnQgaW50ZXJmYWNlIENvbnRlbnRSZWFjdGlvbk1ldGFkYXRhIHtcbiAgLyoqIFJlZmVyZW5jaWEgYSBsYSBlbnRpZGFkIChyZXF1ZXJpZG8pICovXG4gIGVudGl0eVJlZjogRW50aXR5UmVmO1xuXG4gIC8qKiBQcmVndW50YSBhIG1vc3RyYXIgKGRlZmF1bHQ6IFwiwr9UZSByZXN1bHTDsyDDunRpbCBlc3RlIGNvbnRlbmlkbz9cIikgKi9cbiAgcXVlc3Rpb24/OiBzdHJpbmc7XG5cbiAgLyoqIE1vc3RyYXIgY2FtcG8gZGUgY29tZW50YXJpbyAoZGVmYXVsdDogdHJ1ZSkgKi9cbiAgc2hvd0NvbW1lbnQ/OiBib29sZWFuO1xuXG4gIC8qKiBQbGFjZWhvbGRlciBkZWwgY29tZW50YXJpbyAqL1xuICBjb21tZW50UGxhY2Vob2xkZXI/OiBzdHJpbmc7XG5cbiAgLyoqIE3DoXhpbW8gZGUgY2FyYWN0ZXJlcyBkZWwgY29tZW50YXJpbyAoZGVmYXVsdDogNTAwKSAqL1xuICBtYXhDb21tZW50TGVuZ3RoPzogbnVtYmVyO1xuXG4gIC8qKiBFbW9qaXMgcGVyc29uYWxpemFkb3MgW25lZ2F0aXZlLCBuZXV0cmFsLCBwb3NpdGl2ZV0gKi9cbiAgZW1vamlzPzogW3N0cmluZywgc3RyaW5nLCBzdHJpbmddO1xuXG4gIC8qKiBMYWJlbHMgcGFyYSBlbW9qaXMgKGFjY2VzaWJpbGlkYWQpICovXG4gIGVtb2ppTGFiZWxzPzogW3N0cmluZywgc3RyaW5nLCBzdHJpbmddO1xuXG4gIC8qKiBNb3N0cmFyIHRvYXN0IGRlIGFncmFkZWNpbWllbnRvIChkZWZhdWx0OiB0cnVlKSAqL1xuICBzaG93VGhhbmtZb3U/OiBib29sZWFuO1xuXG4gIC8qKiBNZW5zYWplIGRlIGFncmFkZWNpbWllbnRvIHBlcnNvbmFsaXphZG8gKi9cbiAgdGhhbmtZb3VNZXNzYWdlPzogc3RyaW5nO1xuXG4gIC8qKiBEZXNoYWJpbGl0YXIgaW50ZXJhY2Npw7NuICovXG4gIGRpc2FibGVkPzogYm9vbGVhbjtcblxuICAvKiogTW9kbyByZWFkb25seSAoc29sbyBtb3N0cmFyIHNlbGVjY2nDs24gcHJldmlhKSAqL1xuICByZWFkb25seT86IGJvb2xlYW47XG5cbiAgLyoqXG4gICAqIFZhbG9yIGluaWNpYWwgKHBhcmEgU3Rvcnlib29rIG8gY3VhbmRvIHlhIHNlIGNvbm9jZSBlbCBlc3RhZG8pLlxuICAgKiBTaSBzZSBwcm9wb3JjaW9uYSwgbm8gc2UgY29uc3VsdGFyw6EgbGEgQVBJL0ZpcmViYXNlLlxuICAgKi9cbiAgaW5pdGlhbFZhbHVlPzogUmVhY3Rpb25WYWx1ZTtcblxuICAvKipcbiAgICogT21pdGlyIGNvbnN1bHRhIGRlIGZlZWRiYWNrIHByZXZpbyBhbCBjYXJnYXIuXG4gICAqIMOadGlsIHBhcmEgU3Rvcnlib29rIG8gY3VhbmRvIHNlIHVzYSBpbml0aWFsVmFsdWUuXG4gICAqL1xuICBza2lwSW5pdGlhbENoZWNrPzogYm9vbGVhbjtcbn1cblxuLyoqXG4gKiBFc3RhZG8gaW50ZXJubyBkZWwgY29tcG9uZW50ZS5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBDb250ZW50UmVhY3Rpb25TdGF0ZSB7XG4gIC8qKiBWYWxvciBzZWxlY2Npb25hZG8gYWN0dWFsbWVudGUgKi9cbiAgc2VsZWN0ZWRWYWx1ZTogUmVhY3Rpb25WYWx1ZSB8IG51bGw7XG5cbiAgLyoqIENvbWVudGFyaW8gZGVsIHVzdWFyaW8gKi9cbiAgY29tbWVudDogc3RyaW5nO1xuXG4gIC8qKiBJbmRpY2Egc2kgZXN0w6EgY2FyZ2FuZG8gKi9cbiAgaXNMb2FkaW5nOiBib29sZWFuO1xuXG4gIC8qKiBJbmRpY2Egc2kgeWEgZW52acOzIGxhIHJlYWNjacOzbiAqL1xuICBpc1N1Ym1pdHRlZDogYm9vbGVhbjtcblxuICAvKiogSW5kaWNhIHNpIHRlbsOtYSByZWFjY2nDs24gcHJldmlhICovXG4gIGhhZFByZXZpb3VzUmVhY3Rpb246IGJvb2xlYW47XG5cbiAgLyoqIEVycm9yIG1lc3NhZ2UgaWYgYW55ICovXG4gIGVycm9yOiBzdHJpbmcgfCBudWxsO1xufVxuXG4vKipcbiAqIEV2ZW50byBlbWl0aWRvIGFsIGVudmlhciByZWFjY2nDs24uXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgUmVhY3Rpb25TdWJtaXRFdmVudCB7XG4gIHZhbHVlOiBSZWFjdGlvblZhbHVlO1xuICBjb21tZW50Pzogc3RyaW5nO1xuICBlbnRpdHlSZWY6IEVudGl0eVJlZjtcbiAgaXNVcGRhdGU6IGJvb2xlYW47XG59XG5cbi8qKlxuICogRXZlbnRvIGVtaXRpZG8gYWwgY2FtYmlhciBzZWxlY2Npw7NuLlxuICovXG5leHBvcnQgaW50ZXJmYWNlIFJlYWN0aW9uQ2hhbmdlRXZlbnQge1xuICB2YWx1ZTogUmVhY3Rpb25WYWx1ZSB8IG51bGw7XG4gIHByZXZpb3VzVmFsdWU6IFJlYWN0aW9uVmFsdWUgfCBudWxsO1xufVxuIl19
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9zcmMvbGliL2NvbXBvbmVudHMvbW9sZWN1bGVzL2NvbnRlbnQtcmVhY3Rpb24vdHlwZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEVudGl0eVJlZiwgUmVhY3Rpb25WYWx1ZSB9IGZyb20gJy4uLy4uLy4uL3NlcnZpY2VzL2ZlZWRiYWNrL3R5cGVzJztcblxuLyoqXG4gKiBDb25maWd1cmFjacOzbiBkZWwgY29tcG9uZW50ZSBjb250ZW50LXJlYWN0aW9uLlxuICovXG5leHBvcnQgaW50ZXJmYWNlIENvbnRlbnRSZWFjdGlvbk1ldGFkYXRhIHtcbiAgLyoqIFJlZmVyZW5jaWEgYSBsYSBlbnRpZGFkIChyZXF1ZXJpZG8pICovXG4gIGVudGl0eVJlZjogRW50aXR5UmVmO1xuXG4gIC8qKiBQcmVndW50YSBhIG1vc3RyYXIgKGRlZmF1bHQ6IFwiwr9UZSByZXN1bHTDsyDDunRpbCBlc3RlIGNvbnRlbmlkbz9cIikgKi9cbiAgcXVlc3Rpb24/OiBzdHJpbmc7XG5cbiAgLyoqIE1vc3RyYXIgY2FtcG8gZGUgY29tZW50YXJpbyAoZGVmYXVsdDogdHJ1ZSkgKi9cbiAgc2hvd0NvbW1lbnQ/OiBib29sZWFuO1xuXG4gIC8qKiBQbGFjZWhvbGRlciBkZWwgY29tZW50YXJpbyAqL1xuICBjb21tZW50UGxhY2Vob2xkZXI/OiBzdHJpbmc7XG5cbiAgLyoqIE3DoXhpbW8gZGUgY2FyYWN0ZXJlcyBkZWwgY29tZW50YXJpbyAoZGVmYXVsdDogNTAwKSAqL1xuICBtYXhDb21tZW50TGVuZ3RoPzogbnVtYmVyO1xuXG4gIC8qKiBFbW9qaXMgcGVyc29uYWxpemFkb3MgW25lZ2F0aXZlLCBuZXV0cmFsLCBwb3NpdGl2ZV0gKi9cbiAgZW1vamlzPzogW3N0cmluZywgc3RyaW5nLCBzdHJpbmddO1xuXG4gIC8qKiBMYWJlbHMgcGFyYSBlbW9qaXMgKGFjY2VzaWJpbGlkYWQpICovXG4gIGVtb2ppTGFiZWxzPzogW3N0cmluZywgc3RyaW5nLCBzdHJpbmddO1xuXG4gIC8qKiBNb3N0cmFyIHRvYXN0IGRlIGFncmFkZWNpbWllbnRvIChkZWZhdWx0OiB0cnVlKSAqL1xuICBzaG93VGhhbmtZb3U/OiBib29sZWFuO1xuXG4gIC8qKiBNZW5zYWplIGRlIGFncmFkZWNpbWllbnRvIHBlcnNvbmFsaXphZG8gKi9cbiAgdGhhbmtZb3VNZXNzYWdlPzogc3RyaW5nO1xuXG4gIC8qKiBEZXNoYWJpbGl0YXIgaW50ZXJhY2Npw7NuICovXG4gIGRpc2FibGVkPzogYm9vbGVhbjtcblxuICAvKiogTW9kbyByZWFkb25seSAoc29sbyBtb3N0cmFyIHNlbGVjY2nDs24gcHJldmlhKSAqL1xuICByZWFkb25seT86IGJvb2xlYW47XG5cbiAgLyoqXG4gICAqIFZhbG9yIGluaWNpYWwgKHBhcmEgU3Rvcnlib29rIG8gY3VhbmRvIHlhIHNlIGNvbm9jZSBlbCBlc3RhZG8pLlxuICAgKiBTaSBzZSBwcm9wb3JjaW9uYSwgbm8gc2UgY29uc3VsdGFyw6EgbGEgQVBJL0ZpcmViYXNlLlxuICAgKi9cbiAgaW5pdGlhbFZhbHVlPzogUmVhY3Rpb25WYWx1ZTtcblxuICAvKipcbiAgICogT21pdGlyIGNvbnN1bHRhIGRlIGZlZWRiYWNrIHByZXZpbyBhbCBjYXJnYXIuXG4gICAqIMOadGlsIHBhcmEgU3Rvcnlib29rIG8gY3VhbmRvIHNlIHVzYSBpbml0aWFsVmFsdWUuXG4gICAqL1xuICBza2lwSW5pdGlhbENoZWNrPzogYm9vbGVhbjtcblxuICAvKipcbiAgICogUGVybWl0aXIgZmVlZGJhY2sgYW7Ds25pbW8gKHNpbiBhdXRlbnRpY2FjacOzbikuXG4gICAqIFVzYWRvIHBhcmEgYmxvZ3MsIEZBUXMgeSBjb250ZW5pZG8gcMO6YmxpY28uXG4gICAqIERlZmF1bHQ6IGZhbHNlXG4gICAqL1xuICBhbGxvd0Fub255bW91cz86IGJvb2xlYW47XG59XG5cbi8qKlxuICogRXN0YWRvIGludGVybm8gZGVsIGNvbXBvbmVudGUuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgQ29udGVudFJlYWN0aW9uU3RhdGUge1xuICAvKiogVmFsb3Igc2VsZWNjaW9uYWRvIGFjdHVhbG1lbnRlICovXG4gIHNlbGVjdGVkVmFsdWU6IFJlYWN0aW9uVmFsdWUgfCBudWxsO1xuXG4gIC8qKiBDb21lbnRhcmlvIGRlbCB1c3VhcmlvICovXG4gIGNvbW1lbnQ6IHN0cmluZztcblxuICAvKiogSW5kaWNhIHNpIGVzdMOhIGNhcmdhbmRvICovXG4gIGlzTG9hZGluZzogYm9vbGVhbjtcblxuICAvKiogSW5kaWNhIHNpIHlhIGVudmnDsyBsYSByZWFjY2nDs24gKi9cbiAgaXNTdWJtaXR0ZWQ6IGJvb2xlYW47XG5cbiAgLyoqIEluZGljYSBzaSB0ZW7DrWEgcmVhY2Npw7NuIHByZXZpYSAqL1xuICBoYWRQcmV2aW91c1JlYWN0aW9uOiBib29sZWFuO1xuXG4gIC8qKiBFcnJvciBtZXNzYWdlIGlmIGFueSAqL1xuICBlcnJvcjogc3RyaW5nIHwgbnVsbDtcbn1cblxuLyoqXG4gKiBFdmVudG8gZW1pdGlkbyBhbCBlbnZpYXIgcmVhY2Npw7NuLlxuICovXG5leHBvcnQgaW50ZXJmYWNlIFJlYWN0aW9uU3VibWl0RXZlbnQge1xuICB2YWx1ZTogUmVhY3Rpb25WYWx1ZTtcbiAgY29tbWVudD86IHN0cmluZztcbiAgZW50aXR5UmVmOiBFbnRpdHlSZWY7XG4gIGlzVXBkYXRlOiBib29sZWFuO1xufVxuXG4vKipcbiAqIEV2ZW50byBlbWl0aWRvIGFsIGNhbWJpYXIgc2VsZWNjacOzbi5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBSZWFjdGlvbkNoYW5nZUV2ZW50IHtcbiAgdmFsdWU6IFJlYWN0aW9uVmFsdWUgfCBudWxsO1xuICBwcmV2aW91c1ZhbHVlOiBSZWFjdGlvblZhbHVlIHwgbnVsbDtcbn1cbiJdfQ==
@@ -128,7 +128,7 @@ export class DocsApiTableComponent {
128
128
  <p class="docs-api-table__empty">No items to display.</p>
129
129
  }
130
130
  </div>
131
- `, isInline: true, styles: [".docs-api-table{--table-bg: var(--ion-background-color, #fff);--table-border: var(--ion-border-color, #e0e0e0);--table-header-bg: #f8f9fa;--table-row-hover: rgba(0, 0, 0, .02);--table-text: var(--ion-text-color, #1a1a1a);--table-text-secondary: #5b6570;--code-bg: #f1f3f5;--code-text: #0d6efd;--type-bg: #e9ecef;--type-text: #495057;margin:1.5rem 0;font-family:var(--ion-font-family, system-ui, -apple-system, sans-serif)}.docs-api-table__title{font-size:1.25rem;font-weight:700;margin:0 0 1rem;color:var(--table-text)}.docs-api-table__wrapper{overflow-x:auto;-webkit-overflow-scrolling:touch;max-width:100%}.docs-api-table__table{width:100%;min-width:620px;border-collapse:separate;border-spacing:0;font-size:.875rem;line-height:1.5;table-layout:fixed}.docs-api-table__th{text-align:left;padding:.625rem .75rem;font-weight:600;font-size:.8125rem;color:var(--table-text-secondary);background:var(--table-header-bg);border-bottom:2px solid var(--table-border);white-space:nowrap}.docs-api-table__th--name{width:120px}.docs-api-table__th--type{width:160px}.docs-api-table__th--default{width:110px}.docs-api-table__th--description{width:auto}.docs-api-table__td{padding:.625rem .75rem;border-bottom:1px solid var(--table-border);vertical-align:top;color:var(--table-text)}.docs-api-table__td--description{color:var(--table-text-secondary);line-height:1.5}.docs-api-table__row{transition:background-color .15s ease}.docs-api-table__row:hover{background:var(--table-row-hover)}.docs-api-table__row:last-child .docs-api-table__td{border-bottom:none}.docs-api-table__row--deprecated{opacity:.65}.docs-api-table__row--deprecated .docs-api-table__code{text-decoration:line-through}.docs-api-table__code{display:inline-block;font-family:SF Mono,Fira Code,Monaco,Consolas,monospace;font-size:.75rem;font-weight:500;color:var(--code-text);background:var(--code-bg);padding:.125rem .375rem;border-radius:4px;word-break:break-word}.docs-api-table__type,.docs-api-table__default{display:inline-block;font-family:SF Mono,Fira Code,Monaco,Consolas,monospace;font-size:.6875rem;font-weight:500;color:var(--type-text);background:var(--type-bg);padding:.1875rem .375rem;border-radius:4px;white-space:normal;word-break:break-word}.docs-api-table__required{color:var(--ion-color-danger, #dc3545);font-weight:700;margin-left:.25rem;font-size:1rem;vertical-align:middle}.docs-api-table__badge{display:inline-block;margin-left:.5rem;padding:.1875rem .5rem;font-size:.625rem;font-weight:600;text-transform:uppercase;letter-spacing:.025em;border-radius:4px;background:#e9ecef;color:#495057;vertical-align:middle}.docs-api-table__badge--deprecated{background:#fff3cd;color:#856404}.docs-api-table__deprecation-note{margin-top:.5rem;font-size:.75rem;font-style:italic;color:#856404}.docs-api-table__empty{padding:3rem;text-align:center;color:var(--table-text-secondary);font-style:italic}.docs-api-table--bordered .docs-api-table__wrapper{border:1px solid var(--table-border);border-radius:12px;overflow-x:auto;overflow-y:hidden;background:var(--table-bg)}.docs-api-table--bordered .docs-api-table__th:first-child{border-top-left-radius:11px}.docs-api-table--bordered .docs-api-table__th:last-child{border-top-right-radius:11px}@media (max-width: 768px){.docs-api-table__table{display:block}.docs-api-table__table thead{display:none}.docs-api-table__table tbody{display:block}.docs-api-table__row{display:block;padding:1rem;margin-bottom:.5rem;border:1px solid var(--table-border);border-radius:8px;background:var(--table-bg)}.docs-api-table__row:last-child{margin-bottom:0}.docs-api-table__row:hover{background:var(--table-row-hover)}.docs-api-table__td{display:block;padding:.375rem 0;border:none!important}.docs-api-table__td:before{content:attr(data-label);display:block;font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--table-text-secondary);margin-bottom:.25rem}.docs-api-table__td--name{padding-bottom:.5rem;margin-bottom:.5rem;border-bottom:1px solid var(--table-border)!important}.docs-api-table__td--description:before{display:none}.docs-api-table--bordered .docs-api-table__wrapper{border:none;border-radius:0;background:transparent}}:host-context(.dark) .docs-api-table,:host-context([color-scheme=dark]) .docs-api-table{--table-bg: #1e1e1e;--table-border: #3a3a3a;--table-header-bg: #252525;--table-row-hover: rgba(255, 255, 255, .03);--table-text: #f4f5f8;--table-text-secondary: #a0a0a0;--code-bg: rgba(56, 139, 253, .15);--code-text: #79b8ff;--type-bg: rgba(255, 255, 255, .08);--type-text: #c9d1d9}:host-context(.dark) .docs-api-table__badge,:host-context([color-scheme=dark]) .docs-api-table__badge{background:#ffffff14;color:#c9d1d9}:host-context(.dark) .docs-api-table__badge--deprecated,:host-context([color-scheme=dark]) .docs-api-table__badge--deprecated{background:#ffc10726;color:#ffc107}:host-context(.dark) .docs-api-table__deprecation-note,:host-context([color-scheme=dark]) .docs-api-table__deprecation-note{color:#ffc107}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }] }); }
131
+ `, isInline: true, styles: [".docs-api-table{--table-bg: var(--ion-background-color, #fff);--table-border: var(--ion-border-color, #e0e0e0);--table-header-bg: #f8f9fa;--table-row-hover: rgba(0, 0, 0, .02);--table-text: var(--ion-text-color, #1a1a1a);--table-text-secondary: #5b6570;--code-bg: #f1f3f5;--code-text: #0d6efd;--type-bg: #e9ecef;--type-text: #495057;margin:1.5rem 0;font-family:var(--ion-font-family, system-ui, -apple-system, sans-serif)}.docs-api-table__title{font-size:1.25rem;font-weight:700;margin:0 0 1rem;color:var(--table-text)}.docs-api-table__wrapper{overflow-x:auto;-webkit-overflow-scrolling:touch;max-width:100%}.docs-api-table__table{width:100%;min-width:620px;border-collapse:separate;border-spacing:0;font-size:.875rem;line-height:1.5;table-layout:fixed}.docs-api-table__th{text-align:left;padding:.625rem .75rem;font-weight:600;font-size:.8125rem;color:var(--table-text-secondary);background:var(--table-header-bg);border-bottom:2px solid var(--table-border);white-space:nowrap}.docs-api-table__th--name{width:120px}.docs-api-table__th--type{width:160px}.docs-api-table__th--default{width:110px}.docs-api-table__th--description{width:auto}.docs-api-table__td{padding:.625rem .75rem;border-bottom:1px solid var(--table-border);vertical-align:top;color:var(--table-text)}.docs-api-table__td--description{color:var(--table-text-secondary);line-height:1.5}.docs-api-table__row{transition:background-color .15s ease}.docs-api-table__row:hover{background:var(--table-row-hover)}.docs-api-table__row:last-child .docs-api-table__td{border-bottom:none}.docs-api-table__row--deprecated{opacity:.65}.docs-api-table__row--deprecated .docs-api-table__code{text-decoration:line-through}.docs-api-table__code{display:inline-block;font-family:SF Mono,Fira Code,Monaco,Consolas,monospace;font-size:.75rem;font-weight:500;color:var(--code-text);background:var(--code-bg);padding:.125rem .375rem;border-radius:4px;word-break:break-word}.docs-api-table__type,.docs-api-table__default{display:inline-block;font-family:SF Mono,Fira Code,Monaco,Consolas,monospace;font-size:.6875rem;font-weight:500;color:var(--type-text);background:var(--type-bg);padding:.1875rem .375rem;border-radius:4px;white-space:normal;word-break:break-word}.docs-api-table__required{color:var(--ion-color-danger, #dc3545);font-weight:700;margin-left:.25rem;font-size:1rem;vertical-align:middle}.docs-api-table__badge{display:inline-block;margin-left:.5rem;padding:.1875rem .5rem;font-size:.625rem;font-weight:600;text-transform:uppercase;letter-spacing:.025em;border-radius:4px;background:#e9ecef;color:#495057;vertical-align:middle}.docs-api-table__badge--deprecated{background:#fff3cd;color:#856404}.docs-api-table__deprecation-note{margin-top:.5rem;font-size:.75rem;font-style:italic;color:#856404}.docs-api-table__empty{padding:3rem;text-align:center;color:var(--table-text-secondary);font-style:italic}.docs-api-table--bordered .docs-api-table__wrapper{border:1px solid var(--table-border);border-radius:12px;overflow-x:auto;overflow-y:hidden;background:var(--table-bg)}.docs-api-table--bordered .docs-api-table__th:first-child{border-top-left-radius:11px}.docs-api-table--bordered .docs-api-table__th:last-child{border-top-right-radius:11px}@media (max-width: 768px){.docs-api-table__wrapper{overflow-x:visible}.docs-api-table__table{display:block;min-width:0;width:100%}.docs-api-table__table thead{display:none}.docs-api-table__table tbody{display:block}.docs-api-table__row{display:block;padding:1rem;margin-bottom:.5rem;border:1px solid var(--table-border);border-radius:8px;background:var(--table-bg)}.docs-api-table__row:last-child{margin-bottom:0}.docs-api-table__row:hover{background:var(--table-row-hover)}.docs-api-table__td{display:block;padding:.375rem 0;border:none!important;width:100%}.docs-api-table__td:before{content:attr(data-label);display:block;font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--table-text-secondary);margin-bottom:.25rem}.docs-api-table__td--name{padding-bottom:.5rem;margin-bottom:.5rem;border-bottom:1px solid var(--table-border)!important}.docs-api-table__td--description:before{display:none}.docs-api-table--bordered .docs-api-table__wrapper{border:none;border-radius:0;background:transparent;overflow-x:visible}}:host-context(.dark) .docs-api-table,:host-context([color-scheme=dark]) .docs-api-table{--table-bg: #1e1e1e;--table-border: #3a3a3a;--table-header-bg: #252525;--table-row-hover: rgba(255, 255, 255, .03);--table-text: #f4f5f8;--table-text-secondary: #a0a0a0;--code-bg: rgba(56, 139, 253, .15);--code-text: #79b8ff;--type-bg: rgba(255, 255, 255, .08);--type-text: #c9d1d9}:host-context(.dark) .docs-api-table__badge,:host-context([color-scheme=dark]) .docs-api-table__badge{background:#ffffff14;color:#c9d1d9}:host-context(.dark) .docs-api-table__badge--deprecated,:host-context([color-scheme=dark]) .docs-api-table__badge--deprecated{background:#ffc10726;color:#ffc107}:host-context(.dark) .docs-api-table__deprecation-note,:host-context([color-scheme=dark]) .docs-api-table__deprecation-note{color:#ffc107}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }] }); }
132
132
  }
133
133
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: DocsApiTableComponent, decorators: [{
134
134
  type: Component,
@@ -215,8 +215,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
215
215
  <p class="docs-api-table__empty">No items to display.</p>
216
216
  }
217
217
  </div>
218
- `, styles: [".docs-api-table{--table-bg: var(--ion-background-color, #fff);--table-border: var(--ion-border-color, #e0e0e0);--table-header-bg: #f8f9fa;--table-row-hover: rgba(0, 0, 0, .02);--table-text: var(--ion-text-color, #1a1a1a);--table-text-secondary: #5b6570;--code-bg: #f1f3f5;--code-text: #0d6efd;--type-bg: #e9ecef;--type-text: #495057;margin:1.5rem 0;font-family:var(--ion-font-family, system-ui, -apple-system, sans-serif)}.docs-api-table__title{font-size:1.25rem;font-weight:700;margin:0 0 1rem;color:var(--table-text)}.docs-api-table__wrapper{overflow-x:auto;-webkit-overflow-scrolling:touch;max-width:100%}.docs-api-table__table{width:100%;min-width:620px;border-collapse:separate;border-spacing:0;font-size:.875rem;line-height:1.5;table-layout:fixed}.docs-api-table__th{text-align:left;padding:.625rem .75rem;font-weight:600;font-size:.8125rem;color:var(--table-text-secondary);background:var(--table-header-bg);border-bottom:2px solid var(--table-border);white-space:nowrap}.docs-api-table__th--name{width:120px}.docs-api-table__th--type{width:160px}.docs-api-table__th--default{width:110px}.docs-api-table__th--description{width:auto}.docs-api-table__td{padding:.625rem .75rem;border-bottom:1px solid var(--table-border);vertical-align:top;color:var(--table-text)}.docs-api-table__td--description{color:var(--table-text-secondary);line-height:1.5}.docs-api-table__row{transition:background-color .15s ease}.docs-api-table__row:hover{background:var(--table-row-hover)}.docs-api-table__row:last-child .docs-api-table__td{border-bottom:none}.docs-api-table__row--deprecated{opacity:.65}.docs-api-table__row--deprecated .docs-api-table__code{text-decoration:line-through}.docs-api-table__code{display:inline-block;font-family:SF Mono,Fira Code,Monaco,Consolas,monospace;font-size:.75rem;font-weight:500;color:var(--code-text);background:var(--code-bg);padding:.125rem .375rem;border-radius:4px;word-break:break-word}.docs-api-table__type,.docs-api-table__default{display:inline-block;font-family:SF Mono,Fira Code,Monaco,Consolas,monospace;font-size:.6875rem;font-weight:500;color:var(--type-text);background:var(--type-bg);padding:.1875rem .375rem;border-radius:4px;white-space:normal;word-break:break-word}.docs-api-table__required{color:var(--ion-color-danger, #dc3545);font-weight:700;margin-left:.25rem;font-size:1rem;vertical-align:middle}.docs-api-table__badge{display:inline-block;margin-left:.5rem;padding:.1875rem .5rem;font-size:.625rem;font-weight:600;text-transform:uppercase;letter-spacing:.025em;border-radius:4px;background:#e9ecef;color:#495057;vertical-align:middle}.docs-api-table__badge--deprecated{background:#fff3cd;color:#856404}.docs-api-table__deprecation-note{margin-top:.5rem;font-size:.75rem;font-style:italic;color:#856404}.docs-api-table__empty{padding:3rem;text-align:center;color:var(--table-text-secondary);font-style:italic}.docs-api-table--bordered .docs-api-table__wrapper{border:1px solid var(--table-border);border-radius:12px;overflow-x:auto;overflow-y:hidden;background:var(--table-bg)}.docs-api-table--bordered .docs-api-table__th:first-child{border-top-left-radius:11px}.docs-api-table--bordered .docs-api-table__th:last-child{border-top-right-radius:11px}@media (max-width: 768px){.docs-api-table__table{display:block}.docs-api-table__table thead{display:none}.docs-api-table__table tbody{display:block}.docs-api-table__row{display:block;padding:1rem;margin-bottom:.5rem;border:1px solid var(--table-border);border-radius:8px;background:var(--table-bg)}.docs-api-table__row:last-child{margin-bottom:0}.docs-api-table__row:hover{background:var(--table-row-hover)}.docs-api-table__td{display:block;padding:.375rem 0;border:none!important}.docs-api-table__td:before{content:attr(data-label);display:block;font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--table-text-secondary);margin-bottom:.25rem}.docs-api-table__td--name{padding-bottom:.5rem;margin-bottom:.5rem;border-bottom:1px solid var(--table-border)!important}.docs-api-table__td--description:before{display:none}.docs-api-table--bordered .docs-api-table__wrapper{border:none;border-radius:0;background:transparent}}:host-context(.dark) .docs-api-table,:host-context([color-scheme=dark]) .docs-api-table{--table-bg: #1e1e1e;--table-border: #3a3a3a;--table-header-bg: #252525;--table-row-hover: rgba(255, 255, 255, .03);--table-text: #f4f5f8;--table-text-secondary: #a0a0a0;--code-bg: rgba(56, 139, 253, .15);--code-text: #79b8ff;--type-bg: rgba(255, 255, 255, .08);--type-text: #c9d1d9}:host-context(.dark) .docs-api-table__badge,:host-context([color-scheme=dark]) .docs-api-table__badge{background:#ffffff14;color:#c9d1d9}:host-context(.dark) .docs-api-table__badge--deprecated,:host-context([color-scheme=dark]) .docs-api-table__badge--deprecated{background:#ffc10726;color:#ffc107}:host-context(.dark) .docs-api-table__deprecation-note,:host-context([color-scheme=dark]) .docs-api-table__deprecation-note{color:#ffc107}\n"] }]
218
+ `, styles: [".docs-api-table{--table-bg: var(--ion-background-color, #fff);--table-border: var(--ion-border-color, #e0e0e0);--table-header-bg: #f8f9fa;--table-row-hover: rgba(0, 0, 0, .02);--table-text: var(--ion-text-color, #1a1a1a);--table-text-secondary: #5b6570;--code-bg: #f1f3f5;--code-text: #0d6efd;--type-bg: #e9ecef;--type-text: #495057;margin:1.5rem 0;font-family:var(--ion-font-family, system-ui, -apple-system, sans-serif)}.docs-api-table__title{font-size:1.25rem;font-weight:700;margin:0 0 1rem;color:var(--table-text)}.docs-api-table__wrapper{overflow-x:auto;-webkit-overflow-scrolling:touch;max-width:100%}.docs-api-table__table{width:100%;min-width:620px;border-collapse:separate;border-spacing:0;font-size:.875rem;line-height:1.5;table-layout:fixed}.docs-api-table__th{text-align:left;padding:.625rem .75rem;font-weight:600;font-size:.8125rem;color:var(--table-text-secondary);background:var(--table-header-bg);border-bottom:2px solid var(--table-border);white-space:nowrap}.docs-api-table__th--name{width:120px}.docs-api-table__th--type{width:160px}.docs-api-table__th--default{width:110px}.docs-api-table__th--description{width:auto}.docs-api-table__td{padding:.625rem .75rem;border-bottom:1px solid var(--table-border);vertical-align:top;color:var(--table-text)}.docs-api-table__td--description{color:var(--table-text-secondary);line-height:1.5}.docs-api-table__row{transition:background-color .15s ease}.docs-api-table__row:hover{background:var(--table-row-hover)}.docs-api-table__row:last-child .docs-api-table__td{border-bottom:none}.docs-api-table__row--deprecated{opacity:.65}.docs-api-table__row--deprecated .docs-api-table__code{text-decoration:line-through}.docs-api-table__code{display:inline-block;font-family:SF Mono,Fira Code,Monaco,Consolas,monospace;font-size:.75rem;font-weight:500;color:var(--code-text);background:var(--code-bg);padding:.125rem .375rem;border-radius:4px;word-break:break-word}.docs-api-table__type,.docs-api-table__default{display:inline-block;font-family:SF Mono,Fira Code,Monaco,Consolas,monospace;font-size:.6875rem;font-weight:500;color:var(--type-text);background:var(--type-bg);padding:.1875rem .375rem;border-radius:4px;white-space:normal;word-break:break-word}.docs-api-table__required{color:var(--ion-color-danger, #dc3545);font-weight:700;margin-left:.25rem;font-size:1rem;vertical-align:middle}.docs-api-table__badge{display:inline-block;margin-left:.5rem;padding:.1875rem .5rem;font-size:.625rem;font-weight:600;text-transform:uppercase;letter-spacing:.025em;border-radius:4px;background:#e9ecef;color:#495057;vertical-align:middle}.docs-api-table__badge--deprecated{background:#fff3cd;color:#856404}.docs-api-table__deprecation-note{margin-top:.5rem;font-size:.75rem;font-style:italic;color:#856404}.docs-api-table__empty{padding:3rem;text-align:center;color:var(--table-text-secondary);font-style:italic}.docs-api-table--bordered .docs-api-table__wrapper{border:1px solid var(--table-border);border-radius:12px;overflow-x:auto;overflow-y:hidden;background:var(--table-bg)}.docs-api-table--bordered .docs-api-table__th:first-child{border-top-left-radius:11px}.docs-api-table--bordered .docs-api-table__th:last-child{border-top-right-radius:11px}@media (max-width: 768px){.docs-api-table__wrapper{overflow-x:visible}.docs-api-table__table{display:block;min-width:0;width:100%}.docs-api-table__table thead{display:none}.docs-api-table__table tbody{display:block}.docs-api-table__row{display:block;padding:1rem;margin-bottom:.5rem;border:1px solid var(--table-border);border-radius:8px;background:var(--table-bg)}.docs-api-table__row:last-child{margin-bottom:0}.docs-api-table__row:hover{background:var(--table-row-hover)}.docs-api-table__td{display:block;padding:.375rem 0;border:none!important;width:100%}.docs-api-table__td:before{content:attr(data-label);display:block;font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--table-text-secondary);margin-bottom:.25rem}.docs-api-table__td--name{padding-bottom:.5rem;margin-bottom:.5rem;border-bottom:1px solid var(--table-border)!important}.docs-api-table__td--description:before{display:none}.docs-api-table--bordered .docs-api-table__wrapper{border:none;border-radius:0;background:transparent;overflow-x:visible}}:host-context(.dark) .docs-api-table,:host-context([color-scheme=dark]) .docs-api-table{--table-bg: #1e1e1e;--table-border: #3a3a3a;--table-header-bg: #252525;--table-row-hover: rgba(255, 255, 255, .03);--table-text: #f4f5f8;--table-text-secondary: #a0a0a0;--code-bg: rgba(56, 139, 253, .15);--code-text: #79b8ff;--type-bg: rgba(255, 255, 255, .08);--type-text: #c9d1d9}:host-context(.dark) .docs-api-table__badge,:host-context([color-scheme=dark]) .docs-api-table__badge{background:#ffffff14;color:#c9d1d9}:host-context(.dark) .docs-api-table__badge--deprecated,:host-context([color-scheme=dark]) .docs-api-table__badge--deprecated{background:#ffc10726;color:#ffc107}:host-context(.dark) .docs-api-table__deprecation-note,:host-context([color-scheme=dark]) .docs-api-table__deprecation-note{color:#ffc107}\n"] }]
219
219
  }], propDecorators: { props: [{
220
220
  type: Input
221
221
  }] } });
222
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"docs-api-table.component.js","sourceRoot":"","sources":["../../../../../../../src/lib/components/molecules/docs-api-table/docs-api-table.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,SAAS,EAAE,KAAK,EAAE,MAAM,eAAe,CAAC;AACjD,OAAO,EAAoD,uBAAuB,EAAE,MAAM,SAAS,CAAC;;AAEpG;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA8BG;AA2FH,MAAM,OAAO,qBAAqB;IA1FlC;QA2FW,UAAK,GAAyB,EAAE,KAAK,EAAE,EAAE,EAAE,CAAC;QAE5C,iBAAY,GAAG,uBAAuB,CAAC;KASjD;IAPC,IAAI,cAAc;QAChB,OAAO,IAAI,CAAC,KAAK,CAAC,OAAO,IAAI,CAAC,MAAM,EAAE,MAAM,EAAE,SAAS,EAAE,aAAa,CAAC,CAAC;IAC1E,CAAC;IAED,cAAc,CAAC,GAAkB;QAC/B,OAAO,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,CAAC;IAChC,CAAC;+GAXU,qBAAqB;mGAArB,qBAAqB,0GAtFtB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAmFT,+6JApFS,YAAY;;4FAuFX,qBAAqB;kBA1FjC,SAAS;+BACE,oBAAoB,cAClB,IAAI,WACP,CAAC,YAAY,CAAC,YACb;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAmFT;8BAIQ,KAAK;sBAAb,KAAK","sourcesContent":["import { CommonModule } from '@angular/common';\nimport { Component, Input } from '@angular/core';\nimport { DocsApiTableMetadata, DocsApiColumn, DocsApiItem, API_TABLE_COLUMN_LABELS } from './types';\n\n/**\n * val-docs-api-table\n *\n * A table component for documenting component APIs (inputs, outputs, methods).\n *\n * @example Properties table\n * ```html\n * <val-docs-api-table\n *   [props]=\"{\n *     title: 'Properties',\n *     items: [\n *       { name: 'disabled', type: 'boolean', default: 'false', description: 'Disables the button' },\n *       { name: 'color', type: 'string', default: 'primary', description: 'Button color variant' }\n *     ]\n *   }\"\n * ></val-docs-api-table>\n * ```\n *\n * @example Events table\n * ```html\n * <val-docs-api-table\n *   [props]=\"{\n *     title: 'Events',\n *     columns: ['name', 'type', 'description'],\n *     items: [\n *       { name: 'click', type: 'EventEmitter<MouseEvent>', description: 'Emitted when clicked' }\n *     ]\n *   }\"\n * ></val-docs-api-table>\n * ```\n */\n@Component({\n  selector: 'val-docs-api-table',\n  standalone: true,\n  imports: [CommonModule],\n  template: `\n    <div\n      class=\"docs-api-table\"\n      [class]=\"props.cssClass\"\n      [class.docs-api-table--bordered]=\"props.bordered !== false\"\n    >\n      @if (props.title) {\n        <h3 class=\"docs-api-table__title\">{{ props.title }}</h3>\n      }\n\n      <div class=\"docs-api-table__wrapper\">\n        <table class=\"docs-api-table__table\">\n          <thead>\n            <tr>\n              @for (col of displayColumns; track col) {\n                <th\n                  scope=\"col\"\n                  class=\"docs-api-table__th\"\n                  [class.docs-api-table__th--name]=\"col === 'name'\"\n                  [class.docs-api-table__th--type]=\"col === 'type'\"\n                  [class.docs-api-table__th--default]=\"col === 'default'\"\n                  [class.docs-api-table__th--description]=\"col === 'description'\"\n                >\n                  {{ getColumnLabel(col) }}\n                </th>\n              }\n            </tr>\n          </thead>\n          <tbody>\n            @for (item of props.items; track item.name) {\n              <tr\n                class=\"docs-api-table__row\"\n                [class.docs-api-table__row--deprecated]=\"item.deprecated\"\n              >\n                @for (col of displayColumns; track col) {\n                  <td\n                    class=\"docs-api-table__td\"\n                    [class.docs-api-table__td--name]=\"col === 'name'\"\n                    [class.docs-api-table__td--type]=\"col === 'type'\"\n                    [class.docs-api-table__td--default]=\"col === 'default'\"\n                    [class.docs-api-table__td--description]=\"col === 'description'\"\n                    [attr.data-label]=\"getColumnLabel(col)\"\n                  >\n                    @switch (col) {\n                      @case ('name') {\n                        <code class=\"docs-api-table__code\">{{ item.name }}</code>\n                        @if (item.required) {\n                          <span class=\"docs-api-table__required\" aria-label=\"Required\" title=\"Required\">*</span>\n                        }\n                        @if (item.deprecated) {\n                          <span class=\"docs-api-table__badge docs-api-table__badge--deprecated\" aria-label=\"This property is deprecated\">Deprecated</span>\n                        }\n                      }\n                      @case ('type') {\n                        <code class=\"docs-api-table__type\">{{ item.type || '-' }}</code>\n                      }\n                      @case ('default') {\n                        <code class=\"docs-api-table__default\">{{ item.default || '-' }}</code>\n                      }\n                      @case ('description') {\n                        <span>{{ item.description || '-' }}</span>\n                        @if (item.deprecated && item.deprecationNote) {\n                          <div class=\"docs-api-table__deprecation-note\">\n                            {{ item.deprecationNote }}\n                          </div>\n                        }\n                      }\n                      @case ('required') {\n                        {{ item.required ? 'Yes' : 'No' }}\n                      }\n                    }\n                  </td>\n                }\n              </tr>\n            }\n          </tbody>\n        </table>\n      </div>\n\n      @if (props.items.length === 0) {\n        <p class=\"docs-api-table__empty\">No items to display.</p>\n      }\n    </div>\n  `,\n  styleUrls: ['./docs-api-table.component.scss'],\n})\nexport class DocsApiTableComponent {\n  @Input() props: DocsApiTableMetadata = { items: [] };\n\n  readonly columnLabels = API_TABLE_COLUMN_LABELS;\n\n  get displayColumns(): DocsApiColumn[] {\n    return this.props.columns || ['name', 'type', 'default', 'description'];\n  }\n\n  getColumnLabel(col: DocsApiColumn): string {\n    return this.columnLabels[col];\n  }\n}\n"]}
222
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"docs-api-table.component.js","sourceRoot":"","sources":["../../../../../../../src/lib/components/molecules/docs-api-table/docs-api-table.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,SAAS,EAAE,KAAK,EAAE,MAAM,eAAe,CAAC;AACjD,OAAO,EAAoD,uBAAuB,EAAE,MAAM,SAAS,CAAC;;AAEpG;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA8BG;AA2FH,MAAM,OAAO,qBAAqB;IA1FlC;QA2FW,UAAK,GAAyB,EAAE,KAAK,EAAE,EAAE,EAAE,CAAC;QAE5C,iBAAY,GAAG,uBAAuB,CAAC;KASjD;IAPC,IAAI,cAAc;QAChB,OAAO,IAAI,CAAC,KAAK,CAAC,OAAO,IAAI,CAAC,MAAM,EAAE,MAAM,EAAE,SAAS,EAAE,aAAa,CAAC,CAAC;IAC1E,CAAC;IAED,cAAc,CAAC,GAAkB;QAC/B,OAAO,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,CAAC;IAChC,CAAC;+GAXU,qBAAqB;mGAArB,qBAAqB,0GAtFtB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAmFT,ghKApFS,YAAY;;4FAuFX,qBAAqB;kBA1FjC,SAAS;+BACE,oBAAoB,cAClB,IAAI,WACP,CAAC,YAAY,CAAC,YACb;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAmFT;8BAIQ,KAAK;sBAAb,KAAK","sourcesContent":["import { CommonModule } from '@angular/common';\nimport { Component, Input } from '@angular/core';\nimport { DocsApiTableMetadata, DocsApiColumn, DocsApiItem, API_TABLE_COLUMN_LABELS } from './types';\n\n/**\n * val-docs-api-table\n *\n * A table component for documenting component APIs (inputs, outputs, methods).\n *\n * @example Properties table\n * ```html\n * <val-docs-api-table\n *   [props]=\"{\n *     title: 'Properties',\n *     items: [\n *       { name: 'disabled', type: 'boolean', default: 'false', description: 'Disables the button' },\n *       { name: 'color', type: 'string', default: 'primary', description: 'Button color variant' }\n *     ]\n *   }\"\n * ></val-docs-api-table>\n * ```\n *\n * @example Events table\n * ```html\n * <val-docs-api-table\n *   [props]=\"{\n *     title: 'Events',\n *     columns: ['name', 'type', 'description'],\n *     items: [\n *       { name: 'click', type: 'EventEmitter<MouseEvent>', description: 'Emitted when clicked' }\n *     ]\n *   }\"\n * ></val-docs-api-table>\n * ```\n */\n@Component({\n  selector: 'val-docs-api-table',\n  standalone: true,\n  imports: [CommonModule],\n  template: `\n    <div\n      class=\"docs-api-table\"\n      [class]=\"props.cssClass\"\n      [class.docs-api-table--bordered]=\"props.bordered !== false\"\n    >\n      @if (props.title) {\n        <h3 class=\"docs-api-table__title\">{{ props.title }}</h3>\n      }\n\n      <div class=\"docs-api-table__wrapper\">\n        <table class=\"docs-api-table__table\">\n          <thead>\n            <tr>\n              @for (col of displayColumns; track col) {\n                <th\n                  scope=\"col\"\n                  class=\"docs-api-table__th\"\n                  [class.docs-api-table__th--name]=\"col === 'name'\"\n                  [class.docs-api-table__th--type]=\"col === 'type'\"\n                  [class.docs-api-table__th--default]=\"col === 'default'\"\n                  [class.docs-api-table__th--description]=\"col === 'description'\"\n                >\n                  {{ getColumnLabel(col) }}\n                </th>\n              }\n            </tr>\n          </thead>\n          <tbody>\n            @for (item of props.items; track item.name) {\n              <tr\n                class=\"docs-api-table__row\"\n                [class.docs-api-table__row--deprecated]=\"item.deprecated\"\n              >\n                @for (col of displayColumns; track col) {\n                  <td\n                    class=\"docs-api-table__td\"\n                    [class.docs-api-table__td--name]=\"col === 'name'\"\n                    [class.docs-api-table__td--type]=\"col === 'type'\"\n                    [class.docs-api-table__td--default]=\"col === 'default'\"\n                    [class.docs-api-table__td--description]=\"col === 'description'\"\n                    [attr.data-label]=\"getColumnLabel(col)\"\n                  >\n                    @switch (col) {\n                      @case ('name') {\n                        <code class=\"docs-api-table__code\">{{ item.name }}</code>\n                        @if (item.required) {\n                          <span class=\"docs-api-table__required\" aria-label=\"Required\" title=\"Required\">*</span>\n                        }\n                        @if (item.deprecated) {\n                          <span class=\"docs-api-table__badge docs-api-table__badge--deprecated\" aria-label=\"This property is deprecated\">Deprecated</span>\n                        }\n                      }\n                      @case ('type') {\n                        <code class=\"docs-api-table__type\">{{ item.type || '-' }}</code>\n                      }\n                      @case ('default') {\n                        <code class=\"docs-api-table__default\">{{ item.default || '-' }}</code>\n                      }\n                      @case ('description') {\n                        <span>{{ item.description || '-' }}</span>\n                        @if (item.deprecated && item.deprecationNote) {\n                          <div class=\"docs-api-table__deprecation-note\">\n                            {{ item.deprecationNote }}\n                          </div>\n                        }\n                      }\n                      @case ('required') {\n                        {{ item.required ? 'Yes' : 'No' }}\n                      }\n                    }\n                  </td>\n                }\n              </tr>\n            }\n          </tbody>\n        </table>\n      </div>\n\n      @if (props.items.length === 0) {\n        <p class=\"docs-api-table__empty\">No items to display.</p>\n      }\n    </div>\n  `,\n  styleUrls: ['./docs-api-table.component.scss'],\n})\nexport class DocsApiTableComponent {\n  @Input() props: DocsApiTableMetadata = { items: [] };\n\n  readonly columnLabels = API_TABLE_COLUMN_LABELS;\n\n  get displayColumns(): DocsApiColumn[] {\n    return this.props.columns || ['name', 'type', 'default', 'description'];\n  }\n\n  getColumnLabel(col: DocsApiColumn): string {\n    return this.columnLabels[col];\n  }\n}\n"]}
@@ -92,9 +92,10 @@ export class FooterLinksComponent {
92
92
  <ion-col size="12" *ngIf="props.logo || props.socialLinks?.length">
93
93
  <!-- Mobile layout: centered -->
94
94
  <div class="mobile-layout">
95
+ <!-- Light mode logo -->
95
96
  <val-image
96
97
  *ngIf="props.logo"
97
- class="logo-clickable"
98
+ class="logo-clickable footer-logo footer-logo--light"
98
99
  style="display: block; margin-top: 1rem;"
99
100
  [props]="{
100
101
  width: 14,
@@ -109,6 +110,24 @@ export class FooterLinksComponent {
109
110
  }"
110
111
  (click)="onLogoClick()"
111
112
  />
113
+ <!-- Dark mode logo -->
114
+ <val-image
115
+ *ngIf="props.logo && props.logoDark"
116
+ class="logo-clickable footer-logo footer-logo--dark"
117
+ style="display: block; margin-top: 1rem;"
118
+ [props]="{
119
+ width: 14,
120
+ mode: 'box',
121
+ shaded: false,
122
+ bordered: false,
123
+ size: 'small',
124
+ src: props.logoDark,
125
+ alt: props.logoAlt || 'Logo',
126
+ limited: false,
127
+ dark: true
128
+ }"
129
+ (click)="onLogoClick()"
130
+ />
112
131
  <div class="social-links-container" *ngIf="props.socialLinks?.length" style="margin-top: 1rem">
113
132
  <ion-button
114
133
  *ngFor="let social of props.socialLinks"
@@ -127,9 +146,10 @@ export class FooterLinksComponent {
127
146
 
128
147
  <!-- Desktop layout: space-between -->
129
148
  <div class="desktop-layout">
149
+ <!-- Light mode logo -->
130
150
  <val-image
131
151
  *ngIf="props.logo"
132
- class="logo-clickable"
152
+ class="logo-clickable footer-logo footer-logo--light"
133
153
  [props]="{
134
154
  width: 16,
135
155
  mode: 'box',
@@ -143,6 +163,23 @@ export class FooterLinksComponent {
143
163
  }"
144
164
  (click)="onLogoClick()"
145
165
  />
166
+ <!-- Dark mode logo -->
167
+ <val-image
168
+ *ngIf="props.logo && props.logoDark"
169
+ class="logo-clickable footer-logo footer-logo--dark"
170
+ [props]="{
171
+ width: 16,
172
+ mode: 'box',
173
+ shaded: false,
174
+ bordered: false,
175
+ size: 'small',
176
+ src: props.logoDark,
177
+ alt: props.logoAlt || 'Logo',
178
+ limited: false,
179
+ dark: true
180
+ }"
181
+ (click)="onLogoClick()"
182
+ />
146
183
  <div class="social-links-container" *ngIf="props.socialLinks?.length">
147
184
  <ion-button
148
185
  *ngFor="let social of props.socialLinks"
@@ -161,7 +198,7 @@ export class FooterLinksComponent {
161
198
  </ion-col>
162
199
  </ion-row>
163
200
  </div>
164
- `, isInline: true, styles: [".footer-links .mobile-layout{display:block;text-align:center;padding:8px 0}.footer-links .desktop-layout{display:none;align-items:center;justify-content:space-between;margin-top:16px;padding:8px 0}.footer-links .social-links-container{display:flex;align-items:center;justify-content:center;gap:12px;margin-top:8px;flex-wrap:wrap}.footer-links .social-button{--color: #666;--color-hover: #333;transition:all .2s ease;min-height:40px;min-width:40px;margin:0}.footer-links .social-button:hover{--color: #333;transform:translateY(-1px)}.footer-links .social-button ion-icon{font-size:20px}.footer-links .logo-clickable{cursor:pointer}@media (min-width: 768px){.footer-links .mobile-layout{display:none!important}.footer-links .desktop-layout{display:flex!important}.footer-links .social-links-container{margin-top:0;justify-content:flex-end}}@media (max-width: 767px){.footer-links .mobile-layout{display:block!important}.footer-links .desktop-layout{display:none!important}.footer-links .social-links-container{justify-content:center;margin-bottom:8px}}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: IonCol, selector: "ion-col", inputs: ["offset", "offsetLg", "offsetMd", "offsetSm", "offsetXl", "offsetXs", "pull", "pullLg", "pullMd", "pullSm", "pullXl", "pullXs", "push", "pushLg", "pushMd", "pushSm", "pushXl", "pushXs", "size", "sizeLg", "sizeMd", "sizeSm", "sizeXl", "sizeXs"] }, { kind: "component", type: IonRow, selector: "ion-row" }, { kind: "component", type: IonButton, selector: "ion-button", inputs: ["buttonType", "color", "disabled", "download", "expand", "fill", "form", "href", "mode", "rel", "routerAnimation", "routerDirection", "shape", "size", "strong", "target", "type"] }, { kind: "component", type: IonIcon, selector: "ion-icon", inputs: ["color", "flipRtl", "icon", "ios", "lazy", "md", "mode", "name", "sanitize", "size", "src"] }, { kind: "component", type: DividerComponent, selector: "val-divider", inputs: ["props"] }, { kind: "component", type: ImageComponent, selector: "val-image", inputs: ["props"] }, { kind: "component", type: LinksCakeComponent, selector: "val-links-cake", inputs: ["props"] }, { kind: "component", type: LanguageSelectorComponent, selector: "val-language-selector", inputs: ["props"], outputs: ["languageChange"] }] }); }
201
+ `, isInline: true, styles: [".footer-links .mobile-layout{display:block;text-align:center;padding:8px 0}.footer-links .desktop-layout{display:none;align-items:center;justify-content:space-between;margin-top:16px;padding:8px 0}.footer-links .social-links-container{display:flex;align-items:center;justify-content:center;gap:12px;margin-top:8px;flex-wrap:wrap}.footer-links .social-button{--color: #666;--color-hover: #333;transition:all .2s ease;min-height:40px;min-width:40px;margin:0}.footer-links .social-button:hover{--color: #333;transform:translateY(-1px)}.footer-links .social-button ion-icon{font-size:20px}.footer-links .logo-clickable{cursor:pointer}.footer-links .footer-logo--light{display:block}.footer-links .footer-logo--dark{display:none}@media (prefers-color-scheme: dark){.footer-links .footer-logo--light{display:none}.footer-links .footer-logo--dark{display:block}}.footer-links :host-context(.dark) .footer-logo--light{display:none}.footer-links :host-context(.dark) .footer-logo--dark{display:block}@media (min-width: 768px){.footer-links .mobile-layout{display:none!important}.footer-links .desktop-layout{display:flex!important}.footer-links .social-links-container{margin-top:0;justify-content:flex-end}}@media (max-width: 767px){.footer-links .mobile-layout{display:block!important}.footer-links .desktop-layout{display:none!important}.footer-links .social-links-container{justify-content:center;margin-bottom:8px}}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: IonCol, selector: "ion-col", inputs: ["offset", "offsetLg", "offsetMd", "offsetSm", "offsetXl", "offsetXs", "pull", "pullLg", "pullMd", "pullSm", "pullXl", "pullXs", "push", "pushLg", "pushMd", "pushSm", "pushXl", "pushXs", "size", "sizeLg", "sizeMd", "sizeSm", "sizeXl", "sizeXs"] }, { kind: "component", type: IonRow, selector: "ion-row" }, { kind: "component", type: IonButton, selector: "ion-button", inputs: ["buttonType", "color", "disabled", "download", "expand", "fill", "form", "href", "mode", "rel", "routerAnimation", "routerDirection", "shape", "size", "strong", "target", "type"] }, { kind: "component", type: IonIcon, selector: "ion-icon", inputs: ["color", "flipRtl", "icon", "ios", "lazy", "md", "mode", "name", "sanitize", "size", "src"] }, { kind: "component", type: DividerComponent, selector: "val-divider", inputs: ["props"] }, { kind: "component", type: ImageComponent, selector: "val-image", inputs: ["props"] }, { kind: "component", type: LinksCakeComponent, selector: "val-links-cake", inputs: ["props"] }, { kind: "component", type: LanguageSelectorComponent, selector: "val-language-selector", inputs: ["props"], outputs: ["languageChange"] }] }); }
165
202
  }
166
203
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: FooterLinksComponent, decorators: [{
167
204
  type: Component,
@@ -199,9 +236,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
199
236
  <ion-col size="12" *ngIf="props.logo || props.socialLinks?.length">
200
237
  <!-- Mobile layout: centered -->
201
238
  <div class="mobile-layout">
239
+ <!-- Light mode logo -->
202
240
  <val-image
203
241
  *ngIf="props.logo"
204
- class="logo-clickable"
242
+ class="logo-clickable footer-logo footer-logo--light"
205
243
  style="display: block; margin-top: 1rem;"
206
244
  [props]="{
207
245
  width: 14,
@@ -216,6 +254,24 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
216
254
  }"
217
255
  (click)="onLogoClick()"
218
256
  />
257
+ <!-- Dark mode logo -->
258
+ <val-image
259
+ *ngIf="props.logo && props.logoDark"
260
+ class="logo-clickable footer-logo footer-logo--dark"
261
+ style="display: block; margin-top: 1rem;"
262
+ [props]="{
263
+ width: 14,
264
+ mode: 'box',
265
+ shaded: false,
266
+ bordered: false,
267
+ size: 'small',
268
+ src: props.logoDark,
269
+ alt: props.logoAlt || 'Logo',
270
+ limited: false,
271
+ dark: true
272
+ }"
273
+ (click)="onLogoClick()"
274
+ />
219
275
  <div class="social-links-container" *ngIf="props.socialLinks?.length" style="margin-top: 1rem">
220
276
  <ion-button
221
277
  *ngFor="let social of props.socialLinks"
@@ -234,9 +290,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
234
290
 
235
291
  <!-- Desktop layout: space-between -->
236
292
  <div class="desktop-layout">
293
+ <!-- Light mode logo -->
237
294
  <val-image
238
295
  *ngIf="props.logo"
239
- class="logo-clickable"
296
+ class="logo-clickable footer-logo footer-logo--light"
240
297
  [props]="{
241
298
  width: 16,
242
299
  mode: 'box',
@@ -250,6 +307,23 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
250
307
  }"
251
308
  (click)="onLogoClick()"
252
309
  />
310
+ <!-- Dark mode logo -->
311
+ <val-image
312
+ *ngIf="props.logo && props.logoDark"
313
+ class="logo-clickable footer-logo footer-logo--dark"
314
+ [props]="{
315
+ width: 16,
316
+ mode: 'box',
317
+ shaded: false,
318
+ bordered: false,
319
+ size: 'small',
320
+ src: props.logoDark,
321
+ alt: props.logoAlt || 'Logo',
322
+ limited: false,
323
+ dark: true
324
+ }"
325
+ (click)="onLogoClick()"
326
+ />
253
327
  <div class="social-links-container" *ngIf="props.socialLinks?.length">
254
328
  <ion-button
255
329
  *ngFor="let social of props.socialLinks"
@@ -268,10 +342,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
268
342
  </ion-col>
269
343
  </ion-row>
270
344
  </div>
271
- `, styles: [".footer-links .mobile-layout{display:block;text-align:center;padding:8px 0}.footer-links .desktop-layout{display:none;align-items:center;justify-content:space-between;margin-top:16px;padding:8px 0}.footer-links .social-links-container{display:flex;align-items:center;justify-content:center;gap:12px;margin-top:8px;flex-wrap:wrap}.footer-links .social-button{--color: #666;--color-hover: #333;transition:all .2s ease;min-height:40px;min-width:40px;margin:0}.footer-links .social-button:hover{--color: #333;transform:translateY(-1px)}.footer-links .social-button ion-icon{font-size:20px}.footer-links .logo-clickable{cursor:pointer}@media (min-width: 768px){.footer-links .mobile-layout{display:none!important}.footer-links .desktop-layout{display:flex!important}.footer-links .social-links-container{margin-top:0;justify-content:flex-end}}@media (max-width: 767px){.footer-links .mobile-layout{display:block!important}.footer-links .desktop-layout{display:none!important}.footer-links .social-links-container{justify-content:center;margin-bottom:8px}}\n"] }]
345
+ `, styles: [".footer-links .mobile-layout{display:block;text-align:center;padding:8px 0}.footer-links .desktop-layout{display:none;align-items:center;justify-content:space-between;margin-top:16px;padding:8px 0}.footer-links .social-links-container{display:flex;align-items:center;justify-content:center;gap:12px;margin-top:8px;flex-wrap:wrap}.footer-links .social-button{--color: #666;--color-hover: #333;transition:all .2s ease;min-height:40px;min-width:40px;margin:0}.footer-links .social-button:hover{--color: #333;transform:translateY(-1px)}.footer-links .social-button ion-icon{font-size:20px}.footer-links .logo-clickable{cursor:pointer}.footer-links .footer-logo--light{display:block}.footer-links .footer-logo--dark{display:none}@media (prefers-color-scheme: dark){.footer-links .footer-logo--light{display:none}.footer-links .footer-logo--dark{display:block}}.footer-links :host-context(.dark) .footer-logo--light{display:none}.footer-links :host-context(.dark) .footer-logo--dark{display:block}@media (min-width: 768px){.footer-links .mobile-layout{display:none!important}.footer-links .desktop-layout{display:flex!important}.footer-links .social-links-container{margin-top:0;justify-content:flex-end}}@media (max-width: 767px){.footer-links .mobile-layout{display:block!important}.footer-links .desktop-layout{display:none!important}.footer-links .social-links-container{justify-content:center;margin-bottom:8px}}\n"] }]
272
346
  }], propDecorators: { props: [{
273
347
  type: Input
274
348
  }], logoClick: [{
275
349
  type: Output
276
350
  }] } });
277
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"footer-links.component.js","sourceRoot":"","sources":["../../../../../../../src/lib/components/molecules/footer-links/footer-links.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AAC/E,OAAO,EAAE,SAAS,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,EAAE,MAAM,2BAA2B,CAAC;AAC/E,OAAO,EAAE,iBAAiB,EAAE,MAAM,sCAAsC,CAAC;AACzE,OAAO,EAAE,gBAAgB,EAAE,MAAM,uCAAuC,CAAC;AACzE,OAAO,EAAE,cAAc,EAAE,MAAM,mCAAmC,CAAC;AACnE,OAAO,EAAE,yBAAyB,EAAE,MAAM,kDAAkD,CAAC;AAE7F,OAAO,EAAE,kBAAkB,EAAE,MAAM,oCAAoC,CAAC;;;AAGxE;;;;;;;;;;;;;;;;;;;;;GAqBG;AA+GH,MAAM,OAAO,oBAAoB;IA9GjC;QA+GU,QAAG,GAAG,MAAM,CAAC,iBAAiB,CAAC,CAAC;QAOxC;;WAEG;QACO,cAAS,GAAG,IAAI,YAAY,EAAQ,CAAC;KAgChD;IA9BC;;OAEG;IACH,IAAI,sBAAsB;QACxB,IAAI,IAAI,CAAC,KAAK,CAAC,gBAAgB,IAAI,OAAO,IAAI,CAAC,KAAK,CAAC,gBAAgB,KAAK,QAAQ,EAAE,CAAC;YACnF,OAAO,IAAI,CAAC,KAAK,CAAC,gBAAgB,CAAC;QACrC,CAAC;QACD,OAAO;YACL,SAAS,EAAE,KAAK;YAChB,WAAW,EAAE;gBACX,SAAS,EAAE,SAAS;gBACpB,GAAG,EAAE,UAAU;gBACf,QAAQ,EAAE,QAAQ;aACnB;YACD,SAAS,EAAE,IAAI;YACf,KAAK,EAAE,SAAS;YAChB,IAAI,EAAE,SAAS;YACf,IAAI,EAAE,SAAS;SAChB,CAAC;IACJ,CAAC;IAED;;OAEG;IACH,WAAW;QACT,IAAI,IAAI,CAAC,KAAK,CAAC,SAAS,EAAE,CAAC;YACzB,IAAI,CAAC,GAAG,CAAC,aAAa,CAAC,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC;QAC/C,CAAC;QACD,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,CAAC;IACxB,CAAC;+GA1CU,oBAAoB;mGAApB,oBAAoB,6IAhGrB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA6FT,qmCAvGC,YAAY,gQACZ,MAAM,kTACN,MAAM,oDACN,SAAS,oPACT,OAAO,2JACP,gBAAgB,2EAChB,cAAc,yEACd,kBAAkB,8EAClB,yBAAyB;;4FAkGhB,oBAAoB;kBA9GhC,SAAS;+BACE,kBAAkB,cAChB,IAAI,WACP;wBACP,YAAY;wBACZ,MAAM;wBACN,MAAM;wBACN,SAAS;wBACT,OAAO;wBACP,gBAAgB;wBAChB,cAAc;wBACd,kBAAkB;wBAClB,yBAAyB;qBAC1B,YACS;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA6FT;8BASQ,KAAK;sBAAb,KAAK;gBAKI,SAAS;sBAAlB,MAAM","sourcesContent":["import { CommonModule } from '@angular/common';\nimport { Component, EventEmitter, inject, Input, Output } from '@angular/core';\nimport { IonButton, IonCol, IonIcon, IonRow } from '@ionic/angular/standalone';\nimport { NavigationService } from '../../../services/navigation.service';\nimport { DividerComponent } from '../../atoms/divider/divider.component';\nimport { ImageComponent } from '../../atoms/image/image.component';\nimport { LanguageSelectorComponent } from '../language-selector/language-selector.component';\nimport { LanguageSelectorMetadata } from '../language-selector/types';\nimport { LinksCakeComponent } from '../links-cake/links-cake.component';\nimport { FooterLinksMetadata } from './types';\n\n/**\n * val-footer-links\n *\n * A responsive footer component with two columns of links, social media icons,\n * logo, and optional language selector.\n *\n * @example\n * <val-footer-links\n *   [props]=\"{\n *     leftLinks: { title: 'Company', links: [...] },\n *     rightLinks: { title: 'Resources', links: [...] },\n *     logo: 'logo.svg',\n *     logoRoute: '/',\n *     socialLinks: [\n *       { icon: 'logo-facebook', url: 'https://facebook.com', name: 'Facebook' }\n *     ]\n *   }\"\n * ></val-footer-links>\n *\n * @input props - Footer configuration\n * @output logoClick - Emits when logo is clicked\n */\n@Component({\n  selector: 'val-footer-links',\n  standalone: true,\n  imports: [\n    CommonModule,\n    IonCol,\n    IonRow,\n    IonButton,\n    IonIcon,\n    DividerComponent,\n    ImageComponent,\n    LinksCakeComponent,\n    LanguageSelectorComponent,\n  ],\n  template: `\n    <div class=\"footer-links\">\n      <ion-row>\n        <ion-col size=\"12\">\n          <val-divider [props]=\"props.divider || { size: 'small', color: 'medium', fill: 'solid' }\" />\n        </ion-col>\n        <ion-col size-xs=\"12\" size-md=\"6\">\n          <val-links-cake [props]=\"props.leftLinks\" />\n        </ion-col>\n        <ion-col size-xs=\"12\" size-md=\"6\">\n          <val-links-cake [props]=\"props.rightLinks\" />\n        </ion-col>\n      </ion-row>\n\n      <ion-row *ngIf=\"props.languageSelector !== false\" style=\"margin-top: 1rem;\">\n        <ion-col size=\"12\">\n          <val-language-selector [props]=\"languageSelectorConfig\" />\n        </ion-col>\n      </ion-row>\n\n      <ion-row style=\"margin-top: 1rem;\">\n        <ion-col size=\"12\" *ngIf=\"props.logo || props.socialLinks?.length\">\n          <!-- Mobile layout: centered -->\n          <div class=\"mobile-layout\">\n            <val-image\n              *ngIf=\"props.logo\"\n              class=\"logo-clickable\"\n              style=\"display: block; margin-top: 1rem;\"\n              [props]=\"{\n                width: 14,\n                mode: 'box',\n                shaded: false,\n                bordered: false,\n                size: 'small',\n                src: props.logo,\n                alt: props.logoAlt || 'Logo',\n                limited: false,\n                dark: true\n              }\"\n              (click)=\"onLogoClick()\"\n            />\n            <div class=\"social-links-container\" *ngIf=\"props.socialLinks?.length\" style=\"margin-top: 1rem\">\n              <ion-button\n                *ngFor=\"let social of props.socialLinks\"\n                fill=\"clear\"\n                size=\"small\"\n                [href]=\"social.url\"\n                target=\"_blank\"\n                rel=\"noopener\"\n                class=\"social-button\"\n                [attr.aria-label]=\"social.name\"\n              >\n                <ion-icon [name]=\"social.icon\" slot=\"icon-only\" [color]=\"props.socialIconColor || 'dark'\"></ion-icon>\n              </ion-button>\n            </div>\n          </div>\n\n          <!-- Desktop layout: space-between -->\n          <div class=\"desktop-layout\">\n            <val-image\n              *ngIf=\"props.logo\"\n              class=\"logo-clickable\"\n              [props]=\"{\n                width: 16,\n                mode: 'box',\n                shaded: false,\n                bordered: false,\n                size: 'small',\n                src: props.logo,\n                alt: props.logoAlt || 'Logo',\n                limited: false,\n                dark: true\n              }\"\n              (click)=\"onLogoClick()\"\n            />\n            <div class=\"social-links-container\" *ngIf=\"props.socialLinks?.length\">\n              <ion-button\n                *ngFor=\"let social of props.socialLinks\"\n                fill=\"clear\"\n                size=\"small\"\n                [href]=\"social.url\"\n                target=\"_blank\"\n                rel=\"noopener\"\n                class=\"social-button\"\n                [attr.aria-label]=\"social.name\"\n              >\n                <ion-icon [name]=\"social.icon\" slot=\"icon-only\" [color]=\"props.socialIconColor || 'dark'\"></ion-icon>\n              </ion-button>\n            </div>\n          </div>\n        </ion-col>\n      </ion-row>\n    </div>\n  `,\n  styleUrls: ['./footer-links.component.scss'],\n})\nexport class FooterLinksComponent {\n  private nav = inject(NavigationService);\n\n  /**\n   * Footer configuration.\n   */\n  @Input() props!: FooterLinksMetadata;\n\n  /**\n   * Emits when the logo is clicked.\n   */\n  @Output() logoClick = new EventEmitter<void>();\n\n  /**\n   * Default language selector configuration.\n   */\n  get languageSelectorConfig(): LanguageSelectorMetadata {\n    if (this.props.languageSelector && typeof this.props.languageSelector === 'object') {\n      return this.props.languageSelector;\n    }\n    return {\n      showLabel: false,\n      labelConfig: {\n        className: '_global',\n        key: 'language',\n        fallback: 'Idioma',\n      },\n      showFlags: true,\n      color: 'primary',\n      size: 'default',\n      fill: 'outline',\n    };\n  }\n\n  /**\n   * Handles logo click - navigates if route provided, otherwise emits event.\n   */\n  onLogoClick(): void {\n    if (this.props.logoRoute) {\n      this.nav.navigateByUrl(this.props.logoRoute);\n    }\n    this.logoClick.emit();\n  }\n}\n"]}
351
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"footer-links.component.js","sourceRoot":"","sources":["../../../../../../../src/lib/components/molecules/footer-links/footer-links.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AAC/E,OAAO,EAAE,SAAS,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,EAAE,MAAM,2BAA2B,CAAC;AAC/E,OAAO,EAAE,iBAAiB,EAAE,MAAM,sCAAsC,CAAC;AACzE,OAAO,EAAE,gBAAgB,EAAE,MAAM,uCAAuC,CAAC;AACzE,OAAO,EAAE,cAAc,EAAE,MAAM,mCAAmC,CAAC;AACnE,OAAO,EAAE,yBAAyB,EAAE,MAAM,kDAAkD,CAAC;AAE7F,OAAO,EAAE,kBAAkB,EAAE,MAAM,oCAAoC,CAAC;;;AAGxE;;;;;;;;;;;;;;;;;;;;;GAqBG;AAoJH,MAAM,OAAO,oBAAoB;IAnJjC;QAoJU,QAAG,GAAG,MAAM,CAAC,iBAAiB,CAAC,CAAC;QAOxC;;WAEG;QACO,cAAS,GAAG,IAAI,YAAY,EAAQ,CAAC;KAgChD;IA9BC;;OAEG;IACH,IAAI,sBAAsB;QACxB,IAAI,IAAI,CAAC,KAAK,CAAC,gBAAgB,IAAI,OAAO,IAAI,CAAC,KAAK,CAAC,gBAAgB,KAAK,QAAQ,EAAE,CAAC;YACnF,OAAO,IAAI,CAAC,KAAK,CAAC,gBAAgB,CAAC;QACrC,CAAC;QACD,OAAO;YACL,SAAS,EAAE,KAAK;YAChB,WAAW,EAAE;gBACX,SAAS,EAAE,SAAS;gBACpB,GAAG,EAAE,UAAU;gBACf,QAAQ,EAAE,QAAQ;aACnB;YACD,SAAS,EAAE,IAAI;YACf,KAAK,EAAE,SAAS;YAChB,IAAI,EAAE,SAAS;YACf,IAAI,EAAE,SAAS;SAChB,CAAC;IACJ,CAAC;IAED;;OAEG;IACH,WAAW;QACT,IAAI,IAAI,CAAC,KAAK,CAAC,SAAS,EAAE,CAAC;YACzB,IAAI,CAAC,GAAG,CAAC,aAAa,CAAC,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC;QAC/C,CAAC;QACD,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,CAAC;IACxB,CAAC;+GA1CU,oBAAoB;mGAApB,oBAAoB,6IArIrB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAkIT,88CA5IC,YAAY,gQACZ,MAAM,kTACN,MAAM,oDACN,SAAS,oPACT,OAAO,2JACP,gBAAgB,2EAChB,cAAc,yEACd,kBAAkB,8EAClB,yBAAyB;;4FAuIhB,oBAAoB;kBAnJhC,SAAS;+BACE,kBAAkB,cAChB,IAAI,WACP;wBACP,YAAY;wBACZ,MAAM;wBACN,MAAM;wBACN,SAAS;wBACT,OAAO;wBACP,gBAAgB;wBAChB,cAAc;wBACd,kBAAkB;wBAClB,yBAAyB;qBAC1B,YACS;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAkIT;8BASQ,KAAK;sBAAb,KAAK;gBAKI,SAAS;sBAAlB,MAAM","sourcesContent":["import { CommonModule } from '@angular/common';\nimport { Component, EventEmitter, inject, Input, Output } from '@angular/core';\nimport { IonButton, IonCol, IonIcon, IonRow } from '@ionic/angular/standalone';\nimport { NavigationService } from '../../../services/navigation.service';\nimport { DividerComponent } from '../../atoms/divider/divider.component';\nimport { ImageComponent } from '../../atoms/image/image.component';\nimport { LanguageSelectorComponent } from '../language-selector/language-selector.component';\nimport { LanguageSelectorMetadata } from '../language-selector/types';\nimport { LinksCakeComponent } from '../links-cake/links-cake.component';\nimport { FooterLinksMetadata } from './types';\n\n/**\n * val-footer-links\n *\n * A responsive footer component with two columns of links, social media icons,\n * logo, and optional language selector.\n *\n * @example\n * <val-footer-links\n *   [props]=\"{\n *     leftLinks: { title: 'Company', links: [...] },\n *     rightLinks: { title: 'Resources', links: [...] },\n *     logo: 'logo.svg',\n *     logoRoute: '/',\n *     socialLinks: [\n *       { icon: 'logo-facebook', url: 'https://facebook.com', name: 'Facebook' }\n *     ]\n *   }\"\n * ></val-footer-links>\n *\n * @input props - Footer configuration\n * @output logoClick - Emits when logo is clicked\n */\n@Component({\n  selector: 'val-footer-links',\n  standalone: true,\n  imports: [\n    CommonModule,\n    IonCol,\n    IonRow,\n    IonButton,\n    IonIcon,\n    DividerComponent,\n    ImageComponent,\n    LinksCakeComponent,\n    LanguageSelectorComponent,\n  ],\n  template: `\n    <div class=\"footer-links\">\n      <ion-row>\n        <ion-col size=\"12\">\n          <val-divider [props]=\"props.divider || { size: 'small', color: 'medium', fill: 'solid' }\" />\n        </ion-col>\n        <ion-col size-xs=\"12\" size-md=\"6\">\n          <val-links-cake [props]=\"props.leftLinks\" />\n        </ion-col>\n        <ion-col size-xs=\"12\" size-md=\"6\">\n          <val-links-cake [props]=\"props.rightLinks\" />\n        </ion-col>\n      </ion-row>\n\n      <ion-row *ngIf=\"props.languageSelector !== false\" style=\"margin-top: 1rem;\">\n        <ion-col size=\"12\">\n          <val-language-selector [props]=\"languageSelectorConfig\" />\n        </ion-col>\n      </ion-row>\n\n      <ion-row style=\"margin-top: 1rem;\">\n        <ion-col size=\"12\" *ngIf=\"props.logo || props.socialLinks?.length\">\n          <!-- Mobile layout: centered -->\n          <div class=\"mobile-layout\">\n            <!-- Light mode logo -->\n            <val-image\n              *ngIf=\"props.logo\"\n              class=\"logo-clickable footer-logo footer-logo--light\"\n              style=\"display: block; margin-top: 1rem;\"\n              [props]=\"{\n                width: 14,\n                mode: 'box',\n                shaded: false,\n                bordered: false,\n                size: 'small',\n                src: props.logo,\n                alt: props.logoAlt || 'Logo',\n                limited: false,\n                dark: true\n              }\"\n              (click)=\"onLogoClick()\"\n            />\n            <!-- Dark mode logo -->\n            <val-image\n              *ngIf=\"props.logo && props.logoDark\"\n              class=\"logo-clickable footer-logo footer-logo--dark\"\n              style=\"display: block; margin-top: 1rem;\"\n              [props]=\"{\n                width: 14,\n                mode: 'box',\n                shaded: false,\n                bordered: false,\n                size: 'small',\n                src: props.logoDark,\n                alt: props.logoAlt || 'Logo',\n                limited: false,\n                dark: true\n              }\"\n              (click)=\"onLogoClick()\"\n            />\n            <div class=\"social-links-container\" *ngIf=\"props.socialLinks?.length\" style=\"margin-top: 1rem\">\n              <ion-button\n                *ngFor=\"let social of props.socialLinks\"\n                fill=\"clear\"\n                size=\"small\"\n                [href]=\"social.url\"\n                target=\"_blank\"\n                rel=\"noopener\"\n                class=\"social-button\"\n                [attr.aria-label]=\"social.name\"\n              >\n                <ion-icon [name]=\"social.icon\" slot=\"icon-only\" [color]=\"props.socialIconColor || 'dark'\"></ion-icon>\n              </ion-button>\n            </div>\n          </div>\n\n          <!-- Desktop layout: space-between -->\n          <div class=\"desktop-layout\">\n            <!-- Light mode logo -->\n            <val-image\n              *ngIf=\"props.logo\"\n              class=\"logo-clickable footer-logo footer-logo--light\"\n              [props]=\"{\n                width: 16,\n                mode: 'box',\n                shaded: false,\n                bordered: false,\n                size: 'small',\n                src: props.logo,\n                alt: props.logoAlt || 'Logo',\n                limited: false,\n                dark: true\n              }\"\n              (click)=\"onLogoClick()\"\n            />\n            <!-- Dark mode logo -->\n            <val-image\n              *ngIf=\"props.logo && props.logoDark\"\n              class=\"logo-clickable footer-logo footer-logo--dark\"\n              [props]=\"{\n                width: 16,\n                mode: 'box',\n                shaded: false,\n                bordered: false,\n                size: 'small',\n                src: props.logoDark,\n                alt: props.logoAlt || 'Logo',\n                limited: false,\n                dark: true\n              }\"\n              (click)=\"onLogoClick()\"\n            />\n            <div class=\"social-links-container\" *ngIf=\"props.socialLinks?.length\">\n              <ion-button\n                *ngFor=\"let social of props.socialLinks\"\n                fill=\"clear\"\n                size=\"small\"\n                [href]=\"social.url\"\n                target=\"_blank\"\n                rel=\"noopener\"\n                class=\"social-button\"\n                [attr.aria-label]=\"social.name\"\n              >\n                <ion-icon [name]=\"social.icon\" slot=\"icon-only\" [color]=\"props.socialIconColor || 'dark'\"></ion-icon>\n              </ion-button>\n            </div>\n          </div>\n        </ion-col>\n      </ion-row>\n    </div>\n  `,\n  styleUrls: ['./footer-links.component.scss'],\n})\nexport class FooterLinksComponent {\n  private nav = inject(NavigationService);\n\n  /**\n   * Footer configuration.\n   */\n  @Input() props!: FooterLinksMetadata;\n\n  /**\n   * Emits when the logo is clicked.\n   */\n  @Output() logoClick = new EventEmitter<void>();\n\n  /**\n   * Default language selector configuration.\n   */\n  get languageSelectorConfig(): LanguageSelectorMetadata {\n    if (this.props.languageSelector && typeof this.props.languageSelector === 'object') {\n      return this.props.languageSelector;\n    }\n    return {\n      showLabel: false,\n      labelConfig: {\n        className: '_global',\n        key: 'language',\n        fallback: 'Idioma',\n      },\n      showFlags: true,\n      color: 'primary',\n      size: 'default',\n      fill: 'outline',\n    };\n  }\n\n  /**\n   * Handles logo click - navigates if route provided, otherwise emits event.\n   */\n  onLogoClick(): void {\n    if (this.props.logoRoute) {\n      this.nav.navigateByUrl(this.props.logoRoute);\n    }\n    this.logoClick.emit();\n  }\n}\n"]}
@@ -1,2 +1,2 @@
1
1
  export {};
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9zcmMvbGliL2NvbXBvbmVudHMvbW9sZWN1bGVzL2Zvb3Rlci1saW5rcy90eXBlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGl2aWRlck1ldGFkYXRhIH0gZnJvbSAnLi4vLi4vYXRvbXMvZGl2aWRlci90eXBlcyc7XG5pbXBvcnQgeyBMYW5ndWFnZVNlbGVjdG9yTWV0YWRhdGEgfSBmcm9tICcuLi9sYW5ndWFnZS1zZWxlY3Rvci90eXBlcyc7XG5pbXBvcnQgeyBMaW5rQ2FrZU1ldGFkYXRhIH0gZnJvbSAnLi4vbGlua3MtY2FrZS90eXBlcyc7XG5cbi8qKlxuICogU29jaWFsIGxpbmsgY29uZmlndXJhdGlvbi5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBTb2NpYWxMaW5rTWV0YWRhdGEge1xuICAvKiogSW9uaWNvbiBuYW1lIChlLmcuLCAnbG9nby1mYWNlYm9vaycsICdsb2dvLXR3aXR0ZXInKSAqL1xuICBpY29uOiBzdHJpbmc7XG4gIC8qKiBVUkwgdG8gdGhlIHNvY2lhbCBwcm9maWxlICovXG4gIHVybDogc3RyaW5nO1xuICAvKiogQWNjZXNzaWJsZSBuYW1lIGZvciB0aGUgbGluayAqL1xuICBuYW1lOiBzdHJpbmc7XG59XG5cbi8qKlxuICogQ29uZmlndXJhdGlvbiBmb3IgdGhlIGZvb3RlciBsaW5rcyBjb21wb25lbnQuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgRm9vdGVyTGlua3NNZXRhZGF0YSB7XG4gIC8qKiBMZWZ0IGNvbHVtbiBsaW5rcyBjb25maWd1cmF0aW9uICovXG4gIGxlZnRMaW5rczogTGlua0Nha2VNZXRhZGF0YTtcbiAgLyoqIFJpZ2h0IGNvbHVtbiBsaW5rcyBjb25maWd1cmF0aW9uICovXG4gIHJpZ2h0TGlua3M6IExpbmtDYWtlTWV0YWRhdGE7XG4gIC8qKiBPcHRpb25hbCBsb2dvIFVSTCAqL1xuICBsb2dvPzogc3RyaW5nO1xuICAvKiogTG9nbyBhbHQgdGV4dC4gRGVmYXVsdDogJ0xvZ28nICovXG4gIGxvZ29BbHQ/OiBzdHJpbmc7XG4gIC8qKiBSb3V0ZSB0byBuYXZpZ2F0ZSB3aGVuIGxvZ28gaXMgY2xpY2tlZCAqL1xuICBsb2dvUm91dGU/OiBzdHJpbmc7XG4gIC8qKiBPcHRpb25hbCBkaXZpZGVyIGNvbmZpZ3VyYXRpb24gKi9cbiAgZGl2aWRlcj86IERpdmlkZXJNZXRhZGF0YTtcbiAgLyoqIFNvY2lhbCBtZWRpYSBsaW5rcyAqL1xuICBzb2NpYWxMaW5rcz86IFNvY2lhbExpbmtNZXRhZGF0YVtdO1xuICAvKiogTGFuZ3VhZ2Ugc2VsZWN0b3IgY29uZmlndXJhdGlvbi4gU2V0IHRvIGZhbHNlIHRvIGhpZGUuICovXG4gIGxhbmd1YWdlU2VsZWN0b3I/OiBMYW5ndWFnZVNlbGVjdG9yTWV0YWRhdGEgfCBmYWxzZTtcbiAgLyoqIEljb24gY29sb3IgZm9yIHNvY2lhbCBsaW5rcy4gRGVmYXVsdDogJ2RhcmsnICovXG4gIHNvY2lhbEljb25Db2xvcj86IHN0cmluZztcbn1cbiJdfQ==
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9zcmMvbGliL2NvbXBvbmVudHMvbW9sZWN1bGVzL2Zvb3Rlci1saW5rcy90eXBlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGl2aWRlck1ldGFkYXRhIH0gZnJvbSAnLi4vLi4vYXRvbXMvZGl2aWRlci90eXBlcyc7XG5pbXBvcnQgeyBMYW5ndWFnZVNlbGVjdG9yTWV0YWRhdGEgfSBmcm9tICcuLi9sYW5ndWFnZS1zZWxlY3Rvci90eXBlcyc7XG5pbXBvcnQgeyBMaW5rQ2FrZU1ldGFkYXRhIH0gZnJvbSAnLi4vbGlua3MtY2FrZS90eXBlcyc7XG5cbi8qKlxuICogU29jaWFsIGxpbmsgY29uZmlndXJhdGlvbi5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBTb2NpYWxMaW5rTWV0YWRhdGEge1xuICAvKiogSW9uaWNvbiBuYW1lIChlLmcuLCAnbG9nby1mYWNlYm9vaycsICdsb2dvLXR3aXR0ZXInKSAqL1xuICBpY29uOiBzdHJpbmc7XG4gIC8qKiBVUkwgdG8gdGhlIHNvY2lhbCBwcm9maWxlICovXG4gIHVybDogc3RyaW5nO1xuICAvKiogQWNjZXNzaWJsZSBuYW1lIGZvciB0aGUgbGluayAqL1xuICBuYW1lOiBzdHJpbmc7XG59XG5cbi8qKlxuICogQ29uZmlndXJhdGlvbiBmb3IgdGhlIGZvb3RlciBsaW5rcyBjb21wb25lbnQuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgRm9vdGVyTGlua3NNZXRhZGF0YSB7XG4gIC8qKiBMZWZ0IGNvbHVtbiBsaW5rcyBjb25maWd1cmF0aW9uICovXG4gIGxlZnRMaW5rczogTGlua0Nha2VNZXRhZGF0YTtcbiAgLyoqIFJpZ2h0IGNvbHVtbiBsaW5rcyBjb25maWd1cmF0aW9uICovXG4gIHJpZ2h0TGlua3M6IExpbmtDYWtlTWV0YWRhdGE7XG4gIC8qKiBPcHRpb25hbCBsb2dvIFVSTCAqL1xuICBsb2dvPzogc3RyaW5nO1xuICAvKiogTG9nbyBVUkwgZm9yIGRhcmsgbW9kZS4gSWYgbm90IHNldCwgdXNlcyBsb2dvIHdpdGggZmlsdGVyIGludmVydC4gKi9cbiAgbG9nb0Rhcms/OiBzdHJpbmc7XG4gIC8qKiBMb2dvIGFsdCB0ZXh0LiBEZWZhdWx0OiAnTG9nbycgKi9cbiAgbG9nb0FsdD86IHN0cmluZztcbiAgLyoqIFJvdXRlIHRvIG5hdmlnYXRlIHdoZW4gbG9nbyBpcyBjbGlja2VkICovXG4gIGxvZ29Sb3V0ZT86IHN0cmluZztcbiAgLyoqIE9wdGlvbmFsIGRpdmlkZXIgY29uZmlndXJhdGlvbiAqL1xuICBkaXZpZGVyPzogRGl2aWRlck1ldGFkYXRhO1xuICAvKiogU29jaWFsIG1lZGlhIGxpbmtzICovXG4gIHNvY2lhbExpbmtzPzogU29jaWFsTGlua01ldGFkYXRhW107XG4gIC8qKiBMYW5ndWFnZSBzZWxlY3RvciBjb25maWd1cmF0aW9uLiBTZXQgdG8gZmFsc2UgdG8gaGlkZS4gKi9cbiAgbGFuZ3VhZ2VTZWxlY3Rvcj86IExhbmd1YWdlU2VsZWN0b3JNZXRhZGF0YSB8IGZhbHNlO1xuICAvKiogSWNvbiBjb2xvciBmb3Igc29jaWFsIGxpbmtzLiBEZWZhdWx0OiAnZGFyaycgKi9cbiAgc29jaWFsSWNvbkNvbG9yPzogc3RyaW5nO1xufVxuIl19