valtech-components 2.0.720 → 2.0.721

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.
@@ -83,17 +83,10 @@ export class ConfirmationDialogService {
83
83
  * @returns Promise resolving to the confirmation result
84
84
  */
85
85
  async confirmDestructive(options) {
86
- // Marca el modal con val-alert--destructive para que el CSS pinte
87
- // el texto del botón destructivo en rojo (sin tocar el fondo).
88
- const extraClass = 'val-alert--destructive';
89
- const userClasses = options.cssClass
90
- ? Array.isArray(options.cssClass)
91
- ? options.cssClass
92
- : [options.cssClass]
93
- : [];
86
+ // Visualmente idéntico a confirm() sin colores, solo cambia el role
87
+ // semánticamente a 'destructive' para a11y/screen readers.
94
88
  return this.confirm({
95
89
  ...options,
96
- cssClass: [...userClasses, extraClass],
97
90
  confirmButton: {
98
91
  text: options.confirmButton?.text || 'Delete',
99
92
  role: 'destructive',
@@ -191,4 +184,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
191
184
  providedIn: 'root',
192
185
  }]
193
186
  }] });
194
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"confirmation-dialog.service.js","sourceRoot":"","sources":["../../../../../../src/lib/services/confirmation-dialog/confirmation-dialog.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, inject } from '@angular/core';\nimport { AlertController } from '@ionic/angular/standalone';\nimport {\n  ConfirmationDialogMetadata,\n  ConfirmationResult,\n  ConfirmationButton,\n  DEFAULT_CONFIRM_BUTTON,\n  DEFAULT_CANCEL_BUTTON,\n} from './types';\n\n/**\n * Service for displaying confirmation dialogs.\n *\n * @example Basic usage\n * const result = await confirmationService.confirm({\n *   title: 'Delete Item',\n *   message: 'Are you sure you want to delete this item?',\n * });\n *\n * if (result.confirmed) {\n *   // User confirmed\n * }\n *\n * @example Custom buttons\n * const result = await confirmationService.confirm({\n *   title: 'Save Changes',\n *   message: 'Do you want to save your changes before leaving?',\n *   confirmButton: { text: 'Save', color: 'success' },\n *   cancelButton: { text: 'Discard', color: 'danger' },\n *   extraButtons: [{ text: 'Cancel', role: 'cancel' }]\n * });\n *\n * @example Destructive action\n * const result = await confirmationService.confirmDestructive({\n *   title: 'Delete Account',\n *   message: 'This action cannot be undone. Are you sure?',\n * });\n */\n@Injectable({\n  providedIn: 'root',\n})\nexport class ConfirmationDialogService {\n  private alertController = inject(AlertController);\n\n  /**\n   * Shows a confirmation dialog and returns the result.\n   * @param options - Configuration for the dialog\n   * @returns Promise resolving to the confirmation result\n   */\n  async confirm(options: ConfirmationDialogMetadata): Promise<ConfirmationResult> {\n    const buttons = this.buildButtons(options);\n\n    // Default: usa val-alert (estilo iOS dark unificado de la lib)\n    const userClasses = options.cssClass\n      ? Array.isArray(options.cssClass)\n        ? options.cssClass\n        : [options.cssClass]\n      : [];\n    const cssClass = ['val-alert', ...userClasses];\n\n    const alert = await this.alertController.create({\n      header: options.title,\n      subHeader: options.subHeader,\n      message: options.message,\n      buttons,\n      backdropDismiss: options.backdropDismiss ?? false,\n      cssClass,\n      mode: options.mode ?? 'ios',\n      translucent: options.translucent ?? true,\n      animated: options.animated ?? true,\n    });\n\n    await alert.present();\n    const { role, data } = await alert.onDidDismiss();\n\n    return {\n      confirmed: role === 'confirm',\n      role,\n      data,\n    };\n  }\n\n  /**\n   * Shows a simple confirmation dialog with default buttons.\n   * @param title - Dialog title\n   * @param message - Dialog message\n   * @returns Promise resolving to true if confirmed, false otherwise\n   */\n  async confirmSimple(title: string, message: string): Promise<boolean> {\n    const result = await this.confirm({ title, message });\n    return result.confirmed;\n  }\n\n  /**\n   * Shows a destructive action confirmation with red confirm button.\n   * @param options - Configuration for the dialog\n   * @returns Promise resolving to the confirmation result\n   */\n  async confirmDestructive(\n    options: Omit<ConfirmationDialogMetadata, 'confirmButton'> & {\n      confirmButton?: Partial<ConfirmationButton>;\n    }\n  ): Promise<ConfirmationResult> {\n    // Marca el modal con val-alert--destructive para que el CSS pinte\n    // el texto del botón destructivo en rojo (sin tocar el fondo).\n    const extraClass = 'val-alert--destructive';\n    const userClasses = options.cssClass\n      ? Array.isArray(options.cssClass)\n        ? options.cssClass\n        : [options.cssClass]\n      : [];\n\n    return this.confirm({\n      ...options,\n      cssClass: [...userClasses, extraClass],\n      confirmButton: {\n        text: options.confirmButton?.text || 'Delete',\n        role: 'destructive',\n        ...options.confirmButton,\n      },\n    });\n  }\n\n  /**\n   * Shows an info alert with just an OK button.\n   * @param title - Alert title\n   * @param message - Alert message\n   */\n  async alert(title: string, message: string): Promise<void> {\n    const alert = await this.alertController.create({\n      header: title,\n      message,\n      buttons: [{ text: 'OK', role: 'confirm' }],\n    });\n\n    await alert.present();\n    await alert.onDidDismiss();\n  }\n\n  /**\n   * Shows a three-option dialog (Save, Discard, Cancel).\n   * Common for unsaved changes scenarios.\n   * @param title - Dialog title\n   * @param message - Dialog message\n   * @returns Promise resolving to 'save' | 'discard' | 'cancel'\n   */\n  async confirmSaveDiscard(title: string, message: string): Promise<'save' | 'discard' | 'cancel'> {\n    const alert = await this.alertController.create({\n      header: title,\n      message,\n      backdropDismiss: false,\n      buttons: [\n        {\n          text: 'Cancel',\n          role: 'cancel',\n        },\n        {\n          text: 'Discard',\n          role: 'destructive',\n          cssClass: 'text-danger',\n        },\n        {\n          text: 'Save',\n          role: 'confirm',\n        },\n      ],\n    });\n\n    await alert.present();\n    const { role } = await alert.onDidDismiss();\n\n    if (role === 'confirm') return 'save';\n    if (role === 'destructive') return 'discard';\n    return 'cancel';\n  }\n\n  private buildButtons(options: ConfirmationDialogMetadata): any[] {\n    const buttons: any[] = [];\n\n    // Cancel button — sin color ionic por default (el CSS de val-alert se encarga)\n    const cancelBtn = options.cancelButton || DEFAULT_CANCEL_BUTTON;\n    buttons.push({\n      text: cancelBtn.text,\n      role: cancelBtn.role || 'cancel',\n      cssClass: cancelBtn.cssClass,\n      handler: cancelBtn.handler,\n    });\n\n    // Extra buttons (if any)\n    if (options.extraButtons) {\n      options.extraButtons.forEach(btn => {\n        buttons.push({\n          text: btn.text,\n          role: btn.role,\n          cssClass: btn.cssClass,\n          handler: btn.handler,\n        });\n      });\n    }\n\n    // Confirm button\n    const confirmBtn = options.confirmButton || DEFAULT_CONFIRM_BUTTON;\n    buttons.push({\n      text: confirmBtn.text,\n      role: confirmBtn.role || 'confirm',\n      cssClass: confirmBtn.cssClass,\n      handler: confirmBtn.handler,\n    });\n\n    return buttons;\n  }\n}\n"]}
187
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"confirmation-dialog.service.js","sourceRoot":"","sources":["../../../../../../src/lib/services/confirmation-dialog/confirmation-dialog.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, inject } from '@angular/core';\nimport { AlertController } from '@ionic/angular/standalone';\nimport {\n  ConfirmationDialogMetadata,\n  ConfirmationResult,\n  ConfirmationButton,\n  DEFAULT_CONFIRM_BUTTON,\n  DEFAULT_CANCEL_BUTTON,\n} from './types';\n\n/**\n * Service for displaying confirmation dialogs.\n *\n * @example Basic usage\n * const result = await confirmationService.confirm({\n *   title: 'Delete Item',\n *   message: 'Are you sure you want to delete this item?',\n * });\n *\n * if (result.confirmed) {\n *   // User confirmed\n * }\n *\n * @example Custom buttons\n * const result = await confirmationService.confirm({\n *   title: 'Save Changes',\n *   message: 'Do you want to save your changes before leaving?',\n *   confirmButton: { text: 'Save', color: 'success' },\n *   cancelButton: { text: 'Discard', color: 'danger' },\n *   extraButtons: [{ text: 'Cancel', role: 'cancel' }]\n * });\n *\n * @example Destructive action\n * const result = await confirmationService.confirmDestructive({\n *   title: 'Delete Account',\n *   message: 'This action cannot be undone. Are you sure?',\n * });\n */\n@Injectable({\n  providedIn: 'root',\n})\nexport class ConfirmationDialogService {\n  private alertController = inject(AlertController);\n\n  /**\n   * Shows a confirmation dialog and returns the result.\n   * @param options - Configuration for the dialog\n   * @returns Promise resolving to the confirmation result\n   */\n  async confirm(options: ConfirmationDialogMetadata): Promise<ConfirmationResult> {\n    const buttons = this.buildButtons(options);\n\n    // Default: usa val-alert (estilo iOS dark unificado de la lib)\n    const userClasses = options.cssClass\n      ? Array.isArray(options.cssClass)\n        ? options.cssClass\n        : [options.cssClass]\n      : [];\n    const cssClass = ['val-alert', ...userClasses];\n\n    const alert = await this.alertController.create({\n      header: options.title,\n      subHeader: options.subHeader,\n      message: options.message,\n      buttons,\n      backdropDismiss: options.backdropDismiss ?? false,\n      cssClass,\n      mode: options.mode ?? 'ios',\n      translucent: options.translucent ?? true,\n      animated: options.animated ?? true,\n    });\n\n    await alert.present();\n    const { role, data } = await alert.onDidDismiss();\n\n    return {\n      confirmed: role === 'confirm',\n      role,\n      data,\n    };\n  }\n\n  /**\n   * Shows a simple confirmation dialog with default buttons.\n   * @param title - Dialog title\n   * @param message - Dialog message\n   * @returns Promise resolving to true if confirmed, false otherwise\n   */\n  async confirmSimple(title: string, message: string): Promise<boolean> {\n    const result = await this.confirm({ title, message });\n    return result.confirmed;\n  }\n\n  /**\n   * Shows a destructive action confirmation with red confirm button.\n   * @param options - Configuration for the dialog\n   * @returns Promise resolving to the confirmation result\n   */\n  async confirmDestructive(\n    options: Omit<ConfirmationDialogMetadata, 'confirmButton'> & {\n      confirmButton?: Partial<ConfirmationButton>;\n    }\n  ): Promise<ConfirmationResult> {\n    // Visualmente idéntico a confirm() — sin colores, solo cambia el role\n    // semánticamente a 'destructive' para a11y/screen readers.\n    return this.confirm({\n      ...options,\n      confirmButton: {\n        text: options.confirmButton?.text || 'Delete',\n        role: 'destructive',\n        ...options.confirmButton,\n      },\n    });\n  }\n\n  /**\n   * Shows an info alert with just an OK button.\n   * @param title - Alert title\n   * @param message - Alert message\n   */\n  async alert(title: string, message: string): Promise<void> {\n    const alert = await this.alertController.create({\n      header: title,\n      message,\n      buttons: [{ text: 'OK', role: 'confirm' }],\n    });\n\n    await alert.present();\n    await alert.onDidDismiss();\n  }\n\n  /**\n   * Shows a three-option dialog (Save, Discard, Cancel).\n   * Common for unsaved changes scenarios.\n   * @param title - Dialog title\n   * @param message - Dialog message\n   * @returns Promise resolving to 'save' | 'discard' | 'cancel'\n   */\n  async confirmSaveDiscard(title: string, message: string): Promise<'save' | 'discard' | 'cancel'> {\n    const alert = await this.alertController.create({\n      header: title,\n      message,\n      backdropDismiss: false,\n      buttons: [\n        {\n          text: 'Cancel',\n          role: 'cancel',\n        },\n        {\n          text: 'Discard',\n          role: 'destructive',\n          cssClass: 'text-danger',\n        },\n        {\n          text: 'Save',\n          role: 'confirm',\n        },\n      ],\n    });\n\n    await alert.present();\n    const { role } = await alert.onDidDismiss();\n\n    if (role === 'confirm') return 'save';\n    if (role === 'destructive') return 'discard';\n    return 'cancel';\n  }\n\n  private buildButtons(options: ConfirmationDialogMetadata): any[] {\n    const buttons: any[] = [];\n\n    // Cancel button — sin color ionic por default (el CSS de val-alert se encarga)\n    const cancelBtn = options.cancelButton || DEFAULT_CANCEL_BUTTON;\n    buttons.push({\n      text: cancelBtn.text,\n      role: cancelBtn.role || 'cancel',\n      cssClass: cancelBtn.cssClass,\n      handler: cancelBtn.handler,\n    });\n\n    // Extra buttons (if any)\n    if (options.extraButtons) {\n      options.extraButtons.forEach(btn => {\n        buttons.push({\n          text: btn.text,\n          role: btn.role,\n          cssClass: btn.cssClass,\n          handler: btn.handler,\n        });\n      });\n    }\n\n    // Confirm button\n    const confirmBtn = options.confirmButton || DEFAULT_CONFIRM_BUTTON;\n    buttons.push({\n      text: confirmBtn.text,\n      role: confirmBtn.role || 'confirm',\n      cssClass: confirmBtn.cssClass,\n      handler: confirmBtn.handler,\n    });\n\n    return buttons;\n  }\n}\n"]}
@@ -2,5 +2,5 @@
2
2
  * Current version of valtech-components.
3
3
  * This is automatically updated during the publish process.
4
4
  */
5
- export const VERSION = '2.0.720';
6
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmVyc2lvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9saWIvdmVyc2lvbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7O0dBR0c7QUFDSCxNQUFNLENBQUMsTUFBTSxPQUFPLEdBQUcsU0FBUyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBDdXJyZW50IHZlcnNpb24gb2YgdmFsdGVjaC1jb21wb25lbnRzLlxuICogVGhpcyBpcyBhdXRvbWF0aWNhbGx5IHVwZGF0ZWQgZHVyaW5nIHRoZSBwdWJsaXNoIHByb2Nlc3MuXG4gKi9cbmV4cG9ydCBjb25zdCBWRVJTSU9OID0gJzIuMC43MjAnO1xuIl19
5
+ export const VERSION = '2.0.721';
6
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmVyc2lvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9saWIvdmVyc2lvbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7O0dBR0c7QUFDSCxNQUFNLENBQUMsTUFBTSxPQUFPLEdBQUcsU0FBUyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBDdXJyZW50IHZlcnNpb24gb2YgdmFsdGVjaC1jb21wb25lbnRzLlxuICogVGhpcyBpcyBhdXRvbWF0aWNhbGx5IHVwZGF0ZWQgZHVyaW5nIHRoZSBwdWJsaXNoIHByb2Nlc3MuXG4gKi9cbmV4cG9ydCBjb25zdCBWRVJTSU9OID0gJzIuMC43MjEnO1xuIl19
@@ -50,7 +50,7 @@ import 'prismjs/components/prism-json';
50
50
  * Current version of valtech-components.
51
51
  * This is automatically updated during the publish process.
52
52
  */
53
- const VERSION = '2.0.720';
53
+ const VERSION = '2.0.721';
54
54
 
55
55
  /**
56
56
  * Servicio para gestionar presets de componentes.
@@ -28811,17 +28811,10 @@ class ConfirmationDialogService {
28811
28811
  * @returns Promise resolving to the confirmation result
28812
28812
  */
28813
28813
  async confirmDestructive(options) {
28814
- // Marca el modal con val-alert--destructive para que el CSS pinte
28815
- // el texto del botón destructivo en rojo (sin tocar el fondo).
28816
- const extraClass = 'val-alert--destructive';
28817
- const userClasses = options.cssClass
28818
- ? Array.isArray(options.cssClass)
28819
- ? options.cssClass
28820
- : [options.cssClass]
28821
- : [];
28814
+ // Visualmente idéntico a confirm() sin colores, solo cambia el role
28815
+ // semánticamente a 'destructive' para a11y/screen readers.
28822
28816
  return this.confirm({
28823
28817
  ...options,
28824
- cssClass: [...userClasses, extraClass],
28825
28818
  confirmButton: {
28826
28819
  text: options.confirmButton?.text || 'Delete',
28827
28820
  role: 'destructive',