@c80/ui 1.0.23 → 1.0.24

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.
@@ -23,10 +23,19 @@ import * as i0 from "@angular/core";
23
23
  * 3. POR DEFECTO - Columnas normales
24
24
  * - Se muestran siempre (visualización, creación y edición)
25
25
  *
26
+ * VALORES POR DEFECTO EN CREACIÓN:
27
+ * ===============================
28
+ *
29
+ * - Propiedad `default?: unknown` permite definir valores por defecto para modo creación
30
+ * - Solo se aplica cuando se inicia el modo creación (startCreate)
31
+ * - Puede ser cualquier tipo: string, number, boolean, etc.
32
+ * - Si no se especifica `default`, se usa cadena vacía ('')
33
+ *
26
34
  * EJEMPLOS:
27
35
  * - { accessor: 'id', visible: false } → NUNCA se muestra
28
- * - { accessor: 'motorPos', hideIfAllValuesAreNull: true } → Se oculta si todos vacíos, PERO se muestra en creación/edición
29
- * - { accessor: 'name' } → Siempre visible
36
+ * - { accessor: 'motorPos', hideIfAllValuesAreNull: true, default: 0 } → Se autorellena con 0 en creación
37
+ * - { accessor: 'status', default: 'active' } → Se autorellena con 'active' en creación
38
+ * - { accessor: 'name' } → Siempre visible, sin valor por defecto (cadena vacía)
30
39
  */ export class C80TableComponent {
31
40
  modalService = inject(ModalService);
32
41
  data$;
@@ -169,7 +178,9 @@ import * as i0 from "@angular/core";
169
178
  this.columns
170
179
  .filter((col) => this.isColumnVisible(col, true) && !col.readOnly)
171
180
  .forEach((col) => {
172
- row[col.accessor] = '';
181
+ // Si la columna tiene un valor por defecto, usarlo; si no, usar cadena vacía
182
+ const defaultValue = col.default !== undefined ? col.default : '';
183
+ row[col.accessor] = defaultValue;
173
184
  });
174
185
  this.newRow.set(row);
175
186
  }
@@ -778,4 +789,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
778
789
  }], selectable: [{
779
790
  type: Output
780
791
  }] } });
781
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table.component.js","sourceRoot":"","sources":["../../../../../libs/ui/src/lib/table/table.component.ts","../../../../../libs/ui/src/lib/table/table.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  Input,\n  Output,\n  signal,\n  EventEmitter,\n  OnInit,\n  OnDestroy,\n  inject,\n} from '@angular/core';\nimport { Observable, Subscription } from 'rxjs';\nimport { C80IconComponent } from '../icon/icon.component';\nimport { C80ModalComponent, ModalService } from '../modal';\n\nexport interface C80TableColDef {\n  accessor: string;\n  label: string;\n  visible?: boolean; // Si no se especifica, se asume true. Si es false, la columna se oculta SIEMPRE (máxima prioridad)\n  type?: 'string' | 'number' | 'boolean' | 'password' | 'enum'; // Tipo de dato para la columna\n  order?: 'ASC' | 'DESC'; // Ordenamiento de la columna\n  readOnly?: boolean; // Si no se especifica, se asume false\n  enum?: Record<string | number, string>; // Opciones del enum para type 'enum'\n  color?: Record<string | number, string>; // Colores CSS basados en el valor de la celda\n  hideIfAllValuesAreNull?: boolean; // Si es true, oculta la columna cuando todos los valores están vacíos (default: false).\n  // Solo aplica si visible !== false. EXCEPCIÓN: En modo creación Y edición siempre se muestra.\n}\n\nexport type ID = number | string;\n\n/**\n * C80TableComponent - Componente de tabla avanzado con funcionalidades CRUD\n *\n * COMPORTAMIENTO DE VISIBILIDAD DE COLUMNAS:\n * ========================================\n *\n * 1. PRIORIDAD MÁXIMA - visible: false\n *    - La columna se oculta SIEMPRE, sin excepciones\n *    - Ni en modo creación ni en modo edición se muestra\n *\n * 2. OCULTACIÓN AUTOMÁTICA - hideIfAllValuesAreNull: true\n *    - La columna se oculta solo si TODOS los valores actuales están vacíos\n *    - Valores considerados vacíos: null, undefined, '', [], {}\n *    - Valores NO vacíos: 0, false (son valores válidos)\n *    - EXCEPCIONES IMPORTANTES:\n *      * En modo creación (creating=true) estas columnas SÍ se muestran\n *      * En modo edición de una fila específica también se muestran\n *\n * 3. POR DEFECTO - Columnas normales\n *    - Se muestran siempre (visualización, creación y edición)\n *\n * EJEMPLOS:\n * - { accessor: 'id', visible: false } → NUNCA se muestra\n * - { accessor: 'motorPos', hideIfAllValuesAreNull: true } → Se oculta si todos vacíos, PERO se muestra en creación/edición\n * - { accessor: 'name' } → Siempre visible\n */@Component({\n  // eslint-disable-next-line @angular-eslint/component-selector\n  selector: 'c80-table',\n  standalone: true,\n  imports: [C80IconComponent, C80ModalComponent],\n  templateUrl: './table.component.html',\n  styleUrl: './table.component.scss',\n})\nexport class C80TableComponent<T extends Record<string, unknown>> implements OnInit, OnDestroy {\n  private readonly modalService: ModalService = inject(ModalService);\n  @Input() data$!: Observable<T[]>;\n  @Input() columns: C80TableColDef[] = [];\n  @Input() size = 0; // Tamaño de la tabla (0 = sin límite, > 0 aplica max-height)\n  @Input() multiple = true; // Permite selección múltiple por defecto\n  @Input({ transform: (value: boolean | string) => value === '' || value === true || value === 'true' })\n  noConfirm = false; // Si es true, no muestra confirmaciones modales\n  @Output() createAction = new EventEmitter<{ row: Partial<T>; done: (result: boolean) => void; }>();\n  @Output() updateAction = new EventEmitter<{ id: ID; changes: Partial<T>; done: (result: boolean) => void; }>();\n  @Output() deleteAction = new EventEmitter<{ id: ID; done: (result: boolean) => void; }>();\n  @Output() cancelAction = new EventEmitter<{ id: ID; done: (result: boolean) => void; }>();\n  @Output() viewAction = new EventEmitter<T>();\n  @Output() getRowButtonAction = new EventEmitter<T>();\n  @Output() moveUpAction = new EventEmitter<{ id: ID; done: (result: boolean) => void; }>();\n  @Output() moveDownAction = new EventEmitter<{ id: ID; done: (result: boolean) => void; }>();\n  @Output() enableAction = new EventEmitter<{ id: ID; enabled: boolean; done: (result: boolean) => void; }>();\n  @Output() searchTerm = new EventEmitter<string>();\n\n  @Output() errorEvent = new EventEmitter<string>();\n  @Output() selectable = new EventEmitter<T[]>();\n\n  readonly data = signal<T[]>([]);\n  readonly keys = signal<string[]>([]);\n  creating = signal(false);\n  newRow = signal<Partial<T> | null>(null);\n  readonly editing = signal<ID | null>(null); // id of row being edited\n  readonly editRow = signal<Partial<T> | null>(null);\n  readonly selectedItems = signal<Set<ID>>(new Set());\n  readonly selectAllChecked = signal(false);\n  readonly selectAllIndeterminate = signal(false);\n  readonly searchValue = signal<string>('');\n\n  // Flags to check if events have listeners\n  readonly hasCreateActionListener = signal(false);\n  readonly hasUpdateActionListener = signal(false);\n  readonly hasDeleteActionListener = signal(false);\n  readonly hasCancelActionListener = signal(false);\n  readonly hasViewActionListener = signal(false);\n  readonly hasGetRowButtonListener = signal(false);\n  readonly hasMoveUpActionListener = signal(false);\n  readonly hasMoveDownActionListener = signal(false);\n  readonly hasEnableActionListener = signal(false);\n  readonly hasSearchTermListener = signal(false);\n  readonly hasSelectableListener = signal(false);\n\n  private dataSub?: Subscription;\n\n  private getErrorMessage(err: unknown): string {\n    return (err as any)?.message || 'Error al cargar datos';\n  }\n\n  /**\n   * Actualiza las keys de columnas visibles basándose en el estado actual\n   */\n  private updateVisibleKeys(): void {\n    const visibleColumns = this.columns.filter(col => this.isColumnVisibleInHeader(col));\n    this.keys.set(visibleColumns.map((col) => col.accessor));\n  }\n\n  ngOnInit() {\n    // Check if the outputs have listeners\n    this.hasCreateActionListener.set(this.createAction.observed);\n    this.hasUpdateActionListener.set(this.updateAction.observed);\n    this.hasDeleteActionListener.set(this.deleteAction.observed);\n    this.hasCancelActionListener.set(this.cancelAction.observed);\n    this.hasViewActionListener.set(this.viewAction.observed);\n    this.hasGetRowButtonListener.set(this.getRowButtonAction.observed);\n    this.hasMoveUpActionListener.set(this.moveUpAction.observed);\n    this.hasMoveDownActionListener.set(this.moveDownAction.observed);\n    this.hasEnableActionListener.set(this.enableAction.observed);\n    this.hasSearchTermListener.set(this.searchTerm.observed);\n    this.hasSelectableListener.set(this.selectable.observed);\n\n    if (!this.data$) return;\n    this.dataSub = this.data$.subscribe({\n      next: (items) => {\n        this.applySorting(items);\n        this.data.set(items);\n        // Actualizar las columnas visibles basándose en el estado actual\n        this.updateVisibleKeys();\n        // Mantener la selección existente después de actualizar los datos\n        this.preserveSelection();\n      },\n      error: (err: any) =>\n        this.errorEvent.emit(this.getErrorMessage(err)),\n    });\n  }\n\n  ngOnDestroy() {\n    this.dataSub?.unsubscribe();\n\n    // Close any open modal when component is destroyed\n    this.modalService.closeModal();\n  }\n\n  onInput(event: Event, key: string, col?: C80TableColDef) {\n    if (col?.type === 'boolean') {\n      const checked = (event.target as HTMLInputElement).checked;\n      this.updateNewRow(key, checked);\n    } else if (col?.type === 'enum') {\n      const value = (event.target as HTMLSelectElement).value;\n      this.updateNewRow(key, value);\n    } else {\n      const target = event.target as HTMLInputElement;\n      if (target && typeof target.value === 'string') {\n        this.updateNewRow(key, target.value);\n      }\n    }\n  }\n\n  async onDelete(row: T) {\n    const id = row['id'] as ID;\n\n    let confirmed = true;\n    if (!this.noConfirm) {\n      confirmed = await this.modalService.confirm(\n        'Confirmar eliminación',\n        '¿Está seguro de que desea eliminar este elemento? Esta acción no se puede deshacer.',\n        'Eliminar',\n        'Cancelar'\n      );\n    }\n\n    if (confirmed) {\n      this.deleteAction.emit({\n        id,\n        done: (success: boolean) => {\n          if (success) this.cancelEdit();\n        },\n      });\n    }\n  }\n\n  async onCancel(row: T) {\n    const id = row['id'] as ID;\n\n    let confirmed = true;\n    if (!this.noConfirm) {\n      confirmed = await this.modalService.confirm(\n        'Confirmar cancelación',\n        '¿Está seguro de que desea cancelar este elemento?',\n        'Cancelar elemento',\n        'No cancelar'\n      );\n    }\n\n    if (confirmed) {\n      this.cancelAction.emit({\n        id,\n        done: (success: boolean) => {\n          if (success) this.cancelEdit();\n        },\n      });\n    }\n  }\n\n  startCreate() {\n    this.creating.set(true);\n    // Actualizar keys de columnas visibles cuando entramos en modo creación\n    this.updateVisibleKeys();\n    // Inicializa newRow solo con columnas visibles y no readOnly\n    // En modo creación, mostramos columnas con hideIfAllValuesAreNull para permitir entrada de datos\n    const row: Partial<T> = {};\n    this.columns\n      .filter((col) => this.isColumnVisible(col, true) && !col.readOnly)\n      .forEach((col) => {\n        (row as Record<string, unknown>)[col.accessor] = '';\n      });\n    this.newRow.set(row);\n  }\n\n  cancelCreate() {\n    this.creating.set(false);\n    this.newRow.set(null);\n    // Actualizar keys de columnas visibles cuando salimos del modo creación\n    this.updateVisibleKeys();\n  }\n\n  updateNewRow(key: string, value: unknown) {\n    const current = this.newRow();\n    if (!current) return;\n    this.newRow.set({ ...current, [key]: value });\n  }\n\n  saveCreate() {\n    const row = this.newRow();\n    if (!row) return;\n\n    // Validar campos requeridos antes de crear - solo columnas visibles y no readOnly\n    // En modo creación, incluimos columnas con hideIfAllValuesAreNull\n    const visibleColumns = this.columns.filter((col) => this.isColumnVisible(col, true) && !col.readOnly);\n    const converted = visibleColumns.reduce((acc, col) => {\n      acc[col.accessor] = this.convertCellValue(row[col.accessor], col);\n      return acc;\n    }, {} as Record<string, unknown>) as Partial<T>;\n\n    this.createAction.emit({\n      row: converted,\n      done: (success: boolean) => {\n        if (success) {\n          this.cancelCreate();\n        }\n      },\n    });\n  }\n\n  /**\n   * Converts a cell value based on column type or sample data.\n   * Handles stringification of objects for string columns.\n   */\n  /**\n   * Converts a cell value based on column type or sample data.\n   * Delegates to type-specific helpers for clarity and maintainability.\n   */\n  private convertCellValue(value: unknown, col: C80TableColDef): unknown {\n    if (col.type === 'boolean') return this.toBoolean(value);\n    if (col.type === 'number') return this.toNumber(value);\n    if (col.type === 'string' || col.type === 'password')\n      return this.toStringValue(value);\n\n    // Fallback: use sample data if available\n    const sample = this.data()[0];\n    if (sample) {\n      const sampleValue = this.getCellValue(sample, col.accessor);\n      if (typeof sampleValue === 'boolean') return this.toBoolean(value);\n      if (typeof sampleValue === 'number') return this.toNumber(value);\n      if (typeof sampleValue === 'string') return this.toStringValue(value);\n    }\n    return value;\n  }\n\n  /** Converts value to boolean using best practices. */\n  private toBoolean(value: unknown): boolean {\n    if (typeof value === 'boolean') return value;\n    if (typeof value === 'string')\n      return value.trim().toLowerCase() === 'true' || value.trim() === '1';\n    if (typeof value === 'number') return value === 1;\n    return false;\n  }\n\n  /** Converts value to number using best practices. */\n  private toNumber(value: unknown): number | undefined {\n    if (typeof value === 'number') return value;\n    if (typeof value === 'string')\n      return value.trim() === '' ? undefined : Number(value);\n    if (typeof value === 'boolean') return value ? 1 : 0;\n    return undefined;\n  }\n\n  /** Converts value to string using best practices, always stringifies objects. */\n  private toStringValue(value: unknown): string {\n    if (value == null) return '';\n    if (typeof value === 'string') return value;\n    if (typeof value === 'number' || typeof value === 'boolean')\n      return String(value);\n    if (typeof value === 'object') {\n      try {\n        return JSON.stringify(value);\n      } catch {\n        return '[object Object]';\n      }\n    }\n    // For functions, symbols, undefined, etc., return empty string\n    return '';\n  }\n\n  onEdit(row: T) {\n    this.editing.set(row['id'] as ID);\n    // Actualizar keys de columnas visibles cuando entramos en modo edición\n    this.updateVisibleKeys();\n    const edit: Partial<T> = {};\n    this.columns\n      .filter((col) => this.isColumnVisible(col, true) && !col.readOnly)\n      .forEach((col) => {\n        const value = this.getCellValue(row, col.accessor);\n        (edit as Record<string, unknown>)[col.accessor] = value;\n      });\n    this.editRow.set(edit);\n  }\n\n  cancelEdit() {\n    this.editing.set(null);\n    this.editRow.set(null);\n    // Actualizar keys de columnas visibles cuando salimos del modo edición\n    this.updateVisibleKeys();\n  }\n\n  onEditInput(event: Event, key: string, col?: C80TableColDef) {\n    const current = this.editRow();\n    if (!current) return;\n    if (col?.type === 'boolean') {\n      const checked = (event.target as HTMLInputElement).checked;\n      this.editRow.set({ ...current, [key]: checked });\n    } else if (col?.type === 'enum') {\n      const value = (event.target as HTMLSelectElement).value;\n      this.editRow.set({ ...current, [key]: value });\n    } else {\n      const target = event.target as HTMLInputElement;\n      if (target && typeof target.value === 'string') {\n        this.editRow.set({ ...current, [key]: target.value });\n      }\n    }\n  }\n\n  saveEdit(row: T) {\n    const id = row['id'];\n    if ((typeof id !== 'string' && typeof id !== 'number') || !this.editRow())\n      return;\n    const visibleColumns = this.columns.filter(\n      (col) => this.isColumnVisible(col, true) && !col.readOnly\n    );\n    const converted = visibleColumns.reduce((acc, col) => {\n      acc[col.accessor] = this.convertCellValue(\n        this.editRow()![col.accessor],\n        col\n      );\n      return acc;\n    }, {} as Record<string, unknown>) as Partial<T>;\n\n    this.updateAction.emit({\n      id,\n      changes: converted,\n      done: (success: boolean) => {\n        if (success) {\n          this.cancelEdit();\n        }\n      },\n    });\n  }\n\n  /**\n   * TrackBy function for ngFor to avoid DOM re-creation (NG0956 warning).\n   */\n  trackById(index: number, row: T): number | string {\n    const id =\n      row && typeof row === 'object' && 'id' in row\n        ? (row as Record<string, unknown>)['id']\n        : undefined;\n    return typeof id === 'string' || typeof id === 'number' ? id : index;\n  }\n\n  /**\n   * Emits the view event with the entire row data\n   */\n  onView(row: T): void {\n    this.viewAction.emit(row);\n  }\n\n  /**\n   * Emits the getRowButtonAction event with the entire row data\n   */\n  onGetRowButton(row: T): void {\n    this.getRowButtonAction.emit(row);\n  }\n\n  /**\n   * Emits the moveUpAction event with the row id\n   */\n  async onMoveUp(row: T) {\n    const id = row['id'] as ID;\n    this.moveUpAction.emit({\n      id,\n      done: (success: boolean) => {\n        if (success) this.cancelEdit();\n      },\n    });\n  }\n\n  /**\n   * Emits the moveDownAction event with the row id\n   */\n  async onMoveDown(row: T) {\n    const id = row['id'] as ID;\n    this.moveDownAction.emit({\n      id,\n      done: (success: boolean) => {\n        if (success) this.cancelEdit();\n      },\n    });\n  }\n\n  /**\n   * Emits the enableAction event with the row id and current enabled status\n   */\n  async onEnable(row: T) {\n    const id = row['id'] as ID;\n    const currentEnabled = row['enabled'] as boolean;\n    this.enableAction.emit({\n      id,\n      enabled: !currentEnabled, // Toggle the current state\n      done: (success: boolean) => {\n        if (success) this.cancelEdit();\n      },\n    });\n  }\n\n  /**\n   * Handles search input changes with debouncing\n   */\n  onSearchInput(event: Event): void {\n    const target = event.target as HTMLInputElement;\n    const value = target.value;\n    this.searchValue.set(value);\n    this.searchTerm.emit(value);\n  }\n\n  /**\n   * Clears the search input\n   */\n  clearSearch(): void {\n    this.searchValue.set('');\n    this.searchTerm.emit('');\n  }\n\n  /**\n   * Gets the value from an object using dot notation (e.g., 'task.name')\n   */\n  private getNestedValue(obj: any, accessor: string): unknown {\n    return accessor.split('.').reduce((current, key) => {\n      return current && typeof current === 'object' ? current[key] : undefined;\n    }, obj);\n  }\n\n  /**\n   * Gets the value for a cell using the accessor, supporting dot notation for nested properties\n   */\n  getCellValue(row: T, accessor: string): unknown {\n    if (accessor.includes('.')) {\n      return this.getNestedValue(row, accessor);\n    }\n    return (row as Record<string, unknown>)[accessor];\n  }\n\n  /**\n   * Returns the display value for a cell, showing '-' for falsy values except 0, false, and empty objects/arrays\n   */\n  getDisplayValue(value: unknown): string {\n    // If value is 0, show it\n    if (value === 0) {\n      return '0';\n    }\n    // If value is false, it should be handled by boolean logic in template, not here\n    if (value === false) {\n      return 'false';\n    }\n    // Handle objects and arrays (including empty ones)\n    if (typeof value === 'object' && value !== null) {\n      try {\n        return JSON.stringify(value);\n      } catch {\n        return '[object Object]';\n      }\n    }\n    // If value is other falsy values (null, undefined, ''), show '-'\n    if (!value) {\n      return '-';\n    }\n    // Handle other types explicitly\n    if (\n      typeof value === 'string' ||\n      typeof value === 'number' ||\n      typeof value === 'boolean'\n    ) {\n      return String(value);\n    }\n    // For any other type (function, symbol, etc.), return a safe fallback\n    return '-';\n  }\n\n  /**\n   * Gets the display text for an enum value\n   */\n  getEnumDisplayValue(value: unknown, col: C80TableColDef): string {\n    if (!col.enum || (value !== 0 && !value)) {\n      return '-';\n    }\n    const displayValue = col.enum[value as string | number];\n    return (\n      displayValue ||\n      (typeof value === 'string' || typeof value === 'number'\n        ? String(value)\n        : '-')\n    );\n  }\n\n  /**\n   * Gets the enum options as an array for select dropdowns\n   */\n  getEnumOptions(\n    col: C80TableColDef\n  ): { value: string | number; label: string }[] {\n    if (!col.enum) return [];\n    return Object.entries(col.enum).map(([value, label]) => ({\n      value: isNaN(Number(value)) ? value : Number(value),\n      label,\n    }));\n  }\n\n  /**\n   * Gets the CSS color for a cell value based on the column's color configuration\n   */\n  getCellColor(value: unknown, col: C80TableColDef): string | undefined {\n    if (!col.color || (value !== 0 && !value)) {\n      return undefined;\n    }\n    return col.color[value as string | number];\n  }\n\n  /**\n   * Calcula el max-height de la tabla basado en el tamaño\n   * Si size es 0, retorna undefined (sin límite de altura)\n   */\n  getTableMaxHeight(): string | undefined {\n    if (this.size <= 0) {\n      return undefined; // Sin límite de altura\n    }\n    // Altura base de 400px * size\n    const baseHeight = 400;\n    const maxHeight = Math.round(baseHeight * this.size);\n    return `${maxHeight}px`;\n  }\n\n  /**\n   * Selection methods\n   */\n  clearSelection(): void {\n    this.selectedItems.set(new Set());\n    this.updateSelectAllState();\n    this.emitSelection();\n  }\n\n  /**\n   * Mantiene la selección existente después de actualizar los datos,\n   * eliminando solo los IDs que ya no existen en los nuevos datos\n   */\n  private preserveSelection(): void {\n    const currentSelection = this.selectedItems();\n    const currentData = this.data();\n\n    if (currentSelection.size === 0 || currentData.length === 0) {\n      // Si no hay selección o no hay datos, limpiar la selección\n      this.clearSelection();\n      return;\n    }\n\n    // Obtener los IDs disponibles en los nuevos datos\n    const availableIds = new Set(currentData.map(item => item['id'] as ID));\n\n    // Filtrar la selección actual para mantener solo los IDs que aún existen\n    const preservedSelection = new Set(\n      Array.from(currentSelection).filter(id => availableIds.has(id))\n    );\n\n    // Actualizar la selección con los IDs preservados\n    this.selectedItems.set(preservedSelection);\n    this.updateSelectAllState();\n    this.emitSelection();\n  }\n\n  toggleSelectAll(): void {\n    const currentSelection = this.selectedItems();\n    const allItems = this.data();\n\n    if (currentSelection.size === allItems.length) {\n      // Deselect all\n      this.clearSelection();\n    } else {\n      // Select all\n      const allIds = new Set(allItems.map(item => item['id'] as ID));\n      this.selectedItems.set(allIds);\n      this.updateSelectAllState();\n      this.emitSelection();\n    }\n  }\n\n  toggleItemSelection(item: T): void {\n    const id = item['id'] as ID;\n    const currentSelection = new Set(this.selectedItems());\n\n    if (!this.multiple) {\n      // Selección simple: solo permitir un elemento seleccionado\n      if (currentSelection.has(id)) {\n        // Deseleccionar el elemento actual\n        currentSelection.clear();\n      } else {\n        // Seleccionar solo este elemento\n        currentSelection.clear();\n        currentSelection.add(id);\n      }\n    } else if (currentSelection.has(id)) {\n      // Selección múltiple: deseleccionar elemento existente\n      currentSelection.delete(id);\n    } else {\n      // Selección múltiple: agregar nuevo elemento\n      currentSelection.add(id);\n    }\n\n    this.selectedItems.set(currentSelection);\n    this.updateSelectAllState();\n    this.emitSelection();\n  } isItemSelected(item: T): boolean {\n    const id = item['id'] as ID;\n    return this.selectedItems().has(id);\n  }\n\n  private updateSelectAllState(): void {\n    const selectedCount = this.selectedItems().size;\n    const totalCount = this.data().length;\n\n    if (selectedCount === 0) {\n      this.selectAllChecked.set(false);\n      this.selectAllIndeterminate.set(false);\n    } else if (selectedCount === totalCount) {\n      this.selectAllChecked.set(true);\n      this.selectAllIndeterminate.set(false);\n    } else {\n      this.selectAllChecked.set(false);\n      this.selectAllIndeterminate.set(true);\n    }\n  }\n\n  private emitSelection(): void {\n    const selectedIds = this.selectedItems();\n    const selectedItems = this.data().filter(item =>\n      selectedIds.has(item['id'] as ID)\n    );\n    this.selectable.emit(selectedItems);\n  }\n\n  /**\n   * Verifica si todos los valores de una columna están vacíos/nulos\n   */\n  private areAllColumnValuesEmpty(column: C80TableColDef): boolean {\n    const currentData = this.data();\n\n    if (currentData.length === 0) {\n      return true; // Si no hay datos, consideramos la columna como vacía\n    }\n\n    return currentData.every(row => {\n      const value = this.getCellValue(row, column.accessor);\n\n      // Considerar vacío: null, undefined, '', 0 (para números), false (para booleanos), arrays/objetos vacíos\n      if (value === null || value === undefined || value === '') {\n        return true;\n      }\n\n      // Para números, 0 se considera como valor válido, no vacío\n      if (typeof value === 'number') {\n        return false;\n      }\n\n      // Para booleanos, false se considera como valor válido, no vacío\n      if (typeof value === 'boolean') {\n        return false;\n      }\n\n      // Para arrays vacíos\n      if (Array.isArray(value) && value.length === 0) {\n        return true;\n      }\n\n      // Para objetos vacíos\n      if (typeof value === 'object' && value !== null && Object.keys(value).length === 0) {\n        return true;\n      }\n\n      return false;\n    });\n  }\n\n  /**\n   * Determina si una columna debe ser visible basándose en su configuración y datos.\n   *\n   * Orden de prioridad:\n   * 1. Si visible === false: SIEMPRE se oculta (máxima prioridad)\n   * 2. Si hideIfAllValuesAreNull === true Y todos los valores están vacíos: se oculta\n   *    EXCEPCIÓN: En modo creación (creating === true), estas columnas se muestran para permitir entrada de datos\n   * 3. Por defecto: se muestra\n   *\n   * @param column - La definición de la columna\n   * @param forceShowInCreation - Si es true, ignora hideIfAllValuesAreNull (usado en modo creación)\n   */\n  isColumnVisible(column: C80TableColDef, forceShowInCreation = false): boolean {\n    // PRIORIDAD 1: Si visible está explícitamente establecido en false, SIEMPRE ocultar\n    if (column.visible === false) {\n      return false;\n    }\n\n    // PRIORIDAD 2: Si hideIfAllValuesAreNull es true y todos los valores están vacíos, ocultar\n    // EXCEPCIÓN: En modo creación, mostramos estas columnas para permitir entrada de datos\n    if (column.hideIfAllValuesAreNull === true && !forceShowInCreation && this.areAllColumnValuesEmpty(column)) {\n      return false;\n    }\n\n    // Por defecto: mostrar\n    return true;\n  }\n\n  /**\n   * Determina si una columna debe ser visible en los headers.\n   * Los headers se muestran si la columna es visible en cualquiera de estos casos:\n   * - Visualización normal\n   * - Modo creación\n   * - Hay alguna fila en modo edición\n   *\n   * @param column - La definición de la columna\n   */\n  isColumnVisibleInHeader(column: C80TableColDef): boolean {\n    // PRIORIDAD 1: Si visible está explícitamente establecido en false, SIEMPRE ocultar\n    if (column.visible === false) {\n      return false;\n    }\n\n    // Si estamos en modo creación, mostrar columnas con hideIfAllValuesAreNull\n    if (this.creating() && column.hideIfAllValuesAreNull === true) {\n      return true;\n    }\n\n    // Si hay alguna fila en modo edición, mostrar columnas con hideIfAllValuesAreNull\n    if (this.editing() !== null && column.hideIfAllValuesAreNull === true) {\n      return true;\n    }\n\n    // Si hideIfAllValuesAreNull es true y todos los valores están vacíos, ocultar\n    if (column.hideIfAllValuesAreNull === true && this.areAllColumnValuesEmpty(column)) {\n      return false;\n    }\n\n    // Por defecto: mostrar\n    return true;\n  }\n\n  /**\n   * Determina si una columna debe ser visible en una fila específica considerando el modo edición.\n   * En modo edición de esa fila específica, las columnas con hideIfAllValuesAreNull se muestran.\n   *\n   * @param column - La definición de la columna\n   * @param row - La fila actual\n   */\n  isColumnVisibleForRow(column: C80TableColDef, row: T): boolean {\n    // PRIORIDAD 1: Si visible está explícitamente establecido en false, SIEMPRE ocultar\n    if (column.visible === false) {\n      return false;\n    }\n\n    // PRIORIDAD 2: Si esta fila específica está en modo edición, mostrar columnas con hideIfAllValuesAreNull\n    const isEditingThisRow = this.editing() === row['id'];\n    if (isEditingThisRow && column.hideIfAllValuesAreNull === true) {\n      return true;\n    }\n\n    // PRIORIDAD 3: Si hideIfAllValuesAreNull es true y todos los valores están vacíos, ocultar\n    if (column.hideIfAllValuesAreNull === true && this.areAllColumnValuesEmpty(column)) {\n      return false;\n    }\n\n    // Por defecto: mostrar\n    return true;\n  }\n\n  private applySorting(items: T[]): void {\n    const orderedColumns = this.columns.filter((col) => col.order);\n    if (orderedColumns.length > 0) {\n      orderedColumns.forEach((col) => {\n        items.sort((a, b) => {\n          const valueA = this.getCellValue(a, col.accessor) as string | number;\n          const valueB = this.getCellValue(b, col.accessor) as string | number;\n\n          if (col.order === 'ASC') {\n            if (valueA > valueB) return 1;\n            if (valueA < valueB) return -1;\n            return 0;\n          } else {\n            if (valueA < valueB) return 1;\n            if (valueA > valueB) return -1;\n            return 0;\n          }\n        });\n      });\n    }\n  }\n}\n","<div class=\"table-responsive\" [style.max-height]=\"getTableMaxHeight()\" [style.overflow-y]=\"size > 0 ? 'auto' : 'visible'\">\n  <!-- Search Bar -->\n  @if (hasSearchTermListener()) {\n  <div class=\"search-container\">\n    <div class=\"search-input-wrapper\">\n      <div class=\"input-group\">\n        <span class=\"input-group-text\">\n          <c80-icon icon=\"search\" [size]=\".8\"></c80-icon>\n        </span>\n        <input type=\"text\" class=\"form-control search-input\" placeholder=\"Buscar...\" [value]=\"searchValue()\" (input)=\"onSearchInput($event)\" aria-label=\"Buscar en la tabla\" />\n        @if (searchValue()) {\n        <button class=\"btn btn-outline-secondary btn-borrar\" type=\"button\" (click)=\"clearSearch()\" title=\"Limpiar búsqueda\">\n          <c80-icon icon=\"cancel\" [size]=\".7\"></c80-icon>\n        </button>\n        }\n      </div>\n    </div>\n  </div>\n  }\n\n  <table class=\"table table-bordered table-hover align-middle\">\n    <thead class=\"thead table-light sticky-header\">\n      <tr>\n        @if (hasSelectableListener() && data().length !== 0) {\n        <th class=\"text-center selection-column\">\n          @if (multiple) {\n          <input type=\"checkbox\" [checked]=\"selectAllChecked()\" [indeterminate]=\"selectAllIndeterminate()\" (change)=\"toggleSelectAll()\" aria-label=\"Seleccionar todo\" />\n          }\n        </th>\n        }\n        @for (col of columns; track col) {\n        @if (isColumnVisibleInHeader(col)) {\n        @if (col.type === 'boolean') {\n        <th class=\"text-center boolean-column\">{{ col.label }}</th>\n        }\n        @else if (col.type === 'number') {\n        <th class=\"text-center number-column\">{{ col.label }}</th>\n        }\n        @else {\n        <th>{{ col.label }}</th>\n        }\n        }\n        }\n        @if (hasCreateActionListener() || hasUpdateActionListener() || hasDeleteActionListener() ||\n        hasCancelActionListener() || hasViewActionListener() || hasGetRowButtonListener() ||\n        hasMoveUpActionListener() || hasMoveDownActionListener()) {\n        <th class=\"table-actions-header\">\n          <div class=\"actions-wrapper\">\n            <span>Actions</span>\n            @if (hasCreateActionListener()) {\n            <c80-icon button icon=\"add\" [disabled]=\"creating()\" title=\"Agregar\" [size]=\".6\" (iconClick)=\"startCreate()\"></c80-icon>\n            }\n          </div>\n        </th>\n        }\n      </tr>\n    </thead>\n    <tbody>\n      @for (row of data(); track trackById(i, row); let i = $index) {\n      <tr>\n        @if (hasSelectableListener() && data().length !== 0) {\n        <td class=\"text-center selection-column\">\n          <input type=\"checkbox\" [checked]=\"isItemSelected(row)\" (change)=\"toggleItemSelection(row)\" [attr.aria-label]=\"'Seleccionar fila ' + (i + 1)\" />\n        </td>\n        }\n        @for (col of columns; track col) {\n        @if (isColumnVisibleForRow(col, row)) {\n        @if (col.type === 'boolean') {\n        <td class=\"text-center boolean-column\">\n          @if (editing() === row['id'] && !col.readOnly) {\n          <input type=\"checkbox\" [checked]=\"!!editRow()?.[col.accessor]\" (change)=\"onEditInput($event, col.accessor, col)\" [attr.aria-label]=\"col.label\" />\n          }\n          @else {\n          @if (getCellValue(row, col.accessor) === true) {\n          <c80-icon icon=\"check\" [size]=\".7\"></c80-icon>\n          <br />\n          }\n          @else if (getCellValue(row, col.accessor) === false) {\n          <c80-icon icon=\"cancel\" [size]=\".7\"></c80-icon>\n          <br />\n          }\n          }\n        </td>\n        }\n        @else if (col.type === 'number') {\n        <td class=\"text-center number-column\">\n          @if (editing() === row['id'] && !col.readOnly) {\n          <input class=\"form-control form-control-sm\" type=\"number\" [value]=\"editRow()?.[col.accessor] ?? ''\" [placeholder]=\"col.label\" (input)=\"onEditInput($event, col.accessor, col)\" />\n          }\n          @else {\n          <span [style.color]=\"getCellColor(getCellValue(row, col.accessor), col)\">{{ getDisplayValue(getCellValue(row,\n            col.accessor)) }}</span>\n          }\n        </td>\n        }\n        @else {\n        <td>\n          @if (editing() === row['id'] && !col.readOnly) {\n          @if (col.type === 'enum') {\n          <select class=\"form-control form-control-sm\" [value]=\"editRow()?.[col.accessor] ?? ''\" (change)=\"onEditInput($event, col.accessor, col)\">\n            <option value=\"\">{{ col.label }}</option>\n            @for (option of getEnumOptions(col); track option.value) {\n            <option [value]=\"option.value\">{{ option.label }}</option>\n            }\n          </select>\n          }\n          @else {\n          <input class=\"form-control form-control-sm\" [type]=\"col.type === 'password' ? 'password' : 'text'\" [value]=\"editRow()?.[col.accessor] ?? ''\" [placeholder]=\"col.label\" (input)=\"onEditInput($event, col.accessor, col)\" />\n          }\n          }\n          @else {\n          @if (col.type === 'password') {\n          <span [style.color]=\"getCellColor(getCellValue(row, col.accessor), col)\">******</span>\n          }\n          @else if (col.type === 'enum') {\n          <span [style.color]=\"getCellColor(getCellValue(row, col.accessor), col)\">{{\n            getEnumDisplayValue(getCellValue(row, col.accessor), col)\n            }}</span>\n          }\n          @else if (getCellValue(row, col.accessor) === true) {\n          <c80-icon icon=\"check\" [size]=\".7\"></c80-icon>\n          }\n          @else if (getCellValue(row, col.accessor) === false) {\n          <c80-icon icon=\"cancel\" [size]=\".7\"></c80-icon>\n          }\n          @else {\n          <span [style.color]=\"getCellColor(getCellValue(row, col.accessor), col)\">{{ getDisplayValue(getCellValue(row,\n            col.accessor)) }}</span>\n          }\n          }\n        </td>\n        }\n        }\n        }\n        @if (hasCreateActionListener() || hasUpdateActionListener() || hasDeleteActionListener() ||\n        hasCancelActionListener() || hasViewActionListener() || hasGetRowButtonListener() ||\n        hasMoveUpActionListener() || hasMoveDownActionListener()) {\n        <td class=\"text-center actions-cell\">\n          <div class=\"actions-container\">\n            @if (editing() === row['id']) {\n            <c80-icon button icon=\"check\" title=\"Guardar\" (iconClick)=\"saveEdit(row)\" [size]=\".7\"></c80-icon>\n            <c80-icon button icon=\"cancel\" color=\"warn\" title=\"Cancelar\" (iconClick)=\"cancelEdit()\" [size]=\".7\"></c80-icon>\n            }\n            @else {\n            @if (hasUpdateActionListener()) {\n            <c80-icon button icon=\"edit\" title=\"Editar\" (iconClick)=\"onEdit(row)\" [size]=\".7\"></c80-icon>\n            }\n            @if (hasCancelActionListener()) {\n            <c80-icon button icon=\"cancel_circle\" color=\"secondary\" title=\"Cancelar\" (iconClick)=\"onCancel(row)\" [size]=\".7\"></c80-icon>\n            }\n            @if (hasViewActionListener()) {\n            <c80-icon button icon=\"view\" color=\"primary\" title=\"Ver\" (iconClick)=\"onView(row)\" [size]=\".7\"></c80-icon>\n            }\n            @if (hasGetRowButtonListener()) {\n            <c80-icon button icon=\"get\" color=\"success\" title=\"Vincular\" (iconClick)=\"onGetRowButton(row)\" [size]=\".7\"></c80-icon>\n            }\n            @if (hasMoveUpActionListener()) {\n            <c80-icon button icon=\"arrow_up\" color=\"secondary\" title=\"Mover arriba\" (iconClick)=\"onMoveUp(row)\" [size]=\".7\"></c80-icon>\n            }\n            @if (hasMoveDownActionListener()) {\n            <c80-icon button icon=\"arrow_down\" color=\"secondary\" title=\"Mover abajo\" (iconClick)=\"onMoveDown(row)\" [size]=\".7\"></c80-icon>\n            }\n            @if (hasEnableActionListener()) {\n            <c80-icon button [icon]=\"getCellValue(row, 'enabled') ? 'toggle_on' : 'toggle_off'\" [color]=\"getCellValue(row, 'enabled') ? 'success' : 'secondary'\" [title]=\"getCellValue(row, 'enabled') ? 'Deshabilitar' : 'Habilitar'\"\n              (iconClick)=\"onEnable(row)\" [size]=\".7\">\n            </c80-icon>\n            }\n            @if (hasDeleteActionListener()) {\n            <c80-icon button icon=\"delete\" color=\"warn\" title=\"Borrar\" (iconClick)=\"onDelete(row)\" [size]=\".7\"></c80-icon>\n            }\n            }\n          </div>\n        </td>\n        }\n      </tr>\n      }\n      @if (creating() && hasCreateActionListener()) {\n      <tr>\n        @if (hasSelectableListener() && data().length !== 0) {\n        <td class=\"text-center selection-column\">\n          <!-- Empty cell for alignment -->\n        </td>\n        }\n        @for (col of columns; track col) {\n        @if (isColumnVisible(col, true)) {\n        @if (col.type === 'boolean') {\n        <td class=\"text-center\">\n          @if (!col.readOnly) {\n          <input type=\"checkbox\" [checked]=\"!!newRow()?.[col.accessor]\" (change)=\"onInput($event, col.accessor, col)\" [attr.aria-label]=\"col.label\" />\n          }\n          @else {\n          <!-- ReadOnly boolean column in create mode shows empty -->\n          <span class=\"text-muted\">-</span>\n          }\n        </td>\n        } @else if (col.type === 'number') {\n        <td class=\"text-center number-column\">\n          @if (!col.readOnly) {\n          <input class=\"form-control form-control-sm\" type=\"number\" [value]=\"newRow()?.[col.accessor] ?? ''\" [placeholder]=\"col.label\" (input)=\"onInput($event, col.accessor, col)\" />\n          }\n          @else {\n          <!-- ReadOnly number column in create mode shows empty -->\n          <span class=\"text-muted\">-</span>\n          }\n        </td>\n        } @else {\n        <td>\n          @if (!col.readOnly) {\n          @if (col.type === 'enum') {\n          <select class=\"form-control form-control-sm\" [value]=\"newRow()?.[col.accessor] ?? ''\" (change)=\"onInput($event, col.accessor, col)\">\n            <option value=\"\">{{ col.label }}</option>\n            @for (option of getEnumOptions(col); track option.value) {\n            <option [value]=\"option.value\">{{ option.label }}</option>\n            }\n          </select>\n          }\n          @else {\n          <input class=\"form-control form-control-sm\" type=\"text\" [value]=\"newRow()?.[col.accessor] ?? ''\" [placeholder]=\"col.label\" (input)=\"onInput($event, col.accessor, col)\" />\n          }\n          }\n          @else {\n          <!-- ReadOnly column in create mode shows empty -->\n          <span class=\"text-muted\">-</span>\n          }\n        </td>\n        }\n        }\n        }\n        <td class=\"text-center actions-cell\">\n          <div class=\"actions-container\">\n            <c80-icon button icon=\"check\" title=\"Guardar\" (iconClick)=\"saveCreate()\" [size]=\".7\"></c80-icon>\n            <c80-icon button icon=\"cancel\" color=\"warn\" title=\"Cancelar\" (iconClick)=\"cancelCreate()\" [size]=\".7\"></c80-icon>\n          </div>\n        </td>\n      </tr>\n      }\n    </tbody>\n  </table>\n  @if (data().length === 0 && !creating()) {\n  <div class=\"text-center text-muted py-3 small\">\n    No hay datos para mostrar.\n  </div>\n  }\n</div>\n\n<c80-modal></c80-modal>"]}
792
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table.component.js","sourceRoot":"","sources":["../../../../../libs/ui/src/lib/table/table.component.ts","../../../../../libs/ui/src/lib/table/table.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  Input,\n  Output,\n  signal,\n  EventEmitter,\n  OnInit,\n  OnDestroy,\n  inject,\n} from '@angular/core';\nimport { Observable, Subscription } from 'rxjs';\nimport { C80IconComponent } from '../icon/icon.component';\nimport { C80ModalComponent, ModalService } from '../modal';\n\nexport interface C80TableColDef {\n  accessor: string;\n  label: string;\n  visible?: boolean; // Si no se especifica, se asume true. Si es false, la columna se oculta SIEMPRE (máxima prioridad)\n  type?: 'string' | 'number' | 'boolean' | 'password' | 'enum'; // Tipo de dato para la columna\n  order?: 'ASC' | 'DESC'; // Ordenamiento de la columna\n  readOnly?: boolean; // Si no se especifica, se asume false\n  enum?: Record<string | number, string>; // Opciones del enum para type 'enum'\n  color?: Record<string | number, string>; // Colores CSS basados en el valor de la celda\n  hideIfAllValuesAreNull?: boolean; // Si es true, oculta la columna cuando todos los valores están vacíos (default: false).\n  // Solo aplica si visible !== false. EXCEPCIÓN: En modo creación Y edición siempre se muestra.\n  default?: unknown; // Valor por defecto para usar en modo creación. Puede ser string, number, boolean, etc.\n}\n\nexport type ID = number | string;\n\n/**\n * C80TableComponent - Componente de tabla avanzado con funcionalidades CRUD\n *\n * COMPORTAMIENTO DE VISIBILIDAD DE COLUMNAS:\n * ========================================\n *\n * 1. PRIORIDAD MÁXIMA - visible: false\n *    - La columna se oculta SIEMPRE, sin excepciones\n *    - Ni en modo creación ni en modo edición se muestra\n *\n * 2. OCULTACIÓN AUTOMÁTICA - hideIfAllValuesAreNull: true\n *    - La columna se oculta solo si TODOS los valores actuales están vacíos\n *    - Valores considerados vacíos: null, undefined, '', [], {}\n *    - Valores NO vacíos: 0, false (son valores válidos)\n *    - EXCEPCIONES IMPORTANTES:\n *      * En modo creación (creating=true) estas columnas SÍ se muestran\n *      * En modo edición de una fila específica también se muestran\n *\n * 3. POR DEFECTO - Columnas normales\n *    - Se muestran siempre (visualización, creación y edición)\n *\n * VALORES POR DEFECTO EN CREACIÓN:\n * ===============================\n *\n * - Propiedad `default?: unknown` permite definir valores por defecto para modo creación\n * - Solo se aplica cuando se inicia el modo creación (startCreate)\n * - Puede ser cualquier tipo: string, number, boolean, etc.\n * - Si no se especifica `default`, se usa cadena vacía ('')\n *\n * EJEMPLOS:\n * - { accessor: 'id', visible: false } → NUNCA se muestra\n * - { accessor: 'motorPos', hideIfAllValuesAreNull: true, default: 0 } → Se autorellena con 0 en creación\n * - { accessor: 'status', default: 'active' } → Se autorellena con 'active' en creación\n * - { accessor: 'name' } → Siempre visible, sin valor por defecto (cadena vacía)\n */@Component({\n  // eslint-disable-next-line @angular-eslint/component-selector\n  selector: 'c80-table',\n  standalone: true,\n  imports: [C80IconComponent, C80ModalComponent],\n  templateUrl: './table.component.html',\n  styleUrl: './table.component.scss',\n})\nexport class C80TableComponent<T extends Record<string, unknown>> implements OnInit, OnDestroy {\n  private readonly modalService: ModalService = inject(ModalService);\n  @Input() data$!: Observable<T[]>;\n  @Input() columns: C80TableColDef[] = [];\n  @Input() size = 0; // Tamaño de la tabla (0 = sin límite, > 0 aplica max-height)\n  @Input() multiple = true; // Permite selección múltiple por defecto\n  @Input({ transform: (value: boolean | string) => value === '' || value === true || value === 'true' })\n  noConfirm = false; // Si es true, no muestra confirmaciones modales\n  @Output() createAction = new EventEmitter<{ row: Partial<T>; done: (result: boolean) => void; }>();\n  @Output() updateAction = new EventEmitter<{ id: ID; changes: Partial<T>; done: (result: boolean) => void; }>();\n  @Output() deleteAction = new EventEmitter<{ id: ID; done: (result: boolean) => void; }>();\n  @Output() cancelAction = new EventEmitter<{ id: ID; done: (result: boolean) => void; }>();\n  @Output() viewAction = new EventEmitter<T>();\n  @Output() getRowButtonAction = new EventEmitter<T>();\n  @Output() moveUpAction = new EventEmitter<{ id: ID; done: (result: boolean) => void; }>();\n  @Output() moveDownAction = new EventEmitter<{ id: ID; done: (result: boolean) => void; }>();\n  @Output() enableAction = new EventEmitter<{ id: ID; enabled: boolean; done: (result: boolean) => void; }>();\n  @Output() searchTerm = new EventEmitter<string>();\n\n  @Output() errorEvent = new EventEmitter<string>();\n  @Output() selectable = new EventEmitter<T[]>();\n\n  readonly data = signal<T[]>([]);\n  readonly keys = signal<string[]>([]);\n  creating = signal(false);\n  newRow = signal<Partial<T> | null>(null);\n  readonly editing = signal<ID | null>(null); // id of row being edited\n  readonly editRow = signal<Partial<T> | null>(null);\n  readonly selectedItems = signal<Set<ID>>(new Set());\n  readonly selectAllChecked = signal(false);\n  readonly selectAllIndeterminate = signal(false);\n  readonly searchValue = signal<string>('');\n\n  // Flags to check if events have listeners\n  readonly hasCreateActionListener = signal(false);\n  readonly hasUpdateActionListener = signal(false);\n  readonly hasDeleteActionListener = signal(false);\n  readonly hasCancelActionListener = signal(false);\n  readonly hasViewActionListener = signal(false);\n  readonly hasGetRowButtonListener = signal(false);\n  readonly hasMoveUpActionListener = signal(false);\n  readonly hasMoveDownActionListener = signal(false);\n  readonly hasEnableActionListener = signal(false);\n  readonly hasSearchTermListener = signal(false);\n  readonly hasSelectableListener = signal(false);\n\n  private dataSub?: Subscription;\n\n  private getErrorMessage(err: unknown): string {\n    return (err as any)?.message || 'Error al cargar datos';\n  }\n\n  /**\n   * Actualiza las keys de columnas visibles basándose en el estado actual\n   */\n  private updateVisibleKeys(): void {\n    const visibleColumns = this.columns.filter(col => this.isColumnVisibleInHeader(col));\n    this.keys.set(visibleColumns.map((col) => col.accessor));\n  }\n\n  ngOnInit() {\n    // Check if the outputs have listeners\n    this.hasCreateActionListener.set(this.createAction.observed);\n    this.hasUpdateActionListener.set(this.updateAction.observed);\n    this.hasDeleteActionListener.set(this.deleteAction.observed);\n    this.hasCancelActionListener.set(this.cancelAction.observed);\n    this.hasViewActionListener.set(this.viewAction.observed);\n    this.hasGetRowButtonListener.set(this.getRowButtonAction.observed);\n    this.hasMoveUpActionListener.set(this.moveUpAction.observed);\n    this.hasMoveDownActionListener.set(this.moveDownAction.observed);\n    this.hasEnableActionListener.set(this.enableAction.observed);\n    this.hasSearchTermListener.set(this.searchTerm.observed);\n    this.hasSelectableListener.set(this.selectable.observed);\n\n    if (!this.data$) return;\n    this.dataSub = this.data$.subscribe({\n      next: (items) => {\n        this.applySorting(items);\n        this.data.set(items);\n        // Actualizar las columnas visibles basándose en el estado actual\n        this.updateVisibleKeys();\n        // Mantener la selección existente después de actualizar los datos\n        this.preserveSelection();\n      },\n      error: (err: any) =>\n        this.errorEvent.emit(this.getErrorMessage(err)),\n    });\n  }\n\n  ngOnDestroy() {\n    this.dataSub?.unsubscribe();\n\n    // Close any open modal when component is destroyed\n    this.modalService.closeModal();\n  }\n\n  onInput(event: Event, key: string, col?: C80TableColDef) {\n    if (col?.type === 'boolean') {\n      const checked = (event.target as HTMLInputElement).checked;\n      this.updateNewRow(key, checked);\n    } else if (col?.type === 'enum') {\n      const value = (event.target as HTMLSelectElement).value;\n      this.updateNewRow(key, value);\n    } else {\n      const target = event.target as HTMLInputElement;\n      if (target && typeof target.value === 'string') {\n        this.updateNewRow(key, target.value);\n      }\n    }\n  }\n\n  async onDelete(row: T) {\n    const id = row['id'] as ID;\n\n    let confirmed = true;\n    if (!this.noConfirm) {\n      confirmed = await this.modalService.confirm(\n        'Confirmar eliminación',\n        '¿Está seguro de que desea eliminar este elemento? Esta acción no se puede deshacer.',\n        'Eliminar',\n        'Cancelar'\n      );\n    }\n\n    if (confirmed) {\n      this.deleteAction.emit({\n        id,\n        done: (success: boolean) => {\n          if (success) this.cancelEdit();\n        },\n      });\n    }\n  }\n\n  async onCancel(row: T) {\n    const id = row['id'] as ID;\n\n    let confirmed = true;\n    if (!this.noConfirm) {\n      confirmed = await this.modalService.confirm(\n        'Confirmar cancelación',\n        '¿Está seguro de que desea cancelar este elemento?',\n        'Cancelar elemento',\n        'No cancelar'\n      );\n    }\n\n    if (confirmed) {\n      this.cancelAction.emit({\n        id,\n        done: (success: boolean) => {\n          if (success) this.cancelEdit();\n        },\n      });\n    }\n  }\n\n  startCreate() {\n    this.creating.set(true);\n    // Actualizar keys de columnas visibles cuando entramos en modo creación\n    this.updateVisibleKeys();\n    // Inicializa newRow solo con columnas visibles y no readOnly\n    // En modo creación, mostramos columnas con hideIfAllValuesAreNull para permitir entrada de datos\n    const row: Partial<T> = {};\n    this.columns\n      .filter((col) => this.isColumnVisible(col, true) && !col.readOnly)\n      .forEach((col) => {\n        // Si la columna tiene un valor por defecto, usarlo; si no, usar cadena vacía\n        const defaultValue = col.default !== undefined ? col.default : '';\n        (row as Record<string, unknown>)[col.accessor] = defaultValue;\n      });\n    this.newRow.set(row);\n  }\n\n  cancelCreate() {\n    this.creating.set(false);\n    this.newRow.set(null);\n    // Actualizar keys de columnas visibles cuando salimos del modo creación\n    this.updateVisibleKeys();\n  }\n\n  updateNewRow(key: string, value: unknown) {\n    const current = this.newRow();\n    if (!current) return;\n    this.newRow.set({ ...current, [key]: value });\n  }\n\n  saveCreate() {\n    const row = this.newRow();\n    if (!row) return;\n\n    // Validar campos requeridos antes de crear - solo columnas visibles y no readOnly\n    // En modo creación, incluimos columnas con hideIfAllValuesAreNull\n    const visibleColumns = this.columns.filter((col) => this.isColumnVisible(col, true) && !col.readOnly);\n    const converted = visibleColumns.reduce((acc, col) => {\n      acc[col.accessor] = this.convertCellValue(row[col.accessor], col);\n      return acc;\n    }, {} as Record<string, unknown>) as Partial<T>;\n\n    this.createAction.emit({\n      row: converted,\n      done: (success: boolean) => {\n        if (success) {\n          this.cancelCreate();\n        }\n      },\n    });\n  }\n\n  /**\n   * Converts a cell value based on column type or sample data.\n   * Handles stringification of objects for string columns.\n   */\n  /**\n   * Converts a cell value based on column type or sample data.\n   * Delegates to type-specific helpers for clarity and maintainability.\n   */\n  private convertCellValue(value: unknown, col: C80TableColDef): unknown {\n    if (col.type === 'boolean') return this.toBoolean(value);\n    if (col.type === 'number') return this.toNumber(value);\n    if (col.type === 'string' || col.type === 'password')\n      return this.toStringValue(value);\n\n    // Fallback: use sample data if available\n    const sample = this.data()[0];\n    if (sample) {\n      const sampleValue = this.getCellValue(sample, col.accessor);\n      if (typeof sampleValue === 'boolean') return this.toBoolean(value);\n      if (typeof sampleValue === 'number') return this.toNumber(value);\n      if (typeof sampleValue === 'string') return this.toStringValue(value);\n    }\n    return value;\n  }\n\n  /** Converts value to boolean using best practices. */\n  private toBoolean(value: unknown): boolean {\n    if (typeof value === 'boolean') return value;\n    if (typeof value === 'string')\n      return value.trim().toLowerCase() === 'true' || value.trim() === '1';\n    if (typeof value === 'number') return value === 1;\n    return false;\n  }\n\n  /** Converts value to number using best practices. */\n  private toNumber(value: unknown): number | undefined {\n    if (typeof value === 'number') return value;\n    if (typeof value === 'string')\n      return value.trim() === '' ? undefined : Number(value);\n    if (typeof value === 'boolean') return value ? 1 : 0;\n    return undefined;\n  }\n\n  /** Converts value to string using best practices, always stringifies objects. */\n  private toStringValue(value: unknown): string {\n    if (value == null) return '';\n    if (typeof value === 'string') return value;\n    if (typeof value === 'number' || typeof value === 'boolean')\n      return String(value);\n    if (typeof value === 'object') {\n      try {\n        return JSON.stringify(value);\n      } catch {\n        return '[object Object]';\n      }\n    }\n    // For functions, symbols, undefined, etc., return empty string\n    return '';\n  }\n\n  onEdit(row: T) {\n    this.editing.set(row['id'] as ID);\n    // Actualizar keys de columnas visibles cuando entramos en modo edición\n    this.updateVisibleKeys();\n    const edit: Partial<T> = {};\n    this.columns\n      .filter((col) => this.isColumnVisible(col, true) && !col.readOnly)\n      .forEach((col) => {\n        const value = this.getCellValue(row, col.accessor);\n        (edit as Record<string, unknown>)[col.accessor] = value;\n      });\n    this.editRow.set(edit);\n  }\n\n  cancelEdit() {\n    this.editing.set(null);\n    this.editRow.set(null);\n    // Actualizar keys de columnas visibles cuando salimos del modo edición\n    this.updateVisibleKeys();\n  }\n\n  onEditInput(event: Event, key: string, col?: C80TableColDef) {\n    const current = this.editRow();\n    if (!current) return;\n    if (col?.type === 'boolean') {\n      const checked = (event.target as HTMLInputElement).checked;\n      this.editRow.set({ ...current, [key]: checked });\n    } else if (col?.type === 'enum') {\n      const value = (event.target as HTMLSelectElement).value;\n      this.editRow.set({ ...current, [key]: value });\n    } else {\n      const target = event.target as HTMLInputElement;\n      if (target && typeof target.value === 'string') {\n        this.editRow.set({ ...current, [key]: target.value });\n      }\n    }\n  }\n\n  saveEdit(row: T) {\n    const id = row['id'];\n    if ((typeof id !== 'string' && typeof id !== 'number') || !this.editRow())\n      return;\n    const visibleColumns = this.columns.filter(\n      (col) => this.isColumnVisible(col, true) && !col.readOnly\n    );\n    const converted = visibleColumns.reduce((acc, col) => {\n      acc[col.accessor] = this.convertCellValue(\n        this.editRow()![col.accessor],\n        col\n      );\n      return acc;\n    }, {} as Record<string, unknown>) as Partial<T>;\n\n    this.updateAction.emit({\n      id,\n      changes: converted,\n      done: (success: boolean) => {\n        if (success) {\n          this.cancelEdit();\n        }\n      },\n    });\n  }\n\n  /**\n   * TrackBy function for ngFor to avoid DOM re-creation (NG0956 warning).\n   */\n  trackById(index: number, row: T): number | string {\n    const id =\n      row && typeof row === 'object' && 'id' in row\n        ? (row as Record<string, unknown>)['id']\n        : undefined;\n    return typeof id === 'string' || typeof id === 'number' ? id : index;\n  }\n\n  /**\n   * Emits the view event with the entire row data\n   */\n  onView(row: T): void {\n    this.viewAction.emit(row);\n  }\n\n  /**\n   * Emits the getRowButtonAction event with the entire row data\n   */\n  onGetRowButton(row: T): void {\n    this.getRowButtonAction.emit(row);\n  }\n\n  /**\n   * Emits the moveUpAction event with the row id\n   */\n  async onMoveUp(row: T) {\n    const id = row['id'] as ID;\n    this.moveUpAction.emit({\n      id,\n      done: (success: boolean) => {\n        if (success) this.cancelEdit();\n      },\n    });\n  }\n\n  /**\n   * Emits the moveDownAction event with the row id\n   */\n  async onMoveDown(row: T) {\n    const id = row['id'] as ID;\n    this.moveDownAction.emit({\n      id,\n      done: (success: boolean) => {\n        if (success) this.cancelEdit();\n      },\n    });\n  }\n\n  /**\n   * Emits the enableAction event with the row id and current enabled status\n   */\n  async onEnable(row: T) {\n    const id = row['id'] as ID;\n    const currentEnabled = row['enabled'] as boolean;\n    this.enableAction.emit({\n      id,\n      enabled: !currentEnabled, // Toggle the current state\n      done: (success: boolean) => {\n        if (success) this.cancelEdit();\n      },\n    });\n  }\n\n  /**\n   * Handles search input changes with debouncing\n   */\n  onSearchInput(event: Event): void {\n    const target = event.target as HTMLInputElement;\n    const value = target.value;\n    this.searchValue.set(value);\n    this.searchTerm.emit(value);\n  }\n\n  /**\n   * Clears the search input\n   */\n  clearSearch(): void {\n    this.searchValue.set('');\n    this.searchTerm.emit('');\n  }\n\n  /**\n   * Gets the value from an object using dot notation (e.g., 'task.name')\n   */\n  private getNestedValue(obj: any, accessor: string): unknown {\n    return accessor.split('.').reduce((current, key) => {\n      return current && typeof current === 'object' ? current[key] : undefined;\n    }, obj);\n  }\n\n  /**\n   * Gets the value for a cell using the accessor, supporting dot notation for nested properties\n   */\n  getCellValue(row: T, accessor: string): unknown {\n    if (accessor.includes('.')) {\n      return this.getNestedValue(row, accessor);\n    }\n    return (row as Record<string, unknown>)[accessor];\n  }\n\n  /**\n   * Returns the display value for a cell, showing '-' for falsy values except 0, false, and empty objects/arrays\n   */\n  getDisplayValue(value: unknown): string {\n    // If value is 0, show it\n    if (value === 0) {\n      return '0';\n    }\n    // If value is false, it should be handled by boolean logic in template, not here\n    if (value === false) {\n      return 'false';\n    }\n    // Handle objects and arrays (including empty ones)\n    if (typeof value === 'object' && value !== null) {\n      try {\n        return JSON.stringify(value);\n      } catch {\n        return '[object Object]';\n      }\n    }\n    // If value is other falsy values (null, undefined, ''), show '-'\n    if (!value) {\n      return '-';\n    }\n    // Handle other types explicitly\n    if (\n      typeof value === 'string' ||\n      typeof value === 'number' ||\n      typeof value === 'boolean'\n    ) {\n      return String(value);\n    }\n    // For any other type (function, symbol, etc.), return a safe fallback\n    return '-';\n  }\n\n  /**\n   * Gets the display text for an enum value\n   */\n  getEnumDisplayValue(value: unknown, col: C80TableColDef): string {\n    if (!col.enum || (value !== 0 && !value)) {\n      return '-';\n    }\n    const displayValue = col.enum[value as string | number];\n    return (\n      displayValue ||\n      (typeof value === 'string' || typeof value === 'number'\n        ? String(value)\n        : '-')\n    );\n  }\n\n  /**\n   * Gets the enum options as an array for select dropdowns\n   */\n  getEnumOptions(\n    col: C80TableColDef\n  ): { value: string | number; label: string }[] {\n    if (!col.enum) return [];\n    return Object.entries(col.enum).map(([value, label]) => ({\n      value: isNaN(Number(value)) ? value : Number(value),\n      label,\n    }));\n  }\n\n  /**\n   * Gets the CSS color for a cell value based on the column's color configuration\n   */\n  getCellColor(value: unknown, col: C80TableColDef): string | undefined {\n    if (!col.color || (value !== 0 && !value)) {\n      return undefined;\n    }\n    return col.color[value as string | number];\n  }\n\n  /**\n   * Calcula el max-height de la tabla basado en el tamaño\n   * Si size es 0, retorna undefined (sin límite de altura)\n   */\n  getTableMaxHeight(): string | undefined {\n    if (this.size <= 0) {\n      return undefined; // Sin límite de altura\n    }\n    // Altura base de 400px * size\n    const baseHeight = 400;\n    const maxHeight = Math.round(baseHeight * this.size);\n    return `${maxHeight}px`;\n  }\n\n  /**\n   * Selection methods\n   */\n  clearSelection(): void {\n    this.selectedItems.set(new Set());\n    this.updateSelectAllState();\n    this.emitSelection();\n  }\n\n  /**\n   * Mantiene la selección existente después de actualizar los datos,\n   * eliminando solo los IDs que ya no existen en los nuevos datos\n   */\n  private preserveSelection(): void {\n    const currentSelection = this.selectedItems();\n    const currentData = this.data();\n\n    if (currentSelection.size === 0 || currentData.length === 0) {\n      // Si no hay selección o no hay datos, limpiar la selección\n      this.clearSelection();\n      return;\n    }\n\n    // Obtener los IDs disponibles en los nuevos datos\n    const availableIds = new Set(currentData.map(item => item['id'] as ID));\n\n    // Filtrar la selección actual para mantener solo los IDs que aún existen\n    const preservedSelection = new Set(\n      Array.from(currentSelection).filter(id => availableIds.has(id))\n    );\n\n    // Actualizar la selección con los IDs preservados\n    this.selectedItems.set(preservedSelection);\n    this.updateSelectAllState();\n    this.emitSelection();\n  }\n\n  toggleSelectAll(): void {\n    const currentSelection = this.selectedItems();\n    const allItems = this.data();\n\n    if (currentSelection.size === allItems.length) {\n      // Deselect all\n      this.clearSelection();\n    } else {\n      // Select all\n      const allIds = new Set(allItems.map(item => item['id'] as ID));\n      this.selectedItems.set(allIds);\n      this.updateSelectAllState();\n      this.emitSelection();\n    }\n  }\n\n  toggleItemSelection(item: T): void {\n    const id = item['id'] as ID;\n    const currentSelection = new Set(this.selectedItems());\n\n    if (!this.multiple) {\n      // Selección simple: solo permitir un elemento seleccionado\n      if (currentSelection.has(id)) {\n        // Deseleccionar el elemento actual\n        currentSelection.clear();\n      } else {\n        // Seleccionar solo este elemento\n        currentSelection.clear();\n        currentSelection.add(id);\n      }\n    } else if (currentSelection.has(id)) {\n      // Selección múltiple: deseleccionar elemento existente\n      currentSelection.delete(id);\n    } else {\n      // Selección múltiple: agregar nuevo elemento\n      currentSelection.add(id);\n    }\n\n    this.selectedItems.set(currentSelection);\n    this.updateSelectAllState();\n    this.emitSelection();\n  } isItemSelected(item: T): boolean {\n    const id = item['id'] as ID;\n    return this.selectedItems().has(id);\n  }\n\n  private updateSelectAllState(): void {\n    const selectedCount = this.selectedItems().size;\n    const totalCount = this.data().length;\n\n    if (selectedCount === 0) {\n      this.selectAllChecked.set(false);\n      this.selectAllIndeterminate.set(false);\n    } else if (selectedCount === totalCount) {\n      this.selectAllChecked.set(true);\n      this.selectAllIndeterminate.set(false);\n    } else {\n      this.selectAllChecked.set(false);\n      this.selectAllIndeterminate.set(true);\n    }\n  }\n\n  private emitSelection(): void {\n    const selectedIds = this.selectedItems();\n    const selectedItems = this.data().filter(item =>\n      selectedIds.has(item['id'] as ID)\n    );\n    this.selectable.emit(selectedItems);\n  }\n\n  /**\n   * Verifica si todos los valores de una columna están vacíos/nulos\n   */\n  private areAllColumnValuesEmpty(column: C80TableColDef): boolean {\n    const currentData = this.data();\n\n    if (currentData.length === 0) {\n      return true; // Si no hay datos, consideramos la columna como vacía\n    }\n\n    return currentData.every(row => {\n      const value = this.getCellValue(row, column.accessor);\n\n      // Considerar vacío: null, undefined, '', 0 (para números), false (para booleanos), arrays/objetos vacíos\n      if (value === null || value === undefined || value === '') {\n        return true;\n      }\n\n      // Para números, 0 se considera como valor válido, no vacío\n      if (typeof value === 'number') {\n        return false;\n      }\n\n      // Para booleanos, false se considera como valor válido, no vacío\n      if (typeof value === 'boolean') {\n        return false;\n      }\n\n      // Para arrays vacíos\n      if (Array.isArray(value) && value.length === 0) {\n        return true;\n      }\n\n      // Para objetos vacíos\n      if (typeof value === 'object' && value !== null && Object.keys(value).length === 0) {\n        return true;\n      }\n\n      return false;\n    });\n  }\n\n  /**\n   * Determina si una columna debe ser visible basándose en su configuración y datos.\n   *\n   * Orden de prioridad:\n   * 1. Si visible === false: SIEMPRE se oculta (máxima prioridad)\n   * 2. Si hideIfAllValuesAreNull === true Y todos los valores están vacíos: se oculta\n   *    EXCEPCIÓN: En modo creación (creating === true), estas columnas se muestran para permitir entrada de datos\n   * 3. Por defecto: se muestra\n   *\n   * @param column - La definición de la columna\n   * @param forceShowInCreation - Si es true, ignora hideIfAllValuesAreNull (usado en modo creación)\n   */\n  isColumnVisible(column: C80TableColDef, forceShowInCreation = false): boolean {\n    // PRIORIDAD 1: Si visible está explícitamente establecido en false, SIEMPRE ocultar\n    if (column.visible === false) {\n      return false;\n    }\n\n    // PRIORIDAD 2: Si hideIfAllValuesAreNull es true y todos los valores están vacíos, ocultar\n    // EXCEPCIÓN: En modo creación, mostramos estas columnas para permitir entrada de datos\n    if (column.hideIfAllValuesAreNull === true && !forceShowInCreation && this.areAllColumnValuesEmpty(column)) {\n      return false;\n    }\n\n    // Por defecto: mostrar\n    return true;\n  }\n\n  /**\n   * Determina si una columna debe ser visible en los headers.\n   * Los headers se muestran si la columna es visible en cualquiera de estos casos:\n   * - Visualización normal\n   * - Modo creación\n   * - Hay alguna fila en modo edición\n   *\n   * @param column - La definición de la columna\n   */\n  isColumnVisibleInHeader(column: C80TableColDef): boolean {\n    // PRIORIDAD 1: Si visible está explícitamente establecido en false, SIEMPRE ocultar\n    if (column.visible === false) {\n      return false;\n    }\n\n    // Si estamos en modo creación, mostrar columnas con hideIfAllValuesAreNull\n    if (this.creating() && column.hideIfAllValuesAreNull === true) {\n      return true;\n    }\n\n    // Si hay alguna fila en modo edición, mostrar columnas con hideIfAllValuesAreNull\n    if (this.editing() !== null && column.hideIfAllValuesAreNull === true) {\n      return true;\n    }\n\n    // Si hideIfAllValuesAreNull es true y todos los valores están vacíos, ocultar\n    if (column.hideIfAllValuesAreNull === true && this.areAllColumnValuesEmpty(column)) {\n      return false;\n    }\n\n    // Por defecto: mostrar\n    return true;\n  }\n\n  /**\n   * Determina si una columna debe ser visible en una fila específica considerando el modo edición.\n   * En modo edición de esa fila específica, las columnas con hideIfAllValuesAreNull se muestran.\n   *\n   * @param column - La definición de la columna\n   * @param row - La fila actual\n   */\n  isColumnVisibleForRow(column: C80TableColDef, row: T): boolean {\n    // PRIORIDAD 1: Si visible está explícitamente establecido en false, SIEMPRE ocultar\n    if (column.visible === false) {\n      return false;\n    }\n\n    // PRIORIDAD 2: Si esta fila específica está en modo edición, mostrar columnas con hideIfAllValuesAreNull\n    const isEditingThisRow = this.editing() === row['id'];\n    if (isEditingThisRow && column.hideIfAllValuesAreNull === true) {\n      return true;\n    }\n\n    // PRIORIDAD 3: Si hideIfAllValuesAreNull es true y todos los valores están vacíos, ocultar\n    if (column.hideIfAllValuesAreNull === true && this.areAllColumnValuesEmpty(column)) {\n      return false;\n    }\n\n    // Por defecto: mostrar\n    return true;\n  }\n\n  private applySorting(items: T[]): void {\n    const orderedColumns = this.columns.filter((col) => col.order);\n    if (orderedColumns.length > 0) {\n      orderedColumns.forEach((col) => {\n        items.sort((a, b) => {\n          const valueA = this.getCellValue(a, col.accessor) as string | number;\n          const valueB = this.getCellValue(b, col.accessor) as string | number;\n\n          if (col.order === 'ASC') {\n            if (valueA > valueB) return 1;\n            if (valueA < valueB) return -1;\n            return 0;\n          } else {\n            if (valueA < valueB) return 1;\n            if (valueA > valueB) return -1;\n            return 0;\n          }\n        });\n      });\n    }\n  }\n}\n","<div class=\"table-responsive\" [style.max-height]=\"getTableMaxHeight()\" [style.overflow-y]=\"size > 0 ? 'auto' : 'visible'\">\n  <!-- Search Bar -->\n  @if (hasSearchTermListener()) {\n  <div class=\"search-container\">\n    <div class=\"search-input-wrapper\">\n      <div class=\"input-group\">\n        <span class=\"input-group-text\">\n          <c80-icon icon=\"search\" [size]=\".8\"></c80-icon>\n        </span>\n        <input type=\"text\" class=\"form-control search-input\" placeholder=\"Buscar...\" [value]=\"searchValue()\" (input)=\"onSearchInput($event)\" aria-label=\"Buscar en la tabla\" />\n        @if (searchValue()) {\n        <button class=\"btn btn-outline-secondary btn-borrar\" type=\"button\" (click)=\"clearSearch()\" title=\"Limpiar búsqueda\">\n          <c80-icon icon=\"cancel\" [size]=\".7\"></c80-icon>\n        </button>\n        }\n      </div>\n    </div>\n  </div>\n  }\n\n  <table class=\"table table-bordered table-hover align-middle\">\n    <thead class=\"thead table-light sticky-header\">\n      <tr>\n        @if (hasSelectableListener() && data().length !== 0) {\n        <th class=\"text-center selection-column\">\n          @if (multiple) {\n          <input type=\"checkbox\" [checked]=\"selectAllChecked()\" [indeterminate]=\"selectAllIndeterminate()\" (change)=\"toggleSelectAll()\" aria-label=\"Seleccionar todo\" />\n          }\n        </th>\n        }\n        @for (col of columns; track col) {\n        @if (isColumnVisibleInHeader(col)) {\n        @if (col.type === 'boolean') {\n        <th class=\"text-center boolean-column\">{{ col.label }}</th>\n        }\n        @else if (col.type === 'number') {\n        <th class=\"text-center number-column\">{{ col.label }}</th>\n        }\n        @else {\n        <th>{{ col.label }}</th>\n        }\n        }\n        }\n        @if (hasCreateActionListener() || hasUpdateActionListener() || hasDeleteActionListener() ||\n        hasCancelActionListener() || hasViewActionListener() || hasGetRowButtonListener() ||\n        hasMoveUpActionListener() || hasMoveDownActionListener()) {\n        <th class=\"table-actions-header\">\n          <div class=\"actions-wrapper\">\n            <span>Actions</span>\n            @if (hasCreateActionListener()) {\n            <c80-icon button icon=\"add\" [disabled]=\"creating()\" title=\"Agregar\" [size]=\".6\" (iconClick)=\"startCreate()\"></c80-icon>\n            }\n          </div>\n        </th>\n        }\n      </tr>\n    </thead>\n    <tbody>\n      @for (row of data(); track trackById(i, row); let i = $index) {\n      <tr>\n        @if (hasSelectableListener() && data().length !== 0) {\n        <td class=\"text-center selection-column\">\n          <input type=\"checkbox\" [checked]=\"isItemSelected(row)\" (change)=\"toggleItemSelection(row)\" [attr.aria-label]=\"'Seleccionar fila ' + (i + 1)\" />\n        </td>\n        }\n        @for (col of columns; track col) {\n        @if (isColumnVisibleForRow(col, row)) {\n        @if (col.type === 'boolean') {\n        <td class=\"text-center boolean-column\">\n          @if (editing() === row['id'] && !col.readOnly) {\n          <input type=\"checkbox\" [checked]=\"!!editRow()?.[col.accessor]\" (change)=\"onEditInput($event, col.accessor, col)\" [attr.aria-label]=\"col.label\" />\n          }\n          @else {\n          @if (getCellValue(row, col.accessor) === true) {\n          <c80-icon icon=\"check\" [size]=\".7\"></c80-icon>\n          <br />\n          }\n          @else if (getCellValue(row, col.accessor) === false) {\n          <c80-icon icon=\"cancel\" [size]=\".7\"></c80-icon>\n          <br />\n          }\n          }\n        </td>\n        }\n        @else if (col.type === 'number') {\n        <td class=\"text-center number-column\">\n          @if (editing() === row['id'] && !col.readOnly) {\n          <input class=\"form-control form-control-sm\" type=\"number\" [value]=\"editRow()?.[col.accessor] ?? ''\" [placeholder]=\"col.label\" (input)=\"onEditInput($event, col.accessor, col)\" />\n          }\n          @else {\n          <span [style.color]=\"getCellColor(getCellValue(row, col.accessor), col)\">{{ getDisplayValue(getCellValue(row,\n            col.accessor)) }}</span>\n          }\n        </td>\n        }\n        @else {\n        <td>\n          @if (editing() === row['id'] && !col.readOnly) {\n          @if (col.type === 'enum') {\n          <select class=\"form-control form-control-sm\" [value]=\"editRow()?.[col.accessor] ?? ''\" (change)=\"onEditInput($event, col.accessor, col)\">\n            <option value=\"\">{{ col.label }}</option>\n            @for (option of getEnumOptions(col); track option.value) {\n            <option [value]=\"option.value\">{{ option.label }}</option>\n            }\n          </select>\n          }\n          @else {\n          <input class=\"form-control form-control-sm\" [type]=\"col.type === 'password' ? 'password' : 'text'\" [value]=\"editRow()?.[col.accessor] ?? ''\" [placeholder]=\"col.label\" (input)=\"onEditInput($event, col.accessor, col)\" />\n          }\n          }\n          @else {\n          @if (col.type === 'password') {\n          <span [style.color]=\"getCellColor(getCellValue(row, col.accessor), col)\">******</span>\n          }\n          @else if (col.type === 'enum') {\n          <span [style.color]=\"getCellColor(getCellValue(row, col.accessor), col)\">{{\n            getEnumDisplayValue(getCellValue(row, col.accessor), col)\n            }}</span>\n          }\n          @else if (getCellValue(row, col.accessor) === true) {\n          <c80-icon icon=\"check\" [size]=\".7\"></c80-icon>\n          }\n          @else if (getCellValue(row, col.accessor) === false) {\n          <c80-icon icon=\"cancel\" [size]=\".7\"></c80-icon>\n          }\n          @else {\n          <span [style.color]=\"getCellColor(getCellValue(row, col.accessor), col)\">{{ getDisplayValue(getCellValue(row,\n            col.accessor)) }}</span>\n          }\n          }\n        </td>\n        }\n        }\n        }\n        @if (hasCreateActionListener() || hasUpdateActionListener() || hasDeleteActionListener() ||\n        hasCancelActionListener() || hasViewActionListener() || hasGetRowButtonListener() ||\n        hasMoveUpActionListener() || hasMoveDownActionListener()) {\n        <td class=\"text-center actions-cell\">\n          <div class=\"actions-container\">\n            @if (editing() === row['id']) {\n            <c80-icon button icon=\"check\" title=\"Guardar\" (iconClick)=\"saveEdit(row)\" [size]=\".7\"></c80-icon>\n            <c80-icon button icon=\"cancel\" color=\"warn\" title=\"Cancelar\" (iconClick)=\"cancelEdit()\" [size]=\".7\"></c80-icon>\n            }\n            @else {\n            @if (hasUpdateActionListener()) {\n            <c80-icon button icon=\"edit\" title=\"Editar\" (iconClick)=\"onEdit(row)\" [size]=\".7\"></c80-icon>\n            }\n            @if (hasCancelActionListener()) {\n            <c80-icon button icon=\"cancel_circle\" color=\"secondary\" title=\"Cancelar\" (iconClick)=\"onCancel(row)\" [size]=\".7\"></c80-icon>\n            }\n            @if (hasViewActionListener()) {\n            <c80-icon button icon=\"view\" color=\"primary\" title=\"Ver\" (iconClick)=\"onView(row)\" [size]=\".7\"></c80-icon>\n            }\n            @if (hasGetRowButtonListener()) {\n            <c80-icon button icon=\"get\" color=\"success\" title=\"Vincular\" (iconClick)=\"onGetRowButton(row)\" [size]=\".7\"></c80-icon>\n            }\n            @if (hasMoveUpActionListener()) {\n            <c80-icon button icon=\"arrow_up\" color=\"secondary\" title=\"Mover arriba\" (iconClick)=\"onMoveUp(row)\" [size]=\".7\"></c80-icon>\n            }\n            @if (hasMoveDownActionListener()) {\n            <c80-icon button icon=\"arrow_down\" color=\"secondary\" title=\"Mover abajo\" (iconClick)=\"onMoveDown(row)\" [size]=\".7\"></c80-icon>\n            }\n            @if (hasEnableActionListener()) {\n            <c80-icon button [icon]=\"getCellValue(row, 'enabled') ? 'toggle_on' : 'toggle_off'\" [color]=\"getCellValue(row, 'enabled') ? 'success' : 'secondary'\" [title]=\"getCellValue(row, 'enabled') ? 'Deshabilitar' : 'Habilitar'\"\n              (iconClick)=\"onEnable(row)\" [size]=\".7\">\n            </c80-icon>\n            }\n            @if (hasDeleteActionListener()) {\n            <c80-icon button icon=\"delete\" color=\"warn\" title=\"Borrar\" (iconClick)=\"onDelete(row)\" [size]=\".7\"></c80-icon>\n            }\n            }\n          </div>\n        </td>\n        }\n      </tr>\n      }\n      @if (creating() && hasCreateActionListener()) {\n      <tr>\n        @if (hasSelectableListener() && data().length !== 0) {\n        <td class=\"text-center selection-column\">\n          <!-- Empty cell for alignment -->\n        </td>\n        }\n        @for (col of columns; track col) {\n        @if (isColumnVisible(col, true)) {\n        @if (col.type === 'boolean') {\n        <td class=\"text-center\">\n          @if (!col.readOnly) {\n          <input type=\"checkbox\" [checked]=\"!!newRow()?.[col.accessor]\" (change)=\"onInput($event, col.accessor, col)\" [attr.aria-label]=\"col.label\" />\n          }\n          @else {\n          <!-- ReadOnly boolean column in create mode shows empty -->\n          <span class=\"text-muted\">-</span>\n          }\n        </td>\n        } @else if (col.type === 'number') {\n        <td class=\"text-center number-column\">\n          @if (!col.readOnly) {\n          <input class=\"form-control form-control-sm\" type=\"number\" [value]=\"newRow()?.[col.accessor] ?? ''\" [placeholder]=\"col.label\" (input)=\"onInput($event, col.accessor, col)\" />\n          }\n          @else {\n          <!-- ReadOnly number column in create mode shows empty -->\n          <span class=\"text-muted\">-</span>\n          }\n        </td>\n        } @else {\n        <td>\n          @if (!col.readOnly) {\n          @if (col.type === 'enum') {\n          <select class=\"form-control form-control-sm\" [value]=\"newRow()?.[col.accessor] ?? ''\" (change)=\"onInput($event, col.accessor, col)\">\n            <option value=\"\">{{ col.label }}</option>\n            @for (option of getEnumOptions(col); track option.value) {\n            <option [value]=\"option.value\">{{ option.label }}</option>\n            }\n          </select>\n          }\n          @else {\n          <input class=\"form-control form-control-sm\" type=\"text\" [value]=\"newRow()?.[col.accessor] ?? ''\" [placeholder]=\"col.label\" (input)=\"onInput($event, col.accessor, col)\" />\n          }\n          }\n          @else {\n          <!-- ReadOnly column in create mode shows empty -->\n          <span class=\"text-muted\">-</span>\n          }\n        </td>\n        }\n        }\n        }\n        <td class=\"text-center actions-cell\">\n          <div class=\"actions-container\">\n            <c80-icon button icon=\"check\" title=\"Guardar\" (iconClick)=\"saveCreate()\" [size]=\".7\"></c80-icon>\n            <c80-icon button icon=\"cancel\" color=\"warn\" title=\"Cancelar\" (iconClick)=\"cancelCreate()\" [size]=\".7\"></c80-icon>\n          </div>\n        </td>\n      </tr>\n      }\n    </tbody>\n  </table>\n  @if (data().length === 0 && !creating()) {\n  <div class=\"text-center text-muted py-3 small\">\n    No hay datos para mostrar.\n  </div>\n  }\n</div>\n\n<c80-modal></c80-modal>"]}
@@ -11,6 +11,7 @@ export interface C80TableColDef {
11
11
  enum?: Record<string | number, string>;
12
12
  color?: Record<string | number, string>;
13
13
  hideIfAllValuesAreNull?: boolean;
14
+ default?: unknown;
14
15
  }
15
16
  export type ID = number | string;
16
17
  /**
@@ -34,10 +35,19 @@ export type ID = number | string;
34
35
  * 3. POR DEFECTO - Columnas normales
35
36
  * - Se muestran siempre (visualización, creación y edición)
36
37
  *
38
+ * VALORES POR DEFECTO EN CREACIÓN:
39
+ * ===============================
40
+ *
41
+ * - Propiedad `default?: unknown` permite definir valores por defecto para modo creación
42
+ * - Solo se aplica cuando se inicia el modo creación (startCreate)
43
+ * - Puede ser cualquier tipo: string, number, boolean, etc.
44
+ * - Si no se especifica `default`, se usa cadena vacía ('')
45
+ *
37
46
  * EJEMPLOS:
38
47
  * - { accessor: 'id', visible: false } → NUNCA se muestra
39
- * - { accessor: 'motorPos', hideIfAllValuesAreNull: true } → Se oculta si todos vacíos, PERO se muestra en creación/edición
40
- * - { accessor: 'name' } → Siempre visible
48
+ * - { accessor: 'motorPos', hideIfAllValuesAreNull: true, default: 0 } → Se autorellena con 0 en creación
49
+ * - { accessor: 'status', default: 'active' } → Se autorellena con 'active' en creación
50
+ * - { accessor: 'name' } → Siempre visible, sin valor por defecto (cadena vacía)
41
51
  */ export declare class C80TableComponent<T extends Record<string, unknown>> implements OnInit, OnDestroy {
42
52
  private readonly modalService;
43
53
  data$: Observable<T[]>;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@c80/ui",
3
- "version": "1.0.23",
3
+ "version": "1.0.24",
4
4
  "peerDependencies": {
5
5
  "@angular/core": "^18.2.0",
6
6
  "rxjs": "~7.8.0",