@rangertechnologies/ngnxt 2.1.118 → 2.1.120

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.
Files changed (25) hide show
  1. package/esm2022/environments/version.mjs +5 -5
  2. package/esm2022/lib/components/custom-calendar/custom-calendar.component.mjs +3 -2
  3. package/esm2022/lib/components/custom-table/custom-table.component.mjs +3 -2
  4. package/esm2022/lib/components/datatable/datatable.component.mjs +138 -23
  5. package/esm2022/lib/components/file-upload/file-upload.component.mjs +3 -2
  6. package/esm2022/lib/components/table-appendix/table-appendix.component.mjs +3 -2
  7. package/esm2022/lib/pages/booklet/booklet.component.mjs +38 -4
  8. package/esm2022/lib/pages/builder/element/element.component.mjs +45 -17
  9. package/esm2022/lib/pages/builder/properties/properties.component.mjs +554 -200
  10. package/esm2022/lib/pages/questionbook/questionbook.component.mjs +31 -4
  11. package/esm2022/lib/pages/questionnaire/questionnaire.component.mjs +31 -4
  12. package/esm2022/lib/services/change.service.mjs +1 -3
  13. package/esm2022/lib/services/form-builder.service.mjs +22 -3
  14. package/fesm2022/rangertechnologies-ngnxt.mjs +865 -259
  15. package/fesm2022/rangertechnologies-ngnxt.mjs.map +1 -1
  16. package/lib/components/datatable/datatable.component.d.ts +14 -3
  17. package/lib/pages/booklet/booklet.component.d.ts +1 -0
  18. package/lib/pages/builder/element/element.component.d.ts +2 -0
  19. package/lib/pages/builder/properties/properties.component.d.ts +552 -42
  20. package/lib/pages/questionbook/questionbook.component.d.ts +3 -2
  21. package/lib/pages/questionnaire/questionnaire.component.d.ts +3 -2
  22. package/lib/services/form-builder.service.d.ts +14 -1
  23. package/package.json +1 -1
  24. package/rangertechnologies-ngnxt-2.1.120.tgz +0 -0
  25. package/rangertechnologies-ngnxt-2.1.118.tgz +0 -0
@@ -2,14 +2,14 @@
2
2
  /* tslint:disable */
3
3
  export const VERSION = {
4
4
  "dirty": true,
5
- "raw": "61228a7-dirty",
6
- "hash": "61228a7",
5
+ "raw": "ac21f75-dirty",
6
+ "hash": "ac21f75",
7
7
  "distance": null,
8
8
  "tag": null,
9
9
  "semver": null,
10
- "suffix": "61228a7-dirty",
10
+ "suffix": "ac21f75-dirty",
11
11
  "semverString": null,
12
- "version": "2.1.118"
12
+ "version": "2.1.120"
13
13
  };
14
14
  /* tslint:enable */
15
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmVyc2lvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL254dC1hcHAvc3JjL2Vudmlyb25tZW50cy92ZXJzaW9uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLDJFQUEyRTtBQUMzRSxvQkFBb0I7QUFDcEIsTUFBTSxDQUFDLE1BQU0sT0FBTyxHQUFHO0lBQ25CLE9BQU8sRUFBRSxJQUFJO0lBQ2IsS0FBSyxFQUFFLGVBQWU7SUFDdEIsTUFBTSxFQUFFLFNBQVM7SUFDakIsVUFBVSxFQUFFLElBQUk7SUFDaEIsS0FBSyxFQUFFLElBQUk7SUFDWCxRQUFRLEVBQUUsSUFBSTtJQUNkLFFBQVEsRUFBRSxlQUFlO0lBQ3pCLGNBQWMsRUFBRSxJQUFJO0lBQ3BCLFNBQVMsRUFBRSxTQUFTO0NBQ3ZCLENBQUM7QUFDRixtQkFBbUIiLCJzb3VyY2VzQ29udGVudCI6WyIvLyBJTVBPUlRBTlQ6IFRISVMgRklMRSBJUyBBVVRPIEdFTkVSQVRFRCEgRE8gTk9UIE1BTlVBTExZIEVESVQgT1IgQ0hFQ0tJTiFcbi8qIHRzbGludDpkaXNhYmxlICovXG5leHBvcnQgY29uc3QgVkVSU0lPTiA9IHtcbiAgICBcImRpcnR5XCI6IHRydWUsXG4gICAgXCJyYXdcIjogXCI2MTIyOGE3LWRpcnR5XCIsXG4gICAgXCJoYXNoXCI6IFwiNjEyMjhhN1wiLFxuICAgIFwiZGlzdGFuY2VcIjogbnVsbCxcbiAgICBcInRhZ1wiOiBudWxsLFxuICAgIFwic2VtdmVyXCI6IG51bGwsXG4gICAgXCJzdWZmaXhcIjogXCI2MTIyOGE3LWRpcnR5XCIsXG4gICAgXCJzZW12ZXJTdHJpbmdcIjogbnVsbCxcbiAgICBcInZlcnNpb25cIjogXCIyLjEuMTE4XCJcbn07XG4vKiB0c2xpbnQ6ZW5hYmxlICovXG4iXX0=
15
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmVyc2lvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL254dC1hcHAvc3JjL2Vudmlyb25tZW50cy92ZXJzaW9uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLDJFQUEyRTtBQUMzRSxvQkFBb0I7QUFDcEIsTUFBTSxDQUFDLE1BQU0sT0FBTyxHQUFHO0lBQ25CLE9BQU8sRUFBRSxJQUFJO0lBQ2IsS0FBSyxFQUFFLGVBQWU7SUFDdEIsTUFBTSxFQUFFLFNBQVM7SUFDakIsVUFBVSxFQUFFLElBQUk7SUFDaEIsS0FBSyxFQUFFLElBQUk7SUFDWCxRQUFRLEVBQUUsSUFBSTtJQUNkLFFBQVEsRUFBRSxlQUFlO0lBQ3pCLGNBQWMsRUFBRSxJQUFJO0lBQ3BCLFNBQVMsRUFBRSxTQUFTO0NBQ3ZCLENBQUM7QUFDRixtQkFBbUIiLCJzb3VyY2VzQ29udGVudCI6WyIvLyBJTVBPUlRBTlQ6IFRISVMgRklMRSBJUyBBVVRPIEdFTkVSQVRFRCEgRE8gTk9UIE1BTlVBTExZIEVESVQgT1IgQ0hFQ0tJTiFcbi8qIHRzbGludDpkaXNhYmxlICovXG5leHBvcnQgY29uc3QgVkVSU0lPTiA9IHtcbiAgICBcImRpcnR5XCI6IHRydWUsXG4gICAgXCJyYXdcIjogXCJhYzIxZjc1LWRpcnR5XCIsXG4gICAgXCJoYXNoXCI6IFwiYWMyMWY3NVwiLFxuICAgIFwiZGlzdGFuY2VcIjogbnVsbCxcbiAgICBcInRhZ1wiOiBudWxsLFxuICAgIFwic2VtdmVyXCI6IG51bGwsXG4gICAgXCJzdWZmaXhcIjogXCJhYzIxZjc1LWRpcnR5XCIsXG4gICAgXCJzZW12ZXJTdHJpbmdcIjogbnVsbCxcbiAgICBcInZlcnNpb25cIjogXCIyLjEuMTIwXCJcbn07XG4vKiB0c2xpbnQ6ZW5hYmxlICovXG4iXX0=
@@ -61,7 +61,8 @@ export class CustomCalendarComponent {
61
61
  }
62
62
  // RS 09DEC24 Changed keys
63
63
  processQuestion() {
64
- this.entries = JSON.parse(this.question['fieldsMeta']);
64
+ // SKS20MAR25 check if question fieldsmeta is string
65
+ this.entries = typeof this.question['fieldsMeta'] === 'object' ? this.question['fieldsMeta'] || [{}] : JSON.parse(this.question['fieldsMeta']);
65
66
  this.qbRefrenceBook = JSON.parse(this.question['qbReferenceQuestions']);
66
67
  let title = this.qbRefrenceBook?.questionbook?.title;
67
68
  this.modalTitle = title;
@@ -363,4 +364,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
363
364
  }], nxtId: [{
364
365
  type: Input
365
366
  }] } });
366
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"custom-calendar.component.js","sourceRoot":"","sources":["../../../../../../projects/nxt-app/src/lib/components/custom-calendar/custom-calendar.component.ts","../../../../../../projects/nxt-app/src/lib/components/custom-calendar/custom-calendar.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, EventEmitter, Input, OnInit, Output, SimpleChanges, ViewChild } from '@angular/core';\nimport { Question } from '../../wrapper';\n//import { QuestionbookComponent } from '../../pages/questionbook/questionbook.component';\n//import { ComponenthostDirective } from '../../directives/componenthost/componenthost.directive';\nimport { ChangeService } from '../../services/change.service';\ninterface CalendarDay {\n  date: Date;\n  events: any[];\n  isCurrentMonth: boolean;\n  isPast: boolean;\n  isToday: boolean;\n  isFuture: boolean;\n  isSelected?: boolean;\n}\n@Component({\n  selector: 'app-custom-calendar',\n  templateUrl: './custom-calendar.component.html',\n  styleUrls: ['./custom-calendar.component.css'],\n})\nexport class CustomCalendarComponent implements OnInit {\n  @Output() eventSelected = new EventEmitter<any>();\n  // VD 06Sep24 calendar changes\n  @Output() dateSelected = new EventEmitter<any>();\n  @Output() openModal = new EventEmitter<any>();\n  @Output() closeModal = new EventEmitter<any>();\n  @Input() allEvents: any[] = []; \n  @Input() question: Question\n  @Input() nxtId: string;\n  //@ViewChild(ComponenthostDirective, { static: true }) dynamicHost: ComponenthostDirective;\n  entries = [];\n  referenceQuestions = [];\n  qbRefrenceBook:any;\n  calendarQuestion = [];\n  calendar = {};\n  currentDate: Date = new Date();\n  calendarDays: CalendarDay[] = [];\n  daysOfWeek: string[] = ['Sunday', 'Monday', 'Tuesday', 'Wednesday', 'Thursday', 'Friday', 'Saturday'];\n  newEventTitle: string = '';\n  newEventTime: string = '';\n  newDescription: string = '';\n  newLink: string = '';\n  selectedDay: CalendarDay | null = null;\n  isModalOpen = false;\n  modalTitle = 'Custom Modal';\n  modalSize = 'large';\n  saveButtonValue = 'Save';\n  modalFooter = true;\n  editingEventId: number;\n  editingEntryGroup: any;\n  showAppoinmentSection: boolean = true;\n  subscription: any;\n  constructor( private changeService: ChangeService) { }\n  ngOnInit() {\n     if(this.question?.input){\n      this.allEvents = this.question.input;\n     }\n    this.processQuestion();\n    this.generateCalendar();\n    this.subscription = this.changeService.customChange$.subscribe(\n      (changeValue) => {\n          if(changeValue == 'calendar-modal-save') {\n            this.onSave();\n          }\n          if(changeValue == 'dataBind') {\n            if(this.question?.input){\n              this.allEvents = this.question.input;\n             }\n            this.processQuestion();\n            this.generateCalendar();\n          }\n      }\n    );\n   // this.dateSelected.emit(this.calendar);\n    //this.eventSelected.emit(this.allEvents);\n  }\n  // RS 09DEC24 Changed keys\n  processQuestion(){\n    this.entries = JSON.parse(this.question['fieldsMeta']);\n    this.qbRefrenceBook = JSON.parse(this.question['qbReferenceQuestions']);\n    let title = this.qbRefrenceBook?.questionbook?.title;\n    this.modalTitle = title;\n    this.referenceQuestions = [];\n    if(this.entries.length > 0){\n       this.entries.forEach(element => {\n           if(element.questionReference){\n             let qReference = JSON.parse(element.questionReference);\n             this.referenceQuestions.push(qReference?.question);\n           }\n       });\n    }\n    console.log('entries-->');\n    console.log('question-->');\n    console.log(this.entries);\n    console.log(this.referenceQuestions);\n  }\n   // sunday comment\n  // openQuestionBookModal() {\n  //   const viewContainerRef = this.dynamicHost.viewContainerRef;\n  //   viewContainerRef.clear();\n  //   const componentRef = viewContainerRef.createComponent(QuestionbookComponent);\n  //   componentRef.instance.qbItem = this.qbRefrenceBook;\n  //   componentRef.instance.questions = this.referenceQuestions;\n  //   componentRef.instance.handleQuestion.subscribe((event: any) => this.handleQuestionEvent(event));\n  // }\n\n  generateCalendar() {\n    const year = this.currentDate.getFullYear();\n    const month = this.currentDate.getMonth();\n\n    const startOfMonth = new Date(year, month, 1);\n    const endOfMonth = new Date(year, month + 1, 0);\n\n    const startDayOfWeek = startOfMonth.getDay();\n    const endDayOfWeek = endOfMonth.getDay();\n\n    const startDate = new Date(startOfMonth);\n    startDate.setDate(startDate.getDate() - startDayOfWeek);\n\n    const endDate = new Date(endOfMonth);\n    endDate.setDate(endDate.getDate() + (6 - endDayOfWeek));\n\n    const today = new Date(new Date().setHours(0, 0, 0, 0));\n    \n     this.calendarDays = [];\n      for (let d = new Date(startDate); d <= endDate; d.setDate(d.getDate() + 1)) {\n        const date = new Date(d);\n        this.calendarDays.push({\n          date: date,\n          events: [],\n          isCurrentMonth: d.getMonth() === month,\n          isPast: date < today,\n          isToday: date.getTime() === today.getTime(),\n          isFuture: date > today,\n        });\n      }\n\n    // Populate calendar with events from allEvents array\n    this.calendarDays.forEach(day => {\n      day.events = this.allEvents?.filter(event => event?.date?.toDateString() === day.date.toDateString());\n    });\n     // VD 06Sep24 calendar changes\n    let cal = {}\n    cal['year'] = year;\n    cal['month'] = month + 1;\n    this.calendar = cal;\n  }\n\n  selectDay(day: CalendarDay) {\n    console.log(day);\n     // VD 06Sep24 calendar changes\n    this.showAppoinmentSection = true;\n    this.selectedDay = day;\n   // this.eventSelected.emit(day?.events);\n    const previouslySelectedDay = this.calendarDays.find(d => d.isSelected);\n    if (previouslySelectedDay) {\n      previouslySelectedDay.isSelected = false;\n    }\n    // Select the clicked day\n    day.isSelected = true;\n   // VD 09Sep24- setup the query param data for api call\n    let referenceData = [];\n    this.referenceQuestions.forEach(ques => {\n      // VD 09-09-24 get the selected date\n      // need to add in the document\n      // RS 09DEC24 Changed keys\n       if(ques.referenceField == 'selectedDate'){\n          ques.input = day.date.toISOString();\n          console.log(ques.input);\n       }\n       // VD 09-09-24 get the query refrence  field data to pass the queryParam  for api\n       if(ques.subText){\n        let subText = JSON.parse(ques.subText);\n        if (subText.queryField && subText.queryValueReference) {\n            let currentQues = ques;\n            let queryReferences = subText.queryValueReference.split(',');   \n            queryReferences.forEach(refField => {\n                let refQues = this.referenceQuestions.find(q => q.referenceField === refField);\n                if (refQues) {\n                    referenceData.push(refQues);\n                }\n            });\n            // Add the referenceData array to the current question\n            currentQues.referenceQueryData = referenceData;\n        }\n       }\n    })\n  }\n\n  previousMonth() {\n    this.showAppoinmentSection = false;\n    this.currentDate.setMonth(this.currentDate.getMonth() - 1);\n    this.currentDate = new Date(this.currentDate); // Ensure the date object is updated\n    this.generateCalendar();\n    this.dateSelected.emit(this.calendar);\n    this.eventSelected.emit(this.allEvents);\n  }\n\n  nextMonth() {\n     // VD 06Sep24 calendar changes\n    this.showAppoinmentSection = false;\n    this.currentDate.setMonth(this.currentDate.getMonth() + 1);\n    this.currentDate = new Date(this.currentDate); // Ensure the date object is updated\n    this.generateCalendar();\n    this.dateSelected.emit(this.calendar);\n    this.eventSelected.emit(this.allEvents);\n  }\n\n  addAppointment() {\n    this.isModalOpen = true;\n     this.calendarQuestion = this.referenceQuestions.map(q => ({ ...q, input: '' }));\n    this.referenceQuestions.forEach(ques => {\n      // clear the input\n      if(ques.referenceField != 'selectedDate'){\n        if(ques.type == 'Dropdown'){\n          delete ques.input;\n          delete ques.selectedValue;\n           // VD 06Sep24 calendar changes\n        }else {\n          delete ques.input;\n        }\n      }\n    });\n    console.log(this.referenceQuestions);\n    this.editingEventId = null;\n    this.calendarQuestion = this.referenceQuestions;\n    this.openBookModel();\n    // sunday comment\n    //this.openQuestionBookModal();\n  }\n\n  openBookModel(){\n    this.openModal.emit({\n      qbRefrenceBook: this.qbRefrenceBook,\n      referenceQuestions: this.referenceQuestions,\n      modalTitle : this.modalTitle,\n      modalSize : this.modalSize,\n      saveButtonValue : this.saveButtonValue,\n      modalFooter : this.modalFooter,\n\n    });\n  }\n\n  closeCalendarModal() {\n    this.isModalOpen = false;\n    this.closeModal.emit(true);\n  }\n // VD 06Sep24 calendar changes\n\neditEvent(event: any, entryGroup: any) {\n  this.isModalOpen = true;\n  this.referenceQuestions = Object.values(entryGroup);\n  this.calendarQuestion = [...this.referenceQuestions]; // Make a copy of the current entries to edit\n  this.editingEventId = event.id;\n  this.editingEntryGroup = entryGroup; // Store the entry group being edited\n  this.generateCalendar(); // Regenerate the calendar to reflect changes\n  this.openBookModel();\n  // suday comment\n // this.openQuestionBookModal();\n\n}\n\ndeleteEvent( eventId: number, entryGroup: any) {\n  let event = this.allEvents?.find(e => e?.id === eventId);\n  if (event) {\n      // Find the index of the entryGroup to delete\n      const entryIndex = event.entries.indexOf(entryGroup);\n      if (entryIndex > -1) {\n          event.entries.splice(entryIndex, 1); // Remove the specific entry\n      }\n\n      // If the event has no more entries, remove the event entirely\n      if (event.entries.length === 0) {\n          const eventIndex = this.allEvents?.indexOf(event);\n          if (eventIndex > -1) {\n              this.allEvents?.splice(eventIndex, 1); // Remove the entire event\n          }\n      }\n  }\n  let eventData = {};\n   eventData['action'] = \"delete\";\n   eventData['data'] = event;\n  this.eventSelected.emit(eventData);\n  this.generateCalendar(); // Regenerate the calendar to reflect the changes\n}\n\n // VD 06Sep24 calendar changes\n  addEvent(day: CalendarDay, entryQues) {\n    // Transform new entries into the desired format\n    const newEntries = entryQues.reduce((acc, q) => {\n        acc[q.id] = { ...q };\n        return acc;\n    }, {});\n\n    // Find an existing event for the given date\n    const existingEvent = day.events?.find(event => event.date === day.date);\n\n    if (existingEvent) {\n        // Merge new entries into the existing event's entries array\n        // Check if the entries array already contains an object with the same id\n        const existingEntries = existingEvent.entries.map(entry => ({ ...entry }));\n        // Append new entries to the existing entries\n        existingEntries.push(newEntries);\n        existingEvent.entries = existingEntries;\n    } else {\n        // Create a new event if it doesn't exist for the given date\n        const newEvent = {\n            id: this.generateId(),\n            date: day.date,\n            entries: [newEntries] // Wrap the new entries in an array\n        };\n        day.events = day?.events || []\n        day.events.push(newEvent);\n        this.allEvents?.push(newEvent);\n        //this.eventSelected.emit(this.allEvents);\n        let eventData = {};\n        eventData['action'] = \"add\";\n        eventData['data'] = newEvent;\n        this.eventSelected.emit(eventData);\n    }\n    this.generateCalendar();\n    console.log('allEvents', this.allEvents);\n}\n // VD 06Sep24 calendar changes\n onSave() {\n    if (this.editingEventId !== null) {\n        const event = this.allEvents?.find(e => e?.id === this.editingEventId);\n        if (event && this.editingEntryGroup) {\n            // Update the specific entry group within the event\n            const entryIndex = event.entries.findIndex(entryGroup => entryGroup === this.editingEntryGroup);\n            if (entryIndex > -1) {\n                event.entries[entryIndex] = this.calendarQuestion.reduce((acc, q) => {\n                    acc[q.id] = { ...q };\n                    return acc;\n                }, {});\n            }\n        }\n     // this.eventSelected.emit(this.allEvents);\n      let eventData = {};\n      eventData['action'] = \"edit\";\n      eventData['data'] = event;\n      this.eventSelected.emit(eventData);\n    } else {\n        if (this.selectedDay) {\n            this.addEvent(this.selectedDay, this.calendarQuestion);\n        }\n    }\n    this.closeCalendarModal();\n    this.generateCalendar();\n}\n\n  // onCancel() {\n  //   console.log('Cancel button clicked');\n  //   this.closeCalendarModal();\n  // }\n  //this funtion need to be used\n  // handleQuestionEvent(ques){\n  //     // Update the questions array with the new question\n  //     const index = this.calendarQuestion.findIndex(q => q.id === ques.id);\n  //     if (index > -1) {\n  //       // If question already exists, update it\n  //       this.calendarQuestion[index] = ques;\n  //     } else {\n  //       // If question doesn't exist, add it to the array\n  //       this.calendarQuestion.push(ques);\n  //     }\n  //     console.log(this.calendarQuestion);\n  //   }\n\n // VD 06Sep24 calendar changes\n  generateId() {\n    return '_' + Math.random().toString(36).substr(2, 9);\n  }\n\n  getEntryKeys(entryGroup: any): string[] {\n    return Object.keys(entryGroup);\n}\n\nremoveCharacters(questionText:string){\n  let updatedText = questionText?.replace(/<[^>]*>/g, '');\n  return updatedText;\n}\n\n}\n","<div class=\"align-calendar\">\n    <div class=\"calendar-container\">\n      <div class=\"calendar-header\">\n          <button (click)=\"previousMonth()\"><< Previous >></button>\n          <h3>{{ currentDate | date: 'MMMM yyyy' }}</h3>\n          <button (click)=\"nextMonth()\"><< Next >></button>\n      </div>\n      <div class=\"calendar-grid\">\n          <div class=\"day-of-week\" *ngFor=\"let day of daysOfWeek\">{{ day }}</div>\n          <div\n              class=\"calendar-day\"\n              *ngFor=\"let day of calendarDays\"\n              [class.not-current-month]=\"!day.isCurrentMonth\"\n              [class.past]=\"day.isPast\"\n              [class.today]=\"day.isToday\"\n              [class.future]=\"day.isFuture\"\n              [class.selected]=\"day.isSelected\"\n              (click)=\"selectDay(day)\"\n        >\n              <div class=\"day-number\">{{ day.date.getDate() }}\n                <span *ngIf=\"day?.events?.length > 0\" class=\"entry-indicator\" [class.select]=\"day?.isSelected\"></span>\n              </div>\n              <!-- <div *ngFor=\"let event of day.events\" >\n                  <div *ngFor=\"let entryGroup of event.entries\" class=\"event\">\n                      <div *ngFor=\"let key of getEntryKeys(entryGroup)\">\n                          <div *ngIf=\"entryGroup[key].type == 'Time'\">\n                              {{ entryGroup[key].input?.value | date: 'shortTime' }}\n                          </div>\n                          <div *ngIf=\"entryGroup[key].type != 'Time'\">\n                              {{ entryGroup[key].input }}\n                          </div>\n                      </div>\n                  </div>\n              </div> -->\n          </div>\n      </div>\n  </div>\n    <div class=\"appoinappointment\">\n      <div class=\"appointments-container\">\n          <h4>Add Appointment</h4>\n          <button *ngIf=\"selectedDay\" (click)=\"addAppointment()\">Add</button>\n      </div>\n      <!--VD 06Sep24 calendar updates--> \n      <!-- RS 09DEC24 Changed keys--> \n      <div *ngIf=\"showAppoinmentSection && selectedDay?.events?.length > 0\" class=\"appointments-container\">\n          <h4>Appointments</h4>\n          <div  *ngFor=\"let event of selectedDay?.events\">\n              <div class=\"event\" *ngFor=\"let entryGroup of event.entries\">\n                    <div class=\"event-info\">\n                      <div *ngFor=\"let key of getEntryKeys(entryGroup)\" class=\"entry-row\">\n                        <div *ngIf=\"entryGroup[key].questionText\" class=\"entry-text\">\n                            {{removeCharacters(entryGroup[key].questionText)}}:\n                        </div>\n                        <div class=\"entry-value\">\n                            <!-- VD 09Sep24- date type and link type updates    -->\n                            <span *ngIf=\"entryGroup[key].type != 'Time' && entryGroup[key].type != 'Link'&& entryGroup[key].type != 'Date'\">{{ entryGroup[key].input }}</span>\n                            <span *ngIf=\"entryGroup[key].type == 'Time'\">{{ entryGroup[key].input | date: 'shortTime' }}</span>\n                            <span *ngIf=\"entryGroup[key].type == 'Date'\">{{ entryGroup[key].input | date: 'mediumDate' }}</span>\n                            <span *ngIf=\"entryGroup[key].type == 'Link'\">\n                                <a [href]=\"'//'+ entryGroup[key].input\" target=\"_blank\">{{removeCharacters(entryGroup[key].questionText)}}</a>\n                            </span>\n                        </div>\n                    </div>\n                      <div class=\"event-actions\">\n                        <button (click)=\"editEvent(event,entryGroup)\">Edit</button>\n                        <button (click)=\"deleteEvent(event.id,entryGroup)\">Delete</button>\n                     </div>\n                  </div>\n              </div>\n          </div>\n      </div>\n  </div>\n</div>\n\n<!-- <app-custom-model\n  [modalTitle]=\"modalTitle\"\n  [isModalOpen]=\"isModalOpen\"\n  [modalSize]=\"modalSize\"\n  [saveButtonValue]=\"saveButtonValue\"\n  [modalFooter]=\"modalFooter\"\n  (saveButtonEmit)=\"onSave()\"\n  (cancelButtonEmit)=\"onCancel()\"\n>\n<lib-questionbook [qbItem]=\"qbRefrenceBook\" [questions]=\"referenceQuestions\" (handleQuestion)=\"handleQuestionEvent($event)\"></lib-questionbook>\n<ng-template dynamicComponentHost ></ng-template>\n</app-custom-model> -->"]}
367
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"custom-calendar.component.js","sourceRoot":"","sources":["../../../../../../projects/nxt-app/src/lib/components/custom-calendar/custom-calendar.component.ts","../../../../../../projects/nxt-app/src/lib/components/custom-calendar/custom-calendar.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, EventEmitter, Input, OnInit, Output, SimpleChanges, ViewChild } from '@angular/core';\nimport { Question } from '../../wrapper';\n//import { QuestionbookComponent } from '../../pages/questionbook/questionbook.component';\n//import { ComponenthostDirective } from '../../directives/componenthost/componenthost.directive';\nimport { ChangeService } from '../../services/change.service';\ninterface CalendarDay {\n  date: Date;\n  events: any[];\n  isCurrentMonth: boolean;\n  isPast: boolean;\n  isToday: boolean;\n  isFuture: boolean;\n  isSelected?: boolean;\n}\n@Component({\n  selector: 'app-custom-calendar',\n  templateUrl: './custom-calendar.component.html',\n  styleUrls: ['./custom-calendar.component.css'],\n})\nexport class CustomCalendarComponent implements OnInit {\n  @Output() eventSelected = new EventEmitter<any>();\n  // VD 06Sep24 calendar changes\n  @Output() dateSelected = new EventEmitter<any>();\n  @Output() openModal = new EventEmitter<any>();\n  @Output() closeModal = new EventEmitter<any>();\n  @Input() allEvents: any[] = []; \n  @Input() question: Question\n  @Input() nxtId: string;\n  //@ViewChild(ComponenthostDirective, { static: true }) dynamicHost: ComponenthostDirective;\n  entries = [];\n  referenceQuestions = [];\n  qbRefrenceBook:any;\n  calendarQuestion = [];\n  calendar = {};\n  currentDate: Date = new Date();\n  calendarDays: CalendarDay[] = [];\n  daysOfWeek: string[] = ['Sunday', 'Monday', 'Tuesday', 'Wednesday', 'Thursday', 'Friday', 'Saturday'];\n  newEventTitle: string = '';\n  newEventTime: string = '';\n  newDescription: string = '';\n  newLink: string = '';\n  selectedDay: CalendarDay | null = null;\n  isModalOpen = false;\n  modalTitle = 'Custom Modal';\n  modalSize = 'large';\n  saveButtonValue = 'Save';\n  modalFooter = true;\n  editingEventId: number;\n  editingEntryGroup: any;\n  showAppoinmentSection: boolean = true;\n  subscription: any;\n  constructor( private changeService: ChangeService) { }\n  ngOnInit() {\n     if(this.question?.input){\n      this.allEvents = this.question.input;\n     }\n    this.processQuestion();\n    this.generateCalendar();\n    this.subscription = this.changeService.customChange$.subscribe(\n      (changeValue) => {\n          if(changeValue == 'calendar-modal-save') {\n            this.onSave();\n          }\n          if(changeValue == 'dataBind') {\n            if(this.question?.input){\n              this.allEvents = this.question.input;\n             }\n            this.processQuestion();\n            this.generateCalendar();\n          }\n      }\n    );\n   // this.dateSelected.emit(this.calendar);\n    //this.eventSelected.emit(this.allEvents);\n  }\n  // RS 09DEC24 Changed keys\n  processQuestion(){\n    // SKS20MAR25 check if question fieldsmeta is string\n    this.entries =  typeof this.question['fieldsMeta'] === 'object'  ?  this.question['fieldsMeta'] || [{}] : JSON.parse( this.question['fieldsMeta']) ;\n    this.qbRefrenceBook = JSON.parse(this.question['qbReferenceQuestions']);\n    let title = this.qbRefrenceBook?.questionbook?.title;\n    this.modalTitle = title;\n    this.referenceQuestions = [];\n    if(this.entries.length > 0){\n       this.entries.forEach(element => {\n           if(element.questionReference){\n             let qReference = JSON.parse(element.questionReference);\n             this.referenceQuestions.push(qReference?.question);\n           }\n       });\n    }\n    console.log('entries-->');\n    console.log('question-->');\n    console.log(this.entries);\n    console.log(this.referenceQuestions);\n  }\n   // sunday comment\n  // openQuestionBookModal() {\n  //   const viewContainerRef = this.dynamicHost.viewContainerRef;\n  //   viewContainerRef.clear();\n  //   const componentRef = viewContainerRef.createComponent(QuestionbookComponent);\n  //   componentRef.instance.qbItem = this.qbRefrenceBook;\n  //   componentRef.instance.questions = this.referenceQuestions;\n  //   componentRef.instance.handleQuestion.subscribe((event: any) => this.handleQuestionEvent(event));\n  // }\n\n  generateCalendar() {\n    const year = this.currentDate.getFullYear();\n    const month = this.currentDate.getMonth();\n\n    const startOfMonth = new Date(year, month, 1);\n    const endOfMonth = new Date(year, month + 1, 0);\n\n    const startDayOfWeek = startOfMonth.getDay();\n    const endDayOfWeek = endOfMonth.getDay();\n\n    const startDate = new Date(startOfMonth);\n    startDate.setDate(startDate.getDate() - startDayOfWeek);\n\n    const endDate = new Date(endOfMonth);\n    endDate.setDate(endDate.getDate() + (6 - endDayOfWeek));\n\n    const today = new Date(new Date().setHours(0, 0, 0, 0));\n    \n     this.calendarDays = [];\n      for (let d = new Date(startDate); d <= endDate; d.setDate(d.getDate() + 1)) {\n        const date = new Date(d);\n        this.calendarDays.push({\n          date: date,\n          events: [],\n          isCurrentMonth: d.getMonth() === month,\n          isPast: date < today,\n          isToday: date.getTime() === today.getTime(),\n          isFuture: date > today,\n        });\n      }\n\n    // Populate calendar with events from allEvents array\n    this.calendarDays.forEach(day => {\n      day.events = this.allEvents?.filter(event => event?.date?.toDateString() === day.date.toDateString());\n    });\n     // VD 06Sep24 calendar changes\n    let cal = {}\n    cal['year'] = year;\n    cal['month'] = month + 1;\n    this.calendar = cal;\n  }\n\n  selectDay(day: CalendarDay) {\n    console.log(day);\n     // VD 06Sep24 calendar changes\n    this.showAppoinmentSection = true;\n    this.selectedDay = day;\n   // this.eventSelected.emit(day?.events);\n    const previouslySelectedDay = this.calendarDays.find(d => d.isSelected);\n    if (previouslySelectedDay) {\n      previouslySelectedDay.isSelected = false;\n    }\n    // Select the clicked day\n    day.isSelected = true;\n   // VD 09Sep24- setup the query param data for api call\n    let referenceData = [];\n    this.referenceQuestions.forEach(ques => {\n      // VD 09-09-24 get the selected date\n      // need to add in the document\n      // RS 09DEC24 Changed keys\n       if(ques.referenceField == 'selectedDate'){\n          ques.input = day.date.toISOString();\n          console.log(ques.input);\n       }\n       // VD 09-09-24 get the query refrence  field data to pass the queryParam  for api\n       if(ques.subText){\n        let subText = JSON.parse(ques.subText);\n        if (subText.queryField && subText.queryValueReference) {\n            let currentQues = ques;\n            let queryReferences = subText.queryValueReference.split(',');   \n            queryReferences.forEach(refField => {\n                let refQues = this.referenceQuestions.find(q => q.referenceField === refField);\n                if (refQues) {\n                    referenceData.push(refQues);\n                }\n            });\n            // Add the referenceData array to the current question\n            currentQues.referenceQueryData = referenceData;\n        }\n       }\n    })\n  }\n\n  previousMonth() {\n    this.showAppoinmentSection = false;\n    this.currentDate.setMonth(this.currentDate.getMonth() - 1);\n    this.currentDate = new Date(this.currentDate); // Ensure the date object is updated\n    this.generateCalendar();\n    this.dateSelected.emit(this.calendar);\n    this.eventSelected.emit(this.allEvents);\n  }\n\n  nextMonth() {\n     // VD 06Sep24 calendar changes\n    this.showAppoinmentSection = false;\n    this.currentDate.setMonth(this.currentDate.getMonth() + 1);\n    this.currentDate = new Date(this.currentDate); // Ensure the date object is updated\n    this.generateCalendar();\n    this.dateSelected.emit(this.calendar);\n    this.eventSelected.emit(this.allEvents);\n  }\n\n  addAppointment() {\n    this.isModalOpen = true;\n     this.calendarQuestion = this.referenceQuestions.map(q => ({ ...q, input: '' }));\n    this.referenceQuestions.forEach(ques => {\n      // clear the input\n      if(ques.referenceField != 'selectedDate'){\n        if(ques.type == 'Dropdown'){\n          delete ques.input;\n          delete ques.selectedValue;\n           // VD 06Sep24 calendar changes\n        }else {\n          delete ques.input;\n        }\n      }\n    });\n    console.log(this.referenceQuestions);\n    this.editingEventId = null;\n    this.calendarQuestion = this.referenceQuestions;\n    this.openBookModel();\n    // sunday comment\n    //this.openQuestionBookModal();\n  }\n\n  openBookModel(){\n    this.openModal.emit({\n      qbRefrenceBook: this.qbRefrenceBook,\n      referenceQuestions: this.referenceQuestions,\n      modalTitle : this.modalTitle,\n      modalSize : this.modalSize,\n      saveButtonValue : this.saveButtonValue,\n      modalFooter : this.modalFooter,\n\n    });\n  }\n\n  closeCalendarModal() {\n    this.isModalOpen = false;\n    this.closeModal.emit(true);\n  }\n // VD 06Sep24 calendar changes\n\neditEvent(event: any, entryGroup: any) {\n  this.isModalOpen = true;\n  this.referenceQuestions = Object.values(entryGroup);\n  this.calendarQuestion = [...this.referenceQuestions]; // Make a copy of the current entries to edit\n  this.editingEventId = event.id;\n  this.editingEntryGroup = entryGroup; // Store the entry group being edited\n  this.generateCalendar(); // Regenerate the calendar to reflect changes\n  this.openBookModel();\n  // suday comment\n // this.openQuestionBookModal();\n\n}\n\ndeleteEvent( eventId: number, entryGroup: any) {\n  let event = this.allEvents?.find(e => e?.id === eventId);\n  if (event) {\n      // Find the index of the entryGroup to delete\n      const entryIndex = event.entries.indexOf(entryGroup);\n      if (entryIndex > -1) {\n          event.entries.splice(entryIndex, 1); // Remove the specific entry\n      }\n\n      // If the event has no more entries, remove the event entirely\n      if (event.entries.length === 0) {\n          const eventIndex = this.allEvents?.indexOf(event);\n          if (eventIndex > -1) {\n              this.allEvents?.splice(eventIndex, 1); // Remove the entire event\n          }\n      }\n  }\n  let eventData = {};\n   eventData['action'] = \"delete\";\n   eventData['data'] = event;\n  this.eventSelected.emit(eventData);\n  this.generateCalendar(); // Regenerate the calendar to reflect the changes\n}\n\n // VD 06Sep24 calendar changes\n  addEvent(day: CalendarDay, entryQues) {\n    // Transform new entries into the desired format\n    const newEntries = entryQues.reduce((acc, q) => {\n        acc[q.id] = { ...q };\n        return acc;\n    }, {});\n\n    // Find an existing event for the given date\n    const existingEvent = day.events?.find(event => event.date === day.date);\n\n    if (existingEvent) {\n        // Merge new entries into the existing event's entries array\n        // Check if the entries array already contains an object with the same id\n        const existingEntries = existingEvent.entries.map(entry => ({ ...entry }));\n        // Append new entries to the existing entries\n        existingEntries.push(newEntries);\n        existingEvent.entries = existingEntries;\n    } else {\n        // Create a new event if it doesn't exist for the given date\n        const newEvent = {\n            id: this.generateId(),\n            date: day.date,\n            entries: [newEntries] // Wrap the new entries in an array\n        };\n        day.events = day?.events || []\n        day.events.push(newEvent);\n        this.allEvents?.push(newEvent);\n        //this.eventSelected.emit(this.allEvents);\n        let eventData = {};\n        eventData['action'] = \"add\";\n        eventData['data'] = newEvent;\n        this.eventSelected.emit(eventData);\n    }\n    this.generateCalendar();\n    console.log('allEvents', this.allEvents);\n}\n // VD 06Sep24 calendar changes\n onSave() {\n    if (this.editingEventId !== null) {\n        const event = this.allEvents?.find(e => e?.id === this.editingEventId);\n        if (event && this.editingEntryGroup) {\n            // Update the specific entry group within the event\n            const entryIndex = event.entries.findIndex(entryGroup => entryGroup === this.editingEntryGroup);\n            if (entryIndex > -1) {\n                event.entries[entryIndex] = this.calendarQuestion.reduce((acc, q) => {\n                    acc[q.id] = { ...q };\n                    return acc;\n                }, {});\n            }\n        }\n     // this.eventSelected.emit(this.allEvents);\n      let eventData = {};\n      eventData['action'] = \"edit\";\n      eventData['data'] = event;\n      this.eventSelected.emit(eventData);\n    } else {\n        if (this.selectedDay) {\n            this.addEvent(this.selectedDay, this.calendarQuestion);\n        }\n    }\n    this.closeCalendarModal();\n    this.generateCalendar();\n}\n\n  // onCancel() {\n  //   console.log('Cancel button clicked');\n  //   this.closeCalendarModal();\n  // }\n  //this funtion need to be used\n  // handleQuestionEvent(ques){\n  //     // Update the questions array with the new question\n  //     const index = this.calendarQuestion.findIndex(q => q.id === ques.id);\n  //     if (index > -1) {\n  //       // If question already exists, update it\n  //       this.calendarQuestion[index] = ques;\n  //     } else {\n  //       // If question doesn't exist, add it to the array\n  //       this.calendarQuestion.push(ques);\n  //     }\n  //     console.log(this.calendarQuestion);\n  //   }\n\n // VD 06Sep24 calendar changes\n  generateId() {\n    return '_' + Math.random().toString(36).substr(2, 9);\n  }\n\n  getEntryKeys(entryGroup: any): string[] {\n    return Object.keys(entryGroup);\n}\n\nremoveCharacters(questionText:string){\n  let updatedText = questionText?.replace(/<[^>]*>/g, '');\n  return updatedText;\n}\n\n}\n","<div class=\"align-calendar\">\n    <div class=\"calendar-container\">\n      <div class=\"calendar-header\">\n          <button (click)=\"previousMonth()\"><< Previous >></button>\n          <h3>{{ currentDate | date: 'MMMM yyyy' }}</h3>\n          <button (click)=\"nextMonth()\"><< Next >></button>\n      </div>\n      <div class=\"calendar-grid\">\n          <div class=\"day-of-week\" *ngFor=\"let day of daysOfWeek\">{{ day }}</div>\n          <div\n              class=\"calendar-day\"\n              *ngFor=\"let day of calendarDays\"\n              [class.not-current-month]=\"!day.isCurrentMonth\"\n              [class.past]=\"day.isPast\"\n              [class.today]=\"day.isToday\"\n              [class.future]=\"day.isFuture\"\n              [class.selected]=\"day.isSelected\"\n              (click)=\"selectDay(day)\"\n        >\n              <div class=\"day-number\">{{ day.date.getDate() }}\n                <span *ngIf=\"day?.events?.length > 0\" class=\"entry-indicator\" [class.select]=\"day?.isSelected\"></span>\n              </div>\n              <!-- <div *ngFor=\"let event of day.events\" >\n                  <div *ngFor=\"let entryGroup of event.entries\" class=\"event\">\n                      <div *ngFor=\"let key of getEntryKeys(entryGroup)\">\n                          <div *ngIf=\"entryGroup[key].type == 'Time'\">\n                              {{ entryGroup[key].input?.value | date: 'shortTime' }}\n                          </div>\n                          <div *ngIf=\"entryGroup[key].type != 'Time'\">\n                              {{ entryGroup[key].input }}\n                          </div>\n                      </div>\n                  </div>\n              </div> -->\n          </div>\n      </div>\n  </div>\n    <div class=\"appoinappointment\">\n      <div class=\"appointments-container\">\n          <h4>Add Appointment</h4>\n          <button *ngIf=\"selectedDay\" (click)=\"addAppointment()\">Add</button>\n      </div>\n      <!--VD 06Sep24 calendar updates--> \n      <!-- RS 09DEC24 Changed keys--> \n      <div *ngIf=\"showAppoinmentSection && selectedDay?.events?.length > 0\" class=\"appointments-container\">\n          <h4>Appointments</h4>\n          <div  *ngFor=\"let event of selectedDay?.events\">\n              <div class=\"event\" *ngFor=\"let entryGroup of event.entries\">\n                    <div class=\"event-info\">\n                      <div *ngFor=\"let key of getEntryKeys(entryGroup)\" class=\"entry-row\">\n                        <div *ngIf=\"entryGroup[key].questionText\" class=\"entry-text\">\n                            {{removeCharacters(entryGroup[key].questionText)}}:\n                        </div>\n                        <div class=\"entry-value\">\n                            <!-- VD 09Sep24- date type and link type updates    -->\n                            <span *ngIf=\"entryGroup[key].type != 'Time' && entryGroup[key].type != 'Link'&& entryGroup[key].type != 'Date'\">{{ entryGroup[key].input }}</span>\n                            <span *ngIf=\"entryGroup[key].type == 'Time'\">{{ entryGroup[key].input | date: 'shortTime' }}</span>\n                            <span *ngIf=\"entryGroup[key].type == 'Date'\">{{ entryGroup[key].input | date: 'mediumDate' }}</span>\n                            <span *ngIf=\"entryGroup[key].type == 'Link'\">\n                                <a [href]=\"'//'+ entryGroup[key].input\" target=\"_blank\">{{removeCharacters(entryGroup[key].questionText)}}</a>\n                            </span>\n                        </div>\n                    </div>\n                      <div class=\"event-actions\">\n                        <button (click)=\"editEvent(event,entryGroup)\">Edit</button>\n                        <button (click)=\"deleteEvent(event.id,entryGroup)\">Delete</button>\n                     </div>\n                  </div>\n              </div>\n          </div>\n      </div>\n  </div>\n</div>\n\n<!-- <app-custom-model\n  [modalTitle]=\"modalTitle\"\n  [isModalOpen]=\"isModalOpen\"\n  [modalSize]=\"modalSize\"\n  [saveButtonValue]=\"saveButtonValue\"\n  [modalFooter]=\"modalFooter\"\n  (saveButtonEmit)=\"onSave()\"\n  (cancelButtonEmit)=\"onCancel()\"\n>\n<lib-questionbook [qbItem]=\"qbRefrenceBook\" [questions]=\"referenceQuestions\" (handleQuestion)=\"handleQuestionEvent($event)\"></lib-questionbook>\n<ng-template dynamicComponentHost ></ng-template>\n</app-custom-model> -->"]}
@@ -46,7 +46,8 @@ export class CustomTableComponent {
46
46
  this.dataService = dataService;
47
47
  }
48
48
  ngOnInit() {
49
- const parsedMeta = JSON.parse(this.question['fieldsMeta']);
49
+ // SKS20MAR25 check if question fieldsmeta is string
50
+ const parsedMeta = typeof this.question['fieldsMeta'] === 'object' ? this.question['fieldsMeta'] || [{}] : JSON.parse(this.question['fieldsMeta']);
50
51
  if (!parsedMeta || !Array.isArray(parsedMeta) || parsedMeta.length === 0) {
51
52
  console.warn('No valid metadata provided');
52
53
  return;
@@ -246,4 +247,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
246
247
  }], valueChange: [{
247
248
  type: Output
248
249
  }] } });
249
- //# 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      const parsedMeta = 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"]}
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"]}