@seniorsistemas/components-ai 1.0.0 → 1.0.1-master-e779ef31

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.
@@ -164,6 +164,9 @@ export class DynamicFieldLookupComponent {
164
164
  page: this.currentPage,
165
165
  size: this.pageSize
166
166
  };
167
+ if (this.field.lookupSort) {
168
+ listParams.sort = this.field.lookupSort;
169
+ }
167
170
  if (this.searchTerm.trim()) {
168
171
  const term = this.searchTerm.trim();
169
172
  const filterConditions = [];
@@ -582,4 +585,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
582
585
  }], mode: [{
583
586
  type: Input
584
587
  }] } });
585
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dynamic-field-lookup.component.js","sourceRoot":"","sources":["../../../../../../projects/components-ai/src/lib/components/dynamic-form/fields/dynamic-field-lookup.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnInit } from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { FormGroup, ReactiveFormsModule, FormsModule } from '@angular/forms';\nimport { ButtonModule } from 'primeng/button';\nimport { InputTextModule } from 'primeng/inputtext';\nimport { DialogModule } from 'primeng/dialog';\nimport { TableModule } from 'primeng/table';\nimport { TooltipModule } from 'primeng/tooltip';\nimport { DynamicFormFieldConfig } from '../models/dynamic-form.models';\nimport { TranslatePipe } from '../../../pipes/translate.pipe';\nimport { TranslationHelper } from '../../../utils/translation.helper';\nimport { TranslationService } from '../../../services/translation.service';\nimport { DynamicFieldWrapperComponent } from './dynamic-field-wrapper.component';\nimport { LookupColumn } from '../../../models/entity-list.config';\n\n@Component({\n  selector: 'sia-dynamic-field-lookup',\n  standalone: true,\n  imports: [\n    CommonModule,\n    ReactiveFormsModule,\n    FormsModule,\n    ButtonModule,\n    InputTextModule,\n    DialogModule,\n    TableModule,\n    TooltipModule,\n    TranslatePipe,\n    DynamicFieldWrapperComponent\n  ],\n  template: `\n    <sia-dynamic-field-wrapper [field]=\"field\" [form]=\"form\" [mode]=\"mode\">\n      <div [formGroup]=\"form\" class=\"lookup-field\" [ngClass]=\"{'disabled': isFieldDisabled()}\">\n        <!-- Hidden input para o formControl -->\n        <input type=\"hidden\" [formControlName]=\"field.field\" />\n        \n        <div class=\"lookup-input-group\">\n          <input\n            pInputText\n            [value]=\"displayValue\"\n            [placeholder]=\"getPlaceholder()\"\n            [class.p-invalid]=\"isFieldInvalid()\"\n            [disabled]=\"isFieldDisabled()\"\n            readonly\n            class=\"lookup-display\"\n            (click)=\"openLookup()\"\n          />\n          <div class=\"lookup-buttons\">\n            <p-button\n              *ngIf=\"currentValue\"\n              icon=\"pi pi-trash\"\n              severity=\"danger\"\n              [text]=\"true\"\n              [rounded]=\"true\"\n              (onClick)=\"clearValue()\"\n              [disabled]=\"isFieldDisabled()\"\n              pTooltip=\"Limpar\"\n              tooltipPosition=\"top\"\n              size=\"small\"\n            ></p-button>\n            <p-button\n              icon=\"pi pi-search\"\n              severity=\"secondary\"\n              [text]=\"true\"\n              [rounded]=\"true\"\n              (onClick)=\"openLookup()\"\n              [disabled]=\"isFieldDisabled()\"\n              pTooltip=\"Buscar\"\n              tooltipPosition=\"top\"\n              size=\"small\"\n            ></p-button>\n          </div>\n        </div>\n      </div>\n\n      <!-- Lookup Dialog -->\n      <p-dialog\n        [(visible)]=\"showLookupDialog\"\n        [modal]=\"true\"\n        [style]=\"{ width: '800px', maxHeight: '80vh' }\"\n        [contentStyle]=\"{ maxHeight: 'calc(80vh - 120px)', overflow: 'auto' }\"\n        [draggable]=\"false\"\n        [resizable]=\"true\"\n        [header]=\"'Selecionar ' + (field.label | translate)\"\n        [appendTo]=\"'body'\"\n        (onHide)=\"onDialogHide()\"\n      >\n        <div class=\"lookup-dialog-content\">\n          <!-- Search Input -->\n          <div class=\"search-wrapper\">\n            <input\n              pInputText\n              [(ngModel)]=\"searchTerm\"\n              [placeholder]=\"'Buscar ' + (field.label | translate).toLowerCase() + '...'\"\n              (keydown.enter)=\"onSearch()\"\n              class=\"search-input-full\"\n            />\n            <div class=\"search-buttons-inside\">\n              <p-button\n                *ngIf=\"searchTerm\"\n                icon=\"pi pi-trash\"\n                severity=\"danger\"\n                [text]=\"true\"\n                [rounded]=\"true\"\n                (onClick)=\"clearSearch()\"\n                class=\"search-button-clear\"\n                pTooltip=\"Limpar busca\"\n                tooltipPosition=\"top\"\n              ></p-button>\n              <p-button\n                icon=\"pi pi-search\"\n                severity=\"secondary\"\n                [text]=\"true\"\n                [rounded]=\"true\"\n                (onClick)=\"onSearch()\"\n                class=\"search-button-search\"\n                pTooltip=\"Buscar\"\n                tooltipPosition=\"top\"\n              ></p-button>\n            </div>\n          </div>\n\n          <!-- Data Table -->\n          <p-table\n            [value]=\"filteredData\"\n            [loading]=\"loading\"\n            [paginator]=\"true\"\n            [rows]=\"pageSize\"\n            [totalRecords]=\"totalRecords\"\n            [lazy]=\"true\"\n            (onLazyLoad)=\"onPageChange($event)\"\n            [showCurrentPageReport]=\"true\"\n            currentPageReportTemplate=\"Mostrando {first} a {last} de {totalRecords} registros\"\n            dataKey=\"id\"\n            [rowHover]=\"true\"\n            responsiveLayout=\"scroll\"\n            styleClass=\"p-datatable-striped lookup-table\"\n            [(selection)]=\"selectedItem\"\n            (onRowSelect)=\"onRowSelect($event)\"\n            selectionMode=\"single\"\n          >\n            <ng-template pTemplate=\"header\">\n              <tr>\n                <th *ngFor=\"let col of columns\" [style.width]=\"col.width\">\n                  {{ col.header }}\n                </th>\n              </tr>\n            </ng-template>\n\n            <ng-template pTemplate=\"body\" let-item>\n              <tr [pSelectableRow]=\"item\">\n                <td *ngFor=\"let col of columns\">\n                  {{ getFieldValue(item, col.field) }}\n                </td>\n              </tr>\n            </ng-template>\n\n            <ng-template pTemplate=\"emptymessage\">\n              <tr>\n                <td [attr.colspan]=\"columns.length\" class=\"empty-message\">\n                  <div class=\"empty-state\">\n                    <i class=\"pi pi-search\"></i>\n                    <p>Nenhum registro encontrado</p>\n                    <small>Tente ajustar os termos de busca</small>\n                  </div>\n                </td>\n              </tr>\n            </ng-template>\n          </p-table>\n        </div>\n      </p-dialog>\n    </sia-dynamic-field-wrapper>\n  `,\n  styles: [`\n    .lookup-field {\n      width: 100%;\n      position: relative;\n    }\n\n    .lookup-input-group {\n      position: relative;\n      width: 100%;\n      \n      .lookup-display {\n        width: 100%;\n        cursor: pointer;\n        height: 2.857rem;\n        padding: 0.75rem 4rem 0.75rem 0.75rem;\n        font-size: 1rem;\n        line-height: 1.5;\n        box-sizing: border-box;\n        display: flex;\n        align-items: center;\n        \n        &:focus {\n          outline: none;\n        }\n        \n        &:hover {\n          background: transparent;\n        }\n      }\n\n      .lookup-buttons {\n        position: absolute;\n        right: 4px;\n        top: 50%;\n        transform: translateY(-50%);\n        display: flex;\n        gap: 2px;\n        z-index: 10;\n      }\n\n      ::ng-deep .p-button {\n        width: 2rem !important;\n        height: 2rem !important;\n        min-width: 2rem !important;\n        min-height: 2rem !important;\n        padding: 0 !important;\n        margin: 0 !important;\n        display: flex !important;\n        align-items: center !important;\n        justify-content: center !important;\n        box-sizing: border-box !important;\n        \n        .p-button-icon {\n          margin: 0 !important;\n          font-size: 0.875rem !important;\n        }\n        \n        .p-button-label {\n          display: none !important;\n        }\n      }\n    }\n\n    .lookup-dialog-content {\n      height: 100%;\n      display: flex;\n      flex-direction: column;\n      padding: 0;\n\n      .search-wrapper {\n        position: relative;\n        margin-bottom: 16px;\n        width: 100%;\n\n        .search-input-full {\n          width: 100%;\n          padding-right: 5.5rem;\n        }\n\n        .search-buttons-inside {\n          position: absolute;\n          right: 4px;\n          top: 50%;\n          transform: translateY(-50%);\n          display: flex;\n          gap: 2px;\n          \n          ::ng-deep .p-button {\n            width: 2.5rem !important;\n            height: 2.5rem !important;\n          }\n        }\n      }\n\n      .lookup-table {\n        flex: 1;\n        \n        .empty-state {\n          text-align: center;\n          padding: 32px;\n          color: var(--p-text-color-secondary);\n\n          i {\n            font-size: 48px;\n            margin-bottom: 16px;\n            display: block;\n          }\n\n          p {\n            margin: 8px 0;\n            font-size: 16px;\n          }\n\n          small {\n            font-size: 14px;\n          }\n        }\n      }\n    }\n  `]\n})\nexport class DynamicFieldLookupComponent implements OnInit {\n  @Input() field!: DynamicFormFieldConfig;\n  @Input() form!: FormGroup;\n  @Input() formGroup!: FormGroup;\n  @Input() mode: 'form' | 'filter' = 'form';\n\n  displayValue: string = '';\n  showLookupDialog: boolean = false;\n  loading: boolean = false;\n  searchTerm: string = '';\n  \n  data: any[] = [];\n  filteredData: any[] = [];\n  totalRecords: number = 0;\n  currentPage: number = 0;\n  pageSize: number = 5;\n  selectedItem: any = null;\n  \n  columns: LookupColumn[] = [];\n  displayField: string = 'name';\n  valueField: string = 'id';\n  searchFields: string[] = ['name'];\n\n  constructor(private translationService: TranslationService) {}\n\n  ngOnInit(): void {\n    this.setupLookupConfig();\n    this.watchValueChanges();\n  }\n\n  private watchValueChanges(): void {\n    const control = this.getFormControl();\n    if (control) {\n      // Carregar valor inicial\n      if (control.value) {\n        this.handleValueDisplay(control.value);\n      }\n      \n      // Observar mudanças\n      control.valueChanges.subscribe((value: any) => {\n        if (value !== null && value !== undefined && value !== '') {\n          this.handleValueDisplay(value);\n        } else {\n          this.displayValue = '';\n        }\n      });\n    }\n  }\n\n  /**\n   * Obtém o FormControl, lidando com campos aninhados (com ponto no nome)\n   */\n  private getFormControl() {\n    if (!this.field?.field) {\n      return null;\n    }\n\n    // Acessa diretamente via controls[] pois form.get() não funciona com campos que têm ponto\n    return this.form.controls[this.field.field];\n  }\n\n  private get value(): any {\n    const control = this.getFormControl();\n    return control?.value;\n  }\n\n  get currentValue(): any {\n    return this.value;\n  }\n\n  private setValue(value: any): void {\n    const control = this.getFormControl();\n    control?.setValue(value);\n  }\n\n  private setupLookupConfig(): void {\n    if (this.field) {\n      this.displayField = this.field.lookupDisplayField || 'name';\n      this.valueField = this.field.lookupValueField || 'id';\n      this.searchFields = this.field.lookupSearchFields || ['name'];\n      this.columns = this.field.lookupColumns || [\n        { field: this.displayField, header: 'Nome', width: '100%' }\n      ];\n    }\n  }\n\n  private handleValueDisplay(value: any): void {\n    if (value === null || value === undefined || value === '') {\n      this.displayValue = '';\n      return;\n    }\n    \n    if (typeof value === 'object' && value !== null) {\n      this.displayValue = this.formatDisplayValue(value);\n      // Keep the full object in the form control\n      return;\n    }\n    \n    // Se é um ID (string ou number), não fazer requisição\n    // Deixar vazio e só carregar quando abrir o lookup\n    if (typeof value === 'string' || typeof value === 'number') {\n      this.displayValue = '';\n      return;\n    }\n  }\n\n  private formatDisplayValue(item: any): string {\n    if (!item) return '';\n    \n    if (this.field?.lookupDisplayFields && this.field.lookupDisplayFields.length > 0) {\n      const values = this.field.lookupDisplayFields\n        .map(fieldName => this.getFieldValue(item, fieldName))\n        .filter(value => value !== null && value !== undefined && value !== '');\n      \n      return values.join(' - ');\n    }\n    \n    return this.getFieldValue(item, this.displayField) || '';\n  }\n\n  isFieldInvalid(): boolean {\n    const control = this.getFormControl();\n    return !!(control && control.invalid && (control.dirty || control.touched));\n  }\n\n  isFieldDisabled(): boolean {\n    const control = this.getFormControl();\n    return control?.disabled || false;\n  }\n\n  getPlaceholder(): string {\n    return TranslationHelper.getFilterPlaceholder(\n      this.translationService,\n      this.mode,\n      this.field.label,\n      this.field.placeholder\n    );\n  }\n\n  openLookup(): void {\n    if (this.isFieldDisabled()) {\n      return;\n    }\n    \n    this.updateSelectedItem();\n    \n    this.showLookupDialog = true;\n    this.currentPage = 0;\n    this.searchTerm = '';\n    this.loadData();\n  }\n\n  onDialogHide(): void {\n    this.searchTerm = '';\n    this.currentPage = 0;\n  }\n\n  onPageChange(event: any): void {\n    if (!this.showLookupDialog) {\n      return;\n    }\n    \n    this.currentPage = event.first / event.rows;\n    this.loadData();\n  }\n\n  private loadData(): void {\n    if (!this.field?.lookupService) {\n      return;\n    }\n\n    this.loading = true;\n    \n    const listParams: any = { \n      page: this.currentPage,\n      size: this.pageSize\n    };\n    \n    if (this.searchTerm.trim()) {\n      const term = this.searchTerm.trim();\n      const filterConditions: string[] = [];\n      const isNumericTerm = !isNaN(Number(term)) && term !== '';\n      \n      this.searchFields.forEach(field => {\n        const column = this.columns.find(col => col.field === field);\n        const fieldType = column?.type || 'text';\n        \n        if (fieldType === 'number') {\n          if (isNumericTerm) {\n            filterConditions.push(`${field} eq ${term}`);\n          }\n        } else {\n          const upperTerm = term.toUpperCase();\n          filterConditions.push(`UPPER(${field}) like '%${upperTerm}%'`);\n        }\n      });\n      \n      if (filterConditions.length > 0) {\n        listParams.filterQuery = filterConditions.join(' or ');\n      }\n    }\n    \n    if (this.field.lookupFilters) {\n      Object.keys(this.field.lookupFilters).forEach(key => {\n        listParams[key] = this.field.lookupFilters![key];\n      });\n    }\n    \n    if (this.field.lookupDynamicFilters && this.formGroup) {\n      const dynamicFilters = this.field.lookupDynamicFilters(this.formGroup.value);\n      \n      const dynamicFilterConditions: string[] = [];\n      Object.keys(dynamicFilters).forEach(key => {\n        const value = dynamicFilters[key];\n        if (value !== null && value !== undefined) {\n          dynamicFilterConditions.push(`${key} eq '${value}'`);\n        }\n      });\n      \n      if (dynamicFilterConditions.length > 0) {\n        const dynamicFilterQuery = dynamicFilterConditions.join(' and ');\n        if (listParams.filterQuery) {\n          listParams.filterQuery = `(${listParams.filterQuery}) and (${dynamicFilterQuery})`;\n        } else {\n          listParams.filterQuery = dynamicFilterQuery;\n        }\n      }\n    }\n    \n    this.field.lookupService.list(listParams).subscribe({\n      next: (response: any) => {\n        this.data = response.contents || [];\n        this.filteredData = [...this.data];\n        this.totalRecords = response.totalElements || 0;\n        \n        this.updateSelectedItem();\n        \n        // Após carregar os dados da grid, se temos um valor selecionado mas sem displayValue,\n        // tentar encontrar o item nos dados carregados\n        if (this.value && !this.displayValue) {\n          const item = this.filteredData.find(i => i[this.valueField] === this.value);\n          if (item) {\n            this.displayValue = this.formatDisplayValue(item);\n          }\n        }\n        \n        this.loading = false;\n      },\n      error: (_error: unknown) => {\n        this.data = [];\n        this.filteredData = [];\n        this.totalRecords = 0;\n        this.loading = false;\n      }\n    });\n  }\n\n  private updateSelectedItem(): void {\n    if (!this.value) {\n      this.selectedItem = null;\n      return;\n    }\n    \n    const item = this.filteredData.find(i => i[this.valueField] === this.value);\n    if (item) {\n      this.selectedItem = item;\n    }\n  }\n\n  onSearch(): void {\n    if (!this.showLookupDialog) {\n      return;\n    }\n    \n    this.currentPage = 0;\n    this.loadData();\n  }\n\n  clearSearch(): void {\n    this.searchTerm = '';\n    this.currentPage = 0;\n    this.loadData();\n  }\n\n  selectItem(item: any): void {\n    // Always set the full object, not just the ID\n    this.setValue(item);\n    this.displayValue = this.formatDisplayValue(item);\n    this.showLookupDialog = false;\n  }\n\n  onRowSelect(event: any): void {\n    this.selectItem(event.data);\n  }\n\n  clearValue(): void {\n    this.setValue(null);\n    this.displayValue = '';\n    this.selectedItem = null;\n  }\n\n  getFieldValue(item: any, field: string): any {\n    return field.split('.').reduce((obj, key) => obj?.[key], item) || '';\n  }\n}\n"]}
588
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dynamic-field-lookup.component.js","sourceRoot":"","sources":["../../../../../../projects/components-ai/src/lib/components/dynamic-form/fields/dynamic-field-lookup.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnInit } from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { FormGroup, ReactiveFormsModule, FormsModule } from '@angular/forms';\nimport { ButtonModule } from 'primeng/button';\nimport { InputTextModule } from 'primeng/inputtext';\nimport { DialogModule } from 'primeng/dialog';\nimport { TableModule } from 'primeng/table';\nimport { TooltipModule } from 'primeng/tooltip';\nimport { DynamicFormFieldConfig } from '../models/dynamic-form.models';\nimport { TranslatePipe } from '../../../pipes/translate.pipe';\nimport { TranslationHelper } from '../../../utils/translation.helper';\nimport { TranslationService } from '../../../services/translation.service';\nimport { DynamicFieldWrapperComponent } from './dynamic-field-wrapper.component';\nimport { LookupColumn } from '../../../models/entity-list.config';\n\n@Component({\n  selector: 'sia-dynamic-field-lookup',\n  standalone: true,\n  imports: [\n    CommonModule,\n    ReactiveFormsModule,\n    FormsModule,\n    ButtonModule,\n    InputTextModule,\n    DialogModule,\n    TableModule,\n    TooltipModule,\n    TranslatePipe,\n    DynamicFieldWrapperComponent\n  ],\n  template: `\n    <sia-dynamic-field-wrapper [field]=\"field\" [form]=\"form\" [mode]=\"mode\">\n      <div [formGroup]=\"form\" class=\"lookup-field\" [ngClass]=\"{'disabled': isFieldDisabled()}\">\n        <!-- Hidden input para o formControl -->\n        <input type=\"hidden\" [formControlName]=\"field.field\" />\n        \n        <div class=\"lookup-input-group\">\n          <input\n            pInputText\n            [value]=\"displayValue\"\n            [placeholder]=\"getPlaceholder()\"\n            [class.p-invalid]=\"isFieldInvalid()\"\n            [disabled]=\"isFieldDisabled()\"\n            readonly\n            class=\"lookup-display\"\n            (click)=\"openLookup()\"\n          />\n          <div class=\"lookup-buttons\">\n            <p-button\n              *ngIf=\"currentValue\"\n              icon=\"pi pi-trash\"\n              severity=\"danger\"\n              [text]=\"true\"\n              [rounded]=\"true\"\n              (onClick)=\"clearValue()\"\n              [disabled]=\"isFieldDisabled()\"\n              pTooltip=\"Limpar\"\n              tooltipPosition=\"top\"\n              size=\"small\"\n            ></p-button>\n            <p-button\n              icon=\"pi pi-search\"\n              severity=\"secondary\"\n              [text]=\"true\"\n              [rounded]=\"true\"\n              (onClick)=\"openLookup()\"\n              [disabled]=\"isFieldDisabled()\"\n              pTooltip=\"Buscar\"\n              tooltipPosition=\"top\"\n              size=\"small\"\n            ></p-button>\n          </div>\n        </div>\n      </div>\n\n      <!-- Lookup Dialog -->\n      <p-dialog\n        [(visible)]=\"showLookupDialog\"\n        [modal]=\"true\"\n        [style]=\"{ width: '800px', maxHeight: '80vh' }\"\n        [contentStyle]=\"{ maxHeight: 'calc(80vh - 120px)', overflow: 'auto' }\"\n        [draggable]=\"false\"\n        [resizable]=\"true\"\n        [header]=\"'Selecionar ' + (field.label | translate)\"\n        [appendTo]=\"'body'\"\n        (onHide)=\"onDialogHide()\"\n      >\n        <div class=\"lookup-dialog-content\">\n          <!-- Search Input -->\n          <div class=\"search-wrapper\">\n            <input\n              pInputText\n              [(ngModel)]=\"searchTerm\"\n              [placeholder]=\"'Buscar ' + (field.label | translate).toLowerCase() + '...'\"\n              (keydown.enter)=\"onSearch()\"\n              class=\"search-input-full\"\n            />\n            <div class=\"search-buttons-inside\">\n              <p-button\n                *ngIf=\"searchTerm\"\n                icon=\"pi pi-trash\"\n                severity=\"danger\"\n                [text]=\"true\"\n                [rounded]=\"true\"\n                (onClick)=\"clearSearch()\"\n                class=\"search-button-clear\"\n                pTooltip=\"Limpar busca\"\n                tooltipPosition=\"top\"\n              ></p-button>\n              <p-button\n                icon=\"pi pi-search\"\n                severity=\"secondary\"\n                [text]=\"true\"\n                [rounded]=\"true\"\n                (onClick)=\"onSearch()\"\n                class=\"search-button-search\"\n                pTooltip=\"Buscar\"\n                tooltipPosition=\"top\"\n              ></p-button>\n            </div>\n          </div>\n\n          <!-- Data Table -->\n          <p-table\n            [value]=\"filteredData\"\n            [loading]=\"loading\"\n            [paginator]=\"true\"\n            [rows]=\"pageSize\"\n            [totalRecords]=\"totalRecords\"\n            [lazy]=\"true\"\n            (onLazyLoad)=\"onPageChange($event)\"\n            [showCurrentPageReport]=\"true\"\n            currentPageReportTemplate=\"Mostrando {first} a {last} de {totalRecords} registros\"\n            dataKey=\"id\"\n            [rowHover]=\"true\"\n            responsiveLayout=\"scroll\"\n            styleClass=\"p-datatable-striped lookup-table\"\n            [(selection)]=\"selectedItem\"\n            (onRowSelect)=\"onRowSelect($event)\"\n            selectionMode=\"single\"\n          >\n            <ng-template pTemplate=\"header\">\n              <tr>\n                <th *ngFor=\"let col of columns\" [style.width]=\"col.width\">\n                  {{ col.header }}\n                </th>\n              </tr>\n            </ng-template>\n\n            <ng-template pTemplate=\"body\" let-item>\n              <tr [pSelectableRow]=\"item\">\n                <td *ngFor=\"let col of columns\">\n                  {{ getFieldValue(item, col.field) }}\n                </td>\n              </tr>\n            </ng-template>\n\n            <ng-template pTemplate=\"emptymessage\">\n              <tr>\n                <td [attr.colspan]=\"columns.length\" class=\"empty-message\">\n                  <div class=\"empty-state\">\n                    <i class=\"pi pi-search\"></i>\n                    <p>Nenhum registro encontrado</p>\n                    <small>Tente ajustar os termos de busca</small>\n                  </div>\n                </td>\n              </tr>\n            </ng-template>\n          </p-table>\n        </div>\n      </p-dialog>\n    </sia-dynamic-field-wrapper>\n  `,\n  styles: [`\n    .lookup-field {\n      width: 100%;\n      position: relative;\n    }\n\n    .lookup-input-group {\n      position: relative;\n      width: 100%;\n      \n      .lookup-display {\n        width: 100%;\n        cursor: pointer;\n        height: 2.857rem;\n        padding: 0.75rem 4rem 0.75rem 0.75rem;\n        font-size: 1rem;\n        line-height: 1.5;\n        box-sizing: border-box;\n        display: flex;\n        align-items: center;\n        \n        &:focus {\n          outline: none;\n        }\n        \n        &:hover {\n          background: transparent;\n        }\n      }\n\n      .lookup-buttons {\n        position: absolute;\n        right: 4px;\n        top: 50%;\n        transform: translateY(-50%);\n        display: flex;\n        gap: 2px;\n        z-index: 10;\n      }\n\n      ::ng-deep .p-button {\n        width: 2rem !important;\n        height: 2rem !important;\n        min-width: 2rem !important;\n        min-height: 2rem !important;\n        padding: 0 !important;\n        margin: 0 !important;\n        display: flex !important;\n        align-items: center !important;\n        justify-content: center !important;\n        box-sizing: border-box !important;\n        \n        .p-button-icon {\n          margin: 0 !important;\n          font-size: 0.875rem !important;\n        }\n        \n        .p-button-label {\n          display: none !important;\n        }\n      }\n    }\n\n    .lookup-dialog-content {\n      height: 100%;\n      display: flex;\n      flex-direction: column;\n      padding: 0;\n\n      .search-wrapper {\n        position: relative;\n        margin-bottom: 16px;\n        width: 100%;\n\n        .search-input-full {\n          width: 100%;\n          padding-right: 5.5rem;\n        }\n\n        .search-buttons-inside {\n          position: absolute;\n          right: 4px;\n          top: 50%;\n          transform: translateY(-50%);\n          display: flex;\n          gap: 2px;\n          \n          ::ng-deep .p-button {\n            width: 2.5rem !important;\n            height: 2.5rem !important;\n          }\n        }\n      }\n\n      .lookup-table {\n        flex: 1;\n        \n        .empty-state {\n          text-align: center;\n          padding: 32px;\n          color: var(--p-text-color-secondary);\n\n          i {\n            font-size: 48px;\n            margin-bottom: 16px;\n            display: block;\n          }\n\n          p {\n            margin: 8px 0;\n            font-size: 16px;\n          }\n\n          small {\n            font-size: 14px;\n          }\n        }\n      }\n    }\n  `]\n})\nexport class DynamicFieldLookupComponent implements OnInit {\n  @Input() field!: DynamicFormFieldConfig;\n  @Input() form!: FormGroup;\n  @Input() formGroup!: FormGroup;\n  @Input() mode: 'form' | 'filter' = 'form';\n\n  displayValue: string = '';\n  showLookupDialog: boolean = false;\n  loading: boolean = false;\n  searchTerm: string = '';\n  \n  data: any[] = [];\n  filteredData: any[] = [];\n  totalRecords: number = 0;\n  currentPage: number = 0;\n  pageSize: number = 5;\n  selectedItem: any = null;\n  \n  columns: LookupColumn[] = [];\n  displayField: string = 'name';\n  valueField: string = 'id';\n  searchFields: string[] = ['name'];\n\n  constructor(private translationService: TranslationService) {}\n\n  ngOnInit(): void {\n    this.setupLookupConfig();\n    this.watchValueChanges();\n  }\n\n  private watchValueChanges(): void {\n    const control = this.getFormControl();\n    if (control) {\n      // Carregar valor inicial\n      if (control.value) {\n        this.handleValueDisplay(control.value);\n      }\n      \n      // Observar mudanças\n      control.valueChanges.subscribe((value: any) => {\n        if (value !== null && value !== undefined && value !== '') {\n          this.handleValueDisplay(value);\n        } else {\n          this.displayValue = '';\n        }\n      });\n    }\n  }\n\n  /**\n   * Obtém o FormControl, lidando com campos aninhados (com ponto no nome)\n   */\n  private getFormControl() {\n    if (!this.field?.field) {\n      return null;\n    }\n\n    // Acessa diretamente via controls[] pois form.get() não funciona com campos que têm ponto\n    return this.form.controls[this.field.field];\n  }\n\n  private get value(): any {\n    const control = this.getFormControl();\n    return control?.value;\n  }\n\n  get currentValue(): any {\n    return this.value;\n  }\n\n  private setValue(value: any): void {\n    const control = this.getFormControl();\n    control?.setValue(value);\n  }\n\n  private setupLookupConfig(): void {\n    if (this.field) {\n      this.displayField = this.field.lookupDisplayField || 'name';\n      this.valueField = this.field.lookupValueField || 'id';\n      this.searchFields = this.field.lookupSearchFields || ['name'];\n      this.columns = this.field.lookupColumns || [\n        { field: this.displayField, header: 'Nome', width: '100%' }\n      ];\n    }\n  }\n\n  private handleValueDisplay(value: any): void {\n    if (value === null || value === undefined || value === '') {\n      this.displayValue = '';\n      return;\n    }\n    \n    if (typeof value === 'object' && value !== null) {\n      this.displayValue = this.formatDisplayValue(value);\n      // Keep the full object in the form control\n      return;\n    }\n    \n    // Se é um ID (string ou number), não fazer requisição\n    // Deixar vazio e só carregar quando abrir o lookup\n    if (typeof value === 'string' || typeof value === 'number') {\n      this.displayValue = '';\n      return;\n    }\n  }\n\n  private formatDisplayValue(item: any): string {\n    if (!item) return '';\n    \n    if (this.field?.lookupDisplayFields && this.field.lookupDisplayFields.length > 0) {\n      const values = this.field.lookupDisplayFields\n        .map(fieldName => this.getFieldValue(item, fieldName))\n        .filter(value => value !== null && value !== undefined && value !== '');\n      \n      return values.join(' - ');\n    }\n    \n    return this.getFieldValue(item, this.displayField) || '';\n  }\n\n  isFieldInvalid(): boolean {\n    const control = this.getFormControl();\n    return !!(control && control.invalid && (control.dirty || control.touched));\n  }\n\n  isFieldDisabled(): boolean {\n    const control = this.getFormControl();\n    return control?.disabled || false;\n  }\n\n  getPlaceholder(): string {\n    return TranslationHelper.getFilterPlaceholder(\n      this.translationService,\n      this.mode,\n      this.field.label,\n      this.field.placeholder\n    );\n  }\n\n  openLookup(): void {\n    if (this.isFieldDisabled()) {\n      return;\n    }\n    \n    this.updateSelectedItem();\n    \n    this.showLookupDialog = true;\n    this.currentPage = 0;\n    this.searchTerm = '';\n    this.loadData();\n  }\n\n  onDialogHide(): void {\n    this.searchTerm = '';\n    this.currentPage = 0;\n  }\n\n  onPageChange(event: any): void {\n    if (!this.showLookupDialog) {\n      return;\n    }\n    \n    this.currentPage = event.first / event.rows;\n    this.loadData();\n  }\n\n  private loadData(): void {\n    if (!this.field?.lookupService) {\n      return;\n    }\n\n    this.loading = true;\n    \n    const listParams: any = { \n      page: this.currentPage,\n      size: this.pageSize\n    };\n\n    if (this.field.lookupSort) {\n      listParams.sort = this.field.lookupSort;\n    }\n    \n    if (this.searchTerm.trim()) {\n      const term = this.searchTerm.trim();\n      const filterConditions: string[] = [];\n      const isNumericTerm = !isNaN(Number(term)) && term !== '';\n      \n      this.searchFields.forEach(field => {\n        const column = this.columns.find(col => col.field === field);\n        const fieldType = column?.type || 'text';\n        \n        if (fieldType === 'number') {\n          if (isNumericTerm) {\n            filterConditions.push(`${field} eq ${term}`);\n          }\n        } else {\n          const upperTerm = term.toUpperCase();\n          filterConditions.push(`UPPER(${field}) like '%${upperTerm}%'`);\n        }\n      });\n      \n      if (filterConditions.length > 0) {\n        listParams.filterQuery = filterConditions.join(' or ');\n      }\n    }\n    \n    if (this.field.lookupFilters) {\n      Object.keys(this.field.lookupFilters).forEach(key => {\n        listParams[key] = this.field.lookupFilters![key];\n      });\n    }\n    \n    if (this.field.lookupDynamicFilters && this.formGroup) {\n      const dynamicFilters = this.field.lookupDynamicFilters(this.formGroup.value);\n      \n      const dynamicFilterConditions: string[] = [];\n      Object.keys(dynamicFilters).forEach(key => {\n        const value = dynamicFilters[key];\n        if (value !== null && value !== undefined) {\n          dynamicFilterConditions.push(`${key} eq '${value}'`);\n        }\n      });\n      \n      if (dynamicFilterConditions.length > 0) {\n        const dynamicFilterQuery = dynamicFilterConditions.join(' and ');\n        if (listParams.filterQuery) {\n          listParams.filterQuery = `(${listParams.filterQuery}) and (${dynamicFilterQuery})`;\n        } else {\n          listParams.filterQuery = dynamicFilterQuery;\n        }\n      }\n    }\n    \n    this.field.lookupService.list(listParams).subscribe({\n      next: (response: any) => {\n        this.data = response.contents || [];\n        this.filteredData = [...this.data];\n        this.totalRecords = response.totalElements || 0;\n        \n        this.updateSelectedItem();\n        \n        // Após carregar os dados da grid, se temos um valor selecionado mas sem displayValue,\n        // tentar encontrar o item nos dados carregados\n        if (this.value && !this.displayValue) {\n          const item = this.filteredData.find(i => i[this.valueField] === this.value);\n          if (item) {\n            this.displayValue = this.formatDisplayValue(item);\n          }\n        }\n        \n        this.loading = false;\n      },\n      error: (_error: unknown) => {\n        this.data = [];\n        this.filteredData = [];\n        this.totalRecords = 0;\n        this.loading = false;\n      }\n    });\n  }\n\n  private updateSelectedItem(): void {\n    if (!this.value) {\n      this.selectedItem = null;\n      return;\n    }\n    \n    const item = this.filteredData.find(i => i[this.valueField] === this.value);\n    if (item) {\n      this.selectedItem = item;\n    }\n  }\n\n  onSearch(): void {\n    if (!this.showLookupDialog) {\n      return;\n    }\n    \n    this.currentPage = 0;\n    this.loadData();\n  }\n\n  clearSearch(): void {\n    this.searchTerm = '';\n    this.currentPage = 0;\n    this.loadData();\n  }\n\n  selectItem(item: any): void {\n    // Always set the full object, not just the ID\n    this.setValue(item);\n    this.displayValue = this.formatDisplayValue(item);\n    this.showLookupDialog = false;\n  }\n\n  onRowSelect(event: any): void {\n    this.selectItem(event.data);\n  }\n\n  clearValue(): void {\n    this.setValue(null);\n    this.displayValue = '';\n    this.selectedItem = null;\n  }\n\n  getFieldValue(item: any, field: string): any {\n    return field.split('.').reduce((obj, key) => obj?.[key], item) || '';\n  }\n}\n"]}
@@ -26,23 +26,23 @@ export class DynamicFieldWrapperComponent {
26
26
  getFieldError() {
27
27
  const control = this.form.get(this.field.field);
28
28
  if (control?.hasError('required')) {
29
- return this.translationService.translate('components.required_field');
29
+ return this.translationService.translate('design.components_ai.required_field');
30
30
  }
31
31
  if (control?.hasError('minlength')) {
32
32
  const minLength = this.field.minLength || control.errors?.['minlength'].requiredLength;
33
- return this.translationService.translate('components.min_length_error', { length: minLength });
33
+ return this.translationService.translate('design.components_ai.min_length_error', { length: minLength });
34
34
  }
35
35
  if (control?.hasError('maxlength')) {
36
36
  const maxLength = this.field.maxLength || control.errors?.['maxlength'].requiredLength;
37
- return this.translationService.translate('components.max_length_error', { length: maxLength });
37
+ return this.translationService.translate('design.components_ai.max_length_error', { length: maxLength });
38
38
  }
39
39
  if (control?.hasError('min')) {
40
40
  const min = this.field.min || control.errors?.['min'].min;
41
- return this.translationService.translate('components.min_value_error', { value: min });
41
+ return this.translationService.translate('design.components_ai.min_value_error', { value: min });
42
42
  }
43
43
  if (control?.hasError('max')) {
44
44
  const max = this.field.max || control.errors?.['max'].max;
45
- return this.translationService.translate('components.max_value_error', { value: max });
45
+ return this.translationService.translate('design.components_ai.max_value_error', { value: max });
46
46
  }
47
47
  return '';
48
48
  }
@@ -90,4 +90,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
90
90
  }], mode: [{
91
91
  type: Input
92
92
  }] } });
93
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHluYW1pYy1maWVsZC13cmFwcGVyLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NvbXBvbmVudHMtYWkvc3JjL2xpYi9jb21wb25lbnRzL2R5bmFtaWMtZm9ybS9maWVsZHMvZHluYW1pYy1maWVsZC13cmFwcGVyLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNqRCxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFHL0MsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLCtCQUErQixDQUFDOzs7O0FBRzlEOzs7R0FHRztBQThDSCxNQUFNLE9BQU8sNEJBQTRCO0lBS25CO0lBSlgsS0FBSyxDQUEwQjtJQUMvQixJQUFJLENBQWE7SUFDakIsSUFBSSxHQUFzQixNQUFNLENBQUM7SUFFMUMsWUFBb0Isa0JBQXNDO1FBQXRDLHVCQUFrQixHQUFsQixrQkFBa0IsQ0FBb0I7SUFBRyxDQUFDO0lBRTlELFVBQVU7UUFDUixPQUFPLElBQUksQ0FBQyxLQUFLLENBQUMsUUFBUSxLQUFLLElBQUksSUFBSSxJQUFJLENBQUMsSUFBSSxLQUFLLE1BQU0sQ0FBQztJQUM5RCxDQUFDO0lBRUQsY0FBYztRQUNaLE1BQU0sT0FBTyxHQUFHLElBQUksQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDaEQsT0FBTyxDQUFDLENBQUMsQ0FBQyxPQUFPLElBQUksT0FBTyxDQUFDLE9BQU8sSUFBSSxDQUFDLE9BQU8sQ0FBQyxLQUFLLElBQUksT0FBTyxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUM7SUFDOUUsQ0FBQztJQUVELGFBQWE7UUFDWCxNQUFNLE9BQU8sR0FBRyxJQUFJLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBRWhELElBQUksT0FBTyxFQUFFLFFBQVEsQ0FBQyxVQUFVLENBQUMsRUFBRSxDQUFDO1lBQ2xDLE9BQU8sSUFBSSxDQUFDLGtCQUFrQixDQUFDLFNBQVMsQ0FBQywyQkFBMkIsQ0FBQyxDQUFDO1FBQ3hFLENBQUM7UUFDRCxJQUFJLE9BQU8sRUFBRSxRQUFRLENBQUMsV0FBVyxDQUFDLEVBQUUsQ0FBQztZQUNuQyxNQUFNLFNBQVMsR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLFNBQVMsSUFBSSxPQUFPLENBQUMsTUFBTSxFQUFFLENBQUMsV0FBVyxDQUFDLENBQUMsY0FBYyxDQUFDO1lBQ3ZGLE9BQU8sSUFBSSxDQUFDLGtCQUFrQixDQUFDLFNBQVMsQ0FBQyw2QkFBNkIsRUFBRSxFQUFFLE1BQU0sRUFBRSxTQUFTLEVBQUUsQ0FBQyxDQUFDO1FBQ2pHLENBQUM7UUFDRCxJQUFJLE9BQU8sRUFBRSxRQUFRLENBQUMsV0FBVyxDQUFDLEVBQUUsQ0FBQztZQUNuQyxNQUFNLFNBQVMsR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLFNBQVMsSUFBSSxPQUFPLENBQUMsTUFBTSxFQUFFLENBQUMsV0FBVyxDQUFDLENBQUMsY0FBYyxDQUFDO1lBQ3ZGLE9BQU8sSUFBSSxDQUFDLGtCQUFrQixDQUFDLFNBQVMsQ0FBQyw2QkFBNkIsRUFBRSxFQUFFLE1BQU0sRUFBRSxTQUFTLEVBQUUsQ0FBQyxDQUFDO1FBQ2pHLENBQUM7UUFDRCxJQUFJLE9BQU8sRUFBRSxRQUFRLENBQUMsS0FBSyxDQUFDLEVBQUUsQ0FBQztZQUM3QixNQUFNLEdBQUcsR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLEdBQUcsSUFBSSxPQUFPLENBQUMsTUFBTSxFQUFFLENBQUMsS0FBSyxDQUFDLENBQUMsR0FBRyxDQUFDO1lBQzFELE9BQU8sSUFBSSxDQUFDLGtCQUFrQixDQUFDLFNBQVMsQ0FBQyw0QkFBNEIsRUFBRSxFQUFFLEtBQUssRUFBRSxHQUFHLEVBQUUsQ0FBQyxDQUFDO1FBQ3pGLENBQUM7UUFDRCxJQUFJLE9BQU8sRUFBRSxRQUFRLENBQUMsS0FBSyxDQUFDLEVBQUUsQ0FBQztZQUM3QixNQUFNLEdBQUcsR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLEdBQUcsSUFBSSxPQUFPLENBQUMsTUFBTSxFQUFFLENBQUMsS0FBSyxDQUFDLENBQUMsR0FBRyxDQUFDO1lBQzFELE9BQU8sSUFBSSxDQUFDLGtCQUFrQixDQUFDLFNBQVMsQ0FBQyw0QkFBNEIsRUFBRSxFQUFFLEtBQUssRUFBRSxHQUFHLEVBQUUsQ0FBQyxDQUFDO1FBQ3pGLENBQUM7UUFDRCxPQUFPLEVBQUUsQ0FBQztJQUNaLENBQUM7d0dBdkNVLDRCQUE0Qjs0RkFBNUIsNEJBQTRCLDZJQXRDN0I7Ozs7Ozs7Ozs7Ozs7O0dBY1QsbVNBakJDLFlBQVksOEhBQ1osYUFBYTs7NEZBd0NKLDRCQUE0QjtrQkE3Q3hDLFNBQVM7K0JBQ0UsMkJBQTJCLGNBQ3pCLElBQUksV0FDUDt3QkFDUCxZQUFZO3dCQUNaLGFBQWE7cUJBQ2QsWUFDUzs7Ozs7Ozs7Ozs7Ozs7R0FjVDt1RkF5QlEsS0FBSztzQkFBYixLQUFLO2dCQUNHLElBQUk7c0JBQVosS0FBSztnQkFDRyxJQUFJO3NCQUFaLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIElucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgRm9ybUdyb3VwIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xuaW1wb3J0IHsgRHluYW1pY0Zvcm1GaWVsZENvbmZpZyB9IGZyb20gJy4uL21vZGVscy9keW5hbWljLWZvcm0ubW9kZWxzJztcbmltcG9ydCB7IFRyYW5zbGF0ZVBpcGUgfSBmcm9tICcuLi8uLi8uLi9waXBlcy90cmFuc2xhdGUucGlwZSc7XG5pbXBvcnQgeyBUcmFuc2xhdGlvblNlcnZpY2UgfSBmcm9tICcuLi8uLi8uLi9zZXJ2aWNlcy90cmFuc2xhdGlvbi5zZXJ2aWNlJztcblxuLyoqXG4gKiBDb21wb25lbnRlIHdyYXBwZXIgcGFyYSBjYW1wb3MgZGUgZm9ybXVsw6FyaW8gZGluw6JtaWNvXG4gKiBDZW50cmFsaXphIGEgcmVuZGVyaXphw6fDo28gZGUgbGFiZWwsIGNhbXBvIGUgbWVuc2FnZW0gZGUgZXJyb1xuICovXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdzaWEtZHluYW1pYy1maWVsZC13cmFwcGVyJyxcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgaW1wb3J0czogW1xuICAgIENvbW1vbk1vZHVsZSxcbiAgICBUcmFuc2xhdGVQaXBlXG4gIF0sXG4gIHRlbXBsYXRlOiBgXG4gICAgPGRpdiBjbGFzcz1cImZpZWxkXCI+XG4gICAgICA8bGFiZWwgW2Zvcl09XCJmaWVsZC5maWVsZFwiPlxuICAgICAgICB7eyBmaWVsZC5sYWJlbCB8IHRyYW5zbGF0ZSB9fVxuICAgICAgICA8c3BhbiAqbmdJZj1cImlzUmVxdWlyZWQoKVwiIGNsYXNzPVwicmVxdWlyZWQtYXN0ZXJpc2tcIj4qPC9zcGFuPlxuICAgICAgPC9sYWJlbD5cbiAgICAgIFxuICAgICAgPCEtLSBDb250ZcO6ZG8gZG8gY2FtcG8gKHByb2pldGFkbyB2aWEgbmctY29udGVudCkgLS0+XG4gICAgICA8bmctY29udGVudD48L25nLWNvbnRlbnQ+XG4gICAgICBcbiAgICAgIDxzbWFsbCAqbmdJZj1cImlzRmllbGRJbnZhbGlkKClcIiBjbGFzcz1cInAtZXJyb3JcIj5cbiAgICAgICAge3sgZ2V0RmllbGRFcnJvcigpIH19XG4gICAgICA8L3NtYWxsPlxuICAgIDwvZGl2PlxuICBgLFxuICBzdHlsZXM6IFtgXG4gICAgLmZpZWxkIHtcbiAgICAgIGRpc3BsYXk6IGZsZXg7XG4gICAgICBmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xuICAgICAgZ2FwOiAwLjVyZW07XG5cbiAgICAgIGxhYmVsIHtcbiAgICAgICAgZm9udC13ZWlnaHQ6IDUwMDtcbiAgICAgICAgY29sb3I6IHZhcigtLXRleHQtY29sb3IpO1xuXG4gICAgICAgIC5yZXF1aXJlZC1hc3RlcmlzayB7XG4gICAgICAgICAgY29sb3I6IHZhcigtLXAtcmVkLTUwMCk7XG4gICAgICAgICAgbWFyZ2luLWxlZnQ6IDAuMjVyZW07XG4gICAgICAgIH1cbiAgICAgIH1cblxuICAgICAgc21hbGwucC1lcnJvciB7XG4gICAgICAgIG1hcmdpbi10b3A6IDAuMjVyZW07XG4gICAgICAgIGNvbG9yOiB2YXIoLS1wLXJlZC01MDApO1xuICAgICAgfVxuICAgIH1cbiAgYF1cbn0pXG5leHBvcnQgY2xhc3MgRHluYW1pY0ZpZWxkV3JhcHBlckNvbXBvbmVudCB7XG4gIEBJbnB1dCgpIGZpZWxkITogRHluYW1pY0Zvcm1GaWVsZENvbmZpZztcbiAgQElucHV0KCkgZm9ybSE6IEZvcm1Hcm91cDtcbiAgQElucHV0KCkgbW9kZTogJ2Zvcm0nIHwgJ2ZpbHRlcicgPSAnZm9ybSc7XG5cbiAgY29uc3RydWN0b3IocHJpdmF0ZSB0cmFuc2xhdGlvblNlcnZpY2U6IFRyYW5zbGF0aW9uU2VydmljZSkge31cblxuICBpc1JlcXVpcmVkKCk6IGJvb2xlYW4ge1xuICAgIHJldHVybiB0aGlzLmZpZWxkLnJlcXVpcmVkID09PSB0cnVlICYmIHRoaXMubW9kZSA9PT0gJ2Zvcm0nO1xuICB9XG5cbiAgaXNGaWVsZEludmFsaWQoKTogYm9vbGVhbiB7XG4gICAgY29uc3QgY29udHJvbCA9IHRoaXMuZm9ybS5nZXQodGhpcy5maWVsZC5maWVsZCk7XG4gICAgcmV0dXJuICEhKGNvbnRyb2wgJiYgY29udHJvbC5pbnZhbGlkICYmIChjb250cm9sLmRpcnR5IHx8IGNvbnRyb2wudG91Y2hlZCkpO1xuICB9XG5cbiAgZ2V0RmllbGRFcnJvcigpOiBzdHJpbmcge1xuICAgIGNvbnN0IGNvbnRyb2wgPSB0aGlzLmZvcm0uZ2V0KHRoaXMuZmllbGQuZmllbGQpO1xuICAgIFxuICAgIGlmIChjb250cm9sPy5oYXNFcnJvcigncmVxdWlyZWQnKSkge1xuICAgICAgcmV0dXJuIHRoaXMudHJhbnNsYXRpb25TZXJ2aWNlLnRyYW5zbGF0ZSgnY29tcG9uZW50cy5yZXF1aXJlZF9maWVsZCcpO1xuICAgIH1cbiAgICBpZiAoY29udHJvbD8uaGFzRXJyb3IoJ21pbmxlbmd0aCcpKSB7XG4gICAgICBjb25zdCBtaW5MZW5ndGggPSB0aGlzLmZpZWxkLm1pbkxlbmd0aCB8fCBjb250cm9sLmVycm9ycz8uWydtaW5sZW5ndGgnXS5yZXF1aXJlZExlbmd0aDtcbiAgICAgIHJldHVybiB0aGlzLnRyYW5zbGF0aW9uU2VydmljZS50cmFuc2xhdGUoJ2NvbXBvbmVudHMubWluX2xlbmd0aF9lcnJvcicsIHsgbGVuZ3RoOiBtaW5MZW5ndGggfSk7XG4gICAgfVxuICAgIGlmIChjb250cm9sPy5oYXNFcnJvcignbWF4bGVuZ3RoJykpIHtcbiAgICAgIGNvbnN0IG1heExlbmd0aCA9IHRoaXMuZmllbGQubWF4TGVuZ3RoIHx8IGNvbnRyb2wuZXJyb3JzPy5bJ21heGxlbmd0aCddLnJlcXVpcmVkTGVuZ3RoO1xuICAgICAgcmV0dXJuIHRoaXMudHJhbnNsYXRpb25TZXJ2aWNlLnRyYW5zbGF0ZSgnY29tcG9uZW50cy5tYXhfbGVuZ3RoX2Vycm9yJywgeyBsZW5ndGg6IG1heExlbmd0aCB9KTtcbiAgICB9XG4gICAgaWYgKGNvbnRyb2w/Lmhhc0Vycm9yKCdtaW4nKSkge1xuICAgICAgY29uc3QgbWluID0gdGhpcy5maWVsZC5taW4gfHwgY29udHJvbC5lcnJvcnM/LlsnbWluJ10ubWluO1xuICAgICAgcmV0dXJuIHRoaXMudHJhbnNsYXRpb25TZXJ2aWNlLnRyYW5zbGF0ZSgnY29tcG9uZW50cy5taW5fdmFsdWVfZXJyb3InLCB7IHZhbHVlOiBtaW4gfSk7XG4gICAgfVxuICAgIGlmIChjb250cm9sPy5oYXNFcnJvcignbWF4JykpIHtcbiAgICAgIGNvbnN0IG1heCA9IHRoaXMuZmllbGQubWF4IHx8IGNvbnRyb2wuZXJyb3JzPy5bJ21heCddLm1heDtcbiAgICAgIHJldHVybiB0aGlzLnRyYW5zbGF0aW9uU2VydmljZS50cmFuc2xhdGUoJ2NvbXBvbmVudHMubWF4X3ZhbHVlX2Vycm9yJywgeyB2YWx1ZTogbWF4IH0pO1xuICAgIH1cbiAgICByZXR1cm4gJyc7XG4gIH1cbn1cbiJdfQ==
93
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHluYW1pYy1maWVsZC13cmFwcGVyLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NvbXBvbmVudHMtYWkvc3JjL2xpYi9jb21wb25lbnRzL2R5bmFtaWMtZm9ybS9maWVsZHMvZHluYW1pYy1maWVsZC13cmFwcGVyLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNqRCxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFHL0MsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLCtCQUErQixDQUFDOzs7O0FBRzlEOzs7R0FHRztBQThDSCxNQUFNLE9BQU8sNEJBQTRCO0lBS25CO0lBSlgsS0FBSyxDQUEwQjtJQUMvQixJQUFJLENBQWE7SUFDakIsSUFBSSxHQUFzQixNQUFNLENBQUM7SUFFMUMsWUFBb0Isa0JBQXNDO1FBQXRDLHVCQUFrQixHQUFsQixrQkFBa0IsQ0FBb0I7SUFBRyxDQUFDO0lBRTlELFVBQVU7UUFDUixPQUFPLElBQUksQ0FBQyxLQUFLLENBQUMsUUFBUSxLQUFLLElBQUksSUFBSSxJQUFJLENBQUMsSUFBSSxLQUFLLE1BQU0sQ0FBQztJQUM5RCxDQUFDO0lBRUQsY0FBYztRQUNaLE1BQU0sT0FBTyxHQUFHLElBQUksQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDaEQsT0FBTyxDQUFDLENBQUMsQ0FBQyxPQUFPLElBQUksT0FBTyxDQUFDLE9BQU8sSUFBSSxDQUFDLE9BQU8sQ0FBQyxLQUFLLElBQUksT0FBTyxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUM7SUFDOUUsQ0FBQztJQUVELGFBQWE7UUFDWCxNQUFNLE9BQU8sR0FBRyxJQUFJLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBRWhELElBQUksT0FBTyxFQUFFLFFBQVEsQ0FBQyxVQUFVLENBQUMsRUFBRSxDQUFDO1lBQ2xDLE9BQU8sSUFBSSxDQUFDLGtCQUFrQixDQUFDLFNBQVMsQ0FBQyxxQ0FBcUMsQ0FBQyxDQUFDO1FBQ2xGLENBQUM7UUFDRCxJQUFJLE9BQU8sRUFBRSxRQUFRLENBQUMsV0FBVyxDQUFDLEVBQUUsQ0FBQztZQUNuQyxNQUFNLFNBQVMsR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLFNBQVMsSUFBSSxPQUFPLENBQUMsTUFBTSxFQUFFLENBQUMsV0FBVyxDQUFDLENBQUMsY0FBYyxDQUFDO1lBQ3ZGLE9BQU8sSUFBSSxDQUFDLGtCQUFrQixDQUFDLFNBQVMsQ0FBQyx1Q0FBdUMsRUFBRSxFQUFFLE1BQU0sRUFBRSxTQUFTLEVBQUUsQ0FBQyxDQUFDO1FBQzNHLENBQUM7UUFDRCxJQUFJLE9BQU8sRUFBRSxRQUFRLENBQUMsV0FBVyxDQUFDLEVBQUUsQ0FBQztZQUNuQyxNQUFNLFNBQVMsR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLFNBQVMsSUFBSSxPQUFPLENBQUMsTUFBTSxFQUFFLENBQUMsV0FBVyxDQUFDLENBQUMsY0FBYyxDQUFDO1lBQ3ZGLE9BQU8sSUFBSSxDQUFDLGtCQUFrQixDQUFDLFNBQVMsQ0FBQyx1Q0FBdUMsRUFBRSxFQUFFLE1BQU0sRUFBRSxTQUFTLEVBQUUsQ0FBQyxDQUFDO1FBQzNHLENBQUM7UUFDRCxJQUFJLE9BQU8sRUFBRSxRQUFRLENBQUMsS0FBSyxDQUFDLEVBQUUsQ0FBQztZQUM3QixNQUFNLEdBQUcsR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLEdBQUcsSUFBSSxPQUFPLENBQUMsTUFBTSxFQUFFLENBQUMsS0FBSyxDQUFDLENBQUMsR0FBRyxDQUFDO1lBQzFELE9BQU8sSUFBSSxDQUFDLGtCQUFrQixDQUFDLFNBQVMsQ0FBQyxzQ0FBc0MsRUFBRSxFQUFFLEtBQUssRUFBRSxHQUFHLEVBQUUsQ0FBQyxDQUFDO1FBQ25HLENBQUM7UUFDRCxJQUFJLE9BQU8sRUFBRSxRQUFRLENBQUMsS0FBSyxDQUFDLEVBQUUsQ0FBQztZQUM3QixNQUFNLEdBQUcsR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLEdBQUcsSUFBSSxPQUFPLENBQUMsTUFBTSxFQUFFLENBQUMsS0FBSyxDQUFDLENBQUMsR0FBRyxDQUFDO1lBQzFELE9BQU8sSUFBSSxDQUFDLGtCQUFrQixDQUFDLFNBQVMsQ0FBQyxzQ0FBc0MsRUFBRSxFQUFFLEtBQUssRUFBRSxHQUFHLEVBQUUsQ0FBQyxDQUFDO1FBQ25HLENBQUM7UUFDRCxPQUFPLEVBQUUsQ0FBQztJQUNaLENBQUM7d0dBdkNVLDRCQUE0Qjs0RkFBNUIsNEJBQTRCLDZJQXRDN0I7Ozs7Ozs7Ozs7Ozs7O0dBY1QsbVNBakJDLFlBQVksOEhBQ1osYUFBYTs7NEZBd0NKLDRCQUE0QjtrQkE3Q3hDLFNBQVM7K0JBQ0UsMkJBQTJCLGNBQ3pCLElBQUksV0FDUDt3QkFDUCxZQUFZO3dCQUNaLGFBQWE7cUJBQ2QsWUFDUzs7Ozs7Ozs7Ozs7Ozs7R0FjVDt1RkF5QlEsS0FBSztzQkFBYixLQUFLO2dCQUNHLElBQUk7c0JBQVosS0FBSztnQkFDRyxJQUFJO3NCQUFaLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIElucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgRm9ybUdyb3VwIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xuaW1wb3J0IHsgRHluYW1pY0Zvcm1GaWVsZENvbmZpZyB9IGZyb20gJy4uL21vZGVscy9keW5hbWljLWZvcm0ubW9kZWxzJztcbmltcG9ydCB7IFRyYW5zbGF0ZVBpcGUgfSBmcm9tICcuLi8uLi8uLi9waXBlcy90cmFuc2xhdGUucGlwZSc7XG5pbXBvcnQgeyBUcmFuc2xhdGlvblNlcnZpY2UgfSBmcm9tICcuLi8uLi8uLi9zZXJ2aWNlcy90cmFuc2xhdGlvbi5zZXJ2aWNlJztcblxuLyoqXG4gKiBDb21wb25lbnRlIHdyYXBwZXIgcGFyYSBjYW1wb3MgZGUgZm9ybXVsw6FyaW8gZGluw6JtaWNvXG4gKiBDZW50cmFsaXphIGEgcmVuZGVyaXphw6fDo28gZGUgbGFiZWwsIGNhbXBvIGUgbWVuc2FnZW0gZGUgZXJyb1xuICovXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdzaWEtZHluYW1pYy1maWVsZC13cmFwcGVyJyxcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgaW1wb3J0czogW1xuICAgIENvbW1vbk1vZHVsZSxcbiAgICBUcmFuc2xhdGVQaXBlXG4gIF0sXG4gIHRlbXBsYXRlOiBgXG4gICAgPGRpdiBjbGFzcz1cImZpZWxkXCI+XG4gICAgICA8bGFiZWwgW2Zvcl09XCJmaWVsZC5maWVsZFwiPlxuICAgICAgICB7eyBmaWVsZC5sYWJlbCB8IHRyYW5zbGF0ZSB9fVxuICAgICAgICA8c3BhbiAqbmdJZj1cImlzUmVxdWlyZWQoKVwiIGNsYXNzPVwicmVxdWlyZWQtYXN0ZXJpc2tcIj4qPC9zcGFuPlxuICAgICAgPC9sYWJlbD5cbiAgICAgIFxuICAgICAgPCEtLSBDb250ZcO6ZG8gZG8gY2FtcG8gKHByb2pldGFkbyB2aWEgbmctY29udGVudCkgLS0+XG4gICAgICA8bmctY29udGVudD48L25nLWNvbnRlbnQ+XG4gICAgICBcbiAgICAgIDxzbWFsbCAqbmdJZj1cImlzRmllbGRJbnZhbGlkKClcIiBjbGFzcz1cInAtZXJyb3JcIj5cbiAgICAgICAge3sgZ2V0RmllbGRFcnJvcigpIH19XG4gICAgICA8L3NtYWxsPlxuICAgIDwvZGl2PlxuICBgLFxuICBzdHlsZXM6IFtgXG4gICAgLmZpZWxkIHtcbiAgICAgIGRpc3BsYXk6IGZsZXg7XG4gICAgICBmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xuICAgICAgZ2FwOiAwLjVyZW07XG5cbiAgICAgIGxhYmVsIHtcbiAgICAgICAgZm9udC13ZWlnaHQ6IDUwMDtcbiAgICAgICAgY29sb3I6IHZhcigtLXRleHQtY29sb3IpO1xuXG4gICAgICAgIC5yZXF1aXJlZC1hc3RlcmlzayB7XG4gICAgICAgICAgY29sb3I6IHZhcigtLXAtcmVkLTUwMCk7XG4gICAgICAgICAgbWFyZ2luLWxlZnQ6IDAuMjVyZW07XG4gICAgICAgIH1cbiAgICAgIH1cblxuICAgICAgc21hbGwucC1lcnJvciB7XG4gICAgICAgIG1hcmdpbi10b3A6IDAuMjVyZW07XG4gICAgICAgIGNvbG9yOiB2YXIoLS1wLXJlZC01MDApO1xuICAgICAgfVxuICAgIH1cbiAgYF1cbn0pXG5leHBvcnQgY2xhc3MgRHluYW1pY0ZpZWxkV3JhcHBlckNvbXBvbmVudCB7XG4gIEBJbnB1dCgpIGZpZWxkITogRHluYW1pY0Zvcm1GaWVsZENvbmZpZztcbiAgQElucHV0KCkgZm9ybSE6IEZvcm1Hcm91cDtcbiAgQElucHV0KCkgbW9kZTogJ2Zvcm0nIHwgJ2ZpbHRlcicgPSAnZm9ybSc7XG5cbiAgY29uc3RydWN0b3IocHJpdmF0ZSB0cmFuc2xhdGlvblNlcnZpY2U6IFRyYW5zbGF0aW9uU2VydmljZSkge31cblxuICBpc1JlcXVpcmVkKCk6IGJvb2xlYW4ge1xuICAgIHJldHVybiB0aGlzLmZpZWxkLnJlcXVpcmVkID09PSB0cnVlICYmIHRoaXMubW9kZSA9PT0gJ2Zvcm0nO1xuICB9XG5cbiAgaXNGaWVsZEludmFsaWQoKTogYm9vbGVhbiB7XG4gICAgY29uc3QgY29udHJvbCA9IHRoaXMuZm9ybS5nZXQodGhpcy5maWVsZC5maWVsZCk7XG4gICAgcmV0dXJuICEhKGNvbnRyb2wgJiYgY29udHJvbC5pbnZhbGlkICYmIChjb250cm9sLmRpcnR5IHx8IGNvbnRyb2wudG91Y2hlZCkpO1xuICB9XG5cbiAgZ2V0RmllbGRFcnJvcigpOiBzdHJpbmcge1xuICAgIGNvbnN0IGNvbnRyb2wgPSB0aGlzLmZvcm0uZ2V0KHRoaXMuZmllbGQuZmllbGQpO1xuICAgIFxuICAgIGlmIChjb250cm9sPy5oYXNFcnJvcigncmVxdWlyZWQnKSkge1xuICAgICAgcmV0dXJuIHRoaXMudHJhbnNsYXRpb25TZXJ2aWNlLnRyYW5zbGF0ZSgnZGVzaWduLmNvbXBvbmVudHNfYWkucmVxdWlyZWRfZmllbGQnKTtcbiAgICB9XG4gICAgaWYgKGNvbnRyb2w/Lmhhc0Vycm9yKCdtaW5sZW5ndGgnKSkge1xuICAgICAgY29uc3QgbWluTGVuZ3RoID0gdGhpcy5maWVsZC5taW5MZW5ndGggfHwgY29udHJvbC5lcnJvcnM/LlsnbWlubGVuZ3RoJ10ucmVxdWlyZWRMZW5ndGg7XG4gICAgICByZXR1cm4gdGhpcy50cmFuc2xhdGlvblNlcnZpY2UudHJhbnNsYXRlKCdkZXNpZ24uY29tcG9uZW50c19haS5taW5fbGVuZ3RoX2Vycm9yJywgeyBsZW5ndGg6IG1pbkxlbmd0aCB9KTtcbiAgICB9XG4gICAgaWYgKGNvbnRyb2w/Lmhhc0Vycm9yKCdtYXhsZW5ndGgnKSkge1xuICAgICAgY29uc3QgbWF4TGVuZ3RoID0gdGhpcy5maWVsZC5tYXhMZW5ndGggfHwgY29udHJvbC5lcnJvcnM/LlsnbWF4bGVuZ3RoJ10ucmVxdWlyZWRMZW5ndGg7XG4gICAgICByZXR1cm4gdGhpcy50cmFuc2xhdGlvblNlcnZpY2UudHJhbnNsYXRlKCdkZXNpZ24uY29tcG9uZW50c19haS5tYXhfbGVuZ3RoX2Vycm9yJywgeyBsZW5ndGg6IG1heExlbmd0aCB9KTtcbiAgICB9XG4gICAgaWYgKGNvbnRyb2w/Lmhhc0Vycm9yKCdtaW4nKSkge1xuICAgICAgY29uc3QgbWluID0gdGhpcy5maWVsZC5taW4gfHwgY29udHJvbC5lcnJvcnM/LlsnbWluJ10ubWluO1xuICAgICAgcmV0dXJuIHRoaXMudHJhbnNsYXRpb25TZXJ2aWNlLnRyYW5zbGF0ZSgnZGVzaWduLmNvbXBvbmVudHNfYWkubWluX3ZhbHVlX2Vycm9yJywgeyB2YWx1ZTogbWluIH0pO1xuICAgIH1cbiAgICBpZiAoY29udHJvbD8uaGFzRXJyb3IoJ21heCcpKSB7XG4gICAgICBjb25zdCBtYXggPSB0aGlzLmZpZWxkLm1heCB8fCBjb250cm9sLmVycm9ycz8uWydtYXgnXS5tYXg7XG4gICAgICByZXR1cm4gdGhpcy50cmFuc2xhdGlvblNlcnZpY2UudHJhbnNsYXRlKCdkZXNpZ24uY29tcG9uZW50c19haS5tYXhfdmFsdWVfZXJyb3InLCB7IHZhbHVlOiBtYXggfSk7XG4gICAgfVxuICAgIHJldHVybiAnJztcbiAgfVxufVxuIl19
@@ -1,2 +1,2 @@
1
1
  export {};
2
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dynamic-form.models.js","sourceRoot":"","sources":["../../../../../../projects/components-ai/src/lib/components/dynamic-form/models/dynamic-form.models.ts"],"names":[],"mappings":"","sourcesContent":["import { ValidatorFn } from '@angular/forms';\n\n/**\n * Lookup column configuration for dynamic form lookup fields\n */\nexport interface DynamicFormLookupColumn {\n  field: string;\n  header: string;\n  width?: string;\n  type?: 'text' | 'number';\n}\n\n/**\n * Responsive size configuration for form fields\n */\nexport interface DynamicFormFieldSize {\n  xs?: number; // Extra small screens (<576px)\n  sm?: number; // Small screens (≥576px)\n  md?: number; // Medium screens (≥768px)\n  lg?: number; // Large screens (≥992px)\n  xl?: number; // Extra large screens (≥1200px)\n}\n\n/**\n * Dynamic Form Field Configuration\n * Complete configuration interface for all field types in dynamic forms\n */\nexport interface DynamicFormFieldConfig {\n  // Basic properties\n  field: string;\n  label: string;\n  type: 'text' | 'number' | 'dropdown' | 'lookup' | 'textarea' | 'enum' | 'date';\n  \n  // Validation\n  validators?: ValidatorFn[];\n  required?: boolean;\n  \n  // Common properties\n  placeholder?: string;\n  defaultValue?: any;\n  disabled?: boolean;\n  \n  // Layout properties\n  colspan?: number; // Number of columns to span (1-12, default: 6)\n  size?: DynamicFormFieldSize; // Responsive sizes object\n  colspanXs?: number; // Deprecated: use size.xs\n  colspanSm?: number; // Deprecated: use size.sm\n  colspanMd?: number; // Deprecated: use size.md\n  colspanLg?: number; // Deprecated: use size.lg\n  colspanXl?: number; // Deprecated: use size.xl\n  colspanWhen?: { // Conditional colspan based on other field values\n    field: string;\n    value: any;\n    colspan: number;\n  }[];\n  \n  // Conditional visibility and state\n  visibleWhen?: { // Conditional visibility\n    field: string;\n    value: any;\n  };\n  disabledWhen?: { // Conditional disabled state\n    field: string;\n    value: any;\n  };\n  \n  // Text field properties\n  minLength?: number;\n  maxLength?: number;\n  mask?: 'cep' | 'phone' | 'document' | 'cpf' | 'cnpj' | 'dynamic';\n  maskDependsOn?: string; // Field name that determines the mask type (e.g., 'typePerson')\n  maskMapping?: { [key: string]: 'NATURAL_PERSON' | 'JURIDICAL_PERSON' }; // Maps field values to document types\n  useCepMask?: boolean; // Deprecated: use mask='cep'\n  usePhoneMask?: boolean; // Deprecated: use mask='phone'\n  \n  // Textarea properties\n  rows?: number;\n  fullSize?: boolean; // For textarea to take full width\n  \n  // Number field properties\n  min?: number;\n  max?: number;\n  minFractionDigits?: number;\n  maxFractionDigits?: number;\n  numberMode?: 'decimal' | 'currency';\n  currency?: string; // Currency code (default: 'BRL')\n  locale?: string; // Locale for number formatting (default: 'pt-BR')\n  useGrouping?: boolean; // For number inputs\n  \n  // Date field properties\n  dateFormat?: string; // Date format for calendar (default: 'dd/mm/yy')\n  \n  // Dropdown properties\n  options?: any[];\n  optionLabel?: string;\n  optionValue?: string;\n  showClear?: boolean;\n  filter?: boolean;\n  filterBy?: string;\n  \n  // Enum properties\n  enumValues?: string[];\n  enumLabels?: { [key: string]: string };\n  enumOptions?: { value: any; label: string }[]; // Alternative to enumValues/enumLabels\n  \n  // Lookup properties\n  lookupEntity?: string; // Entity name for lookup\n  lookupService?: any; // Service to fetch lookup data\n  lookupDisplayField?: string; // Field to display in the lookup (default: 'name')\n  lookupDisplayFields?: string[]; // Multiple fields to display separated by ' - '\n  lookupValueField?: string; // Field to use as value (default: 'id')\n  lookupSearchFields?: string[]; // Fields to search in (default: ['name'])\n  lookupColumns?: DynamicFormLookupColumn[]; // Columns to display in lookup table\n  lookupFilters?: { [key: string]: any }; // Static filters for lookup\n  lookupDynamicFilters?: (formValues: any) => { [key: string]: any }; // Dynamic filters based on form values\n}\n\n/**\n * Dynamic Form Display Mode\n * Define como o formulário será exibido\n */\nexport type DynamicFormDisplayMode = 'inline' | 'dialog' | 'drawer' | 'inline-edit';\n\n/**\n * Dynamic Form Dialog Configuration\n * Configurações específicas para o modo dialog\n */\nexport interface DynamicFormDialogConfig {\n  header?: string;\n  width?: string;\n  draggable?: boolean;\n  resizable?: boolean;\n  maximizable?: boolean;\n  closeOnEscape?: boolean;\n  dismissableMask?: boolean;\n}\n\n/**\n * Dynamic Form Drawer Size\n * Tamanhos padronizados para o drawer\n */\nexport type DynamicFormDrawerSize = 'small' | 'medium' | 'large' | 'xlarge' | 'full';\n\n/**\n * Dynamic Form Drawer Configuration\n * Configurações específicas para o modo drawer\n */\nexport interface DynamicFormDrawerConfig {\n  header?: string;\n  position?: 'left' | 'right' | 'top' | 'bottom';\n  size?: DynamicFormDrawerSize; // Tamanho padronizado do drawer\n  customWidth?: string; // Largura customizada (sobrescreve size)\n  showCloseIcon?: boolean;\n  closeOnEscape?: boolean;\n  dismissable?: boolean; // Controls modal behavior (backdrop click to close)\n}\n\n/**\n * Dynamic Form Section\n * Agrupa campos em seções colapsáveis\n */\nexport interface DynamicFormSection {\n  title: string;\n  fields: DynamicFormFieldConfig[];\n  collapsed?: boolean; // Se a seção inicia colapsada (padrão: false)\n  toggleable?: boolean; // Se a seção pode ser colapsada (padrão: true)\n  icon?: string; // Ícone da seção (opcional)\n}\n\n/**\n * Dynamic Form Configuration\n * Main configuration interface for the dynamic form component\n */\nexport interface DynamicFormConfig {\n  fields: DynamicFormFieldConfig[];\n  sections?: DynamicFormSection[]; // Seções de campos (opcional)\n  fixedFilters?: DynamicFormFieldConfig[]; // Filtros fixos (sempre visíveis no topo, apenas modo filter)\n  filterSections?: DynamicFormSection[]; // Seções de filtros (colapsáveis, apenas modo filter)\n  mode?: 'form' | 'filter';\n  displayMode?: DynamicFormDisplayMode; // Modo de exibição (inline, dialog, drawer)\n  dialogConfig?: DynamicFormDialogConfig; // Configurações do dialog\n  drawerConfig?: DynamicFormDrawerConfig; // Configurações do drawer\n  initialData?: any;\n  submitOnEnter?: boolean;\n  showSubmitButton?: boolean;\n  submitButtonLabel?: string;\n  showCancelButton?: boolean;\n  cancelButtonLabel?: string;\n}\n\n/**\n * Dynamic Form Submit Event\n */\nexport interface DynamicFormSubmitEvent {\n  value: any;\n  valid: boolean;\n  dirty: boolean;\n  touched: boolean;\n}\n\n/**\n * Type alias for backward compatibility with FormFieldConfig\n * @deprecated Use DynamicFormFieldConfig instead\n */\nexport type FormFieldConfig = DynamicFormFieldConfig;\n"]}
2
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dynamic-form.models.js","sourceRoot":"","sources":["../../../../../../projects/components-ai/src/lib/components/dynamic-form/models/dynamic-form.models.ts"],"names":[],"mappings":"","sourcesContent":["import { ValidatorFn } from '@angular/forms';\n\n/**\n * Lookup column configuration for dynamic form lookup fields\n */\nexport interface DynamicFormLookupColumn {\n  field: string;\n  header: string;\n  width?: string;\n  type?: 'text' | 'number';\n}\n\n/**\n * Responsive size configuration for form fields\n */\nexport interface DynamicFormFieldSize {\n  xs?: number; // Extra small screens (<576px)\n  sm?: number; // Small screens (≥576px)\n  md?: number; // Medium screens (≥768px)\n  lg?: number; // Large screens (≥992px)\n  xl?: number; // Extra large screens (≥1200px)\n}\n\n/**\n * Dynamic Form Field Configuration\n * Complete configuration interface for all field types in dynamic forms\n */\nexport interface DynamicFormFieldConfig {\n  // Basic properties\n  field: string;\n  label: string;\n  type: 'text' | 'number' | 'dropdown' | 'lookup' | 'textarea' | 'enum' | 'date';\n  \n  // Validation\n  validators?: ValidatorFn[];\n  required?: boolean;\n  \n  // Common properties\n  placeholder?: string;\n  defaultValue?: any;\n  disabled?: boolean;\n  \n  // Layout properties\n  colspan?: number; // Number of columns to span (1-12, default: 6)\n  size?: DynamicFormFieldSize; // Responsive sizes object\n  colspanXs?: number; // Deprecated: use size.xs\n  colspanSm?: number; // Deprecated: use size.sm\n  colspanMd?: number; // Deprecated: use size.md\n  colspanLg?: number; // Deprecated: use size.lg\n  colspanXl?: number; // Deprecated: use size.xl\n  colspanWhen?: { // Conditional colspan based on other field values\n    field: string;\n    value: any;\n    colspan: number;\n  }[];\n  \n  // Conditional visibility and state\n  visibleWhen?: { // Conditional visibility\n    field: string;\n    value: any;\n  };\n  disabledWhen?: { // Conditional disabled state\n    field: string;\n    value: any;\n  };\n  \n  // Text field properties\n  minLength?: number;\n  maxLength?: number;\n  mask?: 'cep' | 'phone' | 'document' | 'cpf' | 'cnpj' | 'dynamic';\n  maskDependsOn?: string; // Field name that determines the mask type (e.g., 'typePerson')\n  maskMapping?: { [key: string]: 'NATURAL_PERSON' | 'JURIDICAL_PERSON' }; // Maps field values to document types\n  useCepMask?: boolean; // Deprecated: use mask='cep'\n  usePhoneMask?: boolean; // Deprecated: use mask='phone'\n  \n  // Textarea properties\n  rows?: number;\n  fullSize?: boolean; // For textarea to take full width\n  \n  // Number field properties\n  min?: number;\n  max?: number;\n  minFractionDigits?: number;\n  maxFractionDigits?: number;\n  numberMode?: 'decimal' | 'currency';\n  currency?: string; // Currency code (default: 'BRL')\n  locale?: string; // Locale for number formatting (default: 'pt-BR')\n  useGrouping?: boolean; // For number inputs\n  \n  // Date field properties\n  dateFormat?: string; // Date format for calendar (default: 'dd/mm/yy')\n  \n  // Dropdown properties\n  options?: any[];\n  optionLabel?: string;\n  optionValue?: string;\n  showClear?: boolean;\n  filter?: boolean;\n  filterBy?: string;\n  \n  // Enum properties\n  enumValues?: string[];\n  enumLabels?: { [key: string]: string };\n  enumOptions?: { value: any; label: string }[]; // Alternative to enumValues/enumLabels\n  \n  // Lookup properties\n  lookupEntity?: string; // Entity name for lookup\n  lookupService?: any; // Service to fetch lookup data\n  lookupDisplayField?: string; // Field to display in the lookup (default: 'name')\n  lookupDisplayFields?: string[]; // Multiple fields to display separated by ' - '\n  lookupValueField?: string; // Field to use as value (default: 'id')\n  lookupSearchFields?: string[]; // Fields to search in (default: ['name'])\n  lookupColumns?: DynamicFormLookupColumn[]; // Columns to display in lookup table\n  lookupFilters?: { [key: string]: any }; // Static filters for lookup\n  lookupSort?: { field: string; order: number }[]; // Sort configuration for lookup (order: 1=asc, -1=desc)\n  lookupDynamicFilters?: (formValues: any) => { [key: string]: any }; // Dynamic filters based on form values\n}\n\n/**\n * Dynamic Form Display Mode\n * Define como o formulário será exibido\n */\nexport type DynamicFormDisplayMode = 'inline' | 'dialog' | 'drawer' | 'inline-edit';\n\n/**\n * Dynamic Form Dialog Configuration\n * Configurações específicas para o modo dialog\n */\nexport interface DynamicFormDialogConfig {\n  header?: string;\n  width?: string;\n  draggable?: boolean;\n  resizable?: boolean;\n  maximizable?: boolean;\n  closeOnEscape?: boolean;\n  dismissableMask?: boolean;\n}\n\n/**\n * Dynamic Form Drawer Size\n * Tamanhos padronizados para o drawer\n */\nexport type DynamicFormDrawerSize = 'small' | 'medium' | 'large' | 'xlarge' | 'full';\n\n/**\n * Dynamic Form Drawer Configuration\n * Configurações específicas para o modo drawer\n */\nexport interface DynamicFormDrawerConfig {\n  header?: string;\n  position?: 'left' | 'right' | 'top' | 'bottom';\n  size?: DynamicFormDrawerSize; // Tamanho padronizado do drawer\n  customWidth?: string; // Largura customizada (sobrescreve size)\n  showCloseIcon?: boolean;\n  closeOnEscape?: boolean;\n  dismissable?: boolean; // Controls modal behavior (backdrop click to close)\n}\n\n/**\n * Dynamic Form Section\n * Agrupa campos em seções colapsáveis\n */\nexport interface DynamicFormSection {\n  title: string;\n  fields: DynamicFormFieldConfig[];\n  collapsed?: boolean; // Se a seção inicia colapsada (padrão: false)\n  toggleable?: boolean; // Se a seção pode ser colapsada (padrão: true)\n  icon?: string; // Ícone da seção (opcional)\n}\n\n/**\n * Dynamic Form Configuration\n * Main configuration interface for the dynamic form component\n */\nexport interface DynamicFormConfig {\n  fields: DynamicFormFieldConfig[];\n  sections?: DynamicFormSection[]; // Seções de campos (opcional)\n  fixedFilters?: DynamicFormFieldConfig[]; // Filtros fixos (sempre visíveis no topo, apenas modo filter)\n  filterSections?: DynamicFormSection[]; // Seções de filtros (colapsáveis, apenas modo filter)\n  mode?: 'form' | 'filter';\n  displayMode?: DynamicFormDisplayMode; // Modo de exibição (inline, dialog, drawer)\n  dialogConfig?: DynamicFormDialogConfig; // Configurações do dialog\n  drawerConfig?: DynamicFormDrawerConfig; // Configurações do drawer\n  initialData?: any;\n  submitOnEnter?: boolean;\n  showSubmitButton?: boolean;\n  submitButtonLabel?: string;\n  showCancelButton?: boolean;\n  cancelButtonLabel?: string;\n}\n\n/**\n * Dynamic Form Submit Event\n */\nexport interface DynamicFormSubmitEvent {\n  value: any;\n  valid: boolean;\n  dirty: boolean;\n  touched: boolean;\n}\n\n/**\n * Type alias for backward compatibility with FormFieldConfig\n * @deprecated Use DynamicFormFieldConfig instead\n */\nexport type FormFieldConfig = DynamicFormFieldConfig;\n"]}
@@ -7,8 +7,8 @@ import { RadioButtonModule } from 'primeng/radiobutton';
7
7
  import { CheckboxModule } from 'primeng/checkbox';
8
8
  import { DividerModule } from 'primeng/divider';
9
9
  import * as XLSX from 'xlsx';
10
- import { jsPDF } from 'jspdf';
11
- import autoTable from 'jspdf-autotable';
10
+ import jsPDF from 'jspdf';
11
+ import 'jspdf-autotable';
12
12
  import { TranslatePipe } from '../../pipes/translate.pipe';
13
13
  import * as i0 from "@angular/core";
14
14
  import * as i1 from "../../services/translation.service";
@@ -156,7 +156,7 @@ export class ExportDialogComponent {
156
156
  });
157
157
  });
158
158
  // Tabela
159
- autoTable(doc, {
159
+ doc.autoTable({
160
160
  head: [headers],
161
161
  body: data,
162
162
  startY: 40,
@@ -208,4 +208,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
208
208
  }], visibleChange: [{
209
209
  type: Output
210
210
  }] } });
211
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"export-dialog.component.js","sourceRoot":"","sources":["../../../../../projects/components-ai/src/lib/components/export-dialog/export-dialog.component.ts","../../../../../projects/components-ai/src/lib/components/export-dialog/export-dialog.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, Output, OnChanges } from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { FormsModule } from '@angular/forms';\nimport { DialogModule } from 'primeng/dialog';\nimport { ButtonModule } from 'primeng/button';\nimport { RadioButtonModule } from 'primeng/radiobutton';\nimport { CheckboxModule } from 'primeng/checkbox';\nimport { DividerModule } from 'primeng/divider';\nimport * as XLSX from 'xlsx';\nimport { jsPDF } from 'jspdf';\nimport autoTable from 'jspdf-autotable';\nimport { TranslatePipe } from '../../pipes/translate.pipe';\nimport { TranslationService } from '../../services/translation.service';\n\nexport interface ColumnOption {\n  field: string;\n  header: string;\n  selected: boolean;\n}\n\ninterface ExportFormat {\n  value: 'xlsx' | 'pdf';\n  label: string;\n  icon: string;\n  description: string;\n}\n\ninterface ExportScope {\n  value: 'all' | 'selected';\n  label: string;\n  icon: string;\n  description: string;\n}\n\n@Component({\n  selector: 'sia-export-dialog',\n  standalone: true,\n  imports: [\n    CommonModule,\n    FormsModule,\n    DialogModule,\n    ButtonModule,\n    RadioButtonModule,\n    CheckboxModule,\n    DividerModule,\n    TranslatePipe\n  ],\n  templateUrl: './export-dialog.component.html',\n  styleUrl: './export-dialog.component.scss'\n})\nexport class ExportDialogComponent implements OnChanges {\n  @Input() visible: boolean = false;\n  @Input() allRecords: any[] = [];\n  @Input() selectedRecords: any[] = [];\n  @Input() statusLabels?: { [key: string]: string };\n  @Input() translationPrefix: string = 'design.components_ai';\n  @Input() set availableColumns(columns: ColumnOption[]) {\n    if (columns && columns.length > 0) {\n      this.columns = columns;\n    }\n  }\n  @Output() visibleChange = new EventEmitter<boolean>();\n\n  exportFormat: 'xlsx' | 'pdf' = 'xlsx';\n  exportScope: 'all' | 'selected' = 'all';\n\n  formats: ExportFormat[] = [];\n  scopes: ExportScope[] = [];\n  columns: ColumnOption[] = [];\n\n  constructor(private translationService: TranslationService) {\n    this.initializeFormats();\n    this.initializeScopes();\n  }\n\n  ngOnChanges(): void {\n    this.initializeFormats();\n    this.initializeScopes();\n  }\n\n  private initializeFormats(): void {\n    this.formats = [\n      {\n        value: 'xlsx',\n        label: 'Excel',\n        icon: 'pi-file-excel',\n        description: this.translationService.translate('design.components_ai.export_excel_description')\n      },\n      {\n        value: 'pdf',\n        label: 'PDF',\n        icon: 'pi-file-pdf',\n        description: this.translationService.translate('design.components_ai.export_pdf_description')\n      }\n    ];\n  }\n\n  private initializeScopes(): void {\n    this.scopes = [\n      {\n        value: 'all',\n        label: this.translationService.translate('design.components_ai.export_all_records'),\n        icon: 'pi-list',\n        description: this.translationService.translate('design.components_ai.export_all_records_description')\n      },\n      {\n        value: 'selected',\n        label: this.translationService.translate('design.components_ai.export_selected_records'),\n        icon: 'pi-check-square',\n        description: this.translationService.translate('design.components_ai.export_selected_records_description')\n      }\n    ];\n  }\n\n  get recordsToExport(): any[] {\n    return this.exportScope === 'all' ? this.allRecords : this.selectedRecords;\n  }\n\n  get selectedColumnsCount(): number {\n    return this.columns.filter(col => col.selected).length;\n  }\n\n  get canExport(): boolean {\n    return this.selectedColumnsCount > 0 && this.recordsToExport.length > 0;\n  }\n\n  onHide(): void {\n    this.visibleChange.emit(false);\n  }\n\n  selectAllColumns(): void {\n    this.columns.forEach(col => col.selected = true);\n  }\n\n  deselectAllColumns(): void {\n    this.columns.forEach(col => col.selected = false);\n  }\n\n  export(): void {\n    if (!this.canExport) return;\n\n    if (this.exportFormat === 'xlsx') {\n      this.exportToExcel();\n    } else {\n      this.exportToPDF();\n    }\n\n    this.onHide();\n  }\n\n  private exportToExcel(): void {\n    const selectedColumns = this.columns.filter(col => col.selected);\n    const data = this.recordsToExport.map(record => {\n      const row: any = {};\n      selectedColumns.forEach(col => {\n        if (col.field === 'status' && record.status && this.statusLabels) {\n          row[col.header] = this.statusLabels[record.status];\n        } else {\n          row[col.header] = record[col.field];\n        }\n      });\n      return row;\n    });\n\n    const worksheet = XLSX.utils.json_to_sheet(data);\n    const workbook = XLSX.utils.book_new();\n    XLSX.utils.book_append_sheet(workbook, worksheet, this.translationService.translate('design.components_ai.export_data_sheet_name'));\n\n    // Ajustar largura das colunas\n    const maxWidth = 30;\n    const colWidths = selectedColumns.map(col => ({\n      wch: Math.min(col.header.length + 5, maxWidth)\n    }));\n    worksheet['!cols'] = colWidths;\n\n    const fileName = `export-${new Date().getTime()}.xlsx`;\n    XLSX.writeFile(workbook, fileName);\n  }\n\n  private exportToPDF(): void {\n    const doc = new jsPDF();\n    const selectedColumns = this.columns.filter(col => col.selected);\n\n    // Título\n    doc.setFontSize(18);\n    doc.setTextColor(18, 168, 133);\n    doc.text(this.translationService.translate('design.components_ai.export_pdf_title'), 14, 20);\n\n    // Subtítulo\n    doc.setFontSize(10);\n    doc.setTextColor(100);\n    doc.text(`${this.translationService.translate('design.components_ai.export_exported_at')}: ${new Date().toLocaleString('pt-BR')}`, 14, 28);\n    doc.text(`${this.translationService.translate('design.components_ai.export_total_records')}: ${this.recordsToExport.length}`, 14, 34);\n\n    // Preparar dados\n    const headers = selectedColumns.map(col => col.header);\n    const data = this.recordsToExport.map(record => {\n      return selectedColumns.map(col => {\n        if (col.field === 'status' && record.status && this.statusLabels) {\n          return this.statusLabels[record.status];\n        }\n        return String(record[col.field] || '');\n      });\n    });\n\n    // Tabela\n    autoTable(doc, {\n      head: [headers],\n      body: data,\n      startY: 40,\n      theme: 'grid',\n      headStyles: {\n        fillColor: [18, 168, 133],\n        textColor: [255, 255, 255],\n        fontStyle: 'bold',\n        halign: 'center'\n      },\n      styles: {\n        fontSize: 9,\n        cellPadding: 3\n      },\n      alternateRowStyles: {\n        fillColor: [248, 255, 254]\n      }\n    });\n\n    const fileName = `export-${new Date().getTime()}.pdf`;\n    doc.save(fileName);\n  }\n}\n","<p-dialog\n  [(visible)]=\"visible\"\n  (onHide)=\"onHide()\"\n  [modal]=\"true\"\n  [draggable]=\"false\"\n  [resizable]=\"false\"\n  [style]=\"{ width: '700px' }\"\n  styleClass=\"export-dialog\"\n>\n  <ng-template pTemplate=\"header\">\n    <div class=\"custom-header\">\n      <i class=\"pi pi-download header-icon\"></i>\n      <span>{{ 'design.components_ai.export_data_title' | translate }}</span>\n    </div>\n  </ng-template>\n\n  <div class=\"export-content\">\n    <!-- Formato de Exportação -->\n    <div class=\"export-section\">\n      <div class=\"section-header\">\n        <div class=\"section-icon\">\n          <i class=\"pi pi-file\"></i>\n        </div>\n        <h3>{{ 'design.components_ai.export_format_title' | translate }}</h3>\n      </div>\n      <div class=\"format-options\">\n        <div\n          *ngFor=\"let format of formats\"\n          class=\"format-card\"\n          [class.selected]=\"exportFormat === format.value\"\n          (click)=\"exportFormat = format.value\"\n        >\n          <div class=\"card-radio\">\n            <p-radioButton\n              [value]=\"format.value\"\n              [(ngModel)]=\"exportFormat\"\n              [inputId]=\"format.value\"\n            ></p-radioButton>\n          </div>\n          <div class=\"card-icon\" [class.excel]=\"format.value === 'xlsx'\" [class.pdf]=\"format.value === 'pdf'\">\n            <i class=\"pi\" [ngClass]=\"format.icon\"></i>\n          </div>\n          <div class=\"card-info\">\n            <label [for]=\"format.value\" class=\"card-label\">{{ format.label }}</label>\n            <span class=\"card-description\">{{ format.description }}</span>\n          </div>\n        </div>\n      </div>\n    </div>\n\n    <!-- Escopo de Exportação -->\n    <div class=\"export-section\">\n      <div class=\"section-header\">\n        <div class=\"section-icon\">\n          <i class=\"pi pi-filter\"></i>\n        </div>\n        <h3>{{ 'design.components_ai.export_scope_title' | translate }}</h3>\n      </div>\n      <div class=\"scope-options\">\n        <div\n          *ngFor=\"let scope of scopes\"\n          class=\"scope-card\"\n          [class.selected]=\"exportScope === scope.value\"\n          [class.disabled]=\"scope.value === 'selected' && selectedRecords.length === 0\"\n          (click)=\"scope.value === 'selected' && selectedRecords.length === 0 ? null : exportScope = scope.value\"\n        >\n          <div class=\"card-radio\">\n            <p-radioButton\n              [value]=\"scope.value\"\n              [(ngModel)]=\"exportScope\"\n              [inputId]=\"scope.value\"\n              [disabled]=\"scope.value === 'selected' && selectedRecords.length === 0\"\n            ></p-radioButton>\n          </div>\n          <div class=\"card-icon\">\n            <i class=\"pi\" [ngClass]=\"scope.icon\"></i>\n          </div>\n          <div class=\"card-info\">\n            <label [for]=\"scope.value\" class=\"card-label\">{{ scope.label }}</label>\n            <span class=\"card-description\">{{ scope.description }}</span>\n            <span class=\"card-count\">\n              <i class=\"pi pi-circle-fill\"></i>\n              {{ scope.value === 'all' ? allRecords.length : selectedRecords.length }} {{ 'design.components_ai.export_records_count' | translate }}\n            </span>\n          </div>\n        </div>\n      </div>\n    </div>\n\n    <!-- Seleção de Colunas -->\n    <div class=\"export-section\">\n      <div class=\"section-header\">\n        <div class=\"section-icon\">\n          <i class=\"pi pi-table\"></i>\n        </div>\n        <h3>{{ 'design.components_ai.export_columns_title' | translate }}</h3>\n        <div class=\"column-actions\">\n          <button type=\"button\" class=\"action-link\" (click)=\"selectAllColumns()\">\n            {{ 'design.components_ai.export_select_all_columns' | translate }}\n          </button>\n          <span class=\"separator\">|</span>\n          <button type=\"button\" class=\"action-link\" (click)=\"deselectAllColumns()\">\n            {{ 'design.components_ai.export_clear_selection' | translate }}\n          </button>\n        </div>\n      </div>\n      <div class=\"columns-grid\">\n        <div\n          *ngFor=\"let column of columns\"\n          class=\"column-item\"\n          [class.selected]=\"column.selected\"\n          (click)=\"column.selected = !column.selected\"\n        >\n          <p-checkbox\n            [(ngModel)]=\"column.selected\"\n            [binary]=\"true\"\n            [inputId]=\"column.field\"\n          ></p-checkbox>\n          <label [for]=\"column.field\" class=\"column-label\">\n            {{ column.header }}\n          </label>\n        </div>\n      </div>\n      <div class=\"columns-summary\">\n        <i class=\"pi pi-info-circle\"></i>\n        <span>{{ selectedColumnsCount }} {{ 'design.components_ai.export_columns_summary' | translate }} {{ columns.length }} {{ 'design.components_ai.export_columns_selected' | translate }}</span>\n      </div>\n    </div>\n  </div>\n\n  <ng-template pTemplate=\"footer\">\n    <p-button\n      [label]=\"'design.components_ai.cancel' | translate\"\n      icon=\"pi pi-times\"\n      severity=\"secondary\"\n      [text]=\"true\"\n      (onClick)=\"onHide()\"\n    ></p-button>\n    <p-button\n      [label]=\"'design.components_ai.export_button' | translate\"\n      icon=\"pi pi-download\"\n      [disabled]=\"!canExport\"\n      (onClick)=\"export()\"\n    ></p-button>\n  </ng-template>\n</p-dialog>\n"]}
211
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"export-dialog.component.js","sourceRoot":"","sources":["../../../../../projects/components-ai/src/lib/components/export-dialog/export-dialog.component.ts","../../../../../projects/components-ai/src/lib/components/export-dialog/export-dialog.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, Output, OnChanges } from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { FormsModule } from '@angular/forms';\nimport { DialogModule } from 'primeng/dialog';\nimport { ButtonModule } from 'primeng/button';\nimport { RadioButtonModule } from 'primeng/radiobutton';\nimport { CheckboxModule } from 'primeng/checkbox';\nimport { DividerModule } from 'primeng/divider';\nimport * as XLSX from 'xlsx';\nimport jsPDF from 'jspdf';\nimport 'jspdf-autotable';\nimport { TranslatePipe } from '../../pipes/translate.pipe';\nimport { TranslationService } from '../../services/translation.service';\n\nexport interface ColumnOption {\n  field: string;\n  header: string;\n  selected: boolean;\n}\n\ninterface ExportFormat {\n  value: 'xlsx' | 'pdf';\n  label: string;\n  icon: string;\n  description: string;\n}\n\ninterface ExportScope {\n  value: 'all' | 'selected';\n  label: string;\n  icon: string;\n  description: string;\n}\n\n@Component({\n  selector: 'sia-export-dialog',\n  standalone: true,\n  imports: [\n    CommonModule,\n    FormsModule,\n    DialogModule,\n    ButtonModule,\n    RadioButtonModule,\n    CheckboxModule,\n    DividerModule,\n    TranslatePipe\n  ],\n  templateUrl: './export-dialog.component.html',\n  styleUrl: './export-dialog.component.scss'\n})\nexport class ExportDialogComponent implements OnChanges {\n  @Input() visible: boolean = false;\n  @Input() allRecords: any[] = [];\n  @Input() selectedRecords: any[] = [];\n  @Input() statusLabels?: { [key: string]: string };\n  @Input() translationPrefix: string = 'design.components_ai';\n  @Input() set availableColumns(columns: ColumnOption[]) {\n    if (columns && columns.length > 0) {\n      this.columns = columns;\n    }\n  }\n  @Output() visibleChange = new EventEmitter<boolean>();\n\n  exportFormat: 'xlsx' | 'pdf' = 'xlsx';\n  exportScope: 'all' | 'selected' = 'all';\n\n  formats: ExportFormat[] = [];\n  scopes: ExportScope[] = [];\n  columns: ColumnOption[] = [];\n\n  constructor(private translationService: TranslationService) {\n    this.initializeFormats();\n    this.initializeScopes();\n  }\n\n  ngOnChanges(): void {\n    this.initializeFormats();\n    this.initializeScopes();\n  }\n\n  private initializeFormats(): void {\n    this.formats = [\n      {\n        value: 'xlsx',\n        label: 'Excel',\n        icon: 'pi-file-excel',\n        description: this.translationService.translate('design.components_ai.export_excel_description')\n      },\n      {\n        value: 'pdf',\n        label: 'PDF',\n        icon: 'pi-file-pdf',\n        description: this.translationService.translate('design.components_ai.export_pdf_description')\n      }\n    ];\n  }\n\n  private initializeScopes(): void {\n    this.scopes = [\n      {\n        value: 'all',\n        label: this.translationService.translate('design.components_ai.export_all_records'),\n        icon: 'pi-list',\n        description: this.translationService.translate('design.components_ai.export_all_records_description')\n      },\n      {\n        value: 'selected',\n        label: this.translationService.translate('design.components_ai.export_selected_records'),\n        icon: 'pi-check-square',\n        description: this.translationService.translate('design.components_ai.export_selected_records_description')\n      }\n    ];\n  }\n\n  get recordsToExport(): any[] {\n    return this.exportScope === 'all' ? this.allRecords : this.selectedRecords;\n  }\n\n  get selectedColumnsCount(): number {\n    return this.columns.filter(col => col.selected).length;\n  }\n\n  get canExport(): boolean {\n    return this.selectedColumnsCount > 0 && this.recordsToExport.length > 0;\n  }\n\n  onHide(): void {\n    this.visibleChange.emit(false);\n  }\n\n  selectAllColumns(): void {\n    this.columns.forEach(col => col.selected = true);\n  }\n\n  deselectAllColumns(): void {\n    this.columns.forEach(col => col.selected = false);\n  }\n\n  export(): void {\n    if (!this.canExport) return;\n\n    if (this.exportFormat === 'xlsx') {\n      this.exportToExcel();\n    } else {\n      this.exportToPDF();\n    }\n\n    this.onHide();\n  }\n\n  private exportToExcel(): void {\n    const selectedColumns = this.columns.filter(col => col.selected);\n    const data = this.recordsToExport.map(record => {\n      const row: any = {};\n      selectedColumns.forEach(col => {\n        if (col.field === 'status' && record.status && this.statusLabels) {\n          row[col.header] = this.statusLabels[record.status];\n        } else {\n          row[col.header] = record[col.field];\n        }\n      });\n      return row;\n    });\n\n    const worksheet = XLSX.utils.json_to_sheet(data);\n    const workbook = XLSX.utils.book_new();\n    XLSX.utils.book_append_sheet(workbook, worksheet, this.translationService.translate('design.components_ai.export_data_sheet_name'));\n\n    // Ajustar largura das colunas\n    const maxWidth = 30;\n    const colWidths = selectedColumns.map(col => ({\n      wch: Math.min(col.header.length + 5, maxWidth)\n    }));\n    worksheet['!cols'] = colWidths;\n\n    const fileName = `export-${new Date().getTime()}.xlsx`;\n    XLSX.writeFile(workbook, fileName);\n  }\n\n  private exportToPDF(): void {\n    const doc = new jsPDF();\n    const selectedColumns = this.columns.filter(col => col.selected);\n\n    // Título\n    doc.setFontSize(18);\n    doc.setTextColor(18, 168, 133);\n    doc.text(this.translationService.translate('design.components_ai.export_pdf_title'), 14, 20);\n\n    // Subtítulo\n    doc.setFontSize(10);\n    doc.setTextColor(100);\n    doc.text(`${this.translationService.translate('design.components_ai.export_exported_at')}: ${new Date().toLocaleString('pt-BR')}`, 14, 28);\n    doc.text(`${this.translationService.translate('design.components_ai.export_total_records')}: ${this.recordsToExport.length}`, 14, 34);\n\n    // Preparar dados\n    const headers = selectedColumns.map(col => col.header);\n    const data = this.recordsToExport.map(record => {\n      return selectedColumns.map(col => {\n        if (col.field === 'status' && record.status && this.statusLabels) {\n          return this.statusLabels[record.status];\n        }\n        return String(record[col.field] || '');\n      });\n    });\n\n    // Tabela\n    (doc as any).autoTable({\n      head: [headers],\n      body: data,\n      startY: 40,\n      theme: 'grid',\n      headStyles: {\n        fillColor: [18, 168, 133],\n        textColor: [255, 255, 255],\n        fontStyle: 'bold',\n        halign: 'center'\n      },\n      styles: {\n        fontSize: 9,\n        cellPadding: 3\n      },\n      alternateRowStyles: {\n        fillColor: [248, 255, 254]\n      }\n    });\n\n    const fileName = `export-${new Date().getTime()}.pdf`;\n    doc.save(fileName);\n  }\n}\n","<p-dialog\n  [(visible)]=\"visible\"\n  (onHide)=\"onHide()\"\n  [modal]=\"true\"\n  [draggable]=\"false\"\n  [resizable]=\"false\"\n  [style]=\"{ width: '700px' }\"\n  styleClass=\"export-dialog\"\n>\n  <ng-template pTemplate=\"header\">\n    <div class=\"custom-header\">\n      <i class=\"pi pi-download header-icon\"></i>\n      <span>{{ 'design.components_ai.export_data_title' | translate }}</span>\n    </div>\n  </ng-template>\n\n  <div class=\"export-content\">\n    <!-- Formato de Exportação -->\n    <div class=\"export-section\">\n      <div class=\"section-header\">\n        <div class=\"section-icon\">\n          <i class=\"pi pi-file\"></i>\n        </div>\n        <h3>{{ 'design.components_ai.export_format_title' | translate }}</h3>\n      </div>\n      <div class=\"format-options\">\n        <div\n          *ngFor=\"let format of formats\"\n          class=\"format-card\"\n          [class.selected]=\"exportFormat === format.value\"\n          (click)=\"exportFormat = format.value\"\n        >\n          <div class=\"card-radio\">\n            <p-radioButton\n              [value]=\"format.value\"\n              [(ngModel)]=\"exportFormat\"\n              [inputId]=\"format.value\"\n            ></p-radioButton>\n          </div>\n          <div class=\"card-icon\" [class.excel]=\"format.value === 'xlsx'\" [class.pdf]=\"format.value === 'pdf'\">\n            <i class=\"pi\" [ngClass]=\"format.icon\"></i>\n          </div>\n          <div class=\"card-info\">\n            <label [for]=\"format.value\" class=\"card-label\">{{ format.label }}</label>\n            <span class=\"card-description\">{{ format.description }}</span>\n          </div>\n        </div>\n      </div>\n    </div>\n\n    <!-- Escopo de Exportação -->\n    <div class=\"export-section\">\n      <div class=\"section-header\">\n        <div class=\"section-icon\">\n          <i class=\"pi pi-filter\"></i>\n        </div>\n        <h3>{{ 'design.components_ai.export_scope_title' | translate }}</h3>\n      </div>\n      <div class=\"scope-options\">\n        <div\n          *ngFor=\"let scope of scopes\"\n          class=\"scope-card\"\n          [class.selected]=\"exportScope === scope.value\"\n          [class.disabled]=\"scope.value === 'selected' && selectedRecords.length === 0\"\n          (click)=\"scope.value === 'selected' && selectedRecords.length === 0 ? null : exportScope = scope.value\"\n        >\n          <div class=\"card-radio\">\n            <p-radioButton\n              [value]=\"scope.value\"\n              [(ngModel)]=\"exportScope\"\n              [inputId]=\"scope.value\"\n              [disabled]=\"scope.value === 'selected' && selectedRecords.length === 0\"\n            ></p-radioButton>\n          </div>\n          <div class=\"card-icon\">\n            <i class=\"pi\" [ngClass]=\"scope.icon\"></i>\n          </div>\n          <div class=\"card-info\">\n            <label [for]=\"scope.value\" class=\"card-label\">{{ scope.label }}</label>\n            <span class=\"card-description\">{{ scope.description }}</span>\n            <span class=\"card-count\">\n              <i class=\"pi pi-circle-fill\"></i>\n              {{ scope.value === 'all' ? allRecords.length : selectedRecords.length }} {{ 'design.components_ai.export_records_count' | translate }}\n            </span>\n          </div>\n        </div>\n      </div>\n    </div>\n\n    <!-- Seleção de Colunas -->\n    <div class=\"export-section\">\n      <div class=\"section-header\">\n        <div class=\"section-icon\">\n          <i class=\"pi pi-table\"></i>\n        </div>\n        <h3>{{ 'design.components_ai.export_columns_title' | translate }}</h3>\n        <div class=\"column-actions\">\n          <button type=\"button\" class=\"action-link\" (click)=\"selectAllColumns()\">\n            {{ 'design.components_ai.export_select_all_columns' | translate }}\n          </button>\n          <span class=\"separator\">|</span>\n          <button type=\"button\" class=\"action-link\" (click)=\"deselectAllColumns()\">\n            {{ 'design.components_ai.export_clear_selection' | translate }}\n          </button>\n        </div>\n      </div>\n      <div class=\"columns-grid\">\n        <div\n          *ngFor=\"let column of columns\"\n          class=\"column-item\"\n          [class.selected]=\"column.selected\"\n          (click)=\"column.selected = !column.selected\"\n        >\n          <p-checkbox\n            [(ngModel)]=\"column.selected\"\n            [binary]=\"true\"\n            [inputId]=\"column.field\"\n          ></p-checkbox>\n          <label [for]=\"column.field\" class=\"column-label\">\n            {{ column.header }}\n          </label>\n        </div>\n      </div>\n      <div class=\"columns-summary\">\n        <i class=\"pi pi-info-circle\"></i>\n        <span>{{ selectedColumnsCount }} {{ 'design.components_ai.export_columns_summary' | translate }} {{ columns.length }} {{ 'design.components_ai.export_columns_selected' | translate }}</span>\n      </div>\n    </div>\n  </div>\n\n  <ng-template pTemplate=\"footer\">\n    <p-button\n      [label]=\"'design.components_ai.cancel' | translate\"\n      icon=\"pi pi-times\"\n      severity=\"secondary\"\n      [text]=\"true\"\n      (onClick)=\"onHide()\"\n    ></p-button>\n    <p-button\n      [label]=\"'design.components_ai.export_button' | translate\"\n      icon=\"pi pi-download\"\n      [disabled]=\"!canExport\"\n      (onClick)=\"export()\"\n    ></p-button>\n  </ng-template>\n</p-dialog>\n"]}
@@ -1,4 +1,7 @@
1
1
  {
2
+ "design.components_ai.error": "Oops, something went wrong",
3
+ "design.components_ai.server_error": "Server Error",
4
+ "design.components_ai.server_error_message": "A server error occurred. Please try again later.",
2
5
  "design.components_ai.bulk_delete_title": "Bulk Delete",
3
6
  "design.components_ai.bulk_delete_warning": "You are about to delete <strong>{{count}}</strong> record(s).",
4
7
  "design.components_ai.bulk_delete_description": "This action cannot be undone. Records will be deleted one by one.",
@@ -41,7 +44,6 @@
41
44
  "design.components_ai.close": "Close",
42
45
  "design.components_ai.filter_search_placeholder": "Search by {{label}}",
43
46
  "design.components_ai.filter_select_placeholder": "Select {{label}}",
44
- "design.components_ai.error": "Error",
45
47
  "design.components_ai.success": "Success",
46
48
  "design.components_ai.load_error": "Error loading {{entityType}}",
47
49
  "design.components_ai.confirm_delete": "Confirm Deletion",
@@ -49,5 +51,10 @@
49
51
  "design.components_ai.yes": "Yes",
50
52
  "design.components_ai.no": "No",
51
53
  "design.components_ai.entity_deleted_success": "{{entityName}} deleted successfully",
52
- "design.components_ai.entity_delete_error": "Error deleting {{entityName}}"
54
+ "design.components_ai.entity_delete_error": "Error deleting {{entityName}}",
55
+ "design.components_ai.required_field": "Required field",
56
+ "design.components_ai.min_length_error": "Minimum of {{length}} characters",
57
+ "design.components_ai.max_length_error": "Maximum of {{length}} characters",
58
+ "design.components_ai.min_value_error": "Minimum value is {{value}}",
59
+ "design.components_ai.max_value_error": "Maximum value is {{value}}"
53
60
  }
@@ -1,4 +1,7 @@
1
1
  {
2
+ "design.components_ai.error": "Ups, algo salió mal",
3
+ "design.components_ai.server_error": "Error del Servidor",
4
+ "design.components_ai.server_error_message": "Ocurrió un error en el servidor. Inténtelo de nuevo más tarde.",
2
5
  "design.components_ai.bulk_delete_title": "Eliminación Masiva",
3
6
  "design.components_ai.bulk_delete_warning": "Está a punto de eliminar <strong>{{count}}</strong> registro(s).",
4
7
  "design.components_ai.bulk_delete_description": "Esta acción no se puede deshacer. Los registros se eliminarán uno por uno.",
@@ -41,7 +44,6 @@
41
44
  "design.components_ai.close": "Cerrar",
42
45
  "design.components_ai.filter_search_placeholder": "Buscar por {{label}}",
43
46
  "design.components_ai.filter_select_placeholder": "Seleccione {{label}}",
44
- "design.components_ai.error": "Error",
45
47
  "design.components_ai.success": "Éxito",
46
48
  "design.components_ai.load_error": "Error al cargar {{entityType}}",
47
49
  "design.components_ai.confirm_delete": "Confirmar Eliminación",
@@ -49,5 +51,10 @@
49
51
  "design.components_ai.yes": "Sí",
50
52
  "design.components_ai.no": "No",
51
53
  "design.components_ai.entity_deleted_success": "{{entityName}} eliminado con éxito",
52
- "design.components_ai.entity_delete_error": "Error al eliminar {{entityName}}"
54
+ "design.components_ai.entity_delete_error": "Error al eliminar {{entityName}}",
55
+ "design.components_ai.required_field": "Campo obligatorio",
56
+ "design.components_ai.min_length_error": "Mínimo de {{length}} caracteres",
57
+ "design.components_ai.max_length_error": "Máximo de {{length}} caracteres",
58
+ "design.components_ai.min_value_error": "El valor mínimo es {{value}}",
59
+ "design.components_ai.max_value_error": "El valor máximo es {{value}}"
53
60
  }
@@ -1,4 +1,7 @@
1
1
  {
2
+ "design.components_ai.error": "Ops, algo deu errado",
3
+ "design.components_ai.server_error": "Erro no Servidor",
4
+ "design.components_ai.server_error_message": "Ocorreu um erro no servidor. Tente novamente mais tarde.",
2
5
  "design.components_ai.bulk_delete_title": "Exclusão em Massa",
3
6
  "design.components_ai.bulk_delete_warning": "Você está prestes a excluir <strong>{{count}}</strong> registro(s).",
4
7
  "design.components_ai.bulk_delete_description": "Esta ação não pode ser desfeita. Os registros serão excluídos um por vez.",
@@ -41,7 +44,6 @@
41
44
  "design.components_ai.close": "Fechar",
42
45
  "design.components_ai.filter_search_placeholder": "Pesquisar por {{label}}",
43
46
  "design.components_ai.filter_select_placeholder": "Selecione {{label}}",
44
- "design.components_ai.error": "Erro",
45
47
  "design.components_ai.success": "Sucesso",
46
48
  "design.components_ai.load_error": "Erro ao carregar {{entityType}}",
47
49
  "design.components_ai.confirm_delete": "Confirmar Exclusão",
@@ -49,5 +51,10 @@
49
51
  "design.components_ai.yes": "Sim",
50
52
  "design.components_ai.no": "Não",
51
53
  "design.components_ai.entity_deleted_success": "{{entityName}} excluído com sucesso",
52
- "design.components_ai.entity_delete_error": "Erro ao excluir {{entityName}}"
54
+ "design.components_ai.entity_delete_error": "Erro ao excluir {{entityName}}",
55
+ "design.components_ai.required_field": "Campo obrigatório",
56
+ "design.components_ai.min_length_error": "Mínimo de {{length}} caracteres",
57
+ "design.components_ai.max_length_error": "Máximo de {{length}} caracteres",
58
+ "design.components_ai.min_value_error": "Valor mínimo é {{value}}",
59
+ "design.components_ai.max_value_error": "Valor máximo é {{value}}"
53
60
  }