fx-form-builder-wrapper 1.0.6 → 1.0.8
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.
- package/esm2022/lib/components/dynamic-table/dynamic-table.component.mjs +2 -2
- package/esm2022/lib/components/uploader-checkbox/uploader-checkbox.component.mjs +30 -9
- package/fesm2022/fx-form-builder-wrapper.mjs +30 -9
- package/fesm2022/fx-form-builder-wrapper.mjs.map +1 -1
- package/lib/components/uploader-checkbox/uploader-checkbox.component.d.ts +3 -0
- package/package.json +1 -1
|
@@ -490,7 +490,7 @@ export class DynamicTableComponent extends FxBaseComponent {
|
|
|
490
490
|
const payload = {};
|
|
491
491
|
action.payloadOptions.forEach((option) => {
|
|
492
492
|
const key = option.payloadOptionName;
|
|
493
|
-
const value = option.payloadOptionValue
|
|
493
|
+
const value = option.payloadOptionValue || this.tableConfig?.apiDataToDrawTable[rowIndex][key];
|
|
494
494
|
if (key) {
|
|
495
495
|
payload[key] = value;
|
|
496
496
|
}
|
|
@@ -554,4 +554,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
554
554
|
}], tableConfig: [{
|
|
555
555
|
type: Input
|
|
556
556
|
}] } });
|
|
557
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dynamic-table.component.js","sourceRoot":"","sources":["../../../../../../projects/fx-builder-wrapper/src/lib/components/dynamic-table/dynamic-table.component.ts","../../../../../../projects/fx-builder-wrapper/src/lib/components/dynamic-table/dynamic-table.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, ChangeDetectorRef, Component, inject, Input, NgZone, OnDestroy, OnInit } from '@angular/core';\r\nimport { CommonModule } from '@angular/common';\r\nimport { FormControl, FormsModule, ReactiveFormsModule } from '@angular/forms';\r\nimport { HttpClient } from '@angular/common/http';\r\nimport { Action, FxBaseComponent, FxMode, FxSetting, FxStringSetting, FxValidation, FxValidatorService } from '@instantsys-labs/fx';\r\nimport { SettingsPanelComponent } from '../../panel/settings-panel/settings-panel.component';\r\nimport { FxBuilderWrapperService } from '../../fx-builder-wrapper.service';\r\nimport {forkJoin, map, Observable, Subject, takeUntil } from 'rxjs';\r\nimport { MultiSelectModule } from 'primeng/multiselect';\r\nimport { InputTextModule } from 'primeng/inputtext';\r\nimport { InputNumberModule } from 'primeng/inputnumber';\r\nimport { DropdownModule } from 'primeng/dropdown';\r\nimport { ConfirmationService, MessageService } from 'primeng/api';\r\nimport { ToastModule } from 'primeng/toast';\r\nimport { ConfirmDialogModule } from 'primeng/confirmdialog';\r\nimport { DialogModule } from 'primeng/dialog';\r\n\r\nexport interface TableColumnConfig {\r\n  header: string;\r\n  cellType: 'text' | 'input-text' | 'input-number' | 'dropdown' | 'smart-dropdown' | 'checkbox' | 'radio' | 'radio-group' | 'file-upload' | 'textarea' | 'action';\r\n  placeholder?: string;\r\n  options?: string[];\r\n  apiUrl?: string;\r\n  valueKey?: string;\r\n  labelKey?: string;\r\n  className?: string;\r\n  isMultiselect?: boolean;\r\n  checkedValue?: any;\r\n  unCheckedValue?: any;\r\n  checkBoxLabel?: string;\r\n  isRequired?:boolean,\r\n  errorMessage?:string,\r\n  // actionName?: string,\r\n  // actionIconPath?: string,\r\n  // apiType?:string,\r\n  // apiUrlToCall?: string,\r\n  // payloadOptions?: string[]\r\n  action: string[]\r\n}\r\nexport interface TableConfig {\r\n  columns: TableColumnConfig[];\r\n  rows: any[];\r\n  // apiDataToDrawTable: any[]\r\n}\r\n@Component({\r\n  selector: 'fx-dynamic-table',\r\n  standalone: true,\r\n  imports: [CommonModule, FormsModule, SettingsPanelComponent, ReactiveFormsModule,MultiSelectModule,InputNumberModule,InputTextModule,DropdownModule,ToastModule,ConfirmDialogModule,DialogModule],\r\n  providers: [MessageService,ConfirmationService],\r\n  templateUrl: './dynamic-table.component.html',\r\n  styleUrl: './dynamic-table.component.scss',\r\n})\r\n\r\nexport class DynamicTableComponent extends FxBaseComponent implements OnInit, AfterViewInit, OnDestroy {\r\n  @Input() tableRows: Array<any> = [];\r\n  @Input() previewType: FxMode = FxMode.VIEW;\r\n  @Input() tableConfig: any = {\r\n    columns: [\r\n      { header: 'Column 1', cellType: 'text' },\r\n      { header: 'Column 2', cellType: 'text' },\r\n      { header: 'Column 3', cellType: 'text' },\r\n      { header: 'Column 4', cellType: 'text' },\r\n      { header: 'Column 5', cellType: 'text' },\r\n    ],\r\n};\r\n\r\n  private destroy$ = new Subject<Boolean>();\r\n  // public uploadedImages: Array<Record<string, string | File | null> | null> = [];\r\n  public uploadedImages: Array<Array<{ result: string, file: File | null}>> = [];\r\n\r\npublic generalValues: any;\r\nselectedAction: any;\r\nselectedRow: any;\r\nselectedRowIndex: any;\r\ndisplayConfirmationDialog: boolean = false;\r\napiDataToDrawTable: any[] =[];\r\n\r\n  public tableFormControl = new FormControl();\r\n  public smartDropdownOptions: { [key: string]: Array<{ name: string, value: string }> } = {};\r\n  private http = inject(HttpClient);\r\n  constructor(private cdr: ChangeDetectorRef, private fxBuilderWrapperService: FxBuilderWrapperService,   private messageService: MessageService, private confirmationService: ConfirmationService) {\r\n    super(cdr);\r\n    this.onInit.subscribe((fxData)=>{\r\n      this._register(this.tableFormControl);\r\n    })\r\n  }\r\n\r\n  public ngOnInit(): void {\r\n    this.fxBuilderWrapperService.variables$.pipe(\r\n      takeUntil(this.destroy$)).subscribe((variables: any) => {\r\n        if (variables) {\r\n          let dynamicTableValues: any;\r\n          for (const [key, value] of Object.entries(variables)) {\r\n            if (key.includes('dynamic-table')) {\r\n              dynamicTableValues = value;\r\n            }\r\n          }\r\n          if (Object.keys(dynamicTableValues).length) {\r\n            // const fileHeaderName = dynamicTableValues?.columns.find((f: any) => f.cellType === 'file-upload')?.header;\r\n            const fileHeaderName = dynamicTableValues?.columns.find((f: any) => f.cellType === 'file-upload')?.header;\r\n            dynamicTableValues?.rows?.forEach((item: any, index: number) => {\r\n              // // this.uploadedImages[index] = item[fileHeaderName] ? item[fileHeaderName]: null;\r\n              // const fileUrl = item[fileHeaderName]; // Get the file URL\r\n\r\n              // this.uploadedImages[index] = fileUrl\r\n              //   ? { result: fileUrl, file: null } // Store the URL as 'result'\r\n              //   : null;\r\n              \r\n              if (item[fileHeaderName]) {\r\n                this.parseUrls(item[fileHeaderName], index,dynamicTableValues?.columns);\r\n              }\r\n            })\r\n           this.tableConfig =  this.initializeCheckboxDefaults(dynamicTableValues);\r\n            // this.tableConfig = dynamicTableValues;\r\n            this.fxData.value = this.tableConfig;\r\n            // this.tableFormControl.reset();\r\n            // this.tableFormControl.setValue(this.tableConfig);\r\n            this.tableFormControl = new FormControl();\r\n            setTimeout(() => {  // Delay to ensure proper patching\r\n              this.tableFormControl.patchValue(this.tableConfig, { emitEvent: true });\r\n              console.log(\"tableFormControl\",this.tableFormControl);\r\n              this.cdr.detectChanges();\r\n            }, 50);\r\n          }\r\n        }\r\n      })\r\n  }\r\n\r\n  public ngAfterViewInit(): void {\r\n    setTimeout(() => {\r\n      if(this.fxData?.value && Object.keys(this.fxData?.value)?.length != 0) {\r\n        this.tableConfig = this.fxData.value;\r\n        this.fetchSmartDropdownData();\r\n      }\r\n    }, 100)\r\n  }\r\n  \r\n  protected fetchSmartDropdownData(): void {\r\n    this.tableConfig.columns\r\n      .filter((column: TableColumnConfig) => column.cellType === 'smart-dropdown' && column?.apiUrl)\r\n      .forEach((column: TableColumnConfig) => {\r\n        this.http.get<any>(column.apiUrl!).subscribe((response: any) => {\r\n          this.smartDropdownOptions[column.header] = response.map((item: any) => ({\r\n            value: item[column.valueKey!],\r\n            name: item[column.labelKey!],\r\n          }));\r\n        });\r\n      });\r\n  }\r\n\r\n  // public uploadImage(event: Event, rowIndex: number): void {\r\n  //   const file = (event.target as HTMLInputElement).files?.[0];\r\n  //   if (file) {\r\n  //     const reader = new FileReader();\r\n  //     reader.onload = () => {\r\n  //       this.uploadedImages[rowIndex] = {\r\n  //         result: reader.result as string,\r\n  //         file: file\r\n  //       }\r\n  //       this.tableConfig.rows[rowIndex][this.tableConfig.columns.find((f: any) => f.cellType === 'file-upload')?.header] = file;\r\n  //       console.log(\"tableConfig\", this.tableConfig);\r\n  //     };\r\n  //     reader.readAsDataURL(file);\r\n  //   }\r\n  // }\r\n\r\n  public uploadImage(event: Event, rowIndex: number): void {\r\n    const files = (event.target as HTMLInputElement).files;\r\n    if (files && files.length > 0) {\r\n      this.uploadedImages[rowIndex] = this.uploadedImages[rowIndex] || [];\r\n  \r\n      Array.from(files).forEach((file: File) => {\r\n        const reader = new FileReader();\r\n        reader.onload = () => {\r\n          this.uploadedImages[rowIndex].push({\r\n            result: reader.result as string,\r\n            file: file\r\n          });\r\n  \r\n          // Optionally add to tableConfig if only one file is tracked there\r\n          const columnHeader = this.tableConfig.columns.find((f: any) => f.cellType === 'file-upload')?.header;\r\n          this.tableConfig.rows[rowIndex][columnHeader] = this.uploadedImages[rowIndex].map(img => img.file);\r\n  \r\n          console.log(\"tableConfig\", this.tableConfig);\r\n        };\r\n        reader.readAsDataURL(file);\r\n      });\r\n    }\r\n  }\r\n  \r\n\r\n  protected settings(): FxSetting[] {\r\n    return [\r\n      new FxStringSetting({ key: 'column-size', $title: 'No. of columns', value: 1 }),\r\n      new FxStringSetting({ key: 'table-config', $title: 'Table Configuration', value: {} }),\r\n    ];\r\n  }\r\n\r\n  protected validations(): FxValidation[] {\r\n    return [FxValidatorService.required];\r\n  }\r\n\r\n  public getArray(count: number): number[] {\r\n    return Array.from({ length: count });\r\n  }\r\n\r\n  public onChangeConfiguration(event: any): void { \r\n     this.generalValues = {\r\n      enableAPI: event?.enableAPI,\r\n      api: event?.api\r\n    }\r\n    const columns = event.columns.map((col: any) => {\r\n      return {\r\n        header: col?.header,\r\n        cellType: col?.cellType,\r\n        placeholder: col?.placeholder,\r\n        options: col?.options,\r\n        apiUrl: col?.apiUrl,\r\n        valueKey: col?.valueKey,\r\n        labelKey: col?.labelKey,\r\n        className: col?.className,\r\n        apiKey: col?.apiKey,\r\n        isMultiselect: col?.isMultiselect,\r\n        checkedValue: col?.checkedValue,\r\n        unCheckedValue: col?.unCheckedValue,\r\n        checkBoxLabel:col?.checkBoxLabel,\r\n        isRequired:col?.isRequired,\r\n        errorMessage:col?.errorMessage,\r\n        // actionName: col?.actionName,\r\n        // actionIconPath: col?.actionIconPath,\r\n        // apiType:col?.apiType,\r\n        // apiUrlToCall: col?.apiUrlToCall,\r\n        // payloadOptions: col?.payloadOptions\r\n        action: col?.action \r\n      }\r\n    });\r\n    if(!event?.enableAPI) {\r\n      this.tableConfig.columns = columns;\r\n      // this.tableConfig.rows = Array.from({ length: +event?.rows }, (e, index) => ({ name: `SKU-${index + 1}`, age: index % 2 !== 0, gender: 'male' }))\r\n      // this.tableConfig.rows = Array.from({ length: +event?.rows }, (e, index) => {\r\n      //   const rows = columns.map((c: any) => {\r\n      //     return {\r\n      //       c?.header: null\r\n      //     }\r\n      //   })\r\n      //   return rows\r\n      // })\r\n      this.tableConfig.rows = Array.from({ length: +event?.rows }, (_, index) => {\r\n        return columns.reduce((acc: any, c: any) => {\r\n          acc[c?.header] = ''; // Initialize each column key with null\r\n          return acc;\r\n        }, {});\r\n      });\r\n      \r\n      this.fetchSmartDropdownData();\r\n    }\r\n    if(event?.enableAPI) {\r\n      this.drawTable(event, columns)\r\n      this.tableConfig = {\r\n        columns: columns,\r\n        rows: []\r\n      };\r\n    }\r\n   this.tableConfig =  this.initializeCheckboxDefaults(this.tableConfig);\r\n   this.tableConfig.apiDataToDrawTable = this.apiDataToDrawTable;\r\n    this.tableConfig.generalValues = this.generalValues;\r\n    this.fxData.value = this.tableConfig;\r\n    this.tableFormControl.reset();\r\n    this.tableFormControl.setValue(this.tableConfig);\r\n  }\r\n\r\n  private updateSettings(): void{\r\n    if(this.fxData.settings){\r\n      for(let setting of this.fxData.settings){\r\n      if(setting.key === 'table-config'){\r\n        setting.value = this.tableConfig;\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n  // public drawTable(event: any, columns: any): void {\r\n  //   let rows;\r\n  //   this.http.get(event.api).subscribe((res: any) => {\r\n  //     if(res) {\r\n  //       rows = res.map((item: any) => {\r\n  //         const newObj: Record<string, any> = {};\r\n  //         columns.forEach((col: any) => {\r\n  //           newObj[col.header] = item[col.apiKey];\r\n  //         });\r\n  //         return newObj;\r\n  //       });\r\n  //       this.tableConfig = {\r\n  //         columns,\r\n  //         rows\r\n  //       }\r\n  //       this.tableConfig.generalValues = this.generalValues;\r\n  //       this.fxData.value = this.tableConfig;\r\n  //       this.tableFormControl.reset();\r\n  //       this.tableFormControl.setValue(this.tableConfig);\r\n  //     }\r\n  //   })\r\n  // }\r\n\r\n    public drawTable(event: any, columns: any): void {\r\n    let rows;\r\n    this.http.get(event.api).subscribe((res: any) => {\r\n      if(res) {\r\n        this.apiDataToDrawTable = res;\r\n       \r\n        rows = res.map((item: any) => {\r\n          const newObj: Record<string, any> = {};\r\n          columns.forEach((col: any) => {\r\n            newObj[col.header] = item[col.apiKey] || '';\r\n          });\r\n          return newObj;\r\n        });\r\n        this.tableConfig = {\r\n          columns,\r\n          rows\r\n        }\r\n        this.tableConfig.generalValues = this.generalValues;\r\n        this.tableConfig.apiDataToDrawTable = this.apiDataToDrawTable;\r\n        this.fxData.value = this.tableConfig;\r\n        this.tableFormControl.reset();\r\n        this.tableFormControl.setValue(this.tableConfig);\r\n      }\r\n    })\r\n  }\r\n\r\n  // public deleteFile(file: any, index: number): void {\r\n  //   this.uploadedImages.splice(index, 1, null);\r\n  //   this.tableConfig.rows[index][this.tableConfig.columns.find((f: any) => f.cellType === 'file-upload')?.header] = null;\r\n  //   console.log(\"tableConfig\", this.tableConfig);\r\n  //   this.tableFormControl.setValue(this.tableConfig);\r\n  // }\r\n\r\n  // public deleteFile(rowIndex: number, imageIndex: number): void {\r\n  //   if (this.uploadedImages[rowIndex]) {\r\n  //     this.uploadedImages[rowIndex].splice(imageIndex, 1);\r\n  \r\n  //     const columnHeader = this.tableConfig.columns.find((f: any) => f.cellType === 'file-upload')?.header;\r\n  //     this.tableConfig.rows[rowIndex][columnHeader] = this.uploadedImages[rowIndex].map(img => img.file);\r\n  //     this.tableFormControl.setValue(this.tableConfig);\r\n  //   }\r\n  // }\r\n\r\n  public deleteFile(rowIndex: number, imageIndex: number): void {\r\n    if (this.uploadedImages[rowIndex]) {\r\n      const removedFile = this.uploadedImages[rowIndex][imageIndex];\r\n  \r\n      // Track the file to delete if it's an uploaded file (i.e., has URL and no File object)\r\n      if (removedFile?.result && typeof removedFile.result === 'string' && removedFile.file === null) {\r\n        this.tableConfig.rows[rowIndex].filesToDelete = this.tableConfig.rows[rowIndex].filesToDelete || [];\r\n        this.tableConfig.rows[rowIndex].filesToDelete.push(removedFile.result);\r\n      }\r\n  \r\n      // Remove the file from the UI\r\n      this.uploadedImages[rowIndex].splice(imageIndex, 1);\r\n  \r\n      const columnHeader = this.tableConfig.columns.find((f: any) => f.cellType === 'file-upload')?.header;\r\n      this.tableConfig.rows[rowIndex][columnHeader] = this.uploadedImages[rowIndex].map(img => img.file);\r\n  \r\n      this.tableFormControl.setValue(this.tableConfig);\r\n    }\r\n  }\r\n  \r\n  \r\n\r\n  // public parseUrls(url: string, index: number): void {\r\n  //   this.http.get(url, { responseType: 'blob' }).subscribe({\r\n  //     next: (imageBlob: Blob) => {\r\n  //       const imageURL = URL.createObjectURL(imageBlob);\r\n  //       this.uploadedImages[index] = {\r\n  //         result: imageURL,\r\n  //         file: null\r\n  //       };\r\n  //     },\r\n  //     error: (error) => {\r\n  //       console.error('Error fetching image:', error);\r\n  //     }\r\n  //   });\r\n  // }\r\n\r\n  // public parseUrls(url: string, rowIndex: number): void {\r\n  //   this.http.get(url, { responseType: 'blob' }).subscribe({\r\n  //     next: (imageBlob: Blob) => {\r\n  //       const imageURL = URL.createObjectURL(imageBlob);\r\n  \r\n  //       this.uploadedImages[rowIndex] = this.uploadedImages[rowIndex] || [];\r\n  //       this.uploadedImages[rowIndex].push({\r\n  //         result: imageURL,\r\n  //         file: null\r\n  //       });\r\n  \r\n  //       const columnHeader = this.tableConfig.columns.find((f: any) => f.cellType === 'file-upload')?.header;\r\n  //       this.tableConfig.rows[rowIndex][columnHeader] = this.uploadedImages[rowIndex].map(img => img.file);\r\n  \r\n  //       this.tableFormControl.setValue(this.tableConfig);\r\n  //     },\r\n  //     error: (error) => {\r\n  //       console.error('Error fetching image:', error);\r\n  //     }\r\n  //   });\r\n  // }\r\n\r\n  public parseUrls(urls: string[], rowIndex: number, columns: any): void {\r\n    if (!Array.isArray(urls) || !urls.length) return;\r\n  \r\n    this.uploadedImages[rowIndex] = this.uploadedImages[rowIndex] || [];\r\n  \r\n    const columnHeader = columns.find((f: any) => f.cellType === 'file-upload')?.header;\r\n    if (!columnHeader) return;\r\n  \r\n    const imageFetches: Observable<string>[] = [];\r\n  \r\n    urls.forEach((url: string) => {\r\n      if (url) {\r\n        const image$ = this.http.get(url, { responseType: 'blob' }).pipe(\r\n          map((imageBlob: Blob) => URL.createObjectURL(imageBlob))\r\n        );\r\n        imageFetches.push(image$);\r\n      }\r\n    });\r\n  \r\n    if (!imageFetches.length) return;\r\n  \r\n    forkJoin(imageFetches).subscribe({\r\n      next: (imageURLs: string[]) => {\r\n        imageURLs.forEach((imageURL: string) => {\r\n          this.uploadedImages[rowIndex].push({\r\n            result: imageURL,\r\n            file: null\r\n          });\r\n        });\r\n  \r\n        // this.tableConfig.rows[rowIndex][columnHeader] = this.uploadedImages[rowIndex].map(img => img.result);\r\n  \r\n        // this.tableFormControl.setValue(this.tableConfig);\r\n      },\r\n      error: (error) => {\r\n        console.error('Error fetching one or more images:', error);\r\n      }\r\n    });\r\n  }\r\n  \r\n  onCheckboxChange(event: Event, row: any, column: any): void {\r\n    const input = event.target as HTMLInputElement;\r\n    row[column.header] = input.checked ? column.checkedValue : column.unCheckedValue;\r\n  }\r\n  \r\n\r\n  initializeCheckboxDefaults(tableData: any): void {\r\n    tableData.rows.forEach((row: any) => {\r\n      tableData.columns.forEach((column: any) => {\r\n        if (column.cellType === 'checkbox' && column.unCheckedValue && !row[column.header]) {\r\n          row[column.header] = column.unCheckedValue;\r\n        }\r\n      });\r\n    });\r\n    return tableData;\r\n  }\r\n\r\n  handleAction(row: any, action: any,rowIndex:any): void {\r\n    if (action.isConfirmationRequired) {\r\n      this.selectedAction = action;\r\n      this.selectedRow = row;\r\n      this.selectedRowIndex = rowIndex\r\n      this.displayConfirmationDialog = true;\r\n    } else {\r\n      this.executeAction(row, action,rowIndex);\r\n    }\r\n  }\r\n  \r\n  confirmAction(): void {\r\n    this.executeAction(this.selectedRow, this.selectedAction,this.selectedRowIndex);\r\n    this.displayConfirmationDialog = false;\r\n  }\r\n  \r\n  cancelAction(): void {\r\n    this.messageService.add({\r\n      severity: 'info',\r\n      summary: 'Cancelled',\r\n      detail: 'Action was cancelled',\r\n      life: 2000\r\n    });\r\n    this.displayConfirmationDialog = false;\r\n  }\r\n  \r\n  // handleAction(row: any, action: any): void {\r\n  //   if (!action || !action.apiType || !action.payloadOptions) {\r\n  //     console.warn('Invalid action config:', action);\r\n  //     return;\r\n  //   }\r\n  \r\n  //   const payload: { [key: string]: any } = {};\r\n  \r\n  //   action.payloadOptions.forEach((option: any) => {\r\n  //     const key = option.payloadOptionName;\r\n  //     const value = option.payloadOptionValue ?? row[option.payloadOptionName];\r\n  //     if (key) {\r\n  //       payload[key] = value;\r\n  //     }\r\n  //   });\r\n  \r\n  //   const handleSuccess = (res: any) => {\r\n  //     const actionKey = action.actionName || 'defaultAction';\r\n\r\n  //     if (!row.response || typeof row.response !== 'object' || Array.isArray(row.response)) {\r\n  //       row.response = {};\r\n  //     }\r\n    \r\n  //     row.response[actionKey] = res;\r\n    \r\n  //     this.messageService.add({\r\n  //       severity: 'success',\r\n  //       summary: 'Success',\r\n  //       detail: `Action \"${actionKey}\" completed successfully`,\r\n  //       life: 3000\r\n  //     });\r\n  //   };\r\n    \r\n\r\n  //   const handleError = (err: any) => {\r\n  //     row.response = { error: err };\r\n  //     this.messageService.add({\r\n  //       severity: 'error',\r\n  //       summary: 'Error',\r\n  //       detail: 'Something went wrong',\r\n  //       life: 3000\r\n  //     });\r\n  //   };\r\n  \r\n  //   switch (action.apiType) {\r\n  //     case 'POST':\r\n  //       this.http.post(action.apiUrlToCall, payload).subscribe({ next: handleSuccess, error: handleError });\r\n  //       break;\r\n  \r\n  //     case 'PUT':\r\n  //       this.http.put(action.apiUrlToCall, payload).subscribe({ next: handleSuccess, error: handleError });\r\n  //       break;\r\n  \r\n  //     case 'DELETE':\r\n  //       this.http.delete(action.apiUrlToCall, { body: payload }).subscribe({ next: handleSuccess, error: handleError });\r\n  //       break;\r\n  \r\n  //     case 'GET':\r\n  //       this.http.get(action.apiUrlToCall, { params: payload }).subscribe({ next: handleSuccess, error: handleError });\r\n  //       break;\r\n  \r\n  //     default:\r\n  //       console.warn('Unknown API type:', action.apiType);\r\n  //   }\r\n  // }\r\n  \r\n  // handleAction(row: any, action: any): void {\r\n  //   if (action.isConfirmationRequired) {\r\n  //     this.confirmationService.confirm({\r\n  //       message: `Are you sure you want to perform \"${action.actionName}\"?`,\r\n  //       header: 'Confirmation',\r\n  //       icon: 'pi pi-exclamation-triangle',\r\n  //       accept: () => this.executeAction(row, action),\r\n  //       reject: () => {\r\n  //         this.messageService.add({\r\n  //           severity: 'info',\r\n  //           summary: 'Cancelled',\r\n  //           detail: 'Action was cancelled',\r\n  //           life: 2000\r\n  //         });\r\n  //       }\r\n  //     });\r\n  //   } else {\r\n  //     this.executeAction(row, action);\r\n  //   }\r\n  // }\r\n  \r\n\r\n  executeAction(row: any, action: any,rowIndex:any): void {\r\n    const payload: { [key: string]: any } = {};\r\n  \r\n    action.payloadOptions.forEach((option: any) => {\r\n      const key = option.payloadOptionName;\r\n      const value = option.payloadOptionValue ?? this.tableConfig?.apiDataToDrawTable[rowIndex][key];\r\n      if (key) {\r\n        payload[key] = value;\r\n      }\r\n    });\r\n  \r\n    const actionKey = action.actionName || 'defaultAction';\r\n  \r\n    const handleSuccess = (res: any) => {\r\n      if (!row.response || typeof row.response !== 'object' || Array.isArray(row.response)) {\r\n        row.response = {};\r\n      }\r\n  \r\n      row.response[actionKey] = res;\r\n  \r\n      this.messageService.add({\r\n        severity: 'success',\r\n        summary: 'Success',\r\n        detail: `Action \"${actionKey}\" completed successfully`,\r\n        life: 3000\r\n      });\r\n    };\r\n  \r\n    const handleError = (err: any) => {\r\n      if (!row.response || typeof row.response !== 'object' || Array.isArray(row.response)) {\r\n        row.response = {};\r\n      }\r\n  \r\n      row.response[actionKey] = { error: err };\r\n  \r\n      this.messageService.add({\r\n        severity: 'error',\r\n        summary: 'Error',\r\n        detail: `Action \"${actionKey}\" failed`,\r\n        life: 3000\r\n      });\r\n    };\r\n  \r\n    switch (action.apiType) {\r\n      case 'POST':\r\n        this.http.post(action.apiUrlToCall, payload).subscribe({ next: handleSuccess, error: handleError });\r\n        break;\r\n      case 'PUT':\r\n        this.http.put(action.apiUrlToCall, payload).subscribe({ next: handleSuccess, error: handleError });\r\n        break;\r\n      case 'DELETE':\r\n        this.http.delete(action.apiUrlToCall, { body: payload }).subscribe({ next: handleSuccess, error: handleError });\r\n        break;\r\n      case 'GET':\r\n        this.http.get(action.apiUrlToCall, { params: payload }).subscribe({ next: handleSuccess, error: handleError });\r\n        break;\r\n      default:\r\n        console.warn('Unknown API type:', action.apiType);\r\n    }\r\n  }\r\n  \r\n  \r\n  \r\n\r\n  public ngOnDestroy(): void {\r\n    this.destroy$.next(true);\r\n    this.destroy$.complete();\r\n  }\r\n}\r\n","<fx-settings-panel [fxData]=\"fxData\" [tableData]=\"fxData\" (configuration)=\"onChangeConfiguration($event)\">\r\n  <div *ngIf=\"fxData\">\r\n    <table style=\"width: 100%;\" class=\"formBuilder_dynamic_table\">\r\n      <thead>\r\n        <tr>\r\n          <th *ngFor=\"let column of tableConfig.columns\">{{ column.header }}</th>\r\n        </tr>\r\n      </thead>\r\n      <tbody>\r\n        <tr *ngFor=\"let row of tableConfig.rows; let rowIndex = index\">\r\n          <td *ngFor=\"let column of tableConfig.columns\">\r\n            <ng-container [ngSwitch]=\"column.cellType\">\r\n              <span [class]=\"column?.className\" *ngSwitchCase=\"'text'\">{{row[column.header]}}</span>\r\n\r\n              <!-- <input [class]=\"column?.className\" *ngSwitchCase=\"'input-text'\" type=\"text\" [placeholder]=\"column?.placeholder\"\r\n                                [(ngModel)]=\"row[column.header]\" /> -->\r\n\r\n              <ng-container *ngSwitchCase=\"'input-text'\">\r\n                <input [class]=\"column?.className\" type=\"text\" [placeholder]=\"column?.placeholder\"\r\n                  [(ngModel)]=\"row[column.header]\" [required]=\"column?.isRequired\" #model=\"ngModel\" />\r\n\r\n                <div *ngIf=\"column?.isRequired && model.invalid && model.touched\" class=\"text-red-500 text-sm mt-1\">\r\n                  {{ column?.errorMessage }}\r\n                </div>\r\n              </ng-container>\r\n\r\n\r\n\r\n              <input [class]=\"column?.className\" *ngSwitchCase=\"'input-number'\" type=\"number\"\r\n                [placeholder]=\"column?.placeholder\" [(ngModel)]=\"row[column.header]\" />\r\n\r\n              <select [class]=\"column?.className\" *ngSwitchCase=\"'dropdown'\" [(ngModel)]=\"row[column.header]\">\r\n\r\n                <option *ngIf=\"column.placeholder\" value=\"\">{{ column.placeholder }}</option>\r\n                <option *ngFor=\"let option of column?.options\" [value]=\"option?.optionValue\">\r\n                  {{ option?.optionName }}\r\n                </option>\r\n              </select>\r\n\r\n              <!-- <select [class]=\"column?.className\" style=\"width: 60%;\" *ngSwitchCase=\"'smart-dropdown'\"\r\n                                [(ngModel)]=\"row[column.header]\">\r\n                                <option value=\"\">Select {{column.header}}</option>\r\n                                <option *ngIf=\"column.placeholder\" value=\"\">{{ column.placeholder }}</option>\r\n                                <option *ngFor=\"let option of smartDropdownOptions[column.header]\" [value]=\"option?.value\">\r\n                                    {{option?.name }}\r\n                                </option>\r\n                            </select> -->\r\n\r\n              <!-- <p-multiSelect [options]=\"smartDropdownOptions[column.header]\" [(ngModel)]=\"row[column.header]\" optionLabel=\"name\" optionValue=\"value\" placeholder=\"Select Cities\" *ngSwitchCase=\"'smart-dropdown'\"/> -->\r\n\r\n              <!-- smart-dropdown handling -->\r\n              <ng-container *ngSwitchCase=\"'smart-dropdown'\">\r\n\r\n                <!-- Regular dropdown if isMultiselect is false or not set -->\r\n                <select *ngIf=\"!column?.isMultiselect\" [class]=\"column?.className\" style=\"width: 60%;\"\r\n                  [(ngModel)]=\"row[column.header]\">\r\n                  <option *ngIf=\"column.placeholder\" value=\"\">{{ column.placeholder }}</option>\r\n                  <option *ngFor=\"let option of smartDropdownOptions[column.header]\" [value]=\"option?.value\">\r\n                    {{ option?.name }}\r\n                  </option>\r\n                  <option value=\"__other__\">Other</option>\r\n\r\n                </select>\r\n                <input *ngIf=\"row[column.header] === '__other__'\" type=\"text\" class=\"mt-2 p-inputtext-sm\"\r\n                  [placeholder]=\"'Enter other ' + column.header\" [(ngModel)]=\"row[column.header + '_other']\" />\r\n\r\n                <!-- PrimeNG multiselect if isMultiselect is true -->\r\n                <p-multiSelect *ngIf=\"column?.isMultiselect\" [options]=\"smartDropdownOptions[column.header]\"\r\n                  [(ngModel)]=\"row[column.header]\" [class]=\"column?.className\" optionLabel=\"name\" optionValue=\"value\"\r\n                  [placeholder]=\"column.placeholder || ('Select ' + column.header)\">\r\n                  <ng-template pTemplate=\"dropdownicon\">\r\n                    <div class=\"flex align-items-center dd_down_icon\">\r\n                      <span class=\"pi pi-angle-down text-xl\"></span>\r\n                    </div>\r\n                  </ng-template>\r\n                </p-multiSelect>\r\n\r\n              </ng-container>\r\n\r\n\r\n              <!-- <input [class]=\"column?.className\" *ngSwitchCase=\"'checkbox'\" type=\"checkbox\"\r\n                                [(ngModel)]=\"row[column.header]\" /> -->\r\n              <ng-container *ngSwitchCase=\"'checkbox'\">\r\n                <label [class]=\"column?.className\" class=\"inline-flex items-center gap-2\">\r\n                  <input type=\"checkbox\" [checked]=\"row[column.header] === column.checkedValue\"\r\n                    (change)=\"onCheckboxChange($event, row, column)\" />\r\n                  {{ column?.checkBoxLabel || '' }}\r\n                </label>\r\n              </ng-container>\r\n              <p-toast></p-toast>\r\n              <p-confirmDialog></p-confirmDialog>\r\n              <ng-container *ngSwitchCase=\"'action'\">\r\n                <div class=\"flex flex-row gap-6 justify-start items-start\">\r\n                  <div *ngFor=\"let action of column?.action\" class=\"flex flex-col items-center w-20 cursor-pointer\"\r\n                    (click)=\"handleAction(row, action,rowIndex)\">\r\n                    <img [src]=\"action?.actionIconPath\" alt=\"icon\" class=\"w-6 h-6 mb-1\" />\r\n                    <span class=\"text-xs text-center break-words\">\r\n                      {{ action?.actionName }}\r\n                    </span>\r\n                  </div>\r\n                </div>\r\n              </ng-container>\r\n\r\n\r\n\r\n\r\n\r\n\r\n              <input name=\"radio-{{rowIndex}}\" [class]=\"column?.className\" *ngSwitchCase=\"'radio'\" type=\"radio\"\r\n                [(ngModel)]=\"row[column.header]\" />\r\n\r\n              <div [class]=\"column?.className\" style=\"display: flex; justify-content: center; gap: 10px;\"\r\n                *ngSwitchCase=\"'radio-group'\">\r\n                <label *ngFor=\"let option of column.options\">\r\n                  <input name=\"radio-group-{{rowIndex}}\" type=\"radio\" [value]=\"option?.optionName\"\r\n                    [(ngModel)]=\"row[column.header]\" />\r\n                  {{ option?.optionName }}\r\n                </label>\r\n              </div>\r\n\r\n              <!-- <ng-container *ngSwitchCase=\"'file-upload'\">\r\n                               \r\n\r\n                                  <div class=\"flex flex-col items-end justify-end relative\">\r\n                                    <div class=\"flex gap-2 flex-wrap\">\r\n                                      <div \r\n                                        class=\"relative\" \r\n                                        *ngFor=\"let image of uploadedImages?.[rowIndex]; let i = index\"\r\n                                      >\r\n                                        <img  \r\n                                          width=\"100\" \r\n                                          [src]=\"image?.result\"\r\n                                          alt=\"Uploaded Image\"\r\n                                          class=\"rounded shadow\"\r\n                                        />\r\n                                        <button \r\n                                          (click)=\"deleteFile(rowIndex, i)\" \r\n                                          class=\"absolute top-0 right-0 text-white rounded-md w-5 h-5 flex items-center justify-center shadow-lg hover:bg-red-600\"\r\n                                        >\r\n                                          ❌\r\n                                        </button>\r\n                                      </div>\r\n                                    </div>\r\n                                  \r\n                                    <input \r\n                                      [class]=\"column?.className\" \r\n                                      type=\"file\" \r\n                                      name=\"file\" \r\n                                      #uploadFile  \r\n                                      hidden \r\n                                      multiple\r\n                                      (change)=\"uploadImage($event, rowIndex)\" \r\n                                    />\r\n                                  \r\n                                    <button \r\n                                      (click)=\"uploadFile.click()\" \r\n                                      class=\"mt-2 bg-blue-500 text-white px-3 py-1 rounded hover:bg-blue-600\"\r\n                                    >\r\n                                      Upload\r\n                                    </button>\r\n                                  </div>\r\n                                  \r\n                                  \r\n                            </ng-container> -->\r\n\r\n              <ng-container *ngSwitchCase=\"'file-upload'\">\r\n                <div class=\"flex items-center justify-end relative gap-4 flex-wrap\">\r\n                  <div class=\"flex gap-2 flex-wrap\">\r\n                    <div class=\"relative\" *ngFor=\"let image of uploadedImages?.[rowIndex]; let i = index\">\r\n                      <img width=\"100\" height=\"80\" [src]=\"image?.result\" alt=\"Uploaded Image\"\r\n                        class=\"rounded shadow orientation\" />\r\n                      <a (click)=\"deleteFile(rowIndex, i)\"\r\n                        class=\"absolute top-0 right-0 text-white rounded-md w-5 h-5 flex items-center justify-center cursor-pointer\">\r\n                        <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"18\" height=\"18\" viewBox=\"0 0 18 18\" fill=\"none\">\r\n                          <g clip-path=\"url(#clip0_6837_29683)\">\r\n                            <rect width=\"18\" height=\"18\" rx=\"9\" fill=\"#F3A041\" />\r\n                            <mask id=\"mask0_6837_29683\" style=\"mask-type:alpha\" maskUnits=\"userSpaceOnUse\" x=\"4\" y=\"4\"\r\n                              width=\"24\" height=\"24\">\r\n                              <rect x=\"4\" y=\"4\" width=\"24\" height=\"24\" fill=\"#D9D9D9\" />\r\n                            </mask>\r\n                            <g mask=\"url(#mask0_6837_29683)\">\r\n                              <path\r\n                                d=\"M8.2045 8.99815L5.81802 6.61167L6.61351 5.81617L9 8.20266L11.3865 5.81617L12.182 6.61167L9.7955 8.99815L12.182 11.3846L11.3865 12.1801L9 9.79365L6.61351 12.1801L5.81802 11.3846L8.2045 8.99815Z\"\r\n                                fill=\"white\" />\r\n                            </g>\r\n                          </g>\r\n                          <defs>\r\n                            <clipPath id=\"clip0_6837_29683\">\r\n                              <rect width=\"18\" height=\"18\" rx=\"9\" fill=\"white\" />\r\n                            </clipPath>\r\n                          </defs>\r\n                        </svg>\r\n                      </a>\r\n                    </div>\r\n                  </div>\r\n\r\n                  <input [class]=\"column?.className\" type=\"file\" name=\"file\" #uploadFile hidden multiple\r\n                    (change)=\"uploadImage($event, rowIndex)\" />\r\n                  <div class=\"flex flex-col justify-center items-center cursor-pointer\" (click)=\"uploadFile.click()\">\r\n                    <div>\r\n                      <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"29\" height=\"28\" viewBox=\"0 0 29 28\" fill=\"none\">\r\n                        <path fill-rule=\"evenodd\" clip-rule=\"evenodd\"\r\n                          d=\"M14.001 3.00195C11.5322 3.00195 9.16722 3.86956 7.23641 5.38414L7.23598 4.59695C7.23598 4.52473 7.22175 4.45321 7.19411 4.38648C7.16647 4.31975 7.12596 4.25912 7.07489 4.20804C7.02381 4.15697 6.96318 4.11646 6.89645 4.08882C6.82972 4.06118 6.7582 4.04695 6.68598 4.04695C6.61375 4.04695 6.54223 4.06118 6.4755 4.08882C6.40877 4.11646 6.34814 4.15697 6.29707 4.20804C6.24599 4.25912 6.20548 4.31975 6.17784 4.38648C6.1502 4.45321 6.13598 4.52473 6.13598 4.59695L6.13642 6.68652C6.13643 6.83239 6.19438 6.97228 6.29752 7.07542C6.40067 7.17856 6.54055 7.23651 6.68642 7.23652H8.77598C8.8482 7.23652 8.91972 7.2223 8.98645 7.19466C9.05318 7.16702 9.11381 7.12651 9.16489 7.07543C9.21596 7.02436 9.25647 6.96373 9.28411 6.897C9.31175 6.83027 9.32598 6.75875 9.32598 6.68652C9.32598 6.6143 9.31175 6.54278 9.28411 6.47605C9.25647 6.40932 9.21596 6.34869 9.16489 6.29761C9.11381 6.24654 9.05318 6.20603 8.98645 6.17839C8.91972 6.15075 8.8482 6.13652 8.77598 6.13652H8.0584C9.7702 4.84387 11.8399 4.10195 14.001 4.10195C19.4751 4.10195 23.901 8.52782 23.901 14.002C23.901 19.4761 19.4751 23.902 14.001 23.902C8.52684 23.902 4.10098 19.4761 4.10098 14.002C4.10098 12.6381 4.38263 11.2888 4.92855 10.0389C4.98691 9.90532 4.98982 9.75399 4.93665 9.61822C4.88347 9.48246 4.77855 9.37336 4.64496 9.31492C4.57877 9.28596 4.50753 9.27032 4.4353 9.2689C4.36306 9.26747 4.29126 9.2803 4.22398 9.30663C4.15671 9.33297 4.09528 9.3723 4.04321 9.42238C3.99114 9.47247 3.94944 9.53232 3.92051 9.59852C3.31393 10.9872 3.00098 12.4866 3.00098 14.002C3.00098 20.0706 7.93236 25.002 14.001 25.002C20.0696 25.002 25.001 20.0706 25.001 14.002C25.001 7.93334 20.0696 3.00195 14.001 3.00195Z\"\r\n                          fill=\"#F3A041\" />\r\n                        <path fill-rule=\"evenodd\" clip-rule=\"evenodd\"\r\n                          d=\"M13.9988 6.13965C9.6616 6.13965 6.13379 9.66746 6.13379 14.0046C6.13379 18.3418 9.6616 21.8696 13.9988 21.8696C18.336 21.8696 21.8638 18.3418 21.8638 14.0046C21.8638 9.66746 18.336 6.13965 13.9988 6.13965ZM13.9988 8.22965C14.1447 8.22965 14.2846 8.28759 14.3877 8.39074C14.4908 8.49388 14.5488 8.63378 14.5488 8.77965V13.7769L17.5227 16.7508C17.6258 16.8539 17.6837 16.9938 17.6837 17.1396C17.6837 17.2855 17.6258 17.4254 17.5227 17.5285C17.4195 17.6316 17.2796 17.6896 17.1338 17.6896C16.9879 17.6896 16.8481 17.6316 16.7449 17.5285L13.6099 14.3935C13.5068 14.2904 13.4488 14.1505 13.4488 14.0046V8.77965C13.4488 8.63378 13.5067 8.49388 13.6099 8.39074C13.713 8.28759 13.8529 8.22965 13.9988 8.22965Z\"\r\n                          fill=\"#F3A041\" />\r\n                        <rect width=\"28.56\" height=\"28\" rx=\"1.51479\" fill=\"#F3A041\" />\r\n                        <path\r\n                          d=\"M15.068 22.7391V17.6708H18.4968L14.2108 12.6025L9.9248 17.6708H13.3536V22.7391H9.06759V22.6969C8.92358 22.7053 8.78643 22.7391 8.63899 22.7391C6.93391 22.7391 5.29866 22.0717 4.09298 20.8835C2.8873 19.6954 2.20996 18.084 2.20996 16.4037C2.20996 13.1532 4.70443 10.5042 7.90523 10.141C8.18585 8.6953 8.96892 7.39118 10.1197 6.45292C11.2706 5.51465 12.7172 5.00089 14.2108 5C15.7047 5.00082 17.1515 5.51452 18.3026 6.45277C19.4537 7.39101 20.2371 8.69516 20.5181 10.141C23.7189 10.5042 26.21 13.1532 26.21 16.4037C26.21 18.084 25.5326 19.6954 24.3269 20.8835C23.1213 22.0717 21.486 22.7391 19.7809 22.7391C19.6369 22.7391 19.4981 22.7053 19.3523 22.6969V22.7391H15.068Z\"\r\n                          fill=\"white\" />\r\n                      </svg>\r\n                    </div>\r\n                    <a type=\"button\" (click)=\"uploadFile.click()\" class=\"text-base cursor-pointer\">\r\n                      {{ 'Upload' }}\r\n                    </a>\r\n                  </div>\r\n                </div>\r\n              </ng-container>\r\n              <ng-container *ngSwitchCase=\"'textarea'\">\r\n                <textarea [class]=\"column?.className\" name=\"\" id=\"\" cols=\"30\" rows=\"2\"\r\n                  [placeholder]=\"column?.placeholder\"></textarea>\r\n              </ng-container>\r\n            </ng-container>\r\n          </td>\r\n        </tr>\r\n      </tbody>\r\n    </table>\r\n    <!-- Your main template -->\r\n<p-dialog header=\"Confirmation\"\r\n[(visible)]=\"displayConfirmationDialog\"\r\nmodal=\"true\"\r\n[closable]=\"false\"\r\n[responsive]=\"true\"\r\nstyleClass=\"confirmation-dialog\"\r\n[style]=\"{width: '400px'}\">\r\n\r\n<div class=\"p-d-flex p-ai-center\">\r\n<i class=\"pi pi-exclamation-triangle p-mr-2\" style=\"font-size: 2rem; color: #f39c12\"></i>\r\n<span>Are you sure you want to perform \"<strong>{{ selectedAction?.actionName }}</strong>\"?</span>\r\n</div>\r\n\r\n<ng-template pTemplate=\"footer\">\r\n<button pButton label=\"Yes\" icon=\"pi pi-check\" (click)=\"confirmAction()\" class=\"p-button-text\" autofocus></button>\r\n<button pButton label=\"No\" icon=\"pi pi-times\" (click)=\"cancelAction()\" class=\"p-button-text\"></button>\r\n</ng-template>\r\n</p-dialog>\r\n\r\n  </div>\r\n</fx-settings-panel>"]}
|
|
557
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dynamic-table.component.js","sourceRoot":"","sources":["../../../../../../projects/fx-builder-wrapper/src/lib/components/dynamic-table/dynamic-table.component.ts","../../../../../../projects/fx-builder-wrapper/src/lib/components/dynamic-table/dynamic-table.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAoC,SAAS,EAAE,MAAM,EAAE,KAAK,EAA6B,MAAM,eAAe,CAAC;AACtH,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,WAAW,EAAE,WAAW,EAAE,mBAAmB,EAAE,MAAM,gBAAgB,CAAC;AAC/E,OAAO,EAAE,UAAU,EAAE,MAAM,sBAAsB,CAAC;AAClD,OAAO,EAAU,eAAe,EAAE,MAAM,EAAa,eAAe,EAAgB,kBAAkB,EAAE,MAAM,qBAAqB,CAAC;AACpI,OAAO,EAAE,sBAAsB,EAAE,MAAM,qDAAqD,CAAC;AAE7F,OAAO,EAAC,QAAQ,EAAE,GAAG,EAAc,OAAO,EAAE,SAAS,EAAE,MAAM,MAAM,CAAC;AACpE,OAAO,EAAE,iBAAiB,EAAE,MAAM,qBAAqB,CAAC;AACxD,OAAO,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAC;AACpD,OAAO,EAAE,iBAAiB,EAAE,MAAM,qBAAqB,CAAC;AACxD,OAAO,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAC;AAClD,OAAO,EAAE,mBAAmB,EAAE,cAAc,EAAE,MAAM,aAAa,CAAC;AAClE,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAC5C,OAAO,EAAE,mBAAmB,EAAE,MAAM,uBAAuB,CAAC;AAC5D,OAAO,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAC;;;;;;;;;;;AAsC9C,MAAM,OAAO,qBAAsB,SAAQ,eAAe;IA2BpC;IAAgC;IAA4D;IAAwC;IA1B/I,SAAS,GAAe,EAAE,CAAC;IAC3B,WAAW,GAAW,MAAM,CAAC,IAAI,CAAC;IAClC,WAAW,GAAQ;QAC1B,OAAO,EAAE;YACP,EAAE,MAAM,EAAE,UAAU,EAAE,QAAQ,EAAE,MAAM,EAAE;YACxC,EAAE,MAAM,EAAE,UAAU,EAAE,QAAQ,EAAE,MAAM,EAAE;YACxC,EAAE,MAAM,EAAE,UAAU,EAAE,QAAQ,EAAE,MAAM,EAAE;YACxC,EAAE,MAAM,EAAE,UAAU,EAAE,QAAQ,EAAE,MAAM,EAAE;YACxC,EAAE,MAAM,EAAE,UAAU,EAAE,QAAQ,EAAE,MAAM,EAAE;SACzC;KACJ,CAAC;IAEQ,QAAQ,GAAG,IAAI,OAAO,EAAW,CAAC;IAC1C,kFAAkF;IAC3E,cAAc,GAAuD,EAAE,CAAC;IAE1E,aAAa,CAAM;IAC1B,cAAc,CAAM;IACpB,WAAW,CAAM;IACjB,gBAAgB,CAAM;IACtB,yBAAyB,GAAY,KAAK,CAAC;IAC3C,kBAAkB,GAAS,EAAE,CAAC;IAErB,gBAAgB,GAAG,IAAI,WAAW,EAAE,CAAC;IACrC,oBAAoB,GAA8D,EAAE,CAAC;IACpF,IAAI,GAAG,MAAM,CAAC,UAAU,CAAC,CAAC;IAClC,YAAoB,GAAsB,EAAU,uBAAgD,EAAY,cAA8B,EAAU,mBAAwC;QAC9L,KAAK,CAAC,GAAG,CAAC,CAAC;QADO,QAAG,GAAH,GAAG,CAAmB;QAAU,4BAAuB,GAAvB,uBAAuB,CAAyB;QAAY,mBAAc,GAAd,cAAc,CAAgB;QAAU,wBAAmB,GAAnB,mBAAmB,CAAqB;QAE9L,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,MAAM,EAAC,EAAE;YAC9B,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC;QACxC,CAAC,CAAC,CAAA;IACJ,CAAC;IAEM,QAAQ;QACb,IAAI,CAAC,uBAAuB,CAAC,UAAU,CAAC,IAAI,CAC1C,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,SAAc,EAAE,EAAE;YACrD,IAAI,SAAS,EAAE,CAAC;gBACd,IAAI,kBAAuB,CAAC;gBAC5B,KAAK,MAAM,CAAC,GAAG,EAAE,KAAK,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,SAAS,CAAC,EAAE,CAAC;oBACrD,IAAI,GAAG,CAAC,QAAQ,CAAC,eAAe,CAAC,EAAE,CAAC;wBAClC,kBAAkB,GAAG,KAAK,CAAC;oBAC7B,CAAC;gBACH,CAAC;gBACD,IAAI,MAAM,CAAC,IAAI,CAAC,kBAAkB,CAAC,CAAC,MAAM,EAAE,CAAC;oBAC3C,6GAA6G;oBAC7G,MAAM,cAAc,GAAG,kBAAkB,EAAE,OAAO,CAAC,IAAI,CAAC,CAAC,CAAM,EAAE,EAAE,CAAC,CAAC,CAAC,QAAQ,KAAK,aAAa,CAAC,EAAE,MAAM,CAAC;oBAC1G,kBAAkB,EAAE,IAAI,EAAE,OAAO,CAAC,CAAC,IAAS,EAAE,KAAa,EAAE,EAAE;wBAC7D,qFAAqF;wBACrF,4DAA4D;wBAE5D,uCAAuC;wBACvC,mEAAmE;wBACnE,YAAY;wBAEZ,IAAI,IAAI,CAAC,cAAc,CAAC,EAAE,CAAC;4BACzB,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,cAAc,CAAC,EAAE,KAAK,EAAC,kBAAkB,EAAE,OAAO,CAAC,CAAC;wBAC1E,CAAC;oBACH,CAAC,CAAC,CAAA;oBACH,IAAI,CAAC,WAAW,GAAI,IAAI,CAAC,0BAA0B,CAAC,kBAAkB,CAAC,CAAC;oBACvE,yCAAyC;oBACzC,IAAI,CAAC,MAAM,CAAC,KAAK,GAAG,IAAI,CAAC,WAAW,CAAC;oBACrC,iCAAiC;oBACjC,oDAAoD;oBACpD,IAAI,CAAC,gBAAgB,GAAG,IAAI,WAAW,EAAE,CAAC;oBAC1C,UAAU,CAAC,GAAG,EAAE;wBACd,IAAI,CAAC,gBAAgB,CAAC,UAAU,CAAC,IAAI,CAAC,WAAW,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,CAAC;wBACxE,OAAO,CAAC,GAAG,CAAC,kBAAkB,EAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC;wBACtD,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;oBAC3B,CAAC,EAAE,EAAE,CAAC,CAAC;gBACT,CAAC;YACH,CAAC;QACH,CAAC,CAAC,CAAA;IACN,CAAC;IAEM,eAAe;QACpB,UAAU,CAAC,GAAG,EAAE;YACd,IAAG,IAAI,CAAC,MAAM,EAAE,KAAK,IAAI,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE,KAAK,CAAC,EAAE,MAAM,IAAI,CAAC,EAAE,CAAC;gBACtE,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC;gBACrC,IAAI,CAAC,sBAAsB,EAAE,CAAC;YAChC,CAAC;QACH,CAAC,EAAE,GAAG,CAAC,CAAA;IACT,CAAC;IAES,sBAAsB;QAC9B,IAAI,CAAC,WAAW,CAAC,OAAO;aACrB,MAAM,CAAC,CAAC,MAAyB,EAAE,EAAE,CAAC,MAAM,CAAC,QAAQ,KAAK,gBAAgB,IAAI,MAAM,EAAE,MAAM,CAAC;aAC7F,OAAO,CAAC,CAAC,MAAyB,EAAE,EAAE;YACrC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAM,MAAM,CAAC,MAAO,CAAC,CAAC,SAAS,CAAC,CAAC,QAAa,EAAE,EAAE;gBAC7D,IAAI,CAAC,oBAAoB,CAAC,MAAM,CAAC,MAAM,CAAC,GAAG,QAAQ,CAAC,GAAG,CAAC,CAAC,IAAS,EAAE,EAAE,CAAC,CAAC;oBACtE,KAAK,EAAE,IAAI,CAAC,MAAM,CAAC,QAAS,CAAC;oBAC7B,IAAI,EAAE,IAAI,CAAC,MAAM,CAAC,QAAS,CAAC;iBAC7B,CAAC,CAAC,CAAC;YACN,CAAC,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;IACP,CAAC;IAED,6DAA6D;IAC7D,gEAAgE;IAChE,gBAAgB;IAChB,uCAAuC;IACvC,8BAA8B;IAC9B,0CAA0C;IAC1C,2CAA2C;IAC3C,qBAAqB;IACrB,UAAU;IACV,iIAAiI;IACjI,sDAAsD;IACtD,SAAS;IACT,kCAAkC;IAClC,MAAM;IACN,IAAI;IAEG,WAAW,CAAC,KAAY,EAAE,QAAgB;QAC/C,MAAM,KAAK,GAAI,KAAK,CAAC,MAA2B,CAAC,KAAK,CAAC;QACvD,IAAI,KAAK,IAAI,KAAK,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YAC9B,IAAI,CAAC,cAAc,CAAC,QAAQ,CAAC,GAAG,IAAI,CAAC,cAAc,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC;YAEpE,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,CAAC,IAAU,EAAE,EAAE;gBACvC,MAAM,MAAM,GAAG,IAAI,UAAU,EAAE,CAAC;gBAChC,MAAM,CAAC,MAAM,GAAG,GAAG,EAAE;oBACnB,IAAI,CAAC,cAAc,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC;wBACjC,MAAM,EAAE,MAAM,CAAC,MAAgB;wBAC/B,IAAI,EAAE,IAAI;qBACX,CAAC,CAAC;oBAEH,kEAAkE;oBAClE,MAAM,YAAY,GAAG,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAM,EAAE,EAAE,CAAC,CAAC,CAAC,QAAQ,KAAK,aAAa,CAAC,EAAE,MAAM,CAAC;oBACrG,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,YAAY,CAAC,GAAG,IAAI,CAAC,cAAc,CAAC,QAAQ,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;oBAEnG,OAAO,CAAC,GAAG,CAAC,aAAa,EAAE,IAAI,CAAC,WAAW,CAAC,CAAC;gBAC/C,CAAC,CAAC;gBACF,MAAM,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC;YAC7B,CAAC,CAAC,CAAC;QACL,CAAC;IACH,CAAC;IAGS,QAAQ;QAChB,OAAO;YACL,IAAI,eAAe,CAAC,EAAE,GAAG,EAAE,aAAa,EAAE,MAAM,EAAE,gBAAgB,EAAE,KAAK,EAAE,CAAC,EAAE,CAAC;YAC/E,IAAI,eAAe,CAAC,EAAE,GAAG,EAAE,cAAc,EAAE,MAAM,EAAE,qBAAqB,EAAE,KAAK,EAAE,EAAE,EAAE,CAAC;SACvF,CAAC;IACJ,CAAC;IAES,WAAW;QACnB,OAAO,CAAC,kBAAkB,CAAC,QAAQ,CAAC,CAAC;IACvC,CAAC;IAEM,QAAQ,CAAC,KAAa;QAC3B,OAAO,KAAK,CAAC,IAAI,CAAC,EAAE,MAAM,EAAE,KAAK,EAAE,CAAC,CAAC;IACvC,CAAC;IAEM,qBAAqB,CAAC,KAAU;QACpC,IAAI,CAAC,aAAa,GAAG;YACpB,SAAS,EAAE,KAAK,EAAE,SAAS;YAC3B,GAAG,EAAE,KAAK,EAAE,GAAG;SAChB,CAAA;QACD,MAAM,OAAO,GAAG,KAAK,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,GAAQ,EAAE,EAAE;YAC7C,OAAO;gBACL,MAAM,EAAE,GAAG,EAAE,MAAM;gBACnB,QAAQ,EAAE,GAAG,EAAE,QAAQ;gBACvB,WAAW,EAAE,GAAG,EAAE,WAAW;gBAC7B,OAAO,EAAE,GAAG,EAAE,OAAO;gBACrB,MAAM,EAAE,GAAG,EAAE,MAAM;gBACnB,QAAQ,EAAE,GAAG,EAAE,QAAQ;gBACvB,QAAQ,EAAE,GAAG,EAAE,QAAQ;gBACvB,SAAS,EAAE,GAAG,EAAE,SAAS;gBACzB,MAAM,EAAE,GAAG,EAAE,MAAM;gBACnB,aAAa,EAAE,GAAG,EAAE,aAAa;gBACjC,YAAY,EAAE,GAAG,EAAE,YAAY;gBAC/B,cAAc,EAAE,GAAG,EAAE,cAAc;gBACnC,aAAa,EAAC,GAAG,EAAE,aAAa;gBAChC,UAAU,EAAC,GAAG,EAAE,UAAU;gBAC1B,YAAY,EAAC,GAAG,EAAE,YAAY;gBAC9B,+BAA+B;gBAC/B,uCAAuC;gBACvC,wBAAwB;gBACxB,mCAAmC;gBACnC,sCAAsC;gBACtC,MAAM,EAAE,GAAG,EAAE,MAAM;aACpB,CAAA;QACH,CAAC,CAAC,CAAC;QACH,IAAG,CAAC,KAAK,EAAE,SAAS,EAAE,CAAC;YACrB,IAAI,CAAC,WAAW,CAAC,OAAO,GAAG,OAAO,CAAC;YACnC,mJAAmJ;YACnJ,+EAA+E;YAC/E,2CAA2C;YAC3C,eAAe;YACf,wBAAwB;YACxB,QAAQ;YACR,OAAO;YACP,gBAAgB;YAChB,KAAK;YACL,IAAI,CAAC,WAAW,CAAC,IAAI,GAAG,KAAK,CAAC,IAAI,CAAC,EAAE,MAAM,EAAE,CAAC,KAAK,EAAE,IAAI,EAAE,EAAE,CAAC,CAAC,EAAE,KAAK,EAAE,EAAE;gBACxE,OAAO,OAAO,CAAC,MAAM,CAAC,CAAC,GAAQ,EAAE,CAAM,EAAE,EAAE;oBACzC,GAAG,CAAC,CAAC,EAAE,MAAM,CAAC,GAAG,EAAE,CAAC,CAAC,uCAAuC;oBAC5D,OAAO,GAAG,CAAC;gBACb,CAAC,EAAE,EAAE,CAAC,CAAC;YACT,CAAC,CAAC,CAAC;YAEH,IAAI,CAAC,sBAAsB,EAAE,CAAC;QAChC,CAAC;QACD,IAAG,KAAK,EAAE,SAAS,EAAE,CAAC;YACpB,IAAI,CAAC,SAAS,CAAC,KAAK,EAAE,OAAO,CAAC,CAAA;YAC9B,IAAI,CAAC,WAAW,GAAG;gBACjB,OAAO,EAAE,OAAO;gBAChB,IAAI,EAAE,EAAE;aACT,CAAC;QACJ,CAAC;QACF,IAAI,CAAC,WAAW,GAAI,IAAI,CAAC,0BAA0B,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;QACtE,IAAI,CAAC,WAAW,CAAC,kBAAkB,GAAG,IAAI,CAAC,kBAAkB,CAAC;QAC7D,IAAI,CAAC,WAAW,CAAC,aAAa,GAAG,IAAI,CAAC,aAAa,CAAC;QACpD,IAAI,CAAC,MAAM,CAAC,KAAK,GAAG,IAAI,CAAC,WAAW,CAAC;QACrC,IAAI,CAAC,gBAAgB,CAAC,KAAK,EAAE,CAAC;QAC9B,IAAI,CAAC,gBAAgB,CAAC,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;IACnD,CAAC;IAEO,cAAc;QACpB,IAAG,IAAI,CAAC,MAAM,CAAC,QAAQ,EAAC,CAAC;YACvB,KAAI,IAAI,OAAO,IAAI,IAAI,CAAC,MAAM,CAAC,QAAQ,EAAC,CAAC;gBACzC,IAAG,OAAO,CAAC,GAAG,KAAK,cAAc,EAAC,CAAC;oBACjC,OAAO,CAAC,KAAK,GAAG,IAAI,CAAC,WAAW,CAAC;gBACjC,CAAC;YACH,CAAC;QACH,CAAC;IACH,CAAC;IAED,qDAAqD;IACrD,cAAc;IACd,uDAAuD;IACvD,gBAAgB;IAChB,wCAAwC;IACxC,kDAAkD;IAClD,0CAA0C;IAC1C,mDAAmD;IACnD,cAAc;IACd,yBAAyB;IACzB,YAAY;IACZ,6BAA6B;IAC7B,mBAAmB;IACnB,eAAe;IACf,UAAU;IACV,6DAA6D;IAC7D,8CAA8C;IAC9C,uCAAuC;IACvC,0DAA0D;IAC1D,QAAQ;IACR,OAAO;IACP,IAAI;IAEK,SAAS,CAAC,KAAU,EAAE,OAAY;QACzC,IAAI,IAAI,CAAC;QACT,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,SAAS,CAAC,CAAC,GAAQ,EAAE,EAAE;YAC9C,IAAG,GAAG,EAAE,CAAC;gBACP,IAAI,CAAC,kBAAkB,GAAG,GAAG,CAAC;gBAE9B,IAAI,GAAG,GAAG,CAAC,GAAG,CAAC,CAAC,IAAS,EAAE,EAAE;oBAC3B,MAAM,MAAM,GAAwB,EAAE,CAAC;oBACvC,OAAO,CAAC,OAAO,CAAC,CAAC,GAAQ,EAAE,EAAE;wBAC3B,MAAM,CAAC,GAAG,CAAC,MAAM,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,IAAI,EAAE,CAAC;oBAC9C,CAAC,CAAC,CAAC;oBACH,OAAO,MAAM,CAAC;gBAChB,CAAC,CAAC,CAAC;gBACH,IAAI,CAAC,WAAW,GAAG;oBACjB,OAAO;oBACP,IAAI;iBACL,CAAA;gBACD,IAAI,CAAC,WAAW,CAAC,aAAa,GAAG,IAAI,CAAC,aAAa,CAAC;gBACpD,IAAI,CAAC,WAAW,CAAC,kBAAkB,GAAG,IAAI,CAAC,kBAAkB,CAAC;gBAC9D,IAAI,CAAC,MAAM,CAAC,KAAK,GAAG,IAAI,CAAC,WAAW,CAAC;gBACrC,IAAI,CAAC,gBAAgB,CAAC,KAAK,EAAE,CAAC;gBAC9B,IAAI,CAAC,gBAAgB,CAAC,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;YACnD,CAAC;QACH,CAAC,CAAC,CAAA;IACJ,CAAC;IAED,sDAAsD;IACtD,gDAAgD;IAChD,0HAA0H;IAC1H,kDAAkD;IAClD,sDAAsD;IACtD,IAAI;IAEJ,kEAAkE;IAClE,yCAAyC;IACzC,2DAA2D;IAE3D,4GAA4G;IAC5G,0GAA0G;IAC1G,wDAAwD;IACxD,MAAM;IACN,IAAI;IAEG,UAAU,CAAC,QAAgB,EAAE,UAAkB;QACpD,IAAI,IAAI,CAAC,cAAc,CAAC,QAAQ,CAAC,EAAE,CAAC;YAClC,MAAM,WAAW,GAAG,IAAI,CAAC,cAAc,CAAC,QAAQ,CAAC,CAAC,UAAU,CAAC,CAAC;YAE9D,uFAAuF;YACvF,IAAI,WAAW,EAAE,MAAM,IAAI,OAAO,WAAW,CAAC,MAAM,KAAK,QAAQ,IAAI,WAAW,CAAC,IAAI,KAAK,IAAI,EAAE,CAAC;gBAC/F,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,aAAa,GAAG,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,aAAa,IAAI,EAAE,CAAC;gBACpG,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,aAAa,CAAC,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC;YACzE,CAAC;YAED,8BAA8B;YAC9B,IAAI,CAAC,cAAc,CAAC,QAAQ,CAAC,CAAC,MAAM,CAAC,UAAU,EAAE,CAAC,CAAC,CAAC;YAEpD,MAAM,YAAY,GAAG,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAM,EAAE,EAAE,CAAC,CAAC,CAAC,QAAQ,KAAK,aAAa,CAAC,EAAE,MAAM,CAAC;YACrG,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,YAAY,CAAC,GAAG,IAAI,CAAC,cAAc,CAAC,QAAQ,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;YAEnG,IAAI,CAAC,gBAAgB,CAAC,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;QACnD,CAAC;IACH,CAAC;IAID,uDAAuD;IACvD,6DAA6D;IAC7D,mCAAmC;IACnC,yDAAyD;IACzD,uCAAuC;IACvC,4BAA4B;IAC5B,qBAAqB;IACrB,WAAW;IACX,SAAS;IACT,0BAA0B;IAC1B,uDAAuD;IACvD,QAAQ;IACR,QAAQ;IACR,IAAI;IAEJ,0DAA0D;IAC1D,6DAA6D;IAC7D,mCAAmC;IACnC,yDAAyD;IAEzD,6EAA6E;IAC7E,6CAA6C;IAC7C,4BAA4B;IAC5B,qBAAqB;IACrB,YAAY;IAEZ,8GAA8G;IAC9G,4GAA4G;IAE5G,0DAA0D;IAC1D,SAAS;IACT,0BAA0B;IAC1B,uDAAuD;IACvD,QAAQ;IACR,QAAQ;IACR,IAAI;IAEG,SAAS,CAAC,IAAc,EAAE,QAAgB,EAAE,OAAY;QAC7D,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM;YAAE,OAAO;QAEjD,IAAI,CAAC,cAAc,CAAC,QAAQ,CAAC,GAAG,IAAI,CAAC,cAAc,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC;QAEpE,MAAM,YAAY,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC,CAAM,EAAE,EAAE,CAAC,CAAC,CAAC,QAAQ,KAAK,aAAa,CAAC,EAAE,MAAM,CAAC;QACpF,IAAI,CAAC,YAAY;YAAE,OAAO;QAE1B,MAAM,YAAY,GAAyB,EAAE,CAAC;QAE9C,IAAI,CAAC,OAAO,CAAC,CAAC,GAAW,EAAE,EAAE;YAC3B,IAAI,GAAG,EAAE,CAAC;gBACR,MAAM,MAAM,GAAG,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,EAAE,EAAE,YAAY,EAAE,MAAM,EAAE,CAAC,CAAC,IAAI,CAC9D,GAAG,CAAC,CAAC,SAAe,EAAE,EAAE,CAAC,GAAG,CAAC,eAAe,CAAC,SAAS,CAAC,CAAC,CACzD,CAAC;gBACF,YAAY,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;YAC5B,CAAC;QACH,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,YAAY,CAAC,MAAM;YAAE,OAAO;QAEjC,QAAQ,CAAC,YAAY,CAAC,CAAC,SAAS,CAAC;YAC/B,IAAI,EAAE,CAAC,SAAmB,EAAE,EAAE;gBAC5B,SAAS,CAAC,OAAO,CAAC,CAAC,QAAgB,EAAE,EAAE;oBACrC,IAAI,CAAC,cAAc,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC;wBACjC,MAAM,EAAE,QAAQ;wBAChB,IAAI,EAAE,IAAI;qBACX,CAAC,CAAC;gBACL,CAAC,CAAC,CAAC;gBAEH,wGAAwG;gBAExG,oDAAoD;YACtD,CAAC;YACD,KAAK,EAAE,CAAC,KAAK,EAAE,EAAE;gBACf,OAAO,CAAC,KAAK,CAAC,oCAAoC,EAAE,KAAK,CAAC,CAAC;YAC7D,CAAC;SACF,CAAC,CAAC;IACL,CAAC;IAED,gBAAgB,CAAC,KAAY,EAAE,GAAQ,EAAE,MAAW;QAClD,MAAM,KAAK,GAAG,KAAK,CAAC,MAA0B,CAAC;QAC/C,GAAG,CAAC,MAAM,CAAC,MAAM,CAAC,GAAG,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,YAAY,CAAC,CAAC,CAAC,MAAM,CAAC,cAAc,CAAC;IACnF,CAAC;IAGD,0BAA0B,CAAC,SAAc;QACvC,SAAS,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,GAAQ,EAAE,EAAE;YAClC,SAAS,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,MAAW,EAAE,EAAE;gBACxC,IAAI,MAAM,CAAC,QAAQ,KAAK,UAAU,IAAI,MAAM,CAAC,cAAc,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,MAAM,CAAC,EAAE,CAAC;oBACnF,GAAG,CAAC,MAAM,CAAC,MAAM,CAAC,GAAG,MAAM,CAAC,cAAc,CAAC;gBAC7C,CAAC;YACH,CAAC,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;QACH,OAAO,SAAS,CAAC;IACnB,CAAC;IAED,YAAY,CAAC,GAAQ,EAAE,MAAW,EAAC,QAAY;QAC7C,IAAI,MAAM,CAAC,sBAAsB,EAAE,CAAC;YAClC,IAAI,CAAC,cAAc,GAAG,MAAM,CAAC;YAC7B,IAAI,CAAC,WAAW,GAAG,GAAG,CAAC;YACvB,IAAI,CAAC,gBAAgB,GAAG,QAAQ,CAAA;YAChC,IAAI,CAAC,yBAAyB,GAAG,IAAI,CAAC;QACxC,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,aAAa,CAAC,GAAG,EAAE,MAAM,EAAC,QAAQ,CAAC,CAAC;QAC3C,CAAC;IACH,CAAC;IAED,aAAa;QACX,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,WAAW,EAAE,IAAI,CAAC,cAAc,EAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC;QAChF,IAAI,CAAC,yBAAyB,GAAG,KAAK,CAAC;IACzC,CAAC;IAED,YAAY;QACV,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC;YACtB,QAAQ,EAAE,MAAM;YAChB,OAAO,EAAE,WAAW;YACpB,MAAM,EAAE,sBAAsB;YAC9B,IAAI,EAAE,IAAI;SACX,CAAC,CAAC;QACH,IAAI,CAAC,yBAAyB,GAAG,KAAK,CAAC;IACzC,CAAC;IAED,8CAA8C;IAC9C,gEAAgE;IAChE,sDAAsD;IACtD,cAAc;IACd,MAAM;IAEN,gDAAgD;IAEhD,qDAAqD;IACrD,4CAA4C;IAC5C,gFAAgF;IAChF,iBAAiB;IACjB,8BAA8B;IAC9B,QAAQ;IACR,QAAQ;IAER,0CAA0C;IAC1C,8DAA8D;IAE9D,8FAA8F;IAC9F,2BAA2B;IAC3B,QAAQ;IAER,qCAAqC;IAErC,gCAAgC;IAChC,6BAA6B;IAC7B,4BAA4B;IAC5B,gEAAgE;IAChE,mBAAmB;IACnB,UAAU;IACV,OAAO;IAGP,wCAAwC;IACxC,qCAAqC;IACrC,gCAAgC;IAChC,2BAA2B;IAC3B,0BAA0B;IAC1B,wCAAwC;IACxC,mBAAmB;IACnB,UAAU;IACV,OAAO;IAEP,8BAA8B;IAC9B,mBAAmB;IACnB,6GAA6G;IAC7G,eAAe;IAEf,kBAAkB;IAClB,4GAA4G;IAC5G,eAAe;IAEf,qBAAqB;IACrB,yHAAyH;IACzH,eAAe;IAEf,kBAAkB;IAClB,wHAAwH;IACxH,eAAe;IAEf,eAAe;IACf,2DAA2D;IAC3D,MAAM;IACN,IAAI;IAEJ,8CAA8C;IAC9C,yCAAyC;IACzC,yCAAyC;IACzC,6EAA6E;IAC7E,gCAAgC;IAChC,4CAA4C;IAC5C,uDAAuD;IACvD,wBAAwB;IACxB,oCAAoC;IACpC,8BAA8B;IAC9B,kCAAkC;IAClC,4CAA4C;IAC5C,uBAAuB;IACvB,cAAc;IACd,UAAU;IACV,UAAU;IACV,aAAa;IACb,uCAAuC;IACvC,MAAM;IACN,IAAI;IAGJ,aAAa,CAAC,GAAQ,EAAE,MAAW,EAAC,QAAY;QAC9C,MAAM,OAAO,GAA2B,EAAE,CAAC;QAE3C,MAAM,CAAC,cAAc,CAAC,OAAO,CAAC,CAAC,MAAW,EAAE,EAAE;YAC5C,MAAM,GAAG,GAAG,MAAM,CAAC,iBAAiB,CAAC;YACrC,MAAM,KAAK,GAAG,MAAM,CAAC,kBAAkB,IAAI,IAAI,CAAC,WAAW,EAAE,kBAAkB,CAAC,QAAQ,CAAC,CAAC,GAAG,CAAC,CAAC;YAC/F,IAAI,GAAG,EAAE,CAAC;gBACR,OAAO,CAAC,GAAG,CAAC,GAAG,KAAK,CAAC;YACvB,CAAC;QACH,CAAC,CAAC,CAAC;QAEH,MAAM,SAAS,GAAG,MAAM,CAAC,UAAU,IAAI,eAAe,CAAC;QAEvD,MAAM,aAAa,GAAG,CAAC,GAAQ,EAAE,EAAE;YACjC,IAAI,CAAC,GAAG,CAAC,QAAQ,IAAI,OAAO,GAAG,CAAC,QAAQ,KAAK,QAAQ,IAAI,KAAK,CAAC,OAAO,CAAC,GAAG,CAAC,QAAQ,CAAC,EAAE,CAAC;gBACrF,GAAG,CAAC,QAAQ,GAAG,EAAE,CAAC;YACpB,CAAC;YAED,GAAG,CAAC,QAAQ,CAAC,SAAS,CAAC,GAAG,GAAG,CAAC;YAE9B,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC;gBACtB,QAAQ,EAAE,SAAS;gBACnB,OAAO,EAAE,SAAS;gBAClB,MAAM,EAAE,WAAW,SAAS,0BAA0B;gBACtD,IAAI,EAAE,IAAI;aACX,CAAC,CAAC;QACL,CAAC,CAAC;QAEF,MAAM,WAAW,GAAG,CAAC,GAAQ,EAAE,EAAE;YAC/B,IAAI,CAAC,GAAG,CAAC,QAAQ,IAAI,OAAO,GAAG,CAAC,QAAQ,KAAK,QAAQ,IAAI,KAAK,CAAC,OAAO,CAAC,GAAG,CAAC,QAAQ,CAAC,EAAE,CAAC;gBACrF,GAAG,CAAC,QAAQ,GAAG,EAAE,CAAC;YACpB,CAAC;YAED,GAAG,CAAC,QAAQ,CAAC,SAAS,CAAC,GAAG,EAAE,KAAK,EAAE,GAAG,EAAE,CAAC;YAEzC,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC;gBACtB,QAAQ,EAAE,OAAO;gBACjB,OAAO,EAAE,OAAO;gBAChB,MAAM,EAAE,WAAW,SAAS,UAAU;gBACtC,IAAI,EAAE,IAAI;aACX,CAAC,CAAC;QACL,CAAC,CAAC;QAEF,QAAQ,MAAM,CAAC,OAAO,EAAE,CAAC;YACvB,KAAK,MAAM;gBACT,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,YAAY,EAAE,OAAO,CAAC,CAAC,SAAS,CAAC,EAAE,IAAI,EAAE,aAAa,EAAE,KAAK,EAAE,WAAW,EAAE,CAAC,CAAC;gBACpG,MAAM;YACR,KAAK,KAAK;gBACR,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,YAAY,EAAE,OAAO,CAAC,CAAC,SAAS,CAAC,EAAE,IAAI,EAAE,aAAa,EAAE,KAAK,EAAE,WAAW,EAAE,CAAC,CAAC;gBACnG,MAAM;YACR,KAAK,QAAQ;gBACX,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,YAAY,EAAE,EAAE,IAAI,EAAE,OAAO,EAAE,CAAC,CAAC,SAAS,CAAC,EAAE,IAAI,EAAE,aAAa,EAAE,KAAK,EAAE,WAAW,EAAE,CAAC,CAAC;gBAChH,MAAM;YACR,KAAK,KAAK;gBACR,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,YAAY,EAAE,EAAE,MAAM,EAAE,OAAO,EAAE,CAAC,CAAC,SAAS,CAAC,EAAE,IAAI,EAAE,aAAa,EAAE,KAAK,EAAE,WAAW,EAAE,CAAC,CAAC;gBAC/G,MAAM;YACR;gBACE,OAAO,CAAC,IAAI,CAAC,mBAAmB,EAAE,MAAM,CAAC,OAAO,CAAC,CAAC;QACtD,CAAC;IACH,CAAC;IAKM,WAAW;QAChB,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACzB,IAAI,CAAC,QAAQ,CAAC,QAAQ,EAAE,CAAC;IAC3B,CAAC;wGA/kBU,qBAAqB;4FAArB,qBAAqB,2JALrB,CAAC,cAAc,EAAC,mBAAmB,CAAC,iDChDjD,42hBAyPoB,g+FD1MR,YAAY,2bAAE,WAAW,4lDAAE,sBAAsB,gHAAE,mBAAmB,8BAAC,iBAAiB,27CAAC,iBAAiB,8BAAC,eAAe,8BAAC,cAAc,8BAAC,WAAW,uWAAC,mBAAmB,kzBAAC,YAAY;;4FAMrL,qBAAqB;kBATjC,SAAS;+BACE,kBAAkB,cAChB,IAAI,WACP,CAAC,YAAY,EAAE,WAAW,EAAE,sBAAsB,EAAE,mBAAmB,EAAC,iBAAiB,EAAC,iBAAiB,EAAC,eAAe,EAAC,cAAc,EAAC,WAAW,EAAC,mBAAmB,EAAC,YAAY,CAAC,aACtL,CAAC,cAAc,EAAC,mBAAmB,CAAC;2LAMtC,SAAS;sBAAjB,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACG,WAAW;sBAAnB,KAAK","sourcesContent":["import { AfterViewInit, ChangeDetectorRef, Component, inject, Input, NgZone, OnDestroy, OnInit } from '@angular/core';\r\nimport { CommonModule } from '@angular/common';\r\nimport { FormControl, FormsModule, ReactiveFormsModule } from '@angular/forms';\r\nimport { HttpClient } from '@angular/common/http';\r\nimport { Action, FxBaseComponent, FxMode, FxSetting, FxStringSetting, FxValidation, FxValidatorService } from '@instantsys-labs/fx';\r\nimport { SettingsPanelComponent } from '../../panel/settings-panel/settings-panel.component';\r\nimport { FxBuilderWrapperService } from '../../fx-builder-wrapper.service';\r\nimport {forkJoin, map, Observable, Subject, takeUntil } from 'rxjs';\r\nimport { MultiSelectModule } from 'primeng/multiselect';\r\nimport { InputTextModule } from 'primeng/inputtext';\r\nimport { InputNumberModule } from 'primeng/inputnumber';\r\nimport { DropdownModule } from 'primeng/dropdown';\r\nimport { ConfirmationService, MessageService } from 'primeng/api';\r\nimport { ToastModule } from 'primeng/toast';\r\nimport { ConfirmDialogModule } from 'primeng/confirmdialog';\r\nimport { DialogModule } from 'primeng/dialog';\r\n\r\nexport interface TableColumnConfig {\r\n  header: string;\r\n  cellType: 'text' | 'input-text' | 'input-number' | 'dropdown' | 'smart-dropdown' | 'checkbox' | 'radio' | 'radio-group' | 'file-upload' | 'textarea' | 'action';\r\n  placeholder?: string;\r\n  options?: string[];\r\n  apiUrl?: string;\r\n  valueKey?: string;\r\n  labelKey?: string;\r\n  className?: string;\r\n  isMultiselect?: boolean;\r\n  checkedValue?: any;\r\n  unCheckedValue?: any;\r\n  checkBoxLabel?: string;\r\n  isRequired?:boolean,\r\n  errorMessage?:string,\r\n  // actionName?: string,\r\n  // actionIconPath?: string,\r\n  // apiType?:string,\r\n  // apiUrlToCall?: string,\r\n  // payloadOptions?: string[]\r\n  action: string[]\r\n}\r\nexport interface TableConfig {\r\n  columns: TableColumnConfig[];\r\n  rows: any[];\r\n  // apiDataToDrawTable: any[]\r\n}\r\n@Component({\r\n  selector: 'fx-dynamic-table',\r\n  standalone: true,\r\n  imports: [CommonModule, FormsModule, SettingsPanelComponent, ReactiveFormsModule,MultiSelectModule,InputNumberModule,InputTextModule,DropdownModule,ToastModule,ConfirmDialogModule,DialogModule],\r\n  providers: [MessageService,ConfirmationService],\r\n  templateUrl: './dynamic-table.component.html',\r\n  styleUrl: './dynamic-table.component.scss',\r\n})\r\n\r\nexport class DynamicTableComponent extends FxBaseComponent implements OnInit, AfterViewInit, OnDestroy {\r\n  @Input() tableRows: Array<any> = [];\r\n  @Input() previewType: FxMode = FxMode.VIEW;\r\n  @Input() tableConfig: any = {\r\n    columns: [\r\n      { header: 'Column 1', cellType: 'text' },\r\n      { header: 'Column 2', cellType: 'text' },\r\n      { header: 'Column 3', cellType: 'text' },\r\n      { header: 'Column 4', cellType: 'text' },\r\n      { header: 'Column 5', cellType: 'text' },\r\n    ],\r\n};\r\n\r\n  private destroy$ = new Subject<Boolean>();\r\n  // public uploadedImages: Array<Record<string, string | File | null> | null> = [];\r\n  public uploadedImages: Array<Array<{ result: string, file: File | null}>> = [];\r\n\r\npublic generalValues: any;\r\nselectedAction: any;\r\nselectedRow: any;\r\nselectedRowIndex: any;\r\ndisplayConfirmationDialog: boolean = false;\r\napiDataToDrawTable: any[] =[];\r\n\r\n  public tableFormControl = new FormControl();\r\n  public smartDropdownOptions: { [key: string]: Array<{ name: string, value: string }> } = {};\r\n  private http = inject(HttpClient);\r\n  constructor(private cdr: ChangeDetectorRef, private fxBuilderWrapperService: FxBuilderWrapperService,   private messageService: MessageService, private confirmationService: ConfirmationService) {\r\n    super(cdr);\r\n    this.onInit.subscribe((fxData)=>{\r\n      this._register(this.tableFormControl);\r\n    })\r\n  }\r\n\r\n  public ngOnInit(): void {\r\n    this.fxBuilderWrapperService.variables$.pipe(\r\n      takeUntil(this.destroy$)).subscribe((variables: any) => {\r\n        if (variables) {\r\n          let dynamicTableValues: any;\r\n          for (const [key, value] of Object.entries(variables)) {\r\n            if (key.includes('dynamic-table')) {\r\n              dynamicTableValues = value;\r\n            }\r\n          }\r\n          if (Object.keys(dynamicTableValues).length) {\r\n            // const fileHeaderName = dynamicTableValues?.columns.find((f: any) => f.cellType === 'file-upload')?.header;\r\n            const fileHeaderName = dynamicTableValues?.columns.find((f: any) => f.cellType === 'file-upload')?.header;\r\n            dynamicTableValues?.rows?.forEach((item: any, index: number) => {\r\n              // // this.uploadedImages[index] = item[fileHeaderName] ? item[fileHeaderName]: null;\r\n              // const fileUrl = item[fileHeaderName]; // Get the file URL\r\n\r\n              // this.uploadedImages[index] = fileUrl\r\n              //   ? { result: fileUrl, file: null } // Store the URL as 'result'\r\n              //   : null;\r\n              \r\n              if (item[fileHeaderName]) {\r\n                this.parseUrls(item[fileHeaderName], index,dynamicTableValues?.columns);\r\n              }\r\n            })\r\n           this.tableConfig =  this.initializeCheckboxDefaults(dynamicTableValues);\r\n            // this.tableConfig = dynamicTableValues;\r\n            this.fxData.value = this.tableConfig;\r\n            // this.tableFormControl.reset();\r\n            // this.tableFormControl.setValue(this.tableConfig);\r\n            this.tableFormControl = new FormControl();\r\n            setTimeout(() => {  // Delay to ensure proper patching\r\n              this.tableFormControl.patchValue(this.tableConfig, { emitEvent: true });\r\n              console.log(\"tableFormControl\",this.tableFormControl);\r\n              this.cdr.detectChanges();\r\n            }, 50);\r\n          }\r\n        }\r\n      })\r\n  }\r\n\r\n  public ngAfterViewInit(): void {\r\n    setTimeout(() => {\r\n      if(this.fxData?.value && Object.keys(this.fxData?.value)?.length != 0) {\r\n        this.tableConfig = this.fxData.value;\r\n        this.fetchSmartDropdownData();\r\n      }\r\n    }, 100)\r\n  }\r\n  \r\n  protected fetchSmartDropdownData(): void {\r\n    this.tableConfig.columns\r\n      .filter((column: TableColumnConfig) => column.cellType === 'smart-dropdown' && column?.apiUrl)\r\n      .forEach((column: TableColumnConfig) => {\r\n        this.http.get<any>(column.apiUrl!).subscribe((response: any) => {\r\n          this.smartDropdownOptions[column.header] = response.map((item: any) => ({\r\n            value: item[column.valueKey!],\r\n            name: item[column.labelKey!],\r\n          }));\r\n        });\r\n      });\r\n  }\r\n\r\n  // public uploadImage(event: Event, rowIndex: number): void {\r\n  //   const file = (event.target as HTMLInputElement).files?.[0];\r\n  //   if (file) {\r\n  //     const reader = new FileReader();\r\n  //     reader.onload = () => {\r\n  //       this.uploadedImages[rowIndex] = {\r\n  //         result: reader.result as string,\r\n  //         file: file\r\n  //       }\r\n  //       this.tableConfig.rows[rowIndex][this.tableConfig.columns.find((f: any) => f.cellType === 'file-upload')?.header] = file;\r\n  //       console.log(\"tableConfig\", this.tableConfig);\r\n  //     };\r\n  //     reader.readAsDataURL(file);\r\n  //   }\r\n  // }\r\n\r\n  public uploadImage(event: Event, rowIndex: number): void {\r\n    const files = (event.target as HTMLInputElement).files;\r\n    if (files && files.length > 0) {\r\n      this.uploadedImages[rowIndex] = this.uploadedImages[rowIndex] || [];\r\n  \r\n      Array.from(files).forEach((file: File) => {\r\n        const reader = new FileReader();\r\n        reader.onload = () => {\r\n          this.uploadedImages[rowIndex].push({\r\n            result: reader.result as string,\r\n            file: file\r\n          });\r\n  \r\n          // Optionally add to tableConfig if only one file is tracked there\r\n          const columnHeader = this.tableConfig.columns.find((f: any) => f.cellType === 'file-upload')?.header;\r\n          this.tableConfig.rows[rowIndex][columnHeader] = this.uploadedImages[rowIndex].map(img => img.file);\r\n  \r\n          console.log(\"tableConfig\", this.tableConfig);\r\n        };\r\n        reader.readAsDataURL(file);\r\n      });\r\n    }\r\n  }\r\n  \r\n\r\n  protected settings(): FxSetting[] {\r\n    return [\r\n      new FxStringSetting({ key: 'column-size', $title: 'No. of columns', value: 1 }),\r\n      new FxStringSetting({ key: 'table-config', $title: 'Table Configuration', value: {} }),\r\n    ];\r\n  }\r\n\r\n  protected validations(): FxValidation[] {\r\n    return [FxValidatorService.required];\r\n  }\r\n\r\n  public getArray(count: number): number[] {\r\n    return Array.from({ length: count });\r\n  }\r\n\r\n  public onChangeConfiguration(event: any): void { \r\n     this.generalValues = {\r\n      enableAPI: event?.enableAPI,\r\n      api: event?.api\r\n    }\r\n    const columns = event.columns.map((col: any) => {\r\n      return {\r\n        header: col?.header,\r\n        cellType: col?.cellType,\r\n        placeholder: col?.placeholder,\r\n        options: col?.options,\r\n        apiUrl: col?.apiUrl,\r\n        valueKey: col?.valueKey,\r\n        labelKey: col?.labelKey,\r\n        className: col?.className,\r\n        apiKey: col?.apiKey,\r\n        isMultiselect: col?.isMultiselect,\r\n        checkedValue: col?.checkedValue,\r\n        unCheckedValue: col?.unCheckedValue,\r\n        checkBoxLabel:col?.checkBoxLabel,\r\n        isRequired:col?.isRequired,\r\n        errorMessage:col?.errorMessage,\r\n        // actionName: col?.actionName,\r\n        // actionIconPath: col?.actionIconPath,\r\n        // apiType:col?.apiType,\r\n        // apiUrlToCall: col?.apiUrlToCall,\r\n        // payloadOptions: col?.payloadOptions\r\n        action: col?.action \r\n      }\r\n    });\r\n    if(!event?.enableAPI) {\r\n      this.tableConfig.columns = columns;\r\n      // this.tableConfig.rows = Array.from({ length: +event?.rows }, (e, index) => ({ name: `SKU-${index + 1}`, age: index % 2 !== 0, gender: 'male' }))\r\n      // this.tableConfig.rows = Array.from({ length: +event?.rows }, (e, index) => {\r\n      //   const rows = columns.map((c: any) => {\r\n      //     return {\r\n      //       c?.header: null\r\n      //     }\r\n      //   })\r\n      //   return rows\r\n      // })\r\n      this.tableConfig.rows = Array.from({ length: +event?.rows }, (_, index) => {\r\n        return columns.reduce((acc: any, c: any) => {\r\n          acc[c?.header] = ''; // Initialize each column key with null\r\n          return acc;\r\n        }, {});\r\n      });\r\n      \r\n      this.fetchSmartDropdownData();\r\n    }\r\n    if(event?.enableAPI) {\r\n      this.drawTable(event, columns)\r\n      this.tableConfig = {\r\n        columns: columns,\r\n        rows: []\r\n      };\r\n    }\r\n   this.tableConfig =  this.initializeCheckboxDefaults(this.tableConfig);\r\n   this.tableConfig.apiDataToDrawTable = this.apiDataToDrawTable;\r\n    this.tableConfig.generalValues = this.generalValues;\r\n    this.fxData.value = this.tableConfig;\r\n    this.tableFormControl.reset();\r\n    this.tableFormControl.setValue(this.tableConfig);\r\n  }\r\n\r\n  private updateSettings(): void{\r\n    if(this.fxData.settings){\r\n      for(let setting of this.fxData.settings){\r\n      if(setting.key === 'table-config'){\r\n        setting.value = this.tableConfig;\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n  // public drawTable(event: any, columns: any): void {\r\n  //   let rows;\r\n  //   this.http.get(event.api).subscribe((res: any) => {\r\n  //     if(res) {\r\n  //       rows = res.map((item: any) => {\r\n  //         const newObj: Record<string, any> = {};\r\n  //         columns.forEach((col: any) => {\r\n  //           newObj[col.header] = item[col.apiKey];\r\n  //         });\r\n  //         return newObj;\r\n  //       });\r\n  //       this.tableConfig = {\r\n  //         columns,\r\n  //         rows\r\n  //       }\r\n  //       this.tableConfig.generalValues = this.generalValues;\r\n  //       this.fxData.value = this.tableConfig;\r\n  //       this.tableFormControl.reset();\r\n  //       this.tableFormControl.setValue(this.tableConfig);\r\n  //     }\r\n  //   })\r\n  // }\r\n\r\n    public drawTable(event: any, columns: any): void {\r\n    let rows;\r\n    this.http.get(event.api).subscribe((res: any) => {\r\n      if(res) {\r\n        this.apiDataToDrawTable = res;\r\n       \r\n        rows = res.map((item: any) => {\r\n          const newObj: Record<string, any> = {};\r\n          columns.forEach((col: any) => {\r\n            newObj[col.header] = item[col.apiKey] || '';\r\n          });\r\n          return newObj;\r\n        });\r\n        this.tableConfig = {\r\n          columns,\r\n          rows\r\n        }\r\n        this.tableConfig.generalValues = this.generalValues;\r\n        this.tableConfig.apiDataToDrawTable = this.apiDataToDrawTable;\r\n        this.fxData.value = this.tableConfig;\r\n        this.tableFormControl.reset();\r\n        this.tableFormControl.setValue(this.tableConfig);\r\n      }\r\n    })\r\n  }\r\n\r\n  // public deleteFile(file: any, index: number): void {\r\n  //   this.uploadedImages.splice(index, 1, null);\r\n  //   this.tableConfig.rows[index][this.tableConfig.columns.find((f: any) => f.cellType === 'file-upload')?.header] = null;\r\n  //   console.log(\"tableConfig\", this.tableConfig);\r\n  //   this.tableFormControl.setValue(this.tableConfig);\r\n  // }\r\n\r\n  // public deleteFile(rowIndex: number, imageIndex: number): void {\r\n  //   if (this.uploadedImages[rowIndex]) {\r\n  //     this.uploadedImages[rowIndex].splice(imageIndex, 1);\r\n  \r\n  //     const columnHeader = this.tableConfig.columns.find((f: any) => f.cellType === 'file-upload')?.header;\r\n  //     this.tableConfig.rows[rowIndex][columnHeader] = this.uploadedImages[rowIndex].map(img => img.file);\r\n  //     this.tableFormControl.setValue(this.tableConfig);\r\n  //   }\r\n  // }\r\n\r\n  public deleteFile(rowIndex: number, imageIndex: number): void {\r\n    if (this.uploadedImages[rowIndex]) {\r\n      const removedFile = this.uploadedImages[rowIndex][imageIndex];\r\n  \r\n      // Track the file to delete if it's an uploaded file (i.e., has URL and no File object)\r\n      if (removedFile?.result && typeof removedFile.result === 'string' && removedFile.file === null) {\r\n        this.tableConfig.rows[rowIndex].filesToDelete = this.tableConfig.rows[rowIndex].filesToDelete || [];\r\n        this.tableConfig.rows[rowIndex].filesToDelete.push(removedFile.result);\r\n      }\r\n  \r\n      // Remove the file from the UI\r\n      this.uploadedImages[rowIndex].splice(imageIndex, 1);\r\n  \r\n      const columnHeader = this.tableConfig.columns.find((f: any) => f.cellType === 'file-upload')?.header;\r\n      this.tableConfig.rows[rowIndex][columnHeader] = this.uploadedImages[rowIndex].map(img => img.file);\r\n  \r\n      this.tableFormControl.setValue(this.tableConfig);\r\n    }\r\n  }\r\n  \r\n  \r\n\r\n  // public parseUrls(url: string, index: number): void {\r\n  //   this.http.get(url, { responseType: 'blob' }).subscribe({\r\n  //     next: (imageBlob: Blob) => {\r\n  //       const imageURL = URL.createObjectURL(imageBlob);\r\n  //       this.uploadedImages[index] = {\r\n  //         result: imageURL,\r\n  //         file: null\r\n  //       };\r\n  //     },\r\n  //     error: (error) => {\r\n  //       console.error('Error fetching image:', error);\r\n  //     }\r\n  //   });\r\n  // }\r\n\r\n  // public parseUrls(url: string, rowIndex: number): void {\r\n  //   this.http.get(url, { responseType: 'blob' }).subscribe({\r\n  //     next: (imageBlob: Blob) => {\r\n  //       const imageURL = URL.createObjectURL(imageBlob);\r\n  \r\n  //       this.uploadedImages[rowIndex] = this.uploadedImages[rowIndex] || [];\r\n  //       this.uploadedImages[rowIndex].push({\r\n  //         result: imageURL,\r\n  //         file: null\r\n  //       });\r\n  \r\n  //       const columnHeader = this.tableConfig.columns.find((f: any) => f.cellType === 'file-upload')?.header;\r\n  //       this.tableConfig.rows[rowIndex][columnHeader] = this.uploadedImages[rowIndex].map(img => img.file);\r\n  \r\n  //       this.tableFormControl.setValue(this.tableConfig);\r\n  //     },\r\n  //     error: (error) => {\r\n  //       console.error('Error fetching image:', error);\r\n  //     }\r\n  //   });\r\n  // }\r\n\r\n  public parseUrls(urls: string[], rowIndex: number, columns: any): void {\r\n    if (!Array.isArray(urls) || !urls.length) return;\r\n  \r\n    this.uploadedImages[rowIndex] = this.uploadedImages[rowIndex] || [];\r\n  \r\n    const columnHeader = columns.find((f: any) => f.cellType === 'file-upload')?.header;\r\n    if (!columnHeader) return;\r\n  \r\n    const imageFetches: Observable<string>[] = [];\r\n  \r\n    urls.forEach((url: string) => {\r\n      if (url) {\r\n        const image$ = this.http.get(url, { responseType: 'blob' }).pipe(\r\n          map((imageBlob: Blob) => URL.createObjectURL(imageBlob))\r\n        );\r\n        imageFetches.push(image$);\r\n      }\r\n    });\r\n  \r\n    if (!imageFetches.length) return;\r\n  \r\n    forkJoin(imageFetches).subscribe({\r\n      next: (imageURLs: string[]) => {\r\n        imageURLs.forEach((imageURL: string) => {\r\n          this.uploadedImages[rowIndex].push({\r\n            result: imageURL,\r\n            file: null\r\n          });\r\n        });\r\n  \r\n        // this.tableConfig.rows[rowIndex][columnHeader] = this.uploadedImages[rowIndex].map(img => img.result);\r\n  \r\n        // this.tableFormControl.setValue(this.tableConfig);\r\n      },\r\n      error: (error) => {\r\n        console.error('Error fetching one or more images:', error);\r\n      }\r\n    });\r\n  }\r\n  \r\n  onCheckboxChange(event: Event, row: any, column: any): void {\r\n    const input = event.target as HTMLInputElement;\r\n    row[column.header] = input.checked ? column.checkedValue : column.unCheckedValue;\r\n  }\r\n  \r\n\r\n  initializeCheckboxDefaults(tableData: any): void {\r\n    tableData.rows.forEach((row: any) => {\r\n      tableData.columns.forEach((column: any) => {\r\n        if (column.cellType === 'checkbox' && column.unCheckedValue && !row[column.header]) {\r\n          row[column.header] = column.unCheckedValue;\r\n        }\r\n      });\r\n    });\r\n    return tableData;\r\n  }\r\n\r\n  handleAction(row: any, action: any,rowIndex:any): void {\r\n    if (action.isConfirmationRequired) {\r\n      this.selectedAction = action;\r\n      this.selectedRow = row;\r\n      this.selectedRowIndex = rowIndex\r\n      this.displayConfirmationDialog = true;\r\n    } else {\r\n      this.executeAction(row, action,rowIndex);\r\n    }\r\n  }\r\n  \r\n  confirmAction(): void {\r\n    this.executeAction(this.selectedRow, this.selectedAction,this.selectedRowIndex);\r\n    this.displayConfirmationDialog = false;\r\n  }\r\n  \r\n  cancelAction(): void {\r\n    this.messageService.add({\r\n      severity: 'info',\r\n      summary: 'Cancelled',\r\n      detail: 'Action was cancelled',\r\n      life: 2000\r\n    });\r\n    this.displayConfirmationDialog = false;\r\n  }\r\n  \r\n  // handleAction(row: any, action: any): void {\r\n  //   if (!action || !action.apiType || !action.payloadOptions) {\r\n  //     console.warn('Invalid action config:', action);\r\n  //     return;\r\n  //   }\r\n  \r\n  //   const payload: { [key: string]: any } = {};\r\n  \r\n  //   action.payloadOptions.forEach((option: any) => {\r\n  //     const key = option.payloadOptionName;\r\n  //     const value = option.payloadOptionValue ?? row[option.payloadOptionName];\r\n  //     if (key) {\r\n  //       payload[key] = value;\r\n  //     }\r\n  //   });\r\n  \r\n  //   const handleSuccess = (res: any) => {\r\n  //     const actionKey = action.actionName || 'defaultAction';\r\n\r\n  //     if (!row.response || typeof row.response !== 'object' || Array.isArray(row.response)) {\r\n  //       row.response = {};\r\n  //     }\r\n    \r\n  //     row.response[actionKey] = res;\r\n    \r\n  //     this.messageService.add({\r\n  //       severity: 'success',\r\n  //       summary: 'Success',\r\n  //       detail: `Action \"${actionKey}\" completed successfully`,\r\n  //       life: 3000\r\n  //     });\r\n  //   };\r\n    \r\n\r\n  //   const handleError = (err: any) => {\r\n  //     row.response = { error: err };\r\n  //     this.messageService.add({\r\n  //       severity: 'error',\r\n  //       summary: 'Error',\r\n  //       detail: 'Something went wrong',\r\n  //       life: 3000\r\n  //     });\r\n  //   };\r\n  \r\n  //   switch (action.apiType) {\r\n  //     case 'POST':\r\n  //       this.http.post(action.apiUrlToCall, payload).subscribe({ next: handleSuccess, error: handleError });\r\n  //       break;\r\n  \r\n  //     case 'PUT':\r\n  //       this.http.put(action.apiUrlToCall, payload).subscribe({ next: handleSuccess, error: handleError });\r\n  //       break;\r\n  \r\n  //     case 'DELETE':\r\n  //       this.http.delete(action.apiUrlToCall, { body: payload }).subscribe({ next: handleSuccess, error: handleError });\r\n  //       break;\r\n  \r\n  //     case 'GET':\r\n  //       this.http.get(action.apiUrlToCall, { params: payload }).subscribe({ next: handleSuccess, error: handleError });\r\n  //       break;\r\n  \r\n  //     default:\r\n  //       console.warn('Unknown API type:', action.apiType);\r\n  //   }\r\n  // }\r\n  \r\n  // handleAction(row: any, action: any): void {\r\n  //   if (action.isConfirmationRequired) {\r\n  //     this.confirmationService.confirm({\r\n  //       message: `Are you sure you want to perform \"${action.actionName}\"?`,\r\n  //       header: 'Confirmation',\r\n  //       icon: 'pi pi-exclamation-triangle',\r\n  //       accept: () => this.executeAction(row, action),\r\n  //       reject: () => {\r\n  //         this.messageService.add({\r\n  //           severity: 'info',\r\n  //           summary: 'Cancelled',\r\n  //           detail: 'Action was cancelled',\r\n  //           life: 2000\r\n  //         });\r\n  //       }\r\n  //     });\r\n  //   } else {\r\n  //     this.executeAction(row, action);\r\n  //   }\r\n  // }\r\n  \r\n\r\n  executeAction(row: any, action: any,rowIndex:any): void {\r\n    const payload: { [key: string]: any } = {};\r\n  \r\n    action.payloadOptions.forEach((option: any) => {\r\n      const key = option.payloadOptionName;\r\n      const value = option.payloadOptionValue || this.tableConfig?.apiDataToDrawTable[rowIndex][key];\r\n      if (key) {\r\n        payload[key] = value;\r\n      }\r\n    });\r\n  \r\n    const actionKey = action.actionName || 'defaultAction';\r\n  \r\n    const handleSuccess = (res: any) => {\r\n      if (!row.response || typeof row.response !== 'object' || Array.isArray(row.response)) {\r\n        row.response = {};\r\n      }\r\n  \r\n      row.response[actionKey] = res;\r\n  \r\n      this.messageService.add({\r\n        severity: 'success',\r\n        summary: 'Success',\r\n        detail: `Action \"${actionKey}\" completed successfully`,\r\n        life: 3000\r\n      });\r\n    };\r\n  \r\n    const handleError = (err: any) => {\r\n      if (!row.response || typeof row.response !== 'object' || Array.isArray(row.response)) {\r\n        row.response = {};\r\n      }\r\n  \r\n      row.response[actionKey] = { error: err };\r\n  \r\n      this.messageService.add({\r\n        severity: 'error',\r\n        summary: 'Error',\r\n        detail: `Action \"${actionKey}\" failed`,\r\n        life: 3000\r\n      });\r\n    };\r\n  \r\n    switch (action.apiType) {\r\n      case 'POST':\r\n        this.http.post(action.apiUrlToCall, payload).subscribe({ next: handleSuccess, error: handleError });\r\n        break;\r\n      case 'PUT':\r\n        this.http.put(action.apiUrlToCall, payload).subscribe({ next: handleSuccess, error: handleError });\r\n        break;\r\n      case 'DELETE':\r\n        this.http.delete(action.apiUrlToCall, { body: payload }).subscribe({ next: handleSuccess, error: handleError });\r\n        break;\r\n      case 'GET':\r\n        this.http.get(action.apiUrlToCall, { params: payload }).subscribe({ next: handleSuccess, error: handleError });\r\n        break;\r\n      default:\r\n        console.warn('Unknown API type:', action.apiType);\r\n    }\r\n  }\r\n  \r\n  \r\n  \r\n\r\n  public ngOnDestroy(): void {\r\n    this.destroy$.next(true);\r\n    this.destroy$.complete();\r\n  }\r\n}\r\n","<fx-settings-panel [fxData]=\"fxData\" [tableData]=\"fxData\" (configuration)=\"onChangeConfiguration($event)\">\r\n  <div *ngIf=\"fxData\">\r\n    <table style=\"width: 100%;\" class=\"formBuilder_dynamic_table\">\r\n      <thead>\r\n        <tr>\r\n          <th *ngFor=\"let column of tableConfig.columns\">{{ column.header }}</th>\r\n        </tr>\r\n      </thead>\r\n      <tbody>\r\n        <tr *ngFor=\"let row of tableConfig.rows; let rowIndex = index\">\r\n          <td *ngFor=\"let column of tableConfig.columns\">\r\n            <ng-container [ngSwitch]=\"column.cellType\">\r\n              <span [class]=\"column?.className\" *ngSwitchCase=\"'text'\">{{row[column.header]}}</span>\r\n\r\n              <!-- <input [class]=\"column?.className\" *ngSwitchCase=\"'input-text'\" type=\"text\" [placeholder]=\"column?.placeholder\"\r\n                                [(ngModel)]=\"row[column.header]\" /> -->\r\n\r\n              <ng-container *ngSwitchCase=\"'input-text'\">\r\n                <input [class]=\"column?.className\" type=\"text\" [placeholder]=\"column?.placeholder\"\r\n                  [(ngModel)]=\"row[column.header]\" [required]=\"column?.isRequired\" #model=\"ngModel\" />\r\n\r\n                <div *ngIf=\"column?.isRequired && model.invalid && model.touched\" class=\"text-red-500 text-sm mt-1\">\r\n                  {{ column?.errorMessage }}\r\n                </div>\r\n              </ng-container>\r\n\r\n\r\n\r\n              <input [class]=\"column?.className\" *ngSwitchCase=\"'input-number'\" type=\"number\"\r\n                [placeholder]=\"column?.placeholder\" [(ngModel)]=\"row[column.header]\" />\r\n\r\n              <select [class]=\"column?.className\" *ngSwitchCase=\"'dropdown'\" [(ngModel)]=\"row[column.header]\">\r\n\r\n                <option *ngIf=\"column.placeholder\" value=\"\">{{ column.placeholder }}</option>\r\n                <option *ngFor=\"let option of column?.options\" [value]=\"option?.optionValue\">\r\n                  {{ option?.optionName }}\r\n                </option>\r\n              </select>\r\n\r\n              <!-- <select [class]=\"column?.className\" style=\"width: 60%;\" *ngSwitchCase=\"'smart-dropdown'\"\r\n                                [(ngModel)]=\"row[column.header]\">\r\n                                <option value=\"\">Select {{column.header}}</option>\r\n                                <option *ngIf=\"column.placeholder\" value=\"\">{{ column.placeholder }}</option>\r\n                                <option *ngFor=\"let option of smartDropdownOptions[column.header]\" [value]=\"option?.value\">\r\n                                    {{option?.name }}\r\n                                </option>\r\n                            </select> -->\r\n\r\n              <!-- <p-multiSelect [options]=\"smartDropdownOptions[column.header]\" [(ngModel)]=\"row[column.header]\" optionLabel=\"name\" optionValue=\"value\" placeholder=\"Select Cities\" *ngSwitchCase=\"'smart-dropdown'\"/> -->\r\n\r\n              <!-- smart-dropdown handling -->\r\n              <ng-container *ngSwitchCase=\"'smart-dropdown'\">\r\n\r\n                <!-- Regular dropdown if isMultiselect is false or not set -->\r\n                <select *ngIf=\"!column?.isMultiselect\" [class]=\"column?.className\" style=\"width: 60%;\"\r\n                  [(ngModel)]=\"row[column.header]\">\r\n                  <option *ngIf=\"column.placeholder\" value=\"\">{{ column.placeholder }}</option>\r\n                  <option *ngFor=\"let option of smartDropdownOptions[column.header]\" [value]=\"option?.value\">\r\n                    {{ option?.name }}\r\n                  </option>\r\n                  <option value=\"__other__\">Other</option>\r\n\r\n                </select>\r\n                <input *ngIf=\"row[column.header] === '__other__'\" type=\"text\" class=\"mt-2 p-inputtext-sm\"\r\n                  [placeholder]=\"'Enter other ' + column.header\" [(ngModel)]=\"row[column.header + '_other']\" />\r\n\r\n                <!-- PrimeNG multiselect if isMultiselect is true -->\r\n                <p-multiSelect *ngIf=\"column?.isMultiselect\" [options]=\"smartDropdownOptions[column.header]\"\r\n                  [(ngModel)]=\"row[column.header]\" [class]=\"column?.className\" optionLabel=\"name\" optionValue=\"value\"\r\n                  [placeholder]=\"column.placeholder || ('Select ' + column.header)\">\r\n                  <ng-template pTemplate=\"dropdownicon\">\r\n                    <div class=\"flex align-items-center dd_down_icon\">\r\n                      <span class=\"pi pi-angle-down text-xl\"></span>\r\n                    </div>\r\n                  </ng-template>\r\n                </p-multiSelect>\r\n\r\n              </ng-container>\r\n\r\n\r\n              <!-- <input [class]=\"column?.className\" *ngSwitchCase=\"'checkbox'\" type=\"checkbox\"\r\n                                [(ngModel)]=\"row[column.header]\" /> -->\r\n              <ng-container *ngSwitchCase=\"'checkbox'\">\r\n                <label [class]=\"column?.className\" class=\"inline-flex items-center gap-2\">\r\n                  <input type=\"checkbox\" [checked]=\"row[column.header] === column.checkedValue\"\r\n                    (change)=\"onCheckboxChange($event, row, column)\" />\r\n                  {{ column?.checkBoxLabel || '' }}\r\n                </label>\r\n              </ng-container>\r\n              <p-toast></p-toast>\r\n              <p-confirmDialog></p-confirmDialog>\r\n              <ng-container *ngSwitchCase=\"'action'\">\r\n                <div class=\"flex flex-row gap-6 justify-start items-start\">\r\n                  <div *ngFor=\"let action of column?.action\" class=\"flex flex-col items-center w-20 cursor-pointer\"\r\n                    (click)=\"handleAction(row, action,rowIndex)\">\r\n                    <img [src]=\"action?.actionIconPath\" alt=\"icon\" class=\"w-6 h-6 mb-1\" />\r\n                    <span class=\"text-xs text-center break-words\">\r\n                      {{ action?.actionName }}\r\n                    </span>\r\n                  </div>\r\n                </div>\r\n              </ng-container>\r\n\r\n\r\n\r\n\r\n\r\n\r\n              <input name=\"radio-{{rowIndex}}\" [class]=\"column?.className\" *ngSwitchCase=\"'radio'\" type=\"radio\"\r\n                [(ngModel)]=\"row[column.header]\" />\r\n\r\n              <div [class]=\"column?.className\" style=\"display: flex; justify-content: center; gap: 10px;\"\r\n                *ngSwitchCase=\"'radio-group'\">\r\n                <label *ngFor=\"let option of column.options\">\r\n                  <input name=\"radio-group-{{rowIndex}}\" type=\"radio\" [value]=\"option?.optionName\"\r\n                    [(ngModel)]=\"row[column.header]\" />\r\n                  {{ option?.optionName }}\r\n                </label>\r\n              </div>\r\n\r\n              <!-- <ng-container *ngSwitchCase=\"'file-upload'\">\r\n                               \r\n\r\n                                  <div class=\"flex flex-col items-end justify-end relative\">\r\n                                    <div class=\"flex gap-2 flex-wrap\">\r\n                                      <div \r\n                                        class=\"relative\" \r\n                                        *ngFor=\"let image of uploadedImages?.[rowIndex]; let i = index\"\r\n                                      >\r\n                                        <img  \r\n                                          width=\"100\" \r\n                                          [src]=\"image?.result\"\r\n                                          alt=\"Uploaded Image\"\r\n                                          class=\"rounded shadow\"\r\n                                        />\r\n                                        <button \r\n                                          (click)=\"deleteFile(rowIndex, i)\" \r\n                                          class=\"absolute top-0 right-0 text-white rounded-md w-5 h-5 flex items-center justify-center shadow-lg hover:bg-red-600\"\r\n                                        >\r\n                                          ❌\r\n                                        </button>\r\n                                      </div>\r\n                                    </div>\r\n                                  \r\n                                    <input \r\n                                      [class]=\"column?.className\" \r\n                                      type=\"file\" \r\n                                      name=\"file\" \r\n                                      #uploadFile  \r\n                                      hidden \r\n                                      multiple\r\n                                      (change)=\"uploadImage($event, rowIndex)\" \r\n                                    />\r\n                                  \r\n                                    <button \r\n                                      (click)=\"uploadFile.click()\" \r\n                                      class=\"mt-2 bg-blue-500 text-white px-3 py-1 rounded hover:bg-blue-600\"\r\n                                    >\r\n                                      Upload\r\n                                    </button>\r\n                                  </div>\r\n                                  \r\n                                  \r\n                            </ng-container> -->\r\n\r\n              <ng-container *ngSwitchCase=\"'file-upload'\">\r\n                <div class=\"flex items-center justify-end relative gap-4 flex-wrap\">\r\n                  <div class=\"flex gap-2 flex-wrap\">\r\n                    <div class=\"relative\" *ngFor=\"let image of uploadedImages?.[rowIndex]; let i = index\">\r\n                      <img width=\"100\" height=\"80\" [src]=\"image?.result\" alt=\"Uploaded Image\"\r\n                        class=\"rounded shadow orientation\" />\r\n                      <a (click)=\"deleteFile(rowIndex, i)\"\r\n                        class=\"absolute top-0 right-0 text-white rounded-md w-5 h-5 flex items-center justify-center cursor-pointer\">\r\n                        <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"18\" height=\"18\" viewBox=\"0 0 18 18\" fill=\"none\">\r\n                          <g clip-path=\"url(#clip0_6837_29683)\">\r\n                            <rect width=\"18\" height=\"18\" rx=\"9\" fill=\"#F3A041\" />\r\n                            <mask id=\"mask0_6837_29683\" style=\"mask-type:alpha\" maskUnits=\"userSpaceOnUse\" x=\"4\" y=\"4\"\r\n                              width=\"24\" height=\"24\">\r\n                              <rect x=\"4\" y=\"4\" width=\"24\" height=\"24\" fill=\"#D9D9D9\" />\r\n                            </mask>\r\n                            <g mask=\"url(#mask0_6837_29683)\">\r\n                              <path\r\n                                d=\"M8.2045 8.99815L5.81802 6.61167L6.61351 5.81617L9 8.20266L11.3865 5.81617L12.182 6.61167L9.7955 8.99815L12.182 11.3846L11.3865 12.1801L9 9.79365L6.61351 12.1801L5.81802 11.3846L8.2045 8.99815Z\"\r\n                                fill=\"white\" />\r\n                            </g>\r\n                          </g>\r\n                          <defs>\r\n                            <clipPath id=\"clip0_6837_29683\">\r\n                              <rect width=\"18\" height=\"18\" rx=\"9\" fill=\"white\" />\r\n                            </clipPath>\r\n                          </defs>\r\n                        </svg>\r\n                      </a>\r\n                    </div>\r\n                  </div>\r\n\r\n                  <input [class]=\"column?.className\" type=\"file\" name=\"file\" #uploadFile hidden multiple\r\n                    (change)=\"uploadImage($event, rowIndex)\" />\r\n                  <div class=\"flex flex-col justify-center items-center cursor-pointer\" (click)=\"uploadFile.click()\">\r\n                    <div>\r\n                      <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"29\" height=\"28\" viewBox=\"0 0 29 28\" fill=\"none\">\r\n                        <path fill-rule=\"evenodd\" clip-rule=\"evenodd\"\r\n                          d=\"M14.001 3.00195C11.5322 3.00195 9.16722 3.86956 7.23641 5.38414L7.23598 4.59695C7.23598 4.52473 7.22175 4.45321 7.19411 4.38648C7.16647 4.31975 7.12596 4.25912 7.07489 4.20804C7.02381 4.15697 6.96318 4.11646 6.89645 4.08882C6.82972 4.06118 6.7582 4.04695 6.68598 4.04695C6.61375 4.04695 6.54223 4.06118 6.4755 4.08882C6.40877 4.11646 6.34814 4.15697 6.29707 4.20804C6.24599 4.25912 6.20548 4.31975 6.17784 4.38648C6.1502 4.45321 6.13598 4.52473 6.13598 4.59695L6.13642 6.68652C6.13643 6.83239 6.19438 6.97228 6.29752 7.07542C6.40067 7.17856 6.54055 7.23651 6.68642 7.23652H8.77598C8.8482 7.23652 8.91972 7.2223 8.98645 7.19466C9.05318 7.16702 9.11381 7.12651 9.16489 7.07543C9.21596 7.02436 9.25647 6.96373 9.28411 6.897C9.31175 6.83027 9.32598 6.75875 9.32598 6.68652C9.32598 6.6143 9.31175 6.54278 9.28411 6.47605C9.25647 6.40932 9.21596 6.34869 9.16489 6.29761C9.11381 6.24654 9.05318 6.20603 8.98645 6.17839C8.91972 6.15075 8.8482 6.13652 8.77598 6.13652H8.0584C9.7702 4.84387 11.8399 4.10195 14.001 4.10195C19.4751 4.10195 23.901 8.52782 23.901 14.002C23.901 19.4761 19.4751 23.902 14.001 23.902C8.52684 23.902 4.10098 19.4761 4.10098 14.002C4.10098 12.6381 4.38263 11.2888 4.92855 10.0389C4.98691 9.90532 4.98982 9.75399 4.93665 9.61822C4.88347 9.48246 4.77855 9.37336 4.64496 9.31492C4.57877 9.28596 4.50753 9.27032 4.4353 9.2689C4.36306 9.26747 4.29126 9.2803 4.22398 9.30663C4.15671 9.33297 4.09528 9.3723 4.04321 9.42238C3.99114 9.47247 3.94944 9.53232 3.92051 9.59852C3.31393 10.9872 3.00098 12.4866 3.00098 14.002C3.00098 20.0706 7.93236 25.002 14.001 25.002C20.0696 25.002 25.001 20.0706 25.001 14.002C25.001 7.93334 20.0696 3.00195 14.001 3.00195Z\"\r\n                          fill=\"#F3A041\" />\r\n                        <path fill-rule=\"evenodd\" clip-rule=\"evenodd\"\r\n                          d=\"M13.9988 6.13965C9.6616 6.13965 6.13379 9.66746 6.13379 14.0046C6.13379 18.3418 9.6616 21.8696 13.9988 21.8696C18.336 21.8696 21.8638 18.3418 21.8638 14.0046C21.8638 9.66746 18.336 6.13965 13.9988 6.13965ZM13.9988 8.22965C14.1447 8.22965 14.2846 8.28759 14.3877 8.39074C14.4908 8.49388 14.5488 8.63378 14.5488 8.77965V13.7769L17.5227 16.7508C17.6258 16.8539 17.6837 16.9938 17.6837 17.1396C17.6837 17.2855 17.6258 17.4254 17.5227 17.5285C17.4195 17.6316 17.2796 17.6896 17.1338 17.6896C16.9879 17.6896 16.8481 17.6316 16.7449 17.5285L13.6099 14.3935C13.5068 14.2904 13.4488 14.1505 13.4488 14.0046V8.77965C13.4488 8.63378 13.5067 8.49388 13.6099 8.39074C13.713 8.28759 13.8529 8.22965 13.9988 8.22965Z\"\r\n                          fill=\"#F3A041\" />\r\n                        <rect width=\"28.56\" height=\"28\" rx=\"1.51479\" fill=\"#F3A041\" />\r\n                        <path\r\n                          d=\"M15.068 22.7391V17.6708H18.4968L14.2108 12.6025L9.9248 17.6708H13.3536V22.7391H9.06759V22.6969C8.92358 22.7053 8.78643 22.7391 8.63899 22.7391C6.93391 22.7391 5.29866 22.0717 4.09298 20.8835C2.8873 19.6954 2.20996 18.084 2.20996 16.4037C2.20996 13.1532 4.70443 10.5042 7.90523 10.141C8.18585 8.6953 8.96892 7.39118 10.1197 6.45292C11.2706 5.51465 12.7172 5.00089 14.2108 5C15.7047 5.00082 17.1515 5.51452 18.3026 6.45277C19.4537 7.39101 20.2371 8.69516 20.5181 10.141C23.7189 10.5042 26.21 13.1532 26.21 16.4037C26.21 18.084 25.5326 19.6954 24.3269 20.8835C23.1213 22.0717 21.486 22.7391 19.7809 22.7391C19.6369 22.7391 19.4981 22.7053 19.3523 22.6969V22.7391H15.068Z\"\r\n                          fill=\"white\" />\r\n                      </svg>\r\n                    </div>\r\n                    <a type=\"button\" (click)=\"uploadFile.click()\" class=\"text-base cursor-pointer\">\r\n                      {{ 'Upload' }}\r\n                    </a>\r\n                  </div>\r\n                </div>\r\n              </ng-container>\r\n              <ng-container *ngSwitchCase=\"'textarea'\">\r\n                <textarea [class]=\"column?.className\" name=\"\" id=\"\" cols=\"30\" rows=\"2\"\r\n                  [placeholder]=\"column?.placeholder\"></textarea>\r\n              </ng-container>\r\n            </ng-container>\r\n          </td>\r\n        </tr>\r\n      </tbody>\r\n    </table>\r\n    <!-- Your main template -->\r\n<p-dialog header=\"Confirmation\"\r\n[(visible)]=\"displayConfirmationDialog\"\r\nmodal=\"true\"\r\n[closable]=\"false\"\r\n[responsive]=\"true\"\r\nstyleClass=\"confirmation-dialog\"\r\n[style]=\"{width: '400px'}\">\r\n\r\n<div class=\"p-d-flex p-ai-center\">\r\n<i class=\"pi pi-exclamation-triangle p-mr-2\" style=\"font-size: 2rem; color: #f39c12\"></i>\r\n<span>Are you sure you want to perform \"<strong>{{ selectedAction?.actionName }}</strong>\"?</span>\r\n</div>\r\n\r\n<ng-template pTemplate=\"footer\">\r\n<button pButton label=\"Yes\" icon=\"pi pi-check\" (click)=\"confirmAction()\" class=\"p-button-text\" autofocus></button>\r\n<button pButton label=\"No\" icon=\"pi pi-times\" (click)=\"cancelAction()\" class=\"p-button-text\"></button>\r\n</ng-template>\r\n</p-dialog>\r\n\r\n  </div>\r\n</fx-settings-panel>"]}
|