@rangertechnologies/ngnxt 2.1.124 → 2.1.125

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.
@@ -2,14 +2,14 @@
2
2
  /* tslint:disable */
3
3
  export const VERSION = {
4
4
  "dirty": true,
5
- "raw": "ad2296a-dirty",
6
- "hash": "ad2296a",
5
+ "raw": "05a52cb-dirty",
6
+ "hash": "05a52cb",
7
7
  "distance": null,
8
8
  "tag": null,
9
9
  "semver": null,
10
- "suffix": "ad2296a-dirty",
10
+ "suffix": "05a52cb-dirty",
11
11
  "semverString": null,
12
- "version": "2.1.124"
12
+ "version": "2.1.125"
13
13
  };
14
14
  /* tslint:enable */
15
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmVyc2lvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL254dC1hcHAvc3JjL2Vudmlyb25tZW50cy92ZXJzaW9uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLDJFQUEyRTtBQUMzRSxvQkFBb0I7QUFDcEIsTUFBTSxDQUFDLE1BQU0sT0FBTyxHQUFHO0lBQ25CLE9BQU8sRUFBRSxJQUFJO0lBQ2IsS0FBSyxFQUFFLGVBQWU7SUFDdEIsTUFBTSxFQUFFLFNBQVM7SUFDakIsVUFBVSxFQUFFLElBQUk7SUFDaEIsS0FBSyxFQUFFLElBQUk7SUFDWCxRQUFRLEVBQUUsSUFBSTtJQUNkLFFBQVEsRUFBRSxlQUFlO0lBQ3pCLGNBQWMsRUFBRSxJQUFJO0lBQ3BCLFNBQVMsRUFBRSxTQUFTO0NBQ3ZCLENBQUM7QUFDRixtQkFBbUIiLCJzb3VyY2VzQ29udGVudCI6WyIvLyBJTVBPUlRBTlQ6IFRISVMgRklMRSBJUyBBVVRPIEdFTkVSQVRFRCEgRE8gTk9UIE1BTlVBTExZIEVESVQgT1IgQ0hFQ0tJTiFcbi8qIHRzbGludDpkaXNhYmxlICovXG5leHBvcnQgY29uc3QgVkVSU0lPTiA9IHtcbiAgICBcImRpcnR5XCI6IHRydWUsXG4gICAgXCJyYXdcIjogXCJhZDIyOTZhLWRpcnR5XCIsXG4gICAgXCJoYXNoXCI6IFwiYWQyMjk2YVwiLFxuICAgIFwiZGlzdGFuY2VcIjogbnVsbCxcbiAgICBcInRhZ1wiOiBudWxsLFxuICAgIFwic2VtdmVyXCI6IG51bGwsXG4gICAgXCJzdWZmaXhcIjogXCJhZDIyOTZhLWRpcnR5XCIsXG4gICAgXCJzZW12ZXJTdHJpbmdcIjogbnVsbCxcbiAgICBcInZlcnNpb25cIjogXCIyLjEuMTI0XCJcbn07XG4vKiB0c2xpbnQ6ZW5hYmxlICovXG4iXX0=
15
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmVyc2lvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL254dC1hcHAvc3JjL2Vudmlyb25tZW50cy92ZXJzaW9uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLDJFQUEyRTtBQUMzRSxvQkFBb0I7QUFDcEIsTUFBTSxDQUFDLE1BQU0sT0FBTyxHQUFHO0lBQ25CLE9BQU8sRUFBRSxJQUFJO0lBQ2IsS0FBSyxFQUFFLGVBQWU7SUFDdEIsTUFBTSxFQUFFLFNBQVM7SUFDakIsVUFBVSxFQUFFLElBQUk7SUFDaEIsS0FBSyxFQUFFLElBQUk7SUFDWCxRQUFRLEVBQUUsSUFBSTtJQUNkLFFBQVEsRUFBRSxlQUFlO0lBQ3pCLGNBQWMsRUFBRSxJQUFJO0lBQ3BCLFNBQVMsRUFBRSxTQUFTO0NBQ3ZCLENBQUM7QUFDRixtQkFBbUIiLCJzb3VyY2VzQ29udGVudCI6WyIvLyBJTVBPUlRBTlQ6IFRISVMgRklMRSBJUyBBVVRPIEdFTkVSQVRFRCEgRE8gTk9UIE1BTlVBTExZIEVESVQgT1IgQ0hFQ0tJTiFcbi8qIHRzbGludDpkaXNhYmxlICovXG5leHBvcnQgY29uc3QgVkVSU0lPTiA9IHtcbiAgICBcImRpcnR5XCI6IHRydWUsXG4gICAgXCJyYXdcIjogXCIwNWE1MmNiLWRpcnR5XCIsXG4gICAgXCJoYXNoXCI6IFwiMDVhNTJjYlwiLFxuICAgIFwiZGlzdGFuY2VcIjogbnVsbCxcbiAgICBcInRhZ1wiOiBudWxsLFxuICAgIFwic2VtdmVyXCI6IG51bGwsXG4gICAgXCJzdWZmaXhcIjogXCIwNWE1MmNiLWRpcnR5XCIsXG4gICAgXCJzZW12ZXJTdHJpbmdcIjogbnVsbCxcbiAgICBcInZlcnNpb25cIjogXCIyLjEuMTI1XCJcbn07XG4vKiB0c2xpbnQ6ZW5hYmxlICovXG4iXX0=
@@ -51,7 +51,9 @@ export class CustomDropdownComponent {
51
51
  this.placeholder = this.placeholder ? this.placeholder : '---Select option---';
52
52
  if (this.apiMeta) {
53
53
  try {
54
- this.apiObj = JSON.parse(this.apiMeta);
54
+ // this.apiObj = JSON.parse(this.apiMeta);
55
+ // MSM-27MAR25 Ensure ques.subText is always an object by parsing it if it's a string
56
+ this.apiObj = typeof this.apiMeta === 'object' ? this.apiMeta : JSON.parse(this.apiMeta);
55
57
  // Check if apiObj and apiObj.field are defined
56
58
  if (this.apiObj && this.apiObj.field) {
57
59
  this.labelField = this.apiObj.field;
@@ -216,4 +218,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
216
218
  }], valueChange: [{
217
219
  type: Output
218
220
  }] } });
219
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"custom-dropdown.component.js","sourceRoot":"","sources":["../../../../../../projects/nxt-app/src/lib/components/custom-dropdown/custom-dropdown.component.ts","../../../../../../projects/nxt-app/src/lib/components/custom-dropdown/custom-dropdown.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit,Input,Output,EventEmitter, Optional } from '@angular/core';\nimport { Observable, Subscription } from 'rxjs';\nimport { APIMeta } from '../../interfaces/apimeta';\nimport { ChangeWrapper } from '../../model/changeWrapper';\nimport { ChangeService } from '../../services/change.service';\n// HA 19DEC23 imported translation service\nimport { I18nService } from '../../i18n.service';\n// VD 23JAN24 used service file for callout\nimport { DataService } from '../../services/data.service';\n\n@Component({\n  selector: 'app-custom-dropdown',\n  templateUrl: './custom-dropdown.component.html',\n  styleUrls: ['./custom-dropdown.component.css']\n})\nexport class CustomDropdownComponent implements OnInit {\n  @Input() options: string[];\n  @Input() placeholder: string;\n  @Input() apiMeta: string;\n  @Input() selectedValue: string;\n  @Input() progressBar: boolean;\n  @Input() id:string;\n  @Input() readOnly = false; // VD 12Jun24 - readonly change\n  @Input() errorMessage: string;\n  @Input() error:any;\n  @Input() fromShengel: boolean = false;\n  @Input() question:any;\n  @Input() referenceField:string;\n  @Input() token:string;    // VD 19JAN24 - getting token as input\n  @Output() valueChange: EventEmitter<ChangeWrapper> = new EventEmitter<ChangeWrapper>();\n  invalidFieldIds:string[] = [];\n  constructor( \n    private changeService: ChangeService, \n    private dataService: DataService,\n    public i18nService: I18nService,\n        ) { \n    this.changeService.submitValidate$.subscribe((data)=>{\n      // to get the error message's field id's\n      this.invalidFieldIds.push(data);\n    })\n  }\n\n  public labelField: string;\n  public valueField: string;\n  subscription: Subscription;\n  public apiObj:APIMeta;\n  public uniqueKey:string;\n\n  ngOnInit(): void {\n    \n  }\n  getOptions(){\n    console.log('test click');\n    // console.log('inside oninit of custom-dropdown of ' + this.id);\n    // console.log(this.apiMeta);\n    //VD 07Aug24 - isDependentField change\n    // VD 25Oct24 - changes\n    this.placeholder = this.placeholder ? this.placeholder : '---Select option---';\n    if(this.apiMeta) {\n    try {\n      this.apiObj = JSON.parse(this.apiMeta);\n      // Check if apiObj and apiObj.field are defined\n      if (this.apiObj && this.apiObj.field) {\n        this.labelField = this.apiObj.field;\n        this.uniqueKey = this.apiObj.uniqueKey;\n        const cachedOptions = localStorage.getItem(this.uniqueKey);\n        if (cachedOptions) {\n          this.options = JSON.parse(cachedOptions);\n        }else {\n          if(!this.apiObj.isDependentField){\n            this.options = [];\n          }\n\n          // VD 09Sep24- setup the query param for api call // MR 08JAN24 DependentField API Fix moved below logic from above if condition\n          let fullEndPoint ;\n          if(this.apiObj.endpoint) {\n            if(this.apiObj.queryValueReference && this.apiObj.queryField) {\n              // process the end point with query param\n              let queryReferences = this.apiObj.queryValueReference.split(',');\n              let queryFields = this.apiObj.queryField.split(',');    // MR 08JAN24 similar to above valuereference get list of QUERY Fields\n              let queryValues = this.apiObj.queryValue.split(',');    // MR 08JAN24 similar to above valuereference get list of QUERY Values (Default)\n              let queryParams = [];\n              let qIndex = 0;                                         // MR 08JAN24 Query Index\n              // Iterate over queryReferences and find the corresponding element in referenceData\n              queryReferences.forEach(reference => {\n                // Find the element in referenceData that matches the current reference\n                // RS 09DEC24 Changed keys\n                let matchingElement = this.question?.referenceQueryData.find(element => element.referenceField === reference);\n              // If a matching element is found, get its input value and create a query parameter\n                if (reference && matchingElement) {   // MR 08JAN24 if reference exist & matching element found\n                  queryParams.push(`${queryFields[qIndex]}=${matchingElement.input}`);    // MR 08JAN24 removed reference\n                } else {    // MR 08JAN24 included option for multiple query params and default value in case of reference is not found\n                  queryParams.push(`${queryFields[qIndex]}=${queryValues[qIndex]}`);\n                }\n\n                qIndex++;\n              });\n              fullEndPoint = this.apiObj.endpoint + '?' + queryParams.join('&');\n              console.log(fullEndPoint);\n            } else {\n                // if no query param get the actual endPoint\n              fullEndPoint = this.apiObj.endpoint;\n            }\n\n            // VD 19JAN24 - added one more param for authentication\n            this.dataService.apiResponse(fullEndPoint)?.subscribe((apiResponse) => {\n              // HA 18-JAN-24 Assigned apiresponse directly if we have the response in array also\n              // VD 19JAN24 - if response has key with value(which is array)\n              let responses;\n              if(this.apiObj.variable){\n                // VD 21May24 - handling multiple child objects\n                // VD 22May24 - used common service file\n                responses = this.dataService.getValue(apiResponse,this.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              // VD 25Oct24 - Store fetched options in local storage\n              if(this.uniqueKey){\n                localStorage.setItem(this.uniqueKey, JSON.stringify(this.options));\n              }\n              // Reference https://www.npmjs.com/package/@ng-select/ng-select\n            })\n          }\n\n          // VD NOV23 - handle the dependent update for dropdown\n          // VD 09Sep24- push the dependent field values for dropdown\n          let sourceId = this.apiObj.sourceQuestionId;\n          if(sourceId && this.apiObj.variable || this.apiObj.valueField){\n            // Subscribe for the changes\n            this.subscription = this.changeService.changeAnnounced$.subscribe(\n              (changeValue) => {\n                if(changeValue != undefined) {\n                  // console.log('inside subscription for the change');\n                  if(changeValue.valueObj != undefined && changeValue.fromQuestionId == this.apiObj.sourceQuestionId) {\n                    //  this.selectedValue = changeValue.valueObj[this.apiObj.valueField];\n                    //  let value ={};\n                    //  value['name'] = this.selectedValue;\n                      let responses;\n                      if(this.apiObj.variable){\n                        responses = this.dataService.getValue(changeValue.valueObj,this.apiObj.variable);\n                        let results = [];\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{\n                        responses = changeValue.valueObj;\n                        this.options = responses;\n                      }\n                    // VD 25Oct24 - Store fetched options in local storage\n                    if(this.uniqueKey){\n                      localStorage.setItem(this.uniqueKey, JSON.stringify(this.options));\n                    }\n                    }\n                  this.changeService.confirmChange(this.apiObj.sourceQuestionId);\n                }\n            }\n          );\n          }\n        }\n      }\n    } catch (error) {\n      console.error('Error parsing apiMeta:', error);\n    }\n  } \n}\n// VD 22May24 - used common service file\n\n  selectChange(event:any) {\n    console.log('inside selectChange from ' + this.id);\n    // console.log(event);\n    let change = new ChangeWrapper(); // ChangeWrapper = JSON.parse('{}');\n    change.fromQuestionId = this.id;\n    change.valueObj = event ? event : '';\n    change.referenceField = this.referenceField;\n    change.selectedObj = event ? event[this.labelField] : '';\n    this.valueChange.emit(change);\n    // once got value in dropdown remove the error validation\n    if(event){\n      this.invalidFieldIds =[];\n    }\n  }\n}\n","<!-- HA 18-JAN-24 Commenting these lines as we don't have to use shengel here -->\n<!-- <select\n  [ngClass]=\"{\n    'dt-line dpDown down myt-dropbox myt-border-r myt-font1': progressBar,\n    'custom-select': !progressBar\n  }\" class=\"custom-select mr-sm-2 dd-height\" \n  [id]=\"id\" \n  [(ngModel)]=\"selectedValue\"\n  (change)=\"selectChange($event.target.value);\" \n  [style.borderColor]=\"error ? 'red' : '#858585'\"\n  [style.color]=\"error ? 'red' : ''\">\n    <option *ngFor=\"let option of options\" [value]=\"this.apiMeta !== undefined ? option.title : option.value\" class=\"option\">{{ this.apiMeta !== undefined ? option.title : option.value }}</option>\n    <option *ngIf=\"errorMessage\" value=\"\" disabled hidden>{{ errorMessage }}</option>\n</select> -->\n<!-- // VD 12Jun24 - readonly change-->\n<!-- VD 01Aug24 - validation change-->\n<!-- VD 07Aug24 - isDependentField change-->\n<!-- VD 25Oct24 - changes-->\n<!-- RS 09DEC24 Changed keys--> \n<ng-select\n  [class]=\"invalidFieldIds.includes(id) || error ? 'shengel-custom-select invalid' : 'shengel-custom-select'\"\n  [(ngModel)]=\"selectedValue\" \n  [placeholder]=\"placeholder\"\n  [disabled]=\"readOnly\"\n  (click)=\"getOptions()\"\n  (change)=\"selectChange($event)\"\n  [id]=\"id\">\n  <ng-option \n    *ngFor=\"let option of options\" \n    [value]=\"apiObj && !apiObj.isDependentField ? option : option?.value\">\n    {{ apiObj && !apiObj.isDependentField && option ? option[labelField] : option?.value }}\n  </ng-option> \n</ng-select>\n<span *ngIf=\"error || invalidFieldIds.includes(id)\" class=\"error-msg\">{{errorMessage}}</span>\n"]}
221
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"custom-dropdown.component.js","sourceRoot":"","sources":["../../../../../../projects/nxt-app/src/lib/components/custom-dropdown/custom-dropdown.component.ts","../../../../../../projects/nxt-app/src/lib/components/custom-dropdown/custom-dropdown.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit,Input,Output,EventEmitter, Optional } from '@angular/core';\nimport { Observable, Subscription } from 'rxjs';\nimport { APIMeta } from '../../interfaces/apimeta';\nimport { ChangeWrapper } from '../../model/changeWrapper';\nimport { ChangeService } from '../../services/change.service';\n// HA 19DEC23 imported translation service\nimport { I18nService } from '../../i18n.service';\n// VD 23JAN24 used service file for callout\nimport { DataService } from '../../services/data.service';\n\n@Component({\n  selector: 'app-custom-dropdown',\n  templateUrl: './custom-dropdown.component.html',\n  styleUrls: ['./custom-dropdown.component.css']\n})\nexport class CustomDropdownComponent implements OnInit {\n  @Input() options: string[];\n  @Input() placeholder: string;\n  @Input() apiMeta: string;\n  @Input() selectedValue: string;\n  @Input() progressBar: boolean;\n  @Input() id:string;\n  @Input() readOnly = false; // VD 12Jun24 - readonly change\n  @Input() errorMessage: string;\n  @Input() error:any;\n  @Input() fromShengel: boolean = false;\n  @Input() question:any;\n  @Input() referenceField:string;\n  @Input() token:string;    // VD 19JAN24 - getting token as input\n  @Output() valueChange: EventEmitter<ChangeWrapper> = new EventEmitter<ChangeWrapper>();\n  invalidFieldIds:string[] = [];\n  constructor( \n    private changeService: ChangeService, \n    private dataService: DataService,\n    public i18nService: I18nService,\n        ) { \n    this.changeService.submitValidate$.subscribe((data)=>{\n      // to get the error message's field id's\n      this.invalidFieldIds.push(data);\n    })\n  }\n\n  public labelField: string;\n  public valueField: string;\n  subscription: Subscription;\n  public apiObj:APIMeta;\n  public uniqueKey:string;\n\n  ngOnInit(): void {\n    \n  }\n  getOptions(){\n    console.log('test click');\n    // console.log('inside oninit of custom-dropdown of ' + this.id);\n    // console.log(this.apiMeta);\n    //VD 07Aug24 - isDependentField change\n    // VD 25Oct24 - changes\n    this.placeholder = this.placeholder ? this.placeholder : '---Select option---';\n    if(this.apiMeta) {\n    try {\n      // this.apiObj = JSON.parse(this.apiMeta);\n          // MSM-27MAR25 Ensure ques.subText is always an object by parsing it if it's a string\n      this.apiObj = typeof this.apiMeta === 'object' ? this.apiMeta : JSON.parse(this.apiMeta);\n\n      // Check if apiObj and apiObj.field are defined\n      if (this.apiObj && this.apiObj.field) {\n        this.labelField = this.apiObj.field;\n        this.uniqueKey = this.apiObj.uniqueKey;\n        const cachedOptions = localStorage.getItem(this.uniqueKey);\n        if (cachedOptions) {\n          this.options = JSON.parse(cachedOptions);\n        }else {\n          if(!this.apiObj.isDependentField){\n            this.options = [];\n          }\n\n          // VD 09Sep24- setup the query param for api call // MR 08JAN24 DependentField API Fix moved below logic from above if condition\n          let fullEndPoint ;\n          if(this.apiObj.endpoint) {\n            if(this.apiObj.queryValueReference && this.apiObj.queryField) {\n              // process the end point with query param\n              let queryReferences = this.apiObj.queryValueReference.split(',');\n              let queryFields = this.apiObj.queryField.split(',');    // MR 08JAN24 similar to above valuereference get list of QUERY Fields\n              let queryValues = this.apiObj.queryValue.split(',');    // MR 08JAN24 similar to above valuereference get list of QUERY Values (Default)\n              let queryParams = [];\n              let qIndex = 0;                                         // MR 08JAN24 Query Index\n              // Iterate over queryReferences and find the corresponding element in referenceData\n              queryReferences.forEach(reference => {\n                // Find the element in referenceData that matches the current reference\n                // RS 09DEC24 Changed keys\n                let matchingElement = this.question?.referenceQueryData.find(element => element.referenceField === reference);\n              // If a matching element is found, get its input value and create a query parameter\n                if (reference && matchingElement) {   // MR 08JAN24 if reference exist & matching element found\n                  queryParams.push(`${queryFields[qIndex]}=${matchingElement.input}`);    // MR 08JAN24 removed reference\n                } else {    // MR 08JAN24 included option for multiple query params and default value in case of reference is not found\n                  queryParams.push(`${queryFields[qIndex]}=${queryValues[qIndex]}`);\n                }\n\n                qIndex++;\n              });\n              fullEndPoint = this.apiObj.endpoint + '?' + queryParams.join('&');\n              console.log(fullEndPoint);\n            } else {\n                // if no query param get the actual endPoint\n              fullEndPoint = this.apiObj.endpoint;\n            }\n\n            // VD 19JAN24 - added one more param for authentication\n            this.dataService.apiResponse(fullEndPoint)?.subscribe((apiResponse) => {\n              // HA 18-JAN-24 Assigned apiresponse directly if we have the response in array also\n              // VD 19JAN24 - if response has key with value(which is array)\n              let responses;\n              if(this.apiObj.variable){\n                // VD 21May24 - handling multiple child objects\n                // VD 22May24 - used common service file\n                responses = this.dataService.getValue(apiResponse,this.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              // VD 25Oct24 - Store fetched options in local storage\n              if(this.uniqueKey){\n                localStorage.setItem(this.uniqueKey, JSON.stringify(this.options));\n              }\n              // Reference https://www.npmjs.com/package/@ng-select/ng-select\n            })\n          }\n\n          // VD NOV23 - handle the dependent update for dropdown\n          // VD 09Sep24- push the dependent field values for dropdown\n          let sourceId = this.apiObj.sourceQuestionId;\n          if(sourceId && this.apiObj.variable || this.apiObj.valueField){\n            // Subscribe for the changes\n            this.subscription = this.changeService.changeAnnounced$.subscribe(\n              (changeValue) => {\n                if(changeValue != undefined) {\n                  // console.log('inside subscription for the change');\n                  if(changeValue.valueObj != undefined && changeValue.fromQuestionId == this.apiObj.sourceQuestionId) {\n                    //  this.selectedValue = changeValue.valueObj[this.apiObj.valueField];\n                    //  let value ={};\n                    //  value['name'] = this.selectedValue;\n                      let responses;\n                      if(this.apiObj.variable){\n                        responses = this.dataService.getValue(changeValue.valueObj,this.apiObj.variable);\n                        let results = [];\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{\n                        responses = changeValue.valueObj;\n                        this.options = responses;\n                      }\n                    // VD 25Oct24 - Store fetched options in local storage\n                    if(this.uniqueKey){\n                      localStorage.setItem(this.uniqueKey, JSON.stringify(this.options));\n                    }\n                    }\n                  this.changeService.confirmChange(this.apiObj.sourceQuestionId);\n                }\n            }\n          );\n          }\n        }\n      }\n    } catch (error) {\n      console.error('Error parsing apiMeta:', error);\n    }\n  } \n}\n// VD 22May24 - used common service file\n\n  selectChange(event:any) {\n    console.log('inside selectChange from ' + this.id);\n    // console.log(event);\n    let change = new ChangeWrapper(); // ChangeWrapper = JSON.parse('{}');\n    change.fromQuestionId = this.id;\n    change.valueObj = event ? event : '';\n    change.referenceField = this.referenceField;\n    change.selectedObj = event ? event[this.labelField] : '';\n    this.valueChange.emit(change);\n    // once got value in dropdown remove the error validation\n    if(event){\n      this.invalidFieldIds =[];\n    }\n  }\n}\n","<!-- HA 18-JAN-24 Commenting these lines as we don't have to use shengel here -->\n<!-- <select\n  [ngClass]=\"{\n    'dt-line dpDown down myt-dropbox myt-border-r myt-font1': progressBar,\n    'custom-select': !progressBar\n  }\" class=\"custom-select mr-sm-2 dd-height\" \n  [id]=\"id\" \n  [(ngModel)]=\"selectedValue\"\n  (change)=\"selectChange($event.target.value);\" \n  [style.borderColor]=\"error ? 'red' : '#858585'\"\n  [style.color]=\"error ? 'red' : ''\">\n    <option *ngFor=\"let option of options\" [value]=\"this.apiMeta !== undefined ? option.title : option.value\" class=\"option\">{{ this.apiMeta !== undefined ? option.title : option.value }}</option>\n    <option *ngIf=\"errorMessage\" value=\"\" disabled hidden>{{ errorMessage }}</option>\n</select> -->\n<!-- // VD 12Jun24 - readonly change-->\n<!-- VD 01Aug24 - validation change-->\n<!-- VD 07Aug24 - isDependentField change-->\n<!-- VD 25Oct24 - changes-->\n<!-- RS 09DEC24 Changed keys--> \n<ng-select\n  [class]=\"invalidFieldIds.includes(id) || error ? 'shengel-custom-select invalid' : 'shengel-custom-select'\"\n  [(ngModel)]=\"selectedValue\" \n  [placeholder]=\"placeholder\"\n  [disabled]=\"readOnly\"\n  (click)=\"getOptions()\"\n  (change)=\"selectChange($event)\"\n  [id]=\"id\">\n  <ng-option \n    *ngFor=\"let option of options\" \n    [value]=\"apiObj && !apiObj.isDependentField ? option : option?.value\">\n    {{ apiObj && !apiObj.isDependentField && option ? option[labelField] : option?.value }}\n  </ng-option> \n</ng-select>\n<span *ngIf=\"error || invalidFieldIds.includes(id)\" class=\"error-msg\">{{errorMessage}}</span>\n"]}
@@ -77,7 +77,9 @@ export class CustomTableComponent {
77
77
  }
78
78
  if (this.apiMeta !== undefined) {
79
79
  this.options = [];
80
- let apiObj = JSON.parse(this.apiMeta);
80
+ // let apiObj: APIMeta = JSON.parse(this.apiMeta);
81
+ // MSM-27MAR25 Ensure ques.subText is always an object by parsing it if it's a string
82
+ let apiObj = typeof this.apiMeta === 'object' ? this.apiMeta : JSON.parse(this.apiMeta);
81
83
  if (apiObj && apiObj.endpoint) {
82
84
  this.dataService.apiResponse(apiObj.endpoint)?.subscribe((apiResponse) => {
83
85
  let responses;
@@ -247,4 +249,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
247
249
  }], valueChange: [{
248
250
  type: Output
249
251
  }] } });
250
- //# 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        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":"AAAA,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,KAAK,EAAU,MAAM,EAAE,MAAM,eAAe,CAAC;;;;;;;;AAiB/E,MAAM,OAAO,oBAAoB;IAiCX;IAAqC;IAAkC;IAhClF,QAAQ,CAAU;IAClB,OAAO,CAAS;IACf,WAAW,GAAsB,IAAI,YAAY,EAAO,CAAC;IACnE,WAAW,GAAG,EAAE,CAAC;IACjB,SAAS,GAAG,EAAE,CAAC;IACf,YAAY,GAAG,EAAE,CAAC,CAAC,iCAAiC;IACpD,cAAc;IACd,oJAAoJ;IACpJ,UAAU,GAAY,IAAI,CAAC;IAC3B,cAAc,GAAY,IAAI,CAAC;IAC/B,WAAW,GAAY,IAAI,CAAC;IAC5B,UAAU,GAAY,IAAI,CAAC;IAC3B,YAAY,GAAW,CAAC,CAAC;IACzB,aAAa,CAAS;IACtB,SAAS,CAAS,CAAC,oCAAoC;IACvD,OAAO,CAAM;IACb,WAAW,CAAM;IACjB,SAAS,CAAS;IAClB,MAAM,CAAS;IACf,SAAS,GAAY,KAAK,CAAC;IACpB,OAAO,CAAW;IACzB,UAAU,GAAY,IAAI,CAAC;IAC3B,YAAY,CAAe;IAG3B,cAAc;IACd,2CAA2C;IAC3C,UAAU,GAAW,EAAE,CAAC;IACxB,WAAW,GAAW,CAAC,CAAC;IACxB,UAAU,GAAW,CAAC,CAAC;IACvB,KAAK,GAAa,EAAE,CAAC;IACrB,IAAI,GAAG,IAAI,CAAC;IACZ,YAAoB,aAA4B,EAAS,WAAwB,EAAU,WAAwB;QAA/F,kBAAa,GAAb,aAAa,CAAe;QAAS,gBAAW,GAAX,WAAW,CAAa;QAAU,gBAAW,GAAX,WAAW,CAAa;IAAI,CAAC;IACxH,QAAQ;QACN,oDAAoD;QAClD,MAAM,UAAU,GAAI,OAAO,IAAI,CAAC,QAAQ,CAAC,YAAY,CAAC,KAAK,QAAQ,CAAE,CAAC,CAAE,IAAI,CAAC,QAAQ,CAAC,YAAY,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAE,IAAI,CAAC,QAAQ,CAAC,YAAY,CAAC,CAAC,CAAE;QACxJ,IAAI,CAAC,UAAU,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,UAAU,CAAC,IAAI,UAAU,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YACzE,OAAO,CAAC,IAAI,CAAC,4BAA4B,CAAC,CAAC;YAC3C,OAAO;QACT,CAAC;QAED,cAAc;QACd,6HAA6H;QAC7H,IAAI,UAAU,CAAC,CAAC,CAAC,EAAE,WAAW,EAAE,CAAC;YAC/B,MAAM,MAAM,GAAG,UAAU,CAAC,CAAC,CAAC,CAAC,WAAW,CAAC;YACzC,IAAI,CAAC,UAAU,GAAG,MAAM,CAAC,UAAU,KAAK,KAAK,CAAC;YAC9C,IAAI,CAAC,cAAc,GAAG,MAAM,CAAC,cAAc,KAAK,KAAK,CAAC;YACtD,IAAI,CAAC,WAAW,GAAG,MAAM,CAAC,WAAW,KAAK,KAAK,CAAC;YAChD,IAAI,CAAC,UAAU,GAAG,MAAM,CAAC,UAAU,KAAK,KAAK,CAAC;YAC9C,IAAI,CAAC,YAAY,GAAG,MAAM,CAAC,YAAY,IAAI,CAAC,CAAC;YAE7C,wCAAwC;YACxC,IAAI,CAAC,WAAW,GAAG,UAAU,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;QACzC,CAAC;aAAM,CAAC;YACN,wDAAwD;YACxD,IAAI,CAAC,WAAW,GAAG,UAAU,CAAC;QAChC,CAAC;QAED,IAAI,CAAC,SAAS,GAAG,EAAE,GAAG,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC;QAC9C,gCAAgC;QAChC,IAAI,IAAI,CAAC,QAAQ,EAAE,KAAK,EAAE,CAAC;YACzB,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,QAAQ,EAAE,KAAK,CAAC;YACtC,IAAI,CAAC,YAAY,GAAG,CAAC,GAAG,IAAI,CAAC,SAAS,CAAC,CAAC;YACxC,IAAI,CAAC,gBAAgB,EAAE,CAAC;QAC1B,CAAC;QACD,IAAI,IAAI,CAAC,OAAO,KAAK,SAAS,EAAE,CAAC;YAC/B,IAAI,CAAC,OAAO,GAAG,EAAE,CAAC;YAClB,kDAAkD;YAC9C,qFAAqF;YACzF,IAAI,MAAM,GAAY,OAAO,IAAI,CAAC,OAAO,KAAK,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;YAEjG,IAAI,MAAM,IAAI,MAAM,CAAC,QAAQ,EAAE,CAAC;gBAC9B,IAAI,CAAC,WAAW,CAAC,WAAW,CAAC,MAAM,CAAC,QAAQ,CAAC,EAAE,SAAS,CAAC,CAAC,WAAW,EAAE,EAAE;oBACvE,IAAI,SAAS,CAAC;oBACd,IAAI,MAAM,CAAC,QAAQ,EAAE,CAAC;wBACpB,+CAA+C;wBAC/C,SAAS,GAAG,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,WAAW,EAAE,MAAM,CAAC,QAAQ,CAAC,CAAC;wBACpE,IAAI,OAAO,GAAG,EAAE,CAAC;wBACjB,iDAAiD;wBACjD,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,SAAS,EAAE,MAAM,EAAE,CAAC,EAAE,EAAE,CAAC;4BAC3C,IAAI,IAAI,GAAG,SAAS,CAAC,CAAC,CAAC,CAAC;4BACxB,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;wBACrB,CAAC;wBACD,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC;oBACzB,CAAC;yBAAM,CAAC,CAAE,0DAA0D;wBAClE,SAAS,GAAG,WAAW,CAAC;wBACxB,IAAI,CAAC,OAAO,GAAG,SAAS,CAAC;oBAC3B,CAAC;oBACD,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,GAAQ,EAAE,EAAE,CAAC,CAAC,EAAE,GAAG,GAAG,EAAE,IAAI,EAAE,KAAK,EAAE,CAAC,CAAC,CAAC;oBACzE,+DAA+D;oBAC/D,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,OAAO,CAAC;oBAC9B,OAAO,CAAC,GAAG,CAAC,WAAW,EAAE,IAAI,CAAC,SAAS,CAAC,CAAC;gBAE3C,CAAC,CAAC,CAAC;YACL,CAAC;YAED,sDAAsD;YACtD,IAAI,QAAQ,GAAG,MAAM,EAAE,gBAAgB,CAAC;YACxC,IAAI,KAAK,GAAG,MAAM,EAAE,KAAK,CAAC,CAAQ,qCAAqC;YACvE,IAAI,QAAQ,EAAE,CAAC;gBACb,0CAA0C;gBAC1C,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,aAAa,CAAC,gBAAgB,CAAC,SAAS,CAC/D,CAAC,WAAW,EAAE,EAAE;oBACd,IAAI,WAAW,IAAI,SAAS,EAAE,CAAC;wBAC7B,IAAI,WAAW,CAAC,QAAQ,IAAI,SAAS,IAAI,WAAW,CAAC,cAAc,IAAI,MAAM,CAAC,gBAAgB,EAAE,CAAC;4BAC/F,OAAO,CAAC,GAAG,CAAC,gBAAgB,CAAC,CAAC;4BAC9B,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,GAAQ,EAAE,EAAE,CAAC,CAAC,EAAE,GAAG,GAAG,EAAE,IAAI,EAAE,KAAK,EAAE,CAAC,CAAC,CAAC;4BACzE,IAAI,IAAI,GAAG,WAAW,CAAC,QAAQ,CAAC;4BAChC,IAAI,SAAS,GAAG,IAAI,CAAC;4BACrB,kCAAkC;4BAClC,IAAI,IAAI,CAAC,SAAS,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;gCAC9B,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,OAAO,CAAC,EAAE;oCAC/B,0CAA0C;oCAC1C,MAAM,eAAe,GAAG,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,OAAO,EAAE,KAAK,CAAC,CAAC;oCAClE,MAAM,YAAY,GAAG,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,IAAI,EAAE,KAAK,CAAC,CAAA;oCAC3D,IAAI,eAAe,IAAI,YAAY,EAAE,CAAC;wCACpC,SAAS,GAAG,KAAK,CAAC;oCACpB,CAAC;gCACH,CAAC,CAAC,CAAC;4BACL,CAAC;4BACD,cAAc;4BACd,+BAA+B;4BAC/B,IAAI,SAAS,EAAE,CAAC;gCACd,IAAI,IAAI,CAAC,SAAS,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;oCAC9B,IAAI,CAAC,SAAS,GAAG,CAAC,GAAG,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC,CAAC;gCAC7C,CAAC;qCAAM,CAAC;oCACN,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;gCAC5B,CAAC;gCACD,qCAAqC;gCACrC,IAAI,CAAC,YAAY,GAAG,CAAC,GAAG,IAAI,CAAC,SAAS,CAAC,CAAC;gCACxC,IAAI,CAAC,gBAAgB,EAAE,CAAC;gCACxB,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;4BAC1C,CAAC;wBACH,CAAC;wBACD,IAAI,CAAC,aAAa,CAAC,aAAa,CAAC,MAAM,EAAE,gBAAgB,CAAC,CAAC;oBAC7D,CAAC;gBACH,CAAC,CACF,CAAC;YACJ,CAAC;QACH,CAAC;QACD,IAAI,CAAC,gBAAgB,EAAE,CAAC;IAC5B,CAAC;IACD,cAAc;IACd,+EAA+E;IAC/E,MAAM;QACJ,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,IAAI,EAAE,EAAE,CAAC;YAC5B,IAAI,CAAC,YAAY,GAAG,CAAC,GAAG,IAAI,CAAC,SAAS,CAAC,CAAC;QAC1C,CAAC;aAAM,CAAC;YACN,MAAM,eAAe,GAAG,IAAI,CAAC,UAAU,CAAC,WAAW,EAAE,CAAC;YACtD,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE;gBAC/C,OAAO,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE;oBACpC,MAAM,KAAK,GAAG,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,IAAI,EAAE,MAAM,CAAC,OAAO,CAAC,CAAC;oBAC9D,OAAO,KAAK,IAAI,KAAK,CAAC,QAAQ,EAAE,CAAC,WAAW,EAAE,CAAC,QAAQ,CAAC,eAAe,CAAC,CAAC;gBAC3E,CAAC,CAAC,CAAC;YACL,CAAC,CAAC,CAAC;QACL,CAAC;QACD,IAAI,CAAC,WAAW,GAAG,CAAC,CAAC;QACrB,IAAI,CAAC,gBAAgB,EAAE,CAAC;IAC1B,CAAC;IACD,cAAc;IACd,sGAAsG;IACtG,gBAAgB;QACd,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC;QAC3C,MAAM,UAAU,GAAG,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,YAAY,CAAC,CAAC;QAClE,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC,IAAI,CAAC,EAAE,MAAM,EAAE,UAAU,EAAE,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC;QACjE,IAAI,IAAI,CAAC,WAAW,GAAG,UAAU,EAAE,CAAC;YAClC,IAAI,CAAC,WAAW,GAAG,UAAU,IAAI,CAAC,CAAC;QACrC,CAAC;IACH,CAAC;IACD,cAAc;IACd,yFAAyF;IACzF,IAAI,aAAa;QACf,MAAM,UAAU,GAAG,CAAC,IAAI,CAAC,WAAW,GAAG,CAAC,CAAC,GAAG,IAAI,CAAC,YAAY,CAAC;QAC9D,OAAO,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,UAAU,EAAE,UAAU,GAAG,IAAI,CAAC,YAAY,CAAC,CAAC;IAC7E,CAAC;IACD,cAAc;IACd,4DAA4D;IAC5D,OAAO,CAAC,IAAY;QAClB,IAAI,IAAI,IAAI,CAAC,IAAI,IAAI,IAAI,IAAI,CAAC,KAAK,CAAC,MAAM,EAAE,CAAC;YAC3C,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;QAC1B,CAAC;IACH,CAAC;IAED,MAAM;QACJ,IAAI,OAAO,GAAG,EAAE,CAAC;QACjB,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE;YAC9B,IAAI,IAAI,CAAC,OAAO,EAAE,CAAC;gBACjB,OAAO,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,EAAE,CAAC;YAC7B,CAAC;QACH,CAAC,CAAC,CAAC;QACH,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QAC7B,IAAI,CAAC,YAAY,GAAG,CAAC,GAAG,IAAI,CAAC,SAAS,CAAC,CAAC;QACxC,IAAI,CAAC,gBAAgB,EAAE,CAAC;QAExB,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;IAC1C,CAAC;IAED,WAAW,CAAC,IAAS,EAAE,KAAa;QAClC,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;IAC1C,CAAC;IACD,2CAA2C;IAC3C,WAAW,CAAC,QAAgB,EAAE,KAAa,EAAE,KAAU;QACrD,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC,KAAK,CAAC,GAAG,KAAK,CAAC;QACxC,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;IAC1C,CAAC;IACD,cAAc;IACd,SAAS,CAAC,QAAgB;QACxB,sCAAsC;QACtC,MAAM,WAAW,GAAG,CAAC,IAAI,CAAC,WAAW,GAAG,CAAC,CAAC,GAAG,IAAI,CAAC,YAAY,GAAG,QAAQ,CAAC;QAC1E,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,WAAW,EAAE,CAAC,CAAC,CAAC;QACtC,IAAI,CAAC,YAAY,GAAG,CAAC,GAAG,IAAI,CAAC,SAAS,CAAC,CAAC;QACxC,IAAI,CAAC,gBAAgB,EAAE,CAAC;QAExB,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;IAC1C,CAAC;IAED,OAAO,CAAC,QAAgB;QACtB,IAAI,CAAC,GAAG,CAAC,CAAC;QACV,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,OAAO,CAAC,EAAE;YAC/B,IAAI,CAAC,KAAK,QAAQ,EAAE,CAAC;gBACnB,OAAO,CAAC,IAAI,GAAG,IAAI,CAAC;YACtB,CAAC;YACD,CAAC,EAAE,CAAC;QACN,CAAC,CAAC,CAAC;IACL,CAAC;IAED,YAAY,CAAC,IAAS,EAAE,KAAa,EAAE,KAAa;QAClD,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,GAAG,KAAK,CAAC;QAC1B,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;IAC1C,CAAC;IAGD,kBAAkB,CAAC,gBAAuB;QACxC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC;IAC1C,CAAC;wGA5OU,oBAAoB;4FAApB,oBAAoB,uJCjBjC,i6OAkKA;;4FDjJa,oBAAoB;kBANhC,SAAS;+BACE,kBAAkB;sIAMnB,QAAQ;sBAAhB,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACI,WAAW;sBAApB,MAAM","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"]}
@@ -6674,7 +6674,9 @@ class CustomDropdownComponent {
6674
6674
  this.placeholder = this.placeholder ? this.placeholder : '---Select option---';
6675
6675
  if (this.apiMeta) {
6676
6676
  try {
6677
- this.apiObj = JSON.parse(this.apiMeta);
6677
+ // this.apiObj = JSON.parse(this.apiMeta);
6678
+ // MSM-27MAR25 Ensure ques.subText is always an object by parsing it if it's a string
6679
+ this.apiObj = typeof this.apiMeta === 'object' ? this.apiMeta : JSON.parse(this.apiMeta);
6678
6680
  // Check if apiObj and apiObj.field are defined
6679
6681
  if (this.apiObj && this.apiObj.field) {
6680
6682
  this.labelField = this.apiObj.field;
@@ -9318,7 +9320,9 @@ class CustomTableComponent {
9318
9320
  }
9319
9321
  if (this.apiMeta !== undefined) {
9320
9322
  this.options = [];
9321
- let apiObj = JSON.parse(this.apiMeta);
9323
+ // let apiObj: APIMeta = JSON.parse(this.apiMeta);
9324
+ // MSM-27MAR25 Ensure ques.subText is always an object by parsing it if it's a string
9325
+ let apiObj = typeof this.apiMeta === 'object' ? this.apiMeta : JSON.parse(this.apiMeta);
9322
9326
  if (apiObj && apiObj.endpoint) {
9323
9327
  this.dataService.apiResponse(apiObj.endpoint)?.subscribe((apiResponse) => {
9324
9328
  let responses;
@@ -13909,14 +13913,14 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
13909
13913
  /* tslint:disable */
13910
13914
  const VERSION = {
13911
13915
  "dirty": true,
13912
- "raw": "ad2296a-dirty",
13913
- "hash": "ad2296a",
13916
+ "raw": "05a52cb-dirty",
13917
+ "hash": "05a52cb",
13914
13918
  "distance": null,
13915
13919
  "tag": null,
13916
13920
  "semver": null,
13917
- "suffix": "ad2296a-dirty",
13921
+ "suffix": "05a52cb-dirty",
13918
13922
  "semverString": null,
13919
- "version": "2.1.124"
13923
+ "version": "2.1.125"
13920
13924
  };
13921
13925
  /* tslint:enable */
13922
13926