@rangertechnologies/ngnxt 2.1.126 → 2.1.128
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/environments/version.mjs +2 -2
- package/esm2022/lib/components/cards/group-card/group-card.component.mjs +36 -0
- package/esm2022/lib/components/cards/group-info/group-info.component.mjs +102 -0
- package/esm2022/lib/components/cards/image-card/image-card.component.mjs +83 -0
- package/esm2022/lib/components/cards/info-card/info-card.component.mjs +109 -0
- package/esm2022/lib/components/custom-calendar/custom-calendar.component.mjs +2 -2
- package/esm2022/lib/components/custom-dropdown/custom-dropdown.component.mjs +3 -3
- package/esm2022/lib/components/custom-input/custom-input.component.mjs +7 -2
- package/esm2022/lib/components/custom-table/custom-table.component.mjs +2 -2
- package/esm2022/lib/components/datatable/datatable.component.mjs +55 -39
- package/esm2022/lib/components/file-upload/file-upload.component.mjs +2 -2
- package/esm2022/lib/components/table-appendix/table-appendix.component.mjs +2 -2
- package/esm2022/lib/nxt-app.module.mjs +27 -5
- package/esm2022/lib/pages/builder/element/element.component.mjs +64 -14
- package/esm2022/lib/pages/builder/properties/properties.component.mjs +160 -94
- package/esm2022/lib/pages/questionbook/questionbook.component.mjs +4 -3
- package/esm2022/lib/pages/questionnaire/questionnaire.component.mjs +3 -3
- package/esm2022/lib/pipe/get-value.pipe.mjs +3 -5
- package/esm2022/lib/services/form-builder.service.mjs +14 -7
- package/esm2022/public-api.mjs +6 -1
- package/fesm2022/rangertechnologies-ngnxt.mjs +641 -170
- package/fesm2022/rangertechnologies-ngnxt.mjs.map +1 -1
- package/lib/components/cards/group-card/group-card.component.d.ts +13 -0
- package/lib/components/cards/group-info/group-info.component.d.ts +47 -0
- package/lib/components/cards/image-card/image-card.component.d.ts +34 -0
- package/lib/components/cards/info-card/info-card.component.d.ts +39 -0
- package/lib/components/datatable/datatable.component.d.ts +3 -1
- package/lib/nxt-app.module.d.ts +16 -12
- package/lib/pages/builder/element/element.component.d.ts +2 -0
- package/lib/pages/builder/properties/properties.component.d.ts +11 -0
- package/lib/services/form-builder.service.d.ts +1 -1
- package/package.json +1 -1
- package/public-api.d.ts +4 -0
- package/rangertechnologies-ngnxt-2.1.128.tgz +0 -0
- package/rangertechnologies-ngnxt-2.1.126.tgz +0 -0
|
@@ -47,7 +47,7 @@ export class CustomTableComponent {
|
|
|
47
47
|
}
|
|
48
48
|
ngOnInit() {
|
|
49
49
|
// SKS20MAR25 check if question fieldsmeta is string
|
|
50
|
-
const parsedMeta = typeof this.question['fieldsMeta'] === 'object' ? this.question['fieldsMeta'] || [
|
|
50
|
+
const parsedMeta = typeof this.question['fieldsMeta'] === 'object' ? this.question['fieldsMeta'] || [] : JSON.parse(this.question['fieldsMeta']);
|
|
51
51
|
if (!parsedMeta || !Array.isArray(parsedMeta) || parsedMeta.length === 0) {
|
|
52
52
|
console.warn('No valid metadata provided');
|
|
53
53
|
return;
|
|
@@ -249,4 +249,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
249
249
|
}], valueChange: [{
|
|
250
250
|
type: Output
|
|
251
251
|
}] } });
|
|
252
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"custom-table.component.js","sourceRoot":"","sources":["../../../../../../projects/nxt-app/src/lib/components/custom-table/custom-table.component.ts","../../../../../../projects/nxt-app/src/lib/components/custom-table/custom-table.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\n// HA 19DEC23 imported translation service\nimport { I18nService } from '../../i18n.service';\nimport { Question } from '../../wrapper';\nimport { DataService } from '../../services/data.service';\nimport { APIMeta } from '../../interfaces/apimeta';\nimport { Subscription } from 'rxjs';\nimport { ChangeService } from '../../services/change.service';\n\ndeclare var $: any;\n\n@Component({\n  selector: 'app-custom-table',\n  templateUrl: './custom-table.component.html',\n  styleUrls: ['./custom-table.component.css']\n})\n\nexport class CustomTableComponent implements OnInit {\n  @Input() question: Question\n  @Input() apiMeta: string;\n  @Output() valueChange: EventEmitter<any> = new EventEmitter<any>();\n  tableHeader = [];\n  tableData = [];\n  filteredData = []; // New property for filtered data\n  //RS 03FEB2025\n  // Default UI configurations to control row addition, pagination, actions column visibility, search functionality, and the number of items per page.\n  showAddRow: boolean = true;\n  showPagination: boolean = true;\n  showActions: boolean = true;\n  showSearch: boolean = true;\n  itemsPerPage: number = 5;\n  addRowColSpan: number;\n  tableSize: number; // HA 28DEC23 table size declaration\n  objName: any;\n  filterLogic: any;\n  fieldMeta: string;\n  firStr: string;\n  searchBox: boolean = false;\n  public options: string[];\n  isDisabled: boolean = true;\n  subscription: Subscription;\n\n\n  //RS 03FEB2025\n  // New properties for search and pagination\n  searchTerm: string = '';\n  currentPage: number = 1;\n  totalItems: number = 0;\n  pages: number[] = [];\n  Math = Math;\n  constructor(private changeService: ChangeService, public i18nService: I18nService, private dataService: DataService) { }\n  ngOnInit(): void {\n    // SKS20MAR25 check if question fieldsmeta is string\n      const parsedMeta =  typeof this.question['fieldsMeta'] === 'object'  ?  this.question['fieldsMeta'] || [{}] : JSON.parse( this.question['fieldsMeta']) ;\n      if (!parsedMeta || !Array.isArray(parsedMeta) || parsedMeta.length === 0) {\n        console.warn('No valid metadata provided');\n        return;\n      }\n\n      //RS 03FEB2025\n      // Extracts table configuration settings dynamically from metadata and applies them, ensuring flexibility in UI customization\n      if (parsedMeta[0]?.tableConfig) {\n        const config = parsedMeta[0].tableConfig;\n        this.showAddRow = config.showAddRow !== false;\n        this.showPagination = config.showPagination !== false;\n        this.showActions = config.showActions !== false;\n        this.showSearch = config.showSearch !== false;\n        this.itemsPerPage = config.itemsPerPage || 5;\n\n        // Remove the config object from headers\n        this.tableHeader = parsedMeta.slice(1);\n      } else {\n        // If no config object found, use all objects as headers\n        this.tableHeader = parsedMeta;\n      }\n\n      this.tableSize = 10 / this.tableHeader.length;\n      // 12JUN24 - default table value\n      if (this.question?.input) {\n        this.tableData = this.question?.input;\n        this.filteredData = [...this.tableData];\n        this.updatePagination();\n      }\n      if (this.apiMeta !== undefined) {\n        this.options = [];\n        // let apiObj: APIMeta = JSON.parse(this.apiMeta);\n            // MSM-27MAR25 Ensure ques.subText is always an object by parsing it if it's a string\n        let apiObj: APIMeta = typeof this.apiMeta === 'object' ? this.apiMeta : JSON.parse(this.apiMeta);\n\n        if (apiObj && apiObj.endpoint) {\n          this.dataService.apiResponse(apiObj.endpoint)?.subscribe((apiResponse) => {\n            let responses;\n            if (apiObj.variable) {\n              // VD 22May24 - handling multiple child objects\n              responses = this.dataService.getValue(apiResponse, apiObj.variable);\n              let results = [];\n              // HA 19JAN24 To avoid undefined error in console\n              for (let i = 0; i < responses?.length; i++) {\n                var resp = responses[i];\n                results.push(resp);\n              }\n              this.options = results;\n            } else {  // VD 19JAN24 - if response has value(which is array) only\n              responses = apiResponse;\n              this.options = responses;\n            }\n            this.options = this.options.map((obj: any) => ({ ...obj, edit: false }));\n            // Reference https://www.npmjs.com/package/@ng-select/ng-select\n            this.tableData = this.options;\n            console.log('tableData', this.tableData);\n\n          });\n        }\n\n        // VD NOV23 - handle the dependent update for dropdown\n        let sourceId = apiObj?.sourceQuestionId;\n        let field = apiObj?.field;        // VD 13MAY24 - dynamic field changes\n        if (sourceId) {\n          // // VD 10May24 Subscribe for the changes\n          this.subscription = this.changeService.changeAnnounced$.subscribe(\n            (changeValue) => {\n              if (changeValue != undefined) {\n                if (changeValue.valueObj != undefined && changeValue.fromQuestionId == apiObj.sourceQuestionId) {\n                  console.log('changes happen');\n                  this.options = this.options.map((obj: any) => ({ ...obj, edit: false }));\n                  let item = changeValue.valueObj;\n                  let validItem = true;\n                  // VD 13MAY24 - bind dynamic field\n                  if (this.tableData.length > 0) {\n                    this.tableData.forEach(element => {\n                      // VD 26Jun24 - to handle multiple objects\n                      const objElementValue = this.dataService.getValue(element, field);\n                      const objItemValue = this.dataService.getValue(item, field)\n                      if (objElementValue == objItemValue) {\n                        validItem = false;\n                      }\n                    });\n                  }\n                  //RS 14FEB2025\n                  //Update Pagination before emit\n                  if (validItem) {\n                    if (this.tableData.length > 0) {\n                      this.tableData = [...this.tableData, item];\n                    } else {\n                      this.tableData.push(item);\n                    }\n                    // Update filteredData and pagination\n                    this.filteredData = [...this.tableData];\n                    this.updatePagination();\n                    this.emitTableDataValue(this.tableData);\n                  }\n                }\n                this.changeService.confirmChange(apiObj?.sourceQuestionId);\n              }\n            }\n          );\n        }\n      }\n      this.updatePagination();\n  }\n  //RS 03FEB2025\n  // → Filters table data based on user input and updates pagination accordingly.\n  search(): void {\n    if (!this.searchTerm.trim()) {\n      this.filteredData = [...this.tableData];\n    } else {\n      const searchTermLower = this.searchTerm.toLowerCase();\n      this.filteredData = this.tableData.filter(item => {\n        return this.tableHeader.some(header => {\n          const value = this.dataService.getValue(item, header.apiName);\n          return value && value.toString().toLowerCase().includes(searchTermLower);\n        });\n      });\n    }\n    this.currentPage = 1;\n    this.updatePagination();\n  }\n  //RS 03FEB2025\n  // Calculates total pages, updates the page list, and ensures the current page is within valid bounds.\n  updatePagination(): void {\n    this.totalItems = this.filteredData.length;\n    const totalPages = Math.ceil(this.totalItems / this.itemsPerPage);\n    this.pages = Array.from({ length: totalPages }, (_, i) => i + 1);\n    if (this.currentPage > totalPages) {\n      this.currentPage = totalPages || 1;\n    }\n  }\n  //RS 03FEB2025\n  //Returns a paginated subset of filteredData based on the current page and items per page\n  get paginatedData(): any[] {\n    const startIndex = (this.currentPage - 1) * this.itemsPerPage;\n    return this.filteredData.slice(startIndex, startIndex + this.itemsPerPage);\n  }\n  //RS 03FEB2025\n  //Updates currentPage when the user selects a different page\n  setPage(page: number): void {\n    if (page >= 1 && page <= this.pages.length) {\n      this.currentPage = page;\n    }\n  }\n\n  addRow(): void {\n    let newItem = {};\n    this.tableHeader.forEach(item => {\n      if (item.apiName) {\n        newItem[item.apiName] = \"\";\n      }\n    });\n    this.tableData.push(newItem);\n    this.filteredData = [...this.tableData];\n    this.updatePagination();\n\n    this.emitTableDataValue(this.tableData);\n  }\n\n  updateRadio(item: any, value: string): void {\n    item.value = value;\n    this.emitTableDataValue(this.tableData);\n  }\n  // Modified update methods to track changes\n  updateLabel(rowIndex: number, label: string, value: any): void {\n    this.tableData[rowIndex][label] = value;\n    this.emitTableDataValue(this.tableData);\n  }\n  //RS 03FEB2025\n  deleteRow(rowIndex: number) {\n    // this.tableData.splice(rowIndex, 1);\n    const actualIndex = (this.currentPage - 1) * this.itemsPerPage + rowIndex;\n    this.tableData.splice(actualIndex, 1);\n    this.filteredData = [...this.tableData];\n    this.updatePagination();\n\n    this.emitTableDataValue(this.tableData);\n  }\n\n  editRow(rowIndex: number) {\n    var a = 0;\n    this.tableData.forEach(element => {\n      if (a === rowIndex) {\n        element.edit = true;\n      }\n      a++;\n    });\n  }\n\n  updateNumber(item: any, label: string, value: string) {\n    item.value[label] = value;\n    this.emitTableDataValue(this.tableData);\n  }\n\n\n  emitTableDataValue(updatedTableData: any[]): void {\n    this.valueChange.emit(updatedTableData);\n  }\n}","<!-- RS 03FEB2025 -->\n<!-- Search Bar -->\n<!-- Search, Revert & Save in Same Line -->\n<div class=\"d-flex align-items-center justify-content-between mb-3\">\n  <!-- Search Bar -->\n  <div class=\"search-container me-auto\">\n    <div class=\"input-group\">\n      <input \n        type=\"text\" \n        class=\"form-control search-input\"\n        [(ngModel)]=\"searchTerm\"\n        (input)=\"search()\"\n        placeholder=\"Search...\"\n      >\n      <div class=\"search-icon\">\n    <!-- RS 03FEB2025 -->\n    <!-- Search icon for user input -->\n        <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\">\n          <circle cx=\"11\" cy=\"11\" r=\"8\"></circle>\n          <line x1=\"21\" y1=\"21\" x2=\"16.65\" y2=\"16.65\"></line>\n        </svg>\n      </div>\n    </div>\n  </div>\n</div>\n<!-- Table Container -->\n<div class=\"table-container\">\n  <table class=\"table table-striped table-bordered\">\n    <thead>\n        <!-- HA 28DEC23 changed table header values and changed table size logic to evenly visible -->\n    <!-- <th><input type=\"checkbox\" (change)=\"selectAll($event.target.checked)\"></th> -->\n      <tr>\n        <th *ngFor=\"let header of tableHeader\" [style.width]=\"header.width || 'auto'\">\n          {{ header.label }}\n        </th>\n        <!-- Actions column (only if showActions is true) --><!-- RS 03FEB2025 -->\n        <th *ngIf=\"showActions\" style=\"width: 140px\" class=\"actions-columns\">Actions</th>\n      </tr>\n    </thead>\n    <tbody>\n      <tr *ngFor=\"let item of paginatedData; let i = index\">\n        <td *ngFor=\"let header of tableHeader\">\n          <!-- Image with text input -->\n          <ng-container *ngIf=\"header.fldType === 'imagetext'\">\n            <div class=\"d-flex align-items-center\">\n              <img [src]=\"item.imageSrc\" [alt]=\"item.altText\" style=\"width: 35px; height: 32px; margin-right: 5px;\">\n              <input type=\"text\" \n                [(ngModel)]=\"item[header.fieldName]\" \n                (ngModelChange)=\"updateLabel(i, header.fieldName, item[header.fieldName])\" \n                class=\"she-line-input table-input\">\n            </div>\n          </ng-container>\n\n          <!-- Image only -->\n          <ng-container *ngIf=\"header.fldType === 'image'\">\n            <img [src]=\"item[header.fieldName]\" [alt]=\"item.altText\" style=\"width: 35px; height: 32px;\">\n          </ng-container>\n        <!--VD 23Aug24 handle readOnly  -->\n          <!-- Text input -->\n          <ng-container *ngIf=\"header.fldType === 'Text'\">\n            <input type=\"text\" \n              [readonly]=\"header.readOnly\" \n              [disabled]=\"!item.edit\" \n              [ngClass]=\"{'editInput': item.edit && !header.readOnly}\"\n              [ngModel]=\"'' | getValue: item : header.apiName\" \n              (ngModelChange)=\"updateLabel(i, header.apiName,$event)\" \n              class=\"she-line-input table-input\">\n          </ng-container>\n        <!--VD 23Aug24 handle Number Type -->\n        <!-- Number input -->\n        <!-- VD 26Jun24 - pipe change to handle multiple objects-->\n          <ng-container *ngIf=\"header.fldType === 'Number'\">\n            <input type=\"number\" \n              [readonly]=\"header.readOnly\" \n              [disabled]=\"!item.edit\" \n              [ngClass]=\"{'editInput': item.edit && !header.readOnly}\"\n              [ngModel]=\"'' | getValue: item : header.apiName\" \n              (ngModelChange)=\"updateLabel(i, header.apiName,$event)\" \n              class=\"she-line-input table-input\">\n          </ng-container>\n\n          <!-- Radio input -->\n          <ng-container *ngIf=\"header.fldType === 'radio'\">\n            <input type=\"radio\" \n              [name]=\"item.name\" \n              [checked]=\"item.value == header.fieldName\"  \n              (click)=\"updateRadio(item, header.fieldName)\">\n          </ng-container>\n        </td>\n        <!-- Actions column --><!-- RS 03FEB2025 -->\n        <td *ngIf=\"showActions\" class=\"actions-column\">\n          <div class=\"d-flex justify-content-around\">\n            <button class=\"btn btn-link p-0\" (click)=\"editRow(i)\">\n              <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"#03A9F4\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\">\n                <path d=\"M12 20h9\" />\n                <path d=\"M16.5 3.5a2.121 2.121 0 0 1 3 3L7 19l-4 1 1-4Z\" />\n                <path d=\"m15 5 3 3\" />\n              </svg>\n                                         Edit\n            </button>\n            <button class=\"btn btn-link p-0\" (click)=\"deleteRow(i)\">\n              <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"#F44336\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\">\n                <path d=\"M3 6h18\" />\n                <path d=\"M8 6V4a2 2 0 0 1 2-2h4a2 2 0 0 1 2 2v2\" />\n                <path d=\"m10 11 1 6\" />\n                <path d=\"m14 11-1 6\" />\n                <path d=\"M4 6l1 14a2 2 0 0 0 2 2h10a2 2 0 0 0 2-2l1-14\" />\n              </svg>\n              \n                            Delete\n            </button>\n          </div>\n        </td>\n      </tr>\n    </tbody>\n  </table>\n</div>\n\n<!-- Pagination --><!-- RS 03FEB2025 -->\n<div *ngIf=\"showPagination\" class=\"pagination-container\">\n  <div class=\"d-flex justify-content-end align-items-center\">\n    <div class=\"items-per-page\">\n      <span>Items per page:</span>\n      <select [(ngModel)]=\"itemsPerPage\" (change)=\"updatePagination()\" class=\"form-select form-select-sm\">\n        <option value=\"5\">5</option>\n        <option value=\"10\">10</option>\n        <option value=\"20\">20</option>\n        <option value=\"50\">50</option>\n      </select>\n    </div>\n    <div class=\"page-info ms-3 me-3\">\n      {{((currentPage - 1) * itemsPerPage + 1)}} - {{Math.min(currentPage * itemsPerPage, totalItems)}} of {{totalItems}}\n    </div>\n    <nav aria-label=\"Table pagination\">\n      <!-- First page --><!-- RS 03FEB2025 -->\n      <ul class=\"pagination mb-0\">\n        <li class=\"page-item\" [class.disabled]=\"currentPage === 1\">\n          <a class=\"page-link\" (click)=\"setPage(1)\">«</a>\n        </li>\n        <li class=\"page-item\" [class.disabled]=\"currentPage === 1\">\n          <a class=\"page-link\" (click)=\"setPage(currentPage - 1)\">‹</a>\n        </li>\n        <!-- Dynamic pagination --><!-- RS 03FEB2025 -->\n        <li class=\"page-item\" *ngFor=\"let page of pages\" [class.active]=\"page === currentPage\">\n          <a class=\"page-link\" (click)=\"setPage(page)\">{{page}}</a>\n        </li>\n        <li class=\"page-item\" [class.disabled]=\"currentPage === pages.length\">\n          <a class=\"page-link\" (click)=\"setPage(currentPage + 1)\">›</a>\n        </li>\n        <!-- Last page -->\n        <li class=\"page-item\" [class.disabled]=\"currentPage === pages.length\">\n          <a class=\"page-link\" (click)=\"setPage(pages.length)\">»</a>\n        </li>\n      </ul>\n    </nav>\n  </div>\n</div>\n<!-- RS 03FEB2025 -->\n<!-- Add Row Button -->\n<div *ngIf=\"showAddRow\"  (click)=\"addRow()\" class=\"addRowClass\">\n  <div class=\"circle-button\">+</div>\n</div>\n"]}
|
|
252
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"custom-table.component.js","sourceRoot":"","sources":["../../../../../../projects/nxt-app/src/lib/components/custom-table/custom-table.component.ts","../../../../../../projects/nxt-app/src/lib/components/custom-table/custom-table.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\n// HA 19DEC23 imported translation service\nimport { I18nService } from '../../i18n.service';\nimport { Question } from '../../wrapper';\nimport { DataService } from '../../services/data.service';\nimport { APIMeta } from '../../interfaces/apimeta';\nimport { Subscription } from 'rxjs';\nimport { ChangeService } from '../../services/change.service';\n\ndeclare var $: any;\n\n@Component({\n  selector: 'app-custom-table',\n  templateUrl: './custom-table.component.html',\n  styleUrls: ['./custom-table.component.css']\n})\n\nexport class CustomTableComponent implements OnInit {\n  @Input() question: Question\n  @Input() apiMeta: string;\n  @Output() valueChange: EventEmitter<any> = new EventEmitter<any>();\n  tableHeader = [];\n  tableData = [];\n  filteredData = []; // New property for filtered data\n  //RS 03FEB2025\n  // Default UI configurations to control row addition, pagination, actions column visibility, search functionality, and the number of items per page.\n  showAddRow: boolean = true;\n  showPagination: boolean = true;\n  showActions: boolean = true;\n  showSearch: boolean = true;\n  itemsPerPage: number = 5;\n  addRowColSpan: number;\n  tableSize: number; // HA 28DEC23 table size declaration\n  objName: any;\n  filterLogic: any;\n  fieldMeta: string;\n  firStr: string;\n  searchBox: boolean = false;\n  public options: string[];\n  isDisabled: boolean = true;\n  subscription: Subscription;\n\n\n  //RS 03FEB2025\n  // New properties for search and pagination\n  searchTerm: string = '';\n  currentPage: number = 1;\n  totalItems: number = 0;\n  pages: number[] = [];\n  Math = Math;\n  constructor(private changeService: ChangeService, public i18nService: I18nService, private dataService: DataService) { }\n  ngOnInit(): void {\n    // SKS20MAR25 check if question fieldsmeta is string\n      const parsedMeta =  typeof this.question['fieldsMeta'] === 'object'  ?  this.question['fieldsMeta'] || [] : JSON.parse( this.question['fieldsMeta']) ;\n      if (!parsedMeta || !Array.isArray(parsedMeta) || parsedMeta.length === 0) {\n        console.warn('No valid metadata provided');\n        return;\n      }\n\n      //RS 03FEB2025\n      // Extracts table configuration settings dynamically from metadata and applies them, ensuring flexibility in UI customization\n      if (parsedMeta[0]?.tableConfig) {\n        const config = parsedMeta[0].tableConfig;\n        this.showAddRow = config.showAddRow !== false;\n        this.showPagination = config.showPagination !== false;\n        this.showActions = config.showActions !== false;\n        this.showSearch = config.showSearch !== false;\n        this.itemsPerPage = config.itemsPerPage || 5;\n\n        // Remove the config object from headers\n        this.tableHeader = parsedMeta.slice(1);\n      } else {\n        // If no config object found, use all objects as headers\n        this.tableHeader = parsedMeta;\n      }\n\n      this.tableSize = 10 / this.tableHeader.length;\n      // 12JUN24 - default table value\n      if (this.question?.input) {\n        this.tableData = this.question?.input;\n        this.filteredData = [...this.tableData];\n        this.updatePagination();\n      }\n      if (this.apiMeta !== undefined) {\n        this.options = [];\n        // let apiObj: APIMeta = JSON.parse(this.apiMeta);\n            // MSM-27MAR25 Ensure ques.subText is always an object by parsing it if it's a string\n        let apiObj: APIMeta = typeof this.apiMeta === 'object' ? this.apiMeta : JSON.parse(this.apiMeta);\n\n        if (apiObj && apiObj.endpoint) {\n          this.dataService.apiResponse(apiObj.endpoint)?.subscribe((apiResponse) => {\n            let responses;\n            if (apiObj.variable) {\n              // VD 22May24 - handling multiple child objects\n              responses = this.dataService.getValue(apiResponse, apiObj.variable);\n              let results = [];\n              // HA 19JAN24 To avoid undefined error in console\n              for (let i = 0; i < responses?.length; i++) {\n                var resp = responses[i];\n                results.push(resp);\n              }\n              this.options = results;\n            } else {  // VD 19JAN24 - if response has value(which is array) only\n              responses = apiResponse;\n              this.options = responses;\n            }\n            this.options = this.options.map((obj: any) => ({ ...obj, edit: false }));\n            // Reference https://www.npmjs.com/package/@ng-select/ng-select\n            this.tableData = this.options;\n            console.log('tableData', this.tableData);\n\n          });\n        }\n\n        // VD NOV23 - handle the dependent update for dropdown\n        let sourceId = apiObj?.sourceQuestionId;\n        let field = apiObj?.field;        // VD 13MAY24 - dynamic field changes\n        if (sourceId) {\n          // // VD 10May24 Subscribe for the changes\n          this.subscription = this.changeService.changeAnnounced$.subscribe(\n            (changeValue) => {\n              if (changeValue != undefined) {\n                if (changeValue.valueObj != undefined && changeValue.fromQuestionId == apiObj.sourceQuestionId) {\n                  console.log('changes happen');\n                  this.options = this.options.map((obj: any) => ({ ...obj, edit: false }));\n                  let item = changeValue.valueObj;\n                  let validItem = true;\n                  // VD 13MAY24 - bind dynamic field\n                  if (this.tableData.length > 0) {\n                    this.tableData.forEach(element => {\n                      // VD 26Jun24 - to handle multiple objects\n                      const objElementValue = this.dataService.getValue(element, field);\n                      const objItemValue = this.dataService.getValue(item, field)\n                      if (objElementValue == objItemValue) {\n                        validItem = false;\n                      }\n                    });\n                  }\n                  //RS 14FEB2025\n                  //Update Pagination before emit\n                  if (validItem) {\n                    if (this.tableData.length > 0) {\n                      this.tableData = [...this.tableData, item];\n                    } else {\n                      this.tableData.push(item);\n                    }\n                    // Update filteredData and pagination\n                    this.filteredData = [...this.tableData];\n                    this.updatePagination();\n                    this.emitTableDataValue(this.tableData);\n                  }\n                }\n                this.changeService.confirmChange(apiObj?.sourceQuestionId);\n              }\n            }\n          );\n        }\n      }\n      this.updatePagination();\n  }\n  //RS 03FEB2025\n  // → Filters table data based on user input and updates pagination accordingly.\n  search(): void {\n    if (!this.searchTerm.trim()) {\n      this.filteredData = [...this.tableData];\n    } else {\n      const searchTermLower = this.searchTerm.toLowerCase();\n      this.filteredData = this.tableData.filter(item => {\n        return this.tableHeader.some(header => {\n          const value = this.dataService.getValue(item, header.apiName);\n          return value && value.toString().toLowerCase().includes(searchTermLower);\n        });\n      });\n    }\n    this.currentPage = 1;\n    this.updatePagination();\n  }\n  //RS 03FEB2025\n  // Calculates total pages, updates the page list, and ensures the current page is within valid bounds.\n  updatePagination(): void {\n    this.totalItems = this.filteredData.length;\n    const totalPages = Math.ceil(this.totalItems / this.itemsPerPage);\n    this.pages = Array.from({ length: totalPages }, (_, i) => i + 1);\n    if (this.currentPage > totalPages) {\n      this.currentPage = totalPages || 1;\n    }\n  }\n  //RS 03FEB2025\n  //Returns a paginated subset of filteredData based on the current page and items per page\n  get paginatedData(): any[] {\n    const startIndex = (this.currentPage - 1) * this.itemsPerPage;\n    return this.filteredData.slice(startIndex, startIndex + this.itemsPerPage);\n  }\n  //RS 03FEB2025\n  //Updates currentPage when the user selects a different page\n  setPage(page: number): void {\n    if (page >= 1 && page <= this.pages.length) {\n      this.currentPage = page;\n    }\n  }\n\n  addRow(): void {\n    let newItem = {};\n    this.tableHeader.forEach(item => {\n      if (item.apiName) {\n        newItem[item.apiName] = \"\";\n      }\n    });\n    this.tableData.push(newItem);\n    this.filteredData = [...this.tableData];\n    this.updatePagination();\n\n    this.emitTableDataValue(this.tableData);\n  }\n\n  updateRadio(item: any, value: string): void {\n    item.value = value;\n    this.emitTableDataValue(this.tableData);\n  }\n  // Modified update methods to track changes\n  updateLabel(rowIndex: number, label: string, value: any): void {\n    this.tableData[rowIndex][label] = value;\n    this.emitTableDataValue(this.tableData);\n  }\n  //RS 03FEB2025\n  deleteRow(rowIndex: number) {\n    // this.tableData.splice(rowIndex, 1);\n    const actualIndex = (this.currentPage - 1) * this.itemsPerPage + rowIndex;\n    this.tableData.splice(actualIndex, 1);\n    this.filteredData = [...this.tableData];\n    this.updatePagination();\n\n    this.emitTableDataValue(this.tableData);\n  }\n\n  editRow(rowIndex: number) {\n    var a = 0;\n    this.tableData.forEach(element => {\n      if (a === rowIndex) {\n        element.edit = true;\n      }\n      a++;\n    });\n  }\n\n  updateNumber(item: any, label: string, value: string) {\n    item.value[label] = value;\n    this.emitTableDataValue(this.tableData);\n  }\n\n\n  emitTableDataValue(updatedTableData: any[]): void {\n    this.valueChange.emit(updatedTableData);\n  }\n}","<!-- RS 03FEB2025 -->\n<!-- Search Bar -->\n<!-- Search, Revert & Save in Same Line -->\n<div class=\"d-flex align-items-center justify-content-between mb-3\">\n  <!-- Search Bar -->\n  <div class=\"search-container me-auto\">\n    <div class=\"input-group\">\n      <input \n        type=\"text\" \n        class=\"form-control search-input\"\n        [(ngModel)]=\"searchTerm\"\n        (input)=\"search()\"\n        placeholder=\"Search...\"\n      >\n      <div class=\"search-icon\">\n    <!-- RS 03FEB2025 -->\n    <!-- Search icon for user input -->\n        <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\">\n          <circle cx=\"11\" cy=\"11\" r=\"8\"></circle>\n          <line x1=\"21\" y1=\"21\" x2=\"16.65\" y2=\"16.65\"></line>\n        </svg>\n      </div>\n    </div>\n  </div>\n</div>\n<!-- Table Container -->\n<div class=\"table-container\">\n  <table class=\"table table-striped table-bordered\">\n    <thead>\n        <!-- HA 28DEC23 changed table header values and changed table size logic to evenly visible -->\n    <!-- <th><input type=\"checkbox\" (change)=\"selectAll($event.target.checked)\"></th> -->\n      <tr>\n        <th *ngFor=\"let header of tableHeader\" [style.width]=\"header.width || 'auto'\">\n          {{ header.label }}\n        </th>\n        <!-- Actions column (only if showActions is true) --><!-- RS 03FEB2025 -->\n        <th *ngIf=\"showActions\" style=\"width: 140px\" class=\"actions-columns\">Actions</th>\n      </tr>\n    </thead>\n    <tbody>\n      <tr *ngFor=\"let item of paginatedData; let i = index\">\n        <td *ngFor=\"let header of tableHeader\">\n          <!-- Image with text input -->\n          <ng-container *ngIf=\"header.fldType === 'imagetext'\">\n            <div class=\"d-flex align-items-center\">\n              <img [src]=\"item.imageSrc\" [alt]=\"item.altText\" style=\"width: 35px; height: 32px; margin-right: 5px;\">\n              <input type=\"text\" \n                [(ngModel)]=\"item[header.fieldName]\" \n                (ngModelChange)=\"updateLabel(i, header.fieldName, item[header.fieldName])\" \n                class=\"she-line-input table-input\">\n            </div>\n          </ng-container>\n\n          <!-- Image only -->\n          <ng-container *ngIf=\"header.fldType === 'image'\">\n            <img [src]=\"item[header.fieldName]\" [alt]=\"item.altText\" style=\"width: 35px; height: 32px;\">\n          </ng-container>\n        <!--VD 23Aug24 handle readOnly  -->\n          <!-- Text input -->\n          <ng-container *ngIf=\"header.fldType === 'Text'\">\n            <input type=\"text\" \n              [readonly]=\"header.readOnly\" \n              [disabled]=\"!item.edit\" \n              [ngClass]=\"{'editInput': item.edit && !header.readOnly}\"\n              [ngModel]=\"'' | getValue: item : header.apiName\" \n              (ngModelChange)=\"updateLabel(i, header.apiName,$event)\" \n              class=\"she-line-input table-input\">\n          </ng-container>\n        <!--VD 23Aug24 handle Number Type -->\n        <!-- Number input -->\n        <!-- VD 26Jun24 - pipe change to handle multiple objects-->\n          <ng-container *ngIf=\"header.fldType === 'Number'\">\n            <input type=\"number\" \n              [readonly]=\"header.readOnly\" \n              [disabled]=\"!item.edit\" \n              [ngClass]=\"{'editInput': item.edit && !header.readOnly}\"\n              [ngModel]=\"'' | getValue: item : header.apiName\" \n              (ngModelChange)=\"updateLabel(i, header.apiName,$event)\" \n              class=\"she-line-input table-input\">\n          </ng-container>\n\n          <!-- Radio input -->\n          <ng-container *ngIf=\"header.fldType === 'radio'\">\n            <input type=\"radio\" \n              [name]=\"item.name\" \n              [checked]=\"item.value == header.fieldName\"  \n              (click)=\"updateRadio(item, header.fieldName)\">\n          </ng-container>\n        </td>\n        <!-- Actions column --><!-- RS 03FEB2025 -->\n        <td *ngIf=\"showActions\" class=\"actions-column\">\n          <div class=\"d-flex justify-content-around\">\n            <button class=\"btn btn-link p-0\" (click)=\"editRow(i)\">\n              <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"#03A9F4\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\">\n                <path d=\"M12 20h9\" />\n                <path d=\"M16.5 3.5a2.121 2.121 0 0 1 3 3L7 19l-4 1 1-4Z\" />\n                <path d=\"m15 5 3 3\" />\n              </svg>\n                                         Edit\n            </button>\n            <button class=\"btn btn-link p-0\" (click)=\"deleteRow(i)\">\n              <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"#F44336\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\">\n                <path d=\"M3 6h18\" />\n                <path d=\"M8 6V4a2 2 0 0 1 2-2h4a2 2 0 0 1 2 2v2\" />\n                <path d=\"m10 11 1 6\" />\n                <path d=\"m14 11-1 6\" />\n                <path d=\"M4 6l1 14a2 2 0 0 0 2 2h10a2 2 0 0 0 2-2l1-14\" />\n              </svg>\n              \n                            Delete\n            </button>\n          </div>\n        </td>\n      </tr>\n    </tbody>\n  </table>\n</div>\n\n<!-- Pagination --><!-- RS 03FEB2025 -->\n<div *ngIf=\"showPagination\" class=\"pagination-container\">\n  <div class=\"d-flex justify-content-end align-items-center\">\n    <div class=\"items-per-page\">\n      <span>Items per page:</span>\n      <select [(ngModel)]=\"itemsPerPage\" (change)=\"updatePagination()\" class=\"form-select form-select-sm\">\n        <option value=\"5\">5</option>\n        <option value=\"10\">10</option>\n        <option value=\"20\">20</option>\n        <option value=\"50\">50</option>\n      </select>\n    </div>\n    <div class=\"page-info ms-3 me-3\">\n      {{((currentPage - 1) * itemsPerPage + 1)}} - {{Math.min(currentPage * itemsPerPage, totalItems)}} of {{totalItems}}\n    </div>\n    <nav aria-label=\"Table pagination\">\n      <!-- First page --><!-- RS 03FEB2025 -->\n      <ul class=\"pagination mb-0\">\n        <li class=\"page-item\" [class.disabled]=\"currentPage === 1\">\n          <a class=\"page-link\" (click)=\"setPage(1)\">«</a>\n        </li>\n        <li class=\"page-item\" [class.disabled]=\"currentPage === 1\">\n          <a class=\"page-link\" (click)=\"setPage(currentPage - 1)\">‹</a>\n        </li>\n        <!-- Dynamic pagination --><!-- RS 03FEB2025 -->\n        <li class=\"page-item\" *ngFor=\"let page of pages\" [class.active]=\"page === currentPage\">\n          <a class=\"page-link\" (click)=\"setPage(page)\">{{page}}</a>\n        </li>\n        <li class=\"page-item\" [class.disabled]=\"currentPage === pages.length\">\n          <a class=\"page-link\" (click)=\"setPage(currentPage + 1)\">›</a>\n        </li>\n        <!-- Last page -->\n        <li class=\"page-item\" [class.disabled]=\"currentPage === pages.length\">\n          <a class=\"page-link\" (click)=\"setPage(pages.length)\">»</a>\n        </li>\n      </ul>\n    </nav>\n  </div>\n</div>\n<!-- RS 03FEB2025 -->\n<!-- Add Row Button -->\n<div *ngIf=\"showAddRow\"  (click)=\"addRow()\" class=\"addRowClass\">\n  <div class=\"circle-button\">+</div>\n</div>\n"]}
|