@rangertechnologies/ngnxt 2.1.15 → 2.1.16

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.
@@ -1,43 +1,114 @@
1
1
  import { Component, EventEmitter, Input, Output } from '@angular/core';
2
2
  import * as i0 from "@angular/core";
3
- import * as i1 from "../../i18n.service";
4
- import * as i2 from "@angular/common";
5
- import * as i3 from "@angular/forms";
6
- import * as i4 from "../../i18n.pipe";
3
+ import * as i1 from "../../services/change.service";
4
+ import * as i2 from "../../i18n.service";
5
+ import * as i3 from "../../services/salesforce.service";
6
+ import * as i4 from "../../services/data.service";
7
+ import * as i5 from "@angular/common";
8
+ import * as i6 from "@angular/forms";
7
9
  export class CustomTableComponent {
10
+ changeService;
8
11
  i18nService;
12
+ sfService;
13
+ dataService;
9
14
  question;
10
15
  valueChange = new EventEmitter();
11
16
  tableInfo;
12
17
  tableHeader = [];
13
- tableData;
18
+ tableData = [];
14
19
  addRowColSpan;
15
20
  tableSize; // HA 28DEC23 table size declaration
16
- constructor(i18nService) {
21
+ objName;
22
+ filterLogic;
23
+ fieldMeta;
24
+ firStr;
25
+ searchBox = false;
26
+ apiMeta;
27
+ options;
28
+ isDisabled = true;
29
+ subscription;
30
+ labelField;
31
+ constructor(changeService, i18nService, sfService, dataService) {
32
+ this.changeService = changeService;
17
33
  this.i18nService = i18nService;
34
+ this.sfService = sfService;
35
+ this.dataService = dataService;
18
36
  }
19
37
  ngOnInit() {
20
- // HA 28DEC23 commented the previously working logic of sub Text
21
- // if(this.question.Sub_Text__c != undefined) {
22
- // this.tableInfo = JSON.parse(this.question.Sub_Text__c);
23
- // this.tableHeader = this.tableInfo.header;
24
- // this.tableData = this.tableInfo.data;
25
- // this.valueChange.emit(this.tableData);
26
- // if(this.tableData?.addRow) {
27
- // this.addRowColSpan = this.tableHeader.length - 2;
28
- // }
29
- // }
30
- // HA 28DEC23 Created working logic for table header
31
- if (this.question['QB_Reference_Questions__c'] != undefined) {
32
- this.tableInfo = JSON.parse(this.question['QB_Reference_Questions__c']);
33
- this.tableInfo['questionbook'].Questions__r.records.forEach(element => {
34
- this.tableHeader.push(element);
35
- });
36
- this.tableSize = 12 / this.tableHeader.length;
38
+ this.tableHeader = JSON.parse(this.question['Fields_Meta__c']);
39
+ this.tableSize = 10 / this.tableHeader.length;
40
+ if (this.apiMeta !== undefined) {
41
+ this.options = [];
42
+ let apiObj = JSON.parse(this.apiMeta);
43
+ this.labelField = apiObj.field;
44
+ if (apiObj.endpoint) {
45
+ this.dataService.apiResponse(apiObj.endpoint)?.subscribe((apiResponse) => {
46
+ let responses;
47
+ if (apiObj.variable) {
48
+ responses = apiResponse[apiObj.variable];
49
+ let results = [];
50
+ // HA 19JAN24 To avoid undefined error in console
51
+ for (let i = 0; i < responses?.length; i++) {
52
+ var resp = responses[i];
53
+ results.push(resp);
54
+ }
55
+ this.options = results;
56
+ }
57
+ else { // VD 19JAN24 - if response has value(which is array) only
58
+ responses = apiResponse;
59
+ this.options = responses;
60
+ }
61
+ this.options = this.options.map((obj) => ({ ...obj, edit: false }));
62
+ // Reference https://www.npmjs.com/package/@ng-select/ng-select
63
+ this.tableData = this.options;
64
+ console.log('tableData', this.tableData);
65
+ });
66
+ }
67
+ // VD NOV23 - handle the dependent update for dropdown
68
+ let sourceId = apiObj.sourceQuestionId;
69
+ if (sourceId) {
70
+ // // VD 10May24 Subscribe for the changes
71
+ this.subscription = this.changeService.changeAnnounced$.subscribe((changeValue) => {
72
+ if (changeValue != undefined) {
73
+ if (changeValue.valueObj != undefined && changeValue.fromQuestionId == apiObj.sourceQuestionId) {
74
+ console.log('changes happen');
75
+ this.options = this.options.map((obj) => ({ ...obj, edit: false }));
76
+ let item = changeValue.valueObj;
77
+ let validItem = true;
78
+ if (this.tableData.length > 0) {
79
+ this.tableData.forEach(element => {
80
+ if (element.id == item.id) {
81
+ validItem = false;
82
+ }
83
+ });
84
+ }
85
+ if (validItem) {
86
+ if (this.tableData.length > 0) {
87
+ this.tableData = [...this.tableData, item];
88
+ this.emitTableDataValue(this.tableData);
89
+ }
90
+ else {
91
+ this.tableData.push(item);
92
+ this.emitTableDataValue(this.tableData);
93
+ }
94
+ }
95
+ }
96
+ this.changeService.confirmChange(apiObj.sourceQuestionId);
97
+ }
98
+ });
99
+ }
37
100
  }
101
+ console.log('tableData', this.tableData);
102
+ console.log('tableHeader', this.tableHeader);
103
+ console.log('tableInfo', this.tableInfo);
38
104
  }
39
105
  addRow() {
40
- let newItem = JSON.parse(JSON.stringify(this.tableInfo.newRowDefault));
106
+ let newItem = {};
107
+ this.tableHeader.forEach(item => {
108
+ if (item.apiName) {
109
+ newItem[item.apiName] = "";
110
+ }
111
+ });
41
112
  const updatedTableData = [...this.tableData, newItem];
42
113
  this.tableData = updatedTableData;
43
114
  this.emitTableDataValue(updatedTableData);
@@ -48,9 +119,20 @@ export class CustomTableComponent {
48
119
  }
49
120
  updateLabel(rowIndex, label, value) {
50
121
  this.tableData[rowIndex][label] = value;
51
- this.tableData[rowIndex].name = value.replace(/\s+/g, '').toLowerCase();
52
122
  this.emitTableDataValue(this.tableData);
53
123
  }
124
+ deleteRow(rowIndex) {
125
+ this.tableData.splice(rowIndex, 1);
126
+ }
127
+ editRow(rowIndex) {
128
+ var a = 0;
129
+ this.tableData.forEach(element => {
130
+ if (a === rowIndex) {
131
+ element.edit = true;
132
+ }
133
+ a++;
134
+ });
135
+ }
54
136
  updateNumber(item, label, value) {
55
137
  item.value[label] = value;
56
138
  this.emitTableDataValue(this.tableData);
@@ -58,15 +140,17 @@ export class CustomTableComponent {
58
140
  emitTableDataValue(updatedTableData) {
59
141
  this.valueChange.emit(updatedTableData);
60
142
  }
61
- static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: CustomTableComponent, deps: [{ token: i1.I18nService }], target: i0.ɵɵFactoryTarget.Component });
62
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: CustomTableComponent, selector: "app-custom-table", inputs: { question: "question" }, outputs: { valueChange: "valueChange" }, ngImport: i0, template: "<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 *ngFor=\"let header of tableHeader; let hi = index\" [class]=\"'col-md-' + tableSize\">\n {{ header.Group__c }}\n </th>\n </thead>\n <tbody id=\"safetyMeasuresTableBody\">\n <tr *ngFor=\"let item of tableData; let i = index\">\n <td *ngFor=\"let header of tableHeader; let j = index\">\n <div *ngIf=\"header.type === 'imagetext'\" [class]=\"'col-md-' + header.size\" style=\"display: flex;\">\n <img style=\"width: 35px; height: 32px; margin-right: 5px;\" [src]=\"item.imageSrc\" [alt]=\"item.altText\">\n <input type=\"text\" [(ngModel)]=\"item[header.fieldName]\" (ngModelChange)=\"updateLabel(i, header.fieldName, item[header.fieldName])\" class=\"she-line-input table-input\">\n </div>\n <div *ngIf=\"header.type === 'image'\" [class]=\"'col-md-' + header.size\">\n <img style=\"width: 35px; height: 32px; margin-right: 5px;\" [src]=\"item[header.fieldName]\" [alt]=\"item.altText\">\n </div>\n <div *ngIf=\"header.type === 'text'\">\n <input type=\"text\" [(ngModel)]=\"item[header.fieldName]\" [placeholder]=\"header.placeholder\" (ngModelChange)=\"updateLabel(i, header.fieldName, item[header.fieldName])\" class=\"she-line-input table-input\">\n </div>\n <div *ngIf=\"header.type === 'radio'\" [class]=\"'col-md-' + header.size\">\n <input type=\"radio\" [name]=\"item.name\" [checked]=\"item.value == header.fieldName\" (click)=\"updateRadio(item, header.fieldName)\">\n </div>\n </td>\n </tr>\n <tr *ngIf=\"tableInfo.addRow\">\n <td colspan=\"1\">\n <!-- HA 19DEC23 For translation -->\n <b>{{ 'addMore' | i18n:i18nService.currentLanguage }}</b>\n </td>\n <td colspan=\"3\" style=\"text-align: center; cursor: pointer;\" id=\"addSafety\" (click)=\"addRow()\">\n +\n </td>\n </tr>\n </tbody>\n</table>\n", styles: [".table{width:100%;max-width:100%;margin-bottom:20px;border-collapse:collapse;border-spacing:0}.table-bordered{border:1px solid #ddd}thead{background-color:#03a9f4}thead th{color:#fff;font-size:14px}.table-bordered>tbody>tr>td,.table-bordered>tbody>tr>th,.table-bordered>tfoot>tr>td,.table-bordered>tfoot>tr>th,.table-bordered>thead>tr>td,.table-bordered>thead>tr>th{border:1px solid #ddd}th{text-align:left}thead .permission{text-align:center}.table>tbody>tr>td,.table>tbody>tr>th,.table>tfoot>tr>td,.table>tfoot>tr>th,.table>thead>tr>td,.table>thead>tr>th{padding:8px;line-height:1.42857143;vertical-align:top;border-top:1px solid #ddd}tbody{color:#797979}.table-striped>tbody>tr:nth-of-type(odd){background-color:#f9f9f9}tbody td{font-size:13px}.permission_yes,.permission_no,.permission_na{text-align:center}.none-border th{border:none}\n"], dependencies: [{ kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "pipe", type: i4.I18nPipe, name: "i18n" }] });
143
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: CustomTableComponent, deps: [{ token: i1.ChangeService }, { token: i2.I18nService }, { token: i3.SalesforceService }, { token: i4.DataService }], target: i0.ɵɵFactoryTarget.Component });
144
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: CustomTableComponent, selector: "app-custom-table", inputs: { question: "question", apiMeta: "apiMeta" }, outputs: { valueChange: "valueChange" }, ngImport: i0, template: "<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 <th *ngFor=\"let header of tableHeader; let hi = index\" [class]=\"'col-md-' + tableSize\">\n {{ header.label }}\n </th>\n <th class=\"col-md-2\" colspan=\"2\">Actions</th>\n </thead>\n <tbody *ngIf=\"tableData\">\n <tr *ngFor=\"let item of tableData; let i = index\">\n <!-- <td><input type=\"checkbox\" [(ngModel)]=\"item.selected\" (change)=\"selectItem(item)\"></td> -->\n <td *ngFor=\"let header of tableHeader; let j = index\">\n <div *ngIf=\"header.fldType === 'imagetext'\" [class]=\"'col-md-' + header.size\" style=\"display: flex;\">\n <img style=\"width: 35px; height: 32px; margin-right: 5px;\" [src]=\"item.imageSrc\" [alt]=\"item.altText\">\n <input type=\"text\" [(ngModel)]=\"item[header.fieldName]\" (ngModelChange)=\"updateLabel(i, header.fieldName, item[header.fieldName])\" class=\"she-line-input table-input\">\n </div>\n <div *ngIf=\"header.fldType === 'image'\" [class]=\"'col-md-' + header.size\">\n <img style=\"width: 35px; height: 32px; margin-right: 5px;\" [src]=\"item[header.fieldName]\" [alt]=\"item.altText\">\n </div>\n <div *ngIf=\"header.fldType === 'Text' || header.fldType === 'Text'\">\n <input type=\"text\" [disabled]=\"!item.edit\" [ngClass]=\"{'editInput': item.edit}\" [(ngModel)]=\"item[header.apiName]\" (ngModelChange)=\"updateLabel(i, header.apiName, item[header.apiName])\" class=\"she-line-input table-input\">\n </div>\n <div *ngIf=\"header.fldType === 'radio'\" [class]=\"'col-md-' + header.size\">\n <input type=\"radio\" [name]=\"item.name\" [checked]=\"item.value == header.fieldName\" (click)=\"updateRadio(item, header.fieldName)\">\n </div>\n </td>\n <td class=\"action\">\n <a style=\"display: flex; justify-content: space-evenly;\" (click)=\"editRow(i)\"><img src=\"https://rnxt.s3.amazonaws.com/MytIcon/icon-edit%402x.png\" class=\"icon-edit1\" /><span>Edit</span></a>\n </td>\n <td class=\"action\">\n <a style=\"display: flex; justify-content: space-evenly;\" (click)=\"deleteRow(i)\"><img src=\"https://rnxt.s3.amazonaws.com/MytIcon/icon-delete%402x.png\" class=\"deleteIcon\"/><span>Delete</span></a>\n </td>\n </tr>\n </tbody>\n</table>\n<div (click)=\"addRow()\" class=\"addRowClass\"><div class=\"circle-button\">+</div></div>", styles: [".table{width:100%;max-width:100%;margin-bottom:20px;border-collapse:collapse;border-spacing:0}.table-bordered{border:1px solid #ddd}thead{background-color:#03a9f4}thead th{color:#fff;font-size:14px;text-align:center}.table-bordered>tbody>tr>td,.table-bordered>tbody>tr>th,.table-bordered>tfoot>tr>td,.table-bordered>tfoot>tr>th,.table-bordered>thead>tr>td,.table-bordered>thead>tr>th{border:1px solid #ddd}th{text-align:left}thead .permission{text-align:center}.table>tbody>tr>td,.table>tbody>tr>th,.table>tfoot>tr>td,.table>tfoot>tr>th,.table>thead>tr>td,.table>thead>tr>th{padding:8px;line-height:1.42857143;vertical-align:top;border-top:1px solid #ddd}tbody{color:#797979}.table-striped>tbody>tr:nth-of-type(odd){background-color:#f9f9f9}tbody td{font-size:13px}.permission_yes,.permission_no,.permission_na{text-align:center}.none-border th{border:none}.addRowClass{float:right;margin-right:15%}.editInput{border-bottom:1px solid red!important}.action,.addRowClass{cursor:pointer}.action :hover{color:red}.circle-button{width:50px;height:50px;border-radius:50%;background-color:#03a9f4;color:#fff;font-size:25px;display:flex;justify-content:center;align-items:center;cursor:pointer;box-shadow:0 2px 4px #0003}.circle-button:hover{background-color:#03a9f4}\n"], dependencies: [{ kind: "directive", type: i5.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i5.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i6.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i6.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i6.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }] });
63
145
  }
64
146
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: CustomTableComponent, decorators: [{
65
147
  type: Component,
66
- args: [{ selector: 'app-custom-table', template: "<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 *ngFor=\"let header of tableHeader; let hi = index\" [class]=\"'col-md-' + tableSize\">\n {{ header.Group__c }}\n </th>\n </thead>\n <tbody id=\"safetyMeasuresTableBody\">\n <tr *ngFor=\"let item of tableData; let i = index\">\n <td *ngFor=\"let header of tableHeader; let j = index\">\n <div *ngIf=\"header.type === 'imagetext'\" [class]=\"'col-md-' + header.size\" style=\"display: flex;\">\n <img style=\"width: 35px; height: 32px; margin-right: 5px;\" [src]=\"item.imageSrc\" [alt]=\"item.altText\">\n <input type=\"text\" [(ngModel)]=\"item[header.fieldName]\" (ngModelChange)=\"updateLabel(i, header.fieldName, item[header.fieldName])\" class=\"she-line-input table-input\">\n </div>\n <div *ngIf=\"header.type === 'image'\" [class]=\"'col-md-' + header.size\">\n <img style=\"width: 35px; height: 32px; margin-right: 5px;\" [src]=\"item[header.fieldName]\" [alt]=\"item.altText\">\n </div>\n <div *ngIf=\"header.type === 'text'\">\n <input type=\"text\" [(ngModel)]=\"item[header.fieldName]\" [placeholder]=\"header.placeholder\" (ngModelChange)=\"updateLabel(i, header.fieldName, item[header.fieldName])\" class=\"she-line-input table-input\">\n </div>\n <div *ngIf=\"header.type === 'radio'\" [class]=\"'col-md-' + header.size\">\n <input type=\"radio\" [name]=\"item.name\" [checked]=\"item.value == header.fieldName\" (click)=\"updateRadio(item, header.fieldName)\">\n </div>\n </td>\n </tr>\n <tr *ngIf=\"tableInfo.addRow\">\n <td colspan=\"1\">\n <!-- HA 19DEC23 For translation -->\n <b>{{ 'addMore' | i18n:i18nService.currentLanguage }}</b>\n </td>\n <td colspan=\"3\" style=\"text-align: center; cursor: pointer;\" id=\"addSafety\" (click)=\"addRow()\">\n +\n </td>\n </tr>\n </tbody>\n</table>\n", styles: [".table{width:100%;max-width:100%;margin-bottom:20px;border-collapse:collapse;border-spacing:0}.table-bordered{border:1px solid #ddd}thead{background-color:#03a9f4}thead th{color:#fff;font-size:14px}.table-bordered>tbody>tr>td,.table-bordered>tbody>tr>th,.table-bordered>tfoot>tr>td,.table-bordered>tfoot>tr>th,.table-bordered>thead>tr>td,.table-bordered>thead>tr>th{border:1px solid #ddd}th{text-align:left}thead .permission{text-align:center}.table>tbody>tr>td,.table>tbody>tr>th,.table>tfoot>tr>td,.table>tfoot>tr>th,.table>thead>tr>td,.table>thead>tr>th{padding:8px;line-height:1.42857143;vertical-align:top;border-top:1px solid #ddd}tbody{color:#797979}.table-striped>tbody>tr:nth-of-type(odd){background-color:#f9f9f9}tbody td{font-size:13px}.permission_yes,.permission_no,.permission_na{text-align:center}.none-border th{border:none}\n"] }]
67
- }], ctorParameters: function () { return [{ type: i1.I18nService }]; }, propDecorators: { question: [{
148
+ args: [{ selector: 'app-custom-table', template: "<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 <th *ngFor=\"let header of tableHeader; let hi = index\" [class]=\"'col-md-' + tableSize\">\n {{ header.label }}\n </th>\n <th class=\"col-md-2\" colspan=\"2\">Actions</th>\n </thead>\n <tbody *ngIf=\"tableData\">\n <tr *ngFor=\"let item of tableData; let i = index\">\n <!-- <td><input type=\"checkbox\" [(ngModel)]=\"item.selected\" (change)=\"selectItem(item)\"></td> -->\n <td *ngFor=\"let header of tableHeader; let j = index\">\n <div *ngIf=\"header.fldType === 'imagetext'\" [class]=\"'col-md-' + header.size\" style=\"display: flex;\">\n <img style=\"width: 35px; height: 32px; margin-right: 5px;\" [src]=\"item.imageSrc\" [alt]=\"item.altText\">\n <input type=\"text\" [(ngModel)]=\"item[header.fieldName]\" (ngModelChange)=\"updateLabel(i, header.fieldName, item[header.fieldName])\" class=\"she-line-input table-input\">\n </div>\n <div *ngIf=\"header.fldType === 'image'\" [class]=\"'col-md-' + header.size\">\n <img style=\"width: 35px; height: 32px; margin-right: 5px;\" [src]=\"item[header.fieldName]\" [alt]=\"item.altText\">\n </div>\n <div *ngIf=\"header.fldType === 'Text' || header.fldType === 'Text'\">\n <input type=\"text\" [disabled]=\"!item.edit\" [ngClass]=\"{'editInput': item.edit}\" [(ngModel)]=\"item[header.apiName]\" (ngModelChange)=\"updateLabel(i, header.apiName, item[header.apiName])\" class=\"she-line-input table-input\">\n </div>\n <div *ngIf=\"header.fldType === 'radio'\" [class]=\"'col-md-' + header.size\">\n <input type=\"radio\" [name]=\"item.name\" [checked]=\"item.value == header.fieldName\" (click)=\"updateRadio(item, header.fieldName)\">\n </div>\n </td>\n <td class=\"action\">\n <a style=\"display: flex; justify-content: space-evenly;\" (click)=\"editRow(i)\"><img src=\"https://rnxt.s3.amazonaws.com/MytIcon/icon-edit%402x.png\" class=\"icon-edit1\" /><span>Edit</span></a>\n </td>\n <td class=\"action\">\n <a style=\"display: flex; justify-content: space-evenly;\" (click)=\"deleteRow(i)\"><img src=\"https://rnxt.s3.amazonaws.com/MytIcon/icon-delete%402x.png\" class=\"deleteIcon\"/><span>Delete</span></a>\n </td>\n </tr>\n </tbody>\n</table>\n<div (click)=\"addRow()\" class=\"addRowClass\"><div class=\"circle-button\">+</div></div>", styles: [".table{width:100%;max-width:100%;margin-bottom:20px;border-collapse:collapse;border-spacing:0}.table-bordered{border:1px solid #ddd}thead{background-color:#03a9f4}thead th{color:#fff;font-size:14px;text-align:center}.table-bordered>tbody>tr>td,.table-bordered>tbody>tr>th,.table-bordered>tfoot>tr>td,.table-bordered>tfoot>tr>th,.table-bordered>thead>tr>td,.table-bordered>thead>tr>th{border:1px solid #ddd}th{text-align:left}thead .permission{text-align:center}.table>tbody>tr>td,.table>tbody>tr>th,.table>tfoot>tr>td,.table>tfoot>tr>th,.table>thead>tr>td,.table>thead>tr>th{padding:8px;line-height:1.42857143;vertical-align:top;border-top:1px solid #ddd}tbody{color:#797979}.table-striped>tbody>tr:nth-of-type(odd){background-color:#f9f9f9}tbody td{font-size:13px}.permission_yes,.permission_no,.permission_na{text-align:center}.none-border th{border:none}.addRowClass{float:right;margin-right:15%}.editInput{border-bottom:1px solid red!important}.action,.addRowClass{cursor:pointer}.action :hover{color:red}.circle-button{width:50px;height:50px;border-radius:50%;background-color:#03a9f4;color:#fff;font-size:25px;display:flex;justify-content:center;align-items:center;cursor:pointer;box-shadow:0 2px 4px #0003}.circle-button:hover{background-color:#03a9f4}\n"] }]
149
+ }], ctorParameters: function () { return [{ type: i1.ChangeService }, { type: i2.I18nService }, { type: i3.SalesforceService }, { type: i4.DataService }]; }, propDecorators: { question: [{
68
150
  type: Input
69
151
  }], valueChange: [{
70
152
  type: Output
153
+ }], apiMeta: [{
154
+ type: Input
71
155
  }] } });
72
- //# 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;;;;;;AAc/E,MAAM,OAAO,oBAAoB;IAUZ;IATV,QAAQ,CAAU;IACjB,WAAW,GAAsB,IAAI,YAAY,EAAO,CAAC;IAEnE,SAAS,CAAe;IACxB,WAAW,GAAG,EAAE,CAAC;IACjB,SAAS,CAAM;IACf,aAAa,CAAS;IACtB,SAAS,CAAS,CAAC,oCAAoC;IAEvD,YAAmB,WAAwB;QAAxB,gBAAW,GAAX,WAAW,CAAa;IAAI,CAAC;IAEhD,QAAQ;QACN,iEAAiE;QACjE,+CAA+C;QAC/C,4DAA4D;QAC5D,8CAA8C;QAC9C,0CAA0C;QAC1C,2CAA2C;QAE3C,iCAAiC;QACjC,wDAAwD;QACxD,MAAM;QACN,IAAI;QACJ,oDAAoD;QACpD,IAAG,IAAI,CAAC,QAAQ,CAAC,2BAA2B,CAAC,IAAI,SAAS,EAAE;YAC1D,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,QAAQ,CAAC,2BAA2B,CAAC,CAAC,CAAC;YACxE,IAAI,CAAC,SAAS,CAAC,cAAc,CAAC,CAAC,YAAY,CAAC,OAAO,CAAC,OAAO,CAAC,OAAO,CAAC,EAAE;gBACpE,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;YACjC,CAAC,CAAC,CAAC;YACH,IAAI,CAAC,SAAS,GAAG,EAAE,GAAC,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC;SAC7C;IACH,CAAC;IAED,MAAM;QACJ,IAAI,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,CAAC,CAAC;QACvE,MAAM,gBAAgB,GAAG,CAAC,GAAG,IAAI,CAAC,SAAS,EAAE,OAAO,CAAC,CAAC;QACtD,IAAI,CAAC,SAAS,GAAG,gBAAgB,CAAC;QAClC,IAAI,CAAC,kBAAkB,CAAC,gBAAgB,CAAC,CAAC;IAC5C,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;IAED,WAAW,CAAC,QAAgB,EAAE,KAAa,EAAE,KAAa;QACxD,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC,KAAK,CAAC,GAAG,KAAK,CAAC;QACxC,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC,IAAI,GAAG,KAAK,CAAC,OAAO,CAAC,MAAM,EAAE,EAAE,CAAC,CAAC,WAAW,EAAE,CAAC;QACxE,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;IAC1C,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;wGA5DU,oBAAoB;4FAApB,oBAAoB,mICdjC,ghEAoCA;;4FDtBa,oBAAoB;kBANhC,SAAS;+BACE,kBAAkB;kGAMnB,QAAQ;sBAAhB,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 { TableWrapper } from '../../model/tableWrapper';\nimport { Question } from '../../wrapper';\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  @Output() valueChange: EventEmitter<any> = new EventEmitter<any>();\n\n  tableInfo: TableWrapper;\n  tableHeader = [];\n  tableData: any;\n  addRowColSpan: number;\n  tableSize: number; // HA 28DEC23 table size declaration\n\n  constructor(public i18nService: I18nService) { }\n\n  ngOnInit(): void {\n    // HA 28DEC23 commented the previously working logic of sub Text \n    // if(this.question.Sub_Text__c != undefined) {\n    //   this.tableInfo = JSON.parse(this.question.Sub_Text__c);\n    //   this.tableHeader = this.tableInfo.header;\n    //   this.tableData = this.tableInfo.data;\n    //   this.valueChange.emit(this.tableData);\n\n    //   if(this.tableData?.addRow) {\n    //     this.addRowColSpan = this.tableHeader.length - 2;\n    //   }\n    // }\n    // HA 28DEC23 Created working logic for table header\n    if(this.question['QB_Reference_Questions__c'] != undefined) {\n      this.tableInfo = JSON.parse(this.question['QB_Reference_Questions__c']);\n      this.tableInfo['questionbook'].Questions__r.records.forEach(element => {\n        this.tableHeader.push(element);\n      });\n      this.tableSize = 12/this.tableHeader.length;\n    }\n  }\n\n  addRow(): void {\n    let newItem = JSON.parse(JSON.stringify(this.tableInfo.newRowDefault));\n    const updatedTableData = [...this.tableData, newItem];\n    this.tableData = updatedTableData;\n    this.emitTableDataValue(updatedTableData);\n  }\n\n  updateRadio(item: any, value: string): void {\n    item.value = value;\n    this.emitTableDataValue(this.tableData);\n  }\n\n  updateLabel(rowIndex: number, label: string, value: string): void {\n    this.tableData[rowIndex][label] = value;\n    this.tableData[rowIndex].name = value.replace(/\\s+/g, '').toLowerCase();\n    this.emitTableDataValue(this.tableData);\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}","<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 *ngFor=\"let header of tableHeader; let hi = index\" [class]=\"'col-md-' + tableSize\">\n      {{ header.Group__c }}\n    </th>\n  </thead>\n  <tbody id=\"safetyMeasuresTableBody\">\n    <tr *ngFor=\"let item of tableData; let i = index\">\n      <td *ngFor=\"let header of tableHeader; let j = index\">\n        <div *ngIf=\"header.type === 'imagetext'\" [class]=\"'col-md-' + header.size\" style=\"display: flex;\">\n          <img style=\"width: 35px; height: 32px; margin-right: 5px;\" [src]=\"item.imageSrc\" [alt]=\"item.altText\">\n          <input type=\"text\" [(ngModel)]=\"item[header.fieldName]\" (ngModelChange)=\"updateLabel(i, header.fieldName, item[header.fieldName])\" class=\"she-line-input table-input\">\n        </div>\n        <div *ngIf=\"header.type === 'image'\" [class]=\"'col-md-' + header.size\">\n          <img style=\"width: 35px; height: 32px; margin-right: 5px;\" [src]=\"item[header.fieldName]\" [alt]=\"item.altText\">\n        </div>\n        <div *ngIf=\"header.type === 'text'\">\n          <input type=\"text\" [(ngModel)]=\"item[header.fieldName]\" [placeholder]=\"header.placeholder\" (ngModelChange)=\"updateLabel(i, header.fieldName, item[header.fieldName])\" class=\"she-line-input table-input\">\n        </div>\n        <div *ngIf=\"header.type === 'radio'\" [class]=\"'col-md-' + header.size\">\n          <input type=\"radio\" [name]=\"item.name\" [checked]=\"item.value == header.fieldName\"  (click)=\"updateRadio(item, header.fieldName)\">\n        </div>\n      </td>\n    </tr>\n    <tr *ngIf=\"tableInfo.addRow\">\n      <td colspan=\"1\">\n        <!-- HA 19DEC23 For translation -->\n        <b>{{ 'addMore' | i18n:i18nService.currentLanguage }}</b>\n      </td>\n      <td colspan=\"3\" style=\"text-align: center; cursor: pointer;\" id=\"addSafety\"  (click)=\"addRow()\">\n        +\n      </td>\n    </tr>\n  </tbody>\n</table>\n"]}
156
+ //# 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 { TableWrapper } from '../../model/tableWrapper';\nimport { SalesforceService } from '../../services/salesforce.service';\nimport { Question } from '../../wrapper';\nimport { DataService } from '../../services/data.service';\nimport { APIMeta } from '../../interfaces/apimeta';\nimport { Observable, 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  @Output() valueChange: EventEmitter<any> = new EventEmitter<any>();\n\n  tableInfo: TableWrapper;\n  tableHeader = [];\n  tableData = [];\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  @Input() apiMeta: string;\n  public options: string[];\n  isDisabled: boolean = true;\n  subscription: Subscription;\n\n  public labelField: string;\n\n  constructor(private changeService: ChangeService,public i18nService: I18nService, private sfService: SalesforceService, private dataService: DataService) { }\n\n  ngOnInit(): void {\n    this.tableHeader = JSON.parse(this.question['Fields_Meta__c']);\n    this.tableSize = 10/this.tableHeader.length;\n    \n    if(this.apiMeta !== undefined) {\n      this.options = [];\n      let apiObj: APIMeta = JSON.parse(this.apiMeta);\n      this.labelField = apiObj.field;\n      if(apiObj.endpoint){\n        this.dataService.apiResponse(apiObj.endpoint)?.subscribe((apiResponse) => {\n          let responses;\n          if(apiObj.variable){\n            responses =  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      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                if(this.tableData.length > 0){\n                  this.tableData.forEach(element => {\n                    if(element.id == item.id){\n                       validItem = false;\n                    }\n                  });\n                }\n                if(validItem){\n                  if(this.tableData.length > 0){\n                    this.tableData = [...this.tableData,item];\n                    this.emitTableDataValue(this.tableData);\n                  }else {\n                    this.tableData.push(item);\n                    this.emitTableDataValue(this.tableData);\n                  }\n                }\n              }\n              this.changeService.confirmChange(apiObj.sourceQuestionId);\n            }\n          }\n        );\n      }\n    }\n    console.log('tableData', this.tableData);\n    console.log('tableHeader', this.tableHeader);\n    console.log('tableInfo', this.tableInfo);\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    const updatedTableData = [...this.tableData, newItem];\n    this.tableData = updatedTableData;\n    this.emitTableDataValue(updatedTableData);\n  }\n\n  updateRadio(item: any, value: string): void {\n    item.value = value;\n    this.emitTableDataValue(this.tableData);\n  }\n\n  updateLabel(rowIndex: number, label: string, value: string): void {\n    this.tableData[rowIndex][label] = value;\n    this.emitTableDataValue(this.tableData);\n  }\n  deleteRow(rowIndex: number){\n    this.tableData.splice(rowIndex, 1);\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}","<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    <th *ngFor=\"let header of tableHeader; let hi = index\" [class]=\"'col-md-' + tableSize\">\n      {{ header.label }}\n    </th>\n    <th class=\"col-md-2\" colspan=\"2\">Actions</th>\n  </thead>\n  <tbody *ngIf=\"tableData\">\n    <tr *ngFor=\"let item of tableData; let i = index\">\n      <!-- <td><input type=\"checkbox\" [(ngModel)]=\"item.selected\" (change)=\"selectItem(item)\"></td> -->\n      <td *ngFor=\"let header of tableHeader; let j = index\">\n        <div *ngIf=\"header.fldType === 'imagetext'\" [class]=\"'col-md-' + header.size\" style=\"display: flex;\">\n          <img style=\"width: 35px; height: 32px; margin-right: 5px;\" [src]=\"item.imageSrc\" [alt]=\"item.altText\">\n          <input type=\"text\" [(ngModel)]=\"item[header.fieldName]\" (ngModelChange)=\"updateLabel(i, header.fieldName, item[header.fieldName])\" class=\"she-line-input table-input\">\n        </div>\n        <div *ngIf=\"header.fldType === 'image'\" [class]=\"'col-md-' + header.size\">\n          <img style=\"width: 35px; height: 32px; margin-right: 5px;\" [src]=\"item[header.fieldName]\" [alt]=\"item.altText\">\n        </div>\n        <div *ngIf=\"header.fldType === 'Text' || header.fldType === 'Text'\">\n          <input type=\"text\" [disabled]=\"!item.edit\" [ngClass]=\"{'editInput': item.edit}\" [(ngModel)]=\"item[header.apiName]\" (ngModelChange)=\"updateLabel(i, header.apiName, item[header.apiName])\" class=\"she-line-input table-input\">\n        </div>\n        <div *ngIf=\"header.fldType === 'radio'\" [class]=\"'col-md-' + header.size\">\n          <input type=\"radio\" [name]=\"item.name\" [checked]=\"item.value == header.fieldName\"  (click)=\"updateRadio(item, header.fieldName)\">\n        </div>\n      </td>\n      <td class=\"action\">\n        <a style=\"display: flex; justify-content: space-evenly;\" (click)=\"editRow(i)\"><img src=\"https://rnxt.s3.amazonaws.com/MytIcon/icon-edit%402x.png\" class=\"icon-edit1\" /><span>Edit</span></a>\n      </td>\n      <td class=\"action\">\n        <a style=\"display: flex; justify-content: space-evenly;\" (click)=\"deleteRow(i)\"><img src=\"https://rnxt.s3.amazonaws.com/MytIcon/icon-delete%402x.png\" class=\"deleteIcon\"/><span>Delete</span></a>\n      </td>\n    </tr>\n  </tbody>\n</table>\n<div (click)=\"addRow()\" class=\"addRowClass\"><div class=\"circle-button\">+</div></div>"]}
@@ -36,10 +36,13 @@ export class SearchBoxComponent {
36
36
  this.route = route;
37
37
  this.i18nService = i18nService;
38
38
  }
39
+ z;
39
40
  ngOnInit() {
40
41
  // VD 03May- search changes
41
- let apiObj = JSON.parse(this.apiMeta);
42
- this.SearchItem = apiObj.field;
42
+ if (this.apiMeta) {
43
+ let apiObj = JSON.parse(this.apiMeta);
44
+ this.SearchItem = apiObj.field;
45
+ }
43
46
  }
44
47
  clearList() {
45
48
  setTimeout(() => {
@@ -114,4 +117,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImpo
114
117
  }], searchValueChange: [{
115
118
  type: Output
116
119
  }] } });
117
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"search-box.component.js","sourceRoot":"","sources":["../../../../../../projects/nxt-app/src/lib/components/search-box/search-box.component.ts","../../../../../../projects/nxt-app/src/lib/components/search-box/search-box.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  OnInit,\n  OnChanges,\n  Inject,\n  Input,\n  Output,\n  EventEmitter,\n  ViewEncapsulation,\n  ElementRef,\n  ViewChild,\n} from \"@angular/core\";\nimport { DataService } from '../../services/data.service';\nimport { SalesforceService } from \"../../services/salesforce.service\";\nimport { ActivatedRoute, Params } from \"@angular/router\";\n// VD 23JAN24 removed httpClient import used service file for callout\nimport { Observable } from 'rxjs';\nimport { ItemsList } from \"@ng-select/ng-select/lib/items-list\";\nimport { ConsoleService } from \"@ng-select/ng-select/lib/console.service\";\nimport { APIMeta } from \"../../interfaces/apimeta\";\nimport { ChangeWrapper } from \"../../model/changeWrapper\";\n// HA 19DEC23 imported translation service\nimport { I18nService } from \"../../i18n.service\";\n\n@Component({\n  selector: 'lib-search-box',\n  templateUrl: './search-box.component.html',\n  styleUrls: ['./search-box.component.css']\n})\nexport class SearchBoxComponent implements OnInit {\n  @Input() placeHolderText: string;\n  @ViewChild('auto') auto;\n\n  @Input() question;\n  @Input() apiMeta: string;\n  @Input() id: string;\n  @Output() searchValueChange: EventEmitter<ChangeWrapper> = new EventEmitter<ChangeWrapper>();\n   apiObj:any;\n   SearchItem: any;\n\n  public filterName: string;\n  public finalResults: any[] = [];\n  public searchKeyWord: string = '';\n  public newResult: any;\n  public showResult = false;\n  public noResult = false;\n  public showSuggestion = true;\n  private el: HTMLElement;\n  private serv: string = 'api';\n  private tkn: string = '';\n  \n  constructor(\n    private sfService: SalesforceService,\n    private dataService: DataService,\n    private route: ActivatedRoute,\n    el: ElementRef,\n        public i18nService: I18nService\n  ) { }\n\n  ngOnInit(): void {\n//  VD 03May- search changes\n    let apiObj: APIMeta = JSON.parse(this.apiMeta);\n    this.SearchItem = apiObj.field;\n  }\n\n  clearList(){\n    setTimeout(()=> {\n      this.finalResults = [];\n    }, 1000);\n  }\n\n  getSourceDataLocal(event) { //to get results list from backend API whenever key is up after the entering atleast one key\n    if(event.target.value.length > 2){\n      this.showSuggestion=true;\n      this.finalResults=[];\n      this.searchKeyWord = event.target.value;\n      this.showResult = false;\n      this.getSourceData(event.target.value);\n    } else {\n      this.showSuggestion=false;\n      this.finalResults = [];\n      this.noResult = false;\n    }\n  }\n  // VD 03May- search changes\n  public getSourceData = (keyword: string) => {\n    if(this.apiMeta !== undefined) {\n     let apiObj: APIMeta = JSON.parse(this.apiMeta);\n      this.dataService.apiResponse(apiObj.endpoint).subscribe((apiResponse) => {\n        let response;\n        if(apiObj.variable){\n           response = apiResponse[apiObj.variable];\n        }else{\n          response = apiResponse;\n        }\n      let field = apiObj.field;\n      let results=[];\n      for (let i = 0; i < response.length; i++) { // VD NOV23 - updated the search keys\n        if(response[i][field]?.toLowerCase().includes(keyword?.toLowerCase())) {\n          console.log('pushing ' + response[i].field);\n          results.push(response[i]);\n        }\n      }\n      this.noResult = !(results.length > 1);\n      this.finalResults = results;\n    })\n  }\n  }\n\n  public clickItem(event) {\n    // console.log('inside clickItem of ' + event.target.value);\n    let apiObj: APIMeta = JSON.parse(this.apiMeta);\n    this.filterName = event[apiObj.field];\n    let change = new ChangeWrapper(); // ChangeWrapper = JSON.parse('{}');\n    change.fromQuestionId = this.id;\n    change.valueObj = event;\n    this.searchValueChange.emit(change);\n  }\n  /*\n  public getSourceData = (keyword: string) => {\n    if(this.serv == \"api\") {\n      this.dataService.getAPIData(\n        this.tkn,\n        [\"QuestionBook\", \"read\", uuid],\n        this.successSourceData,\n        this.failureSourceData\n      );\n    } else {\n      this.sfService.remoteAction(\n        \"NxtController.process\",\n        [\"QuestionBook\", \"read\", uuid],\n        this.successSourceData,\n        this.failureSourceData\n      );\n    }\n  }\n\n  public successSourceData = (response) => {\n    let results=[];\n    results=response.results;\n    results.push({uuid: null, name: \"\"});\n    this.noResult = !(results.length > 1);\n    this.finalResults = results;\n  }\n\n  public failureSourceData = (response) => {\n    console.log(\"Error reading the data from API\");\n  }\n  */\n}\n","<div id=\"autocomplete-input\">\n    <input #auto id=\"searchbox-style\"\n            (blur)=\"clearList()\" \n            [(ngModel)]=\"filterName\" \n            type=\"text\" \n            name=\"name\" \n            [placeholder]=\"placeHolderText\" \n            style=\"margin: 0 !important;\" \n            class=\"searchInput she-line-input form-control\" \n            (focusin)=\"getSourceDataLocal($event)\" \n            (input)=\"getSourceDataLocal($event)\">\n    <div id=\"selectList\" style=\"position: absolute;position: absolute;background: white;z-index: 2;\">\n    <div *ngIf=\"finalResults.length > 0 && showSuggestion\" \n        style=\"max-height: 100vh;border: 1px solid #d2d4d6;overflow: scroll;\" \n        class=\"suggestions-container\">\n        <!-- HA 20DEC23 Uncommented the logic -->\n         <!-- VD 03May- search changes -->\n        <div *ngFor=\"let item of finalResults\" (click)='clickItem(item)' class=\"hoover\">\n            <div class=\"grid-x align-middle\" style=\"padding: 1rem\" *ngIf=\"item.id != null\">\n                <div *ngIf=\"item.thumbnail\" class=\"cell shrink\" style=\"width: 60px; margin-right: 1.6rem;\">\n                    <img [src]=\"item.thumbnail\" style=\"width: 60px;\" alt=\"\">\n                </div>\n                <div class=\"cell auto\" style=\"text-align: left; padding-left: 20px;\">\n                    <h4 >{{item[SearchItem]}}</h4>\n                </div>\n            </div>\n        </div>\n        <!-- HA 20DEC23 For Commented this for future purpose -->\n        <!-- <table class=\"table table-striped table-bordered\">\n            <thead>\n              <tr>\n                <th>{{ 'firstName' | i18n:i18nService.currentLanguage }}</th>\n                <th>{{ 'lastName' | i18n:i18nService.currentLanguage }}</th>\n                <th>{{ 'division' | i18n:i18nService.currentLanguage }}</th>\n                <th>{{ 'numberPlate' | i18n:i18nService.currentLanguage }}</th>\n              </tr>\n            </thead>\n            <tbody>\n              <tr *ngFor=\"let item of finalResults\" (click)='clickItem(item)'>\n                <td>{{ item.firstName }}</td>\n                <td>{{ item.lastName }}</td>\n                <td>{{ item.division }}</td>\n                <td>{{ item.numberPlate }}</td>\n              </tr>\n            </tbody>\n          </table> -->\n    </div>\n</div>\n"]}
120
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"search-box.component.js","sourceRoot":"","sources":["../../../../../../projects/nxt-app/src/lib/components/search-box/search-box.component.ts","../../../../../../projects/nxt-app/src/lib/components/search-box/search-box.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  OnInit,\n  OnChanges,\n  Inject,\n  Input,\n  Output,\n  EventEmitter,\n  ViewEncapsulation,\n  ElementRef,\n  ViewChild,\n} from \"@angular/core\";\nimport { DataService } from '../../services/data.service';\nimport { SalesforceService } from \"../../services/salesforce.service\";\nimport { ActivatedRoute, Params } from \"@angular/router\";\n// VD 23JAN24 removed httpClient import used service file for callout\nimport { Observable } from 'rxjs';\nimport { ItemsList } from \"@ng-select/ng-select/lib/items-list\";\nimport { ConsoleService } from \"@ng-select/ng-select/lib/console.service\";\nimport { APIMeta } from \"../../interfaces/apimeta\";\nimport { ChangeWrapper } from \"../../model/changeWrapper\";\n// HA 19DEC23 imported translation service\nimport { I18nService } from \"../../i18n.service\";\n\n@Component({\n  selector: 'lib-search-box',\n  templateUrl: './search-box.component.html',\n  styleUrls: ['./search-box.component.css']\n})\nexport class SearchBoxComponent implements OnInit {\n  @Input() placeHolderText: string;\n  @ViewChild('auto') auto;\n\n  @Input() question;\n  @Input() apiMeta: string;\n  @Input() id: string;\n  @Output() searchValueChange: EventEmitter<ChangeWrapper> = new EventEmitter<ChangeWrapper>();\n   apiObj:any;\n   SearchItem: any;\n\n  public filterName: string;\n  public finalResults: any[] = [];\n  public searchKeyWord: string = '';\n  public newResult: any;\n  public showResult = false;\n  public noResult = false;\n  public showSuggestion = true;\n  private el: HTMLElement;\n  private serv: string = 'api';\n  private tkn: string = '';\n  \n  constructor(\n    private sfService: SalesforceService,\n    private dataService: DataService,\n    private route: ActivatedRoute,\n    el: ElementRef,\n        public i18nService: I18nService\n  ) { }\nz\n  ngOnInit(): void {\n//  VD 03May- search changes\n    if(this.apiMeta){\n      let apiObj: APIMeta = JSON.parse(this.apiMeta);\n      this.SearchItem = apiObj.field;\n    }\n  }\n\n  clearList(){\n    setTimeout(()=> {\n      this.finalResults = [];\n    }, 1000);\n  }\n\n  getSourceDataLocal(event) { //to get results list from backend API whenever key is up after the entering atleast one key\n    if(event.target.value.length > 2){\n      this.showSuggestion=true;\n      this.finalResults=[];\n      this.searchKeyWord = event.target.value;\n      this.showResult = false;\n      this.getSourceData(event.target.value);\n    } else {\n      this.showSuggestion=false;\n      this.finalResults = [];\n      this.noResult = false;\n    }\n  }\n  // VD 03May- search changes\n  public getSourceData = (keyword: string) => {\n    if(this.apiMeta !== undefined) {\n     let apiObj: APIMeta = JSON.parse(this.apiMeta);\n      this.dataService.apiResponse(apiObj.endpoint).subscribe((apiResponse) => {\n        let response;\n        if(apiObj.variable){\n           response = apiResponse[apiObj.variable];\n        }else{\n          response = apiResponse;\n        }\n      let field = apiObj.field;\n      let results=[];\n      for (let i = 0; i < response.length; i++) { // VD NOV23 - updated the search keys\n        if(response[i][field]?.toLowerCase().includes(keyword?.toLowerCase())) {\n          console.log('pushing ' + response[i].field);\n          results.push(response[i]);\n        }\n      }\n      this.noResult = !(results.length > 1);\n      this.finalResults = results;\n    })\n  }\n  }\n\n  public clickItem(event) {\n    // console.log('inside clickItem of ' + event.target.value);\n    let apiObj: APIMeta = JSON.parse(this.apiMeta);\n    this.filterName = event[apiObj.field];\n    let change = new ChangeWrapper(); // ChangeWrapper = JSON.parse('{}');\n    change.fromQuestionId = this.id;\n    change.valueObj = event;\n    this.searchValueChange.emit(change);\n  }\n  /*\n  public getSourceData = (keyword: string) => {\n    if(this.serv == \"api\") {\n      this.dataService.getAPIData(\n        this.tkn,\n        [\"QuestionBook\", \"read\", uuid],\n        this.successSourceData,\n        this.failureSourceData\n      );\n    } else {\n      this.sfService.remoteAction(\n        \"NxtController.process\",\n        [\"QuestionBook\", \"read\", uuid],\n        this.successSourceData,\n        this.failureSourceData\n      );\n    }\n  }\n\n  public successSourceData = (response) => {\n    let results=[];\n    results=response.results;\n    results.push({uuid: null, name: \"\"});\n    this.noResult = !(results.length > 1);\n    this.finalResults = results;\n  }\n\n  public failureSourceData = (response) => {\n    console.log(\"Error reading the data from API\");\n  }\n  */\n}\n","<div id=\"autocomplete-input\">\n    <input #auto id=\"searchbox-style\"\n            (blur)=\"clearList()\" \n            [(ngModel)]=\"filterName\" \n            type=\"text\" \n            name=\"name\" \n            [placeholder]=\"placeHolderText\" \n            style=\"margin: 0 !important;\" \n            class=\"searchInput she-line-input form-control\" \n            (focusin)=\"getSourceDataLocal($event)\" \n            (input)=\"getSourceDataLocal($event)\">\n    <div id=\"selectList\" style=\"position: absolute;position: absolute;background: white;z-index: 2;\">\n    <div *ngIf=\"finalResults.length > 0 && showSuggestion\" \n        style=\"max-height: 100vh;border: 1px solid #d2d4d6;overflow: scroll;\" \n        class=\"suggestions-container\">\n        <!-- HA 20DEC23 Uncommented the logic -->\n         <!-- VD 03May- search changes -->\n        <div *ngFor=\"let item of finalResults\" (click)='clickItem(item)' class=\"hoover\">\n            <div class=\"grid-x align-middle\" style=\"padding: 1rem\" *ngIf=\"item.id != null\">\n                <div *ngIf=\"item.thumbnail\" class=\"cell shrink\" style=\"width: 60px; margin-right: 1.6rem;\">\n                    <img [src]=\"item.thumbnail\" style=\"width: 60px;\" alt=\"\">\n                </div>\n                <div class=\"cell auto\" style=\"text-align: left; padding-left: 20px;\">\n                    <h4 >{{item[SearchItem]}}</h4>\n                </div>\n            </div>\n        </div>\n        <!-- HA 20DEC23 For Commented this for future purpose -->\n        <!-- <table class=\"table table-striped table-bordered\">\n            <thead>\n              <tr>\n                <th>{{ 'firstName' | i18n:i18nService.currentLanguage }}</th>\n                <th>{{ 'lastName' | i18n:i18nService.currentLanguage }}</th>\n                <th>{{ 'division' | i18n:i18nService.currentLanguage }}</th>\n                <th>{{ 'numberPlate' | i18n:i18nService.currentLanguage }}</th>\n              </tr>\n            </thead>\n            <tbody>\n              <tr *ngFor=\"let item of finalResults\" (click)='clickItem(item)'>\n                <td>{{ item.firstName }}</td>\n                <td>{{ item.lastName }}</td>\n                <td>{{ item.division }}</td>\n                <td>{{ item.numberPlate }}</td>\n              </tr>\n            </tbody>\n          </table> -->\n    </div>\n</div>\n"]}