@rangertechnologies/ngnxt 2.0.44 → 2.0.46
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/components/custom-button/custom-button.component.mjs +39 -0
- package/esm2022/lib/components/custom-dropdown/custom-dropdown.component.mjs +2 -1
- package/esm2022/lib/components/search-box/search-box.component.mjs +2 -2
- package/esm2022/lib/interfaces/apimeta.mjs +1 -1
- package/esm2022/lib/nxt-app.module.mjs +6 -3
- package/esm2022/lib/pages/booklet/booklet.component.mjs +5 -4
- package/esm2022/lib/pages/questionbook/questionbook.component.mjs +4 -3
- package/fesm2022/rangertechnologies-ngnxt.mjs +49 -8
- package/fesm2022/rangertechnologies-ngnxt.mjs.map +1 -1
- package/lib/components/custom-button/custom-button.component.d.ts +16 -0
- package/lib/nxt-app.module.d.ts +11 -10
- package/package.json +1 -1
- package/rangertechnologies-ngnxt-2.0.46.tgz +0 -0
- package/rangertechnologies-ngnxt-2.0.44.tgz +0 -0
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
import { Component, EventEmitter, Input, Output } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export class CustomButtonComponent {
|
|
4
|
+
// 08NOV23 - button input and outpts
|
|
5
|
+
height;
|
|
6
|
+
width;
|
|
7
|
+
textColor = '#fff';
|
|
8
|
+
buttonText;
|
|
9
|
+
value;
|
|
10
|
+
backgroundColor = '#007bff'; // Default background color
|
|
11
|
+
buttonValue = new EventEmitter();
|
|
12
|
+
constructor() { }
|
|
13
|
+
ngOnInit() {
|
|
14
|
+
}
|
|
15
|
+
handleClick(event) {
|
|
16
|
+
this.buttonValue.emit(event);
|
|
17
|
+
}
|
|
18
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: CustomButtonComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
19
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: CustomButtonComponent, selector: "app-custom-button", inputs: { height: "height", width: "width", textColor: "textColor", buttonText: "buttonText", value: "value", backgroundColor: "backgroundColor" }, outputs: { buttonValue: "buttonValue" }, ngImport: i0, template: "\n<!-- 08NOV23 - button html added-->\n<button \n[style.height]=\"height\" \n[style.color]=\"textColor\"\n[style.background-color]=\"backgroundColor\"\n[style.width]=\"width\" class=\"custom-button\"\n[value] =\"value\"\n(click)=\"handleClick(value)\"\n >{{ buttonText }}</button>\n", styles: [".custom-button{border:none;cursor:pointer;border-radius:5px;font-size:16px;font-size:14px}.custom-button:hover{background-color:#0056b3}\n"] });
|
|
20
|
+
}
|
|
21
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: CustomButtonComponent, decorators: [{
|
|
22
|
+
type: Component,
|
|
23
|
+
args: [{ selector: 'app-custom-button', template: "\n<!-- 08NOV23 - button html added-->\n<button \n[style.height]=\"height\" \n[style.color]=\"textColor\"\n[style.background-color]=\"backgroundColor\"\n[style.width]=\"width\" class=\"custom-button\"\n[value] =\"value\"\n(click)=\"handleClick(value)\"\n >{{ buttonText }}</button>\n", styles: [".custom-button{border:none;cursor:pointer;border-radius:5px;font-size:16px;font-size:14px}.custom-button:hover{background-color:#0056b3}\n"] }]
|
|
24
|
+
}], ctorParameters: function () { return []; }, propDecorators: { height: [{
|
|
25
|
+
type: Input
|
|
26
|
+
}], width: [{
|
|
27
|
+
type: Input
|
|
28
|
+
}], textColor: [{
|
|
29
|
+
type: Input
|
|
30
|
+
}], buttonText: [{
|
|
31
|
+
type: Input
|
|
32
|
+
}], value: [{
|
|
33
|
+
type: Input
|
|
34
|
+
}], backgroundColor: [{
|
|
35
|
+
type: Input
|
|
36
|
+
}], buttonValue: [{
|
|
37
|
+
type: Output
|
|
38
|
+
}] } });
|
|
39
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3VzdG9tLWJ1dHRvbi5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9ueHQtYXBwL3NyYy9saWIvY29tcG9uZW50cy9jdXN0b20tYnV0dG9uL2N1c3RvbS1idXR0b24uY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbnh0LWFwcC9zcmMvbGliL2NvbXBvbmVudHMvY3VzdG9tLWJ1dHRvbi9jdXN0b20tYnV0dG9uLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsWUFBWSxFQUFFLEtBQUssRUFBVSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7O0FBTy9FLE1BQU0sT0FBTyxxQkFBcUI7SUFDaEMscUNBQXFDO0lBQzVCLE1BQU0sQ0FBUztJQUNmLEtBQUssQ0FBUztJQUNkLFNBQVMsR0FBVSxNQUFNLENBQUE7SUFDekIsVUFBVSxDQUFTO0lBQ25CLEtBQUssQ0FBUTtJQUNiLGVBQWUsR0FBVyxTQUFTLENBQUMsQ0FBQywyQkFBMkI7SUFDL0QsV0FBVyxHQUFHLElBQUksWUFBWSxFQUFPLENBQUM7SUFDaEQsZ0JBQWdCLENBQUM7SUFFakIsUUFBUTtJQUNSLENBQUM7SUFFRCxXQUFXLENBQUMsS0FBSztRQUNmLElBQUksQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQy9CLENBQUM7d0dBaEJVLHFCQUFxQjs0RkFBckIscUJBQXFCLHNQQ1BsQyw0UkFVQTs7NEZESGEscUJBQXFCO2tCQUxqQyxTQUFTOytCQUNFLG1CQUFtQjswRUFNcEIsTUFBTTtzQkFBZCxLQUFLO2dCQUNHLEtBQUs7c0JBQWIsS0FBSztnQkFDRyxTQUFTO3NCQUFqQixLQUFLO2dCQUNHLFVBQVU7c0JBQWxCLEtBQUs7Z0JBQ0csS0FBSztzQkFBYixLQUFLO2dCQUNHLGVBQWU7c0JBQXZCLEtBQUs7Z0JBQ0ksV0FBVztzQkFBcEIsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgRXZlbnRFbWl0dGVyLCBJbnB1dCwgT25Jbml0LCBPdXRwdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnYXBwLWN1c3RvbS1idXR0b24nLFxuICB0ZW1wbGF0ZVVybDogJy4vY3VzdG9tLWJ1dHRvbi5jb21wb25lbnQuaHRtbCcsXG4gIHN0eWxlVXJsczogWycuL2N1c3RvbS1idXR0b24uY29tcG9uZW50LmNzcyddXG59KVxuZXhwb3J0IGNsYXNzIEN1c3RvbUJ1dHRvbkNvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCB7XG4gIC8vICAwOE5PVjIzIC0gYnV0dG9uIGlucHV0IGFuZCBvdXRwdHNcbiAgQElucHV0KCkgaGVpZ2h0OiBzdHJpbmc7XG4gIEBJbnB1dCgpIHdpZHRoOiBzdHJpbmc7XG4gIEBJbnB1dCgpIHRleHRDb2xvcjogc3RyaW5nID0nI2ZmZidcbiAgQElucHV0KCkgYnV0dG9uVGV4dDogc3RyaW5nO1xuICBASW5wdXQoKSB2YWx1ZTpzdHJpbmc7XG4gIEBJbnB1dCgpIGJhY2tncm91bmRDb2xvcjogc3RyaW5nID0gJyMwMDdiZmYnOyAvLyBEZWZhdWx0IGJhY2tncm91bmQgY29sb3JcbiAgQE91dHB1dCgpIGJ1dHRvblZhbHVlID0gbmV3IEV2ZW50RW1pdHRlcjxhbnk+KCk7IFxuICBjb25zdHJ1Y3RvcigpIHsgfVxuXG4gIG5nT25Jbml0KCk6IHZvaWQge1xuICB9XG5cbiAgaGFuZGxlQ2xpY2soZXZlbnQpe1xuICAgIHRoaXMuYnV0dG9uVmFsdWUuZW1pdChldmVudCk7XG4gIH1cbn1cbiIsIlxuPCEtLSAwOE5PVjIzIC0gYnV0dG9uIGh0bWwgYWRkZWQtLT5cbjxidXR0b24gXG5bc3R5bGUuaGVpZ2h0XT1cImhlaWdodFwiIFxuW3N0eWxlLmNvbG9yXT1cInRleHRDb2xvclwiXG5bc3R5bGUuYmFja2dyb3VuZC1jb2xvcl09XCJiYWNrZ3JvdW5kQ29sb3JcIlxuW3N0eWxlLndpZHRoXT1cIndpZHRoXCIgY2xhc3M9XCJjdXN0b20tYnV0dG9uXCJcblt2YWx1ZV0gPVwidmFsdWVcIlxuKGNsaWNrKT1cImhhbmRsZUNsaWNrKHZhbHVlKVwiXG4gPnt7IGJ1dHRvblRleHQgfX08L2J1dHRvbj5cbiJdfQ==
|
|
@@ -49,6 +49,7 @@ export class CustomDropdownComponent {
|
|
|
49
49
|
// Reference https://www.npmjs.com/package/@ng-select/ng-select
|
|
50
50
|
this.options = results;
|
|
51
51
|
});
|
|
52
|
+
// VD NOV23 - handle the dependent update for dropdown
|
|
52
53
|
let sourceId = apiObj.sourceQuestionId;
|
|
53
54
|
if (sourceId) {
|
|
54
55
|
// Subscribe for the changes
|
|
@@ -111,4 +112,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImpo
|
|
|
111
112
|
}], valueChange: [{
|
|
112
113
|
type: Output
|
|
113
114
|
}] } });
|
|
114
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"custom-dropdown.component.js","sourceRoot":"","sources":["../../../../../../projects/nxt-app/src/lib/components/custom-dropdown/custom-dropdown.component.ts","../../../../../../projects/nxt-app/src/lib/components/custom-dropdown/custom-dropdown.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit,Input,Output,EventEmitter } from '@angular/core';\nimport { HttpClient } from '@angular/common/http';\nimport { Observable, Subscription } from 'rxjs';\nimport { APIMeta } from '../../interfaces/apimeta';\nimport { ChangeWrapper } from '../../model/changeWrapper';\nimport { ChangeService } from '../../services/change.service';\n\n@Component({\n  selector: 'app-custom-dropdown',\n  templateUrl: './custom-dropdown.component.html',\n  styleUrls: ['./custom-dropdown.component.css']\n})\nexport class CustomDropdownComponent implements OnInit {\n  @Input() options: string[];\n  @Input() placeholder: string;\n  @Input() apiMeta: string;\n  @Input() selectedValue: string;\n  @Input() progressBar: boolean;\n  @Input() id:string;\n  @Input() errorMessage: string;\n  @Input() error:any;\n  @Input() fromShengel: boolean = false;\n  @Input() referenceField:string;\n  @Output() valueChange: EventEmitter<ChangeWrapper> = new EventEmitter<ChangeWrapper>();\n  invalidFieldIds:string[] = [];\n  constructor(private http: HttpClient,private changeService: ChangeService) { \n    this.changeService.submitValidate$.subscribe((data)=>{\n      // to get the error message's field id's\n      this.invalidFieldIds.push(data);\n    })\n  }\n\n  public labelField: string;\n  public valueField: string;\n  subscription: Subscription;\n\n  ngOnInit(): void {\n    // console.log('inside oninit of custom-dropdown of ' + this.id);\n    // console.log(this.apiMeta);\n    if(this.apiMeta !== undefined) {\n      this.options = [];\n      let apiObj: APIMeta = JSON.parse(this.apiMeta);\n      this.labelField = apiObj.field;\n\n      this.apiResponse(apiObj.endpoint).subscribe((apiResponse) => {\n        let responses = apiResponse[apiObj.variable];\n        let results = [];\n        for (let i = 0; i < responses.length; i++) {\n          var resp = responses[i];\n          results.push(resp);\n        }\n        // Reference https://www.npmjs.com/package/@ng-select/ng-select\n        this.options = results;\n      })\n      let sourceId = apiObj.sourceQuestionId;\n      if(sourceId){\n        // Subscribe for the changes\n        this.subscription = this.changeService.changeAnnounced$.subscribe(\n          (changeValue) => {\n            if(changeValue != undefined) {\n              // console.log('inside subscription for the change');\n              if(changeValue.valueObj != undefined && changeValue.fromQuestionId == apiObj.sourceQuestionId) {\n                this.selectedValue = changeValue.valueObj[apiObj.valueField];\n                let value ={};\n                value['name'] = this.selectedValue;\n                this.selectChange(value);\n              }\n              this.changeService.confirmChange(apiObj.sourceQuestionId);\n            }\n          }\n        );\n      }\n    }\n  }\n\n  public apiResponse(endpoint: string): Observable<any> {\n    return this.http.get(endpoint);\n  }\n\n  selectChange(event:any) {\n    console.log('inside selectChange from ' + this.id);\n    // console.log(event);\n    let change = new ChangeWrapper(); // ChangeWrapper = JSON.parse('{}');\n    change.fromQuestionId = this.id;\n    change.valueObj = event;\n    this.valueChange.emit(change);\n    // once got value in dropdown remove the error validation\n    if(event){\n      this.invalidFieldIds =[];\n    }\n  }\n}\n","<select *ngIf=\"!fromShengel\"\n  [ngClass]=\"{\n    'dt-line dpDown down myt-dropbox myt-border-r myt-font1': progressBar,\n    'custom-select': !progressBar\n  }\" class=\"custom-select mr-sm-2 dd-height\" \n  [id]=\"id\" \n  [(ngModel)]=\"selectedValue\"\n  (change)=\"selectChange($event.target.value);\" \n  [style.borderColor]=\"error ? 'red' : '#858585'\"\n  [style.color]=\"error ? 'red' : ''\">\n    <option *ngFor=\"let option of options\" [value]=\"option.Value__c\" class=\"option\">{{ option.Value__c }}</option>\n    <option *ngIf=\"errorMessage\" value=\"\" disabled hidden>{{ errorMessage }}</option>\n</select>\n\n<ng-select  *ngIf=\"fromShengel\"\n            [class]=\"invalidFieldIds.includes(id) ? 'shengel-custom-select invalid' : 'shengel-custom-select'\"\n            [(ngModel)]=\"selectedValue\" \n            [placeholder]=\"placeholder\"\n            (change)=\"selectChange($event)\"\n            [id]=\"id\">\n  <ng-option *ngFor=\"let option of options\" [value]=\"option\">{{ this.apiMeta !== undefined ? option[labelField] : option.Value__c  }}</ng-option> \n  <!-- <ng-option *ngIf=\"errorMessage\"  value=\"\" disabled hidden>{{ errorMessage }}</ng-option> -->\n</ng-select>\n<span *ngIf=\"error || invalidFieldIds.includes(id)\" class=\"error-msg\">Required*</span>\n"]}
|
|
115
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"custom-dropdown.component.js","sourceRoot":"","sources":["../../../../../../projects/nxt-app/src/lib/components/custom-dropdown/custom-dropdown.component.ts","../../../../../../projects/nxt-app/src/lib/components/custom-dropdown/custom-dropdown.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit,Input,Output,EventEmitter } from '@angular/core';\nimport { HttpClient } from '@angular/common/http';\nimport { Observable, Subscription } from 'rxjs';\nimport { APIMeta } from '../../interfaces/apimeta';\nimport { ChangeWrapper } from '../../model/changeWrapper';\nimport { ChangeService } from '../../services/change.service';\n\n@Component({\n  selector: 'app-custom-dropdown',\n  templateUrl: './custom-dropdown.component.html',\n  styleUrls: ['./custom-dropdown.component.css']\n})\nexport class CustomDropdownComponent implements OnInit {\n  @Input() options: string[];\n  @Input() placeholder: string;\n  @Input() apiMeta: string;\n  @Input() selectedValue: string;\n  @Input() progressBar: boolean;\n  @Input() id:string;\n  @Input() errorMessage: string;\n  @Input() error:any;\n  @Input() fromShengel: boolean = false;\n  @Input() referenceField:string;\n  @Output() valueChange: EventEmitter<ChangeWrapper> = new EventEmitter<ChangeWrapper>();\n  invalidFieldIds:string[] = [];\n  constructor(private http: HttpClient,private changeService: ChangeService) { \n    this.changeService.submitValidate$.subscribe((data)=>{\n      // to get the error message's field id's\n      this.invalidFieldIds.push(data);\n    })\n  }\n\n  public labelField: string;\n  public valueField: string;\n  subscription: Subscription;\n\n  ngOnInit(): void {\n    // console.log('inside oninit of custom-dropdown of ' + this.id);\n    // console.log(this.apiMeta);\n    if(this.apiMeta !== undefined) {\n      this.options = [];\n      let apiObj: APIMeta = JSON.parse(this.apiMeta);\n      this.labelField = apiObj.field;\n\n      this.apiResponse(apiObj.endpoint).subscribe((apiResponse) => {\n        let responses = apiResponse[apiObj.variable];\n        let results = [];\n        for (let i = 0; i < responses.length; i++) {\n          var resp = responses[i];\n          results.push(resp);\n        }\n        // Reference https://www.npmjs.com/package/@ng-select/ng-select\n        this.options = results;\n      })\n      // VD NOV23 - handle the dependent update for dropdown\n      let sourceId = apiObj.sourceQuestionId;\n      if(sourceId){\n        // Subscribe for the changes\n        this.subscription = this.changeService.changeAnnounced$.subscribe(\n          (changeValue) => {\n            if(changeValue != undefined) {\n              // console.log('inside subscription for the change');\n              if(changeValue.valueObj != undefined && changeValue.fromQuestionId == apiObj.sourceQuestionId) {\n                this.selectedValue = changeValue.valueObj[apiObj.valueField];\n                let value ={};\n                value['name'] = this.selectedValue;\n                this.selectChange(value);\n              }\n              this.changeService.confirmChange(apiObj.sourceQuestionId);\n            }\n          }\n        );\n      }\n    }\n  }\n\n  public apiResponse(endpoint: string): Observable<any> {\n    return this.http.get(endpoint);\n  }\n\n  selectChange(event:any) {\n    console.log('inside selectChange from ' + this.id);\n    // console.log(event);\n    let change = new ChangeWrapper(); // ChangeWrapper = JSON.parse('{}');\n    change.fromQuestionId = this.id;\n    change.valueObj = event;\n    this.valueChange.emit(change);\n    // once got value in dropdown remove the error validation\n    if(event){\n      this.invalidFieldIds =[];\n    }\n  }\n}\n","<select *ngIf=\"!fromShengel\"\n  [ngClass]=\"{\n    'dt-line dpDown down myt-dropbox myt-border-r myt-font1': progressBar,\n    'custom-select': !progressBar\n  }\" class=\"custom-select mr-sm-2 dd-height\" \n  [id]=\"id\" \n  [(ngModel)]=\"selectedValue\"\n  (change)=\"selectChange($event.target.value);\" \n  [style.borderColor]=\"error ? 'red' : '#858585'\"\n  [style.color]=\"error ? 'red' : ''\">\n    <option *ngFor=\"let option of options\" [value]=\"option.Value__c\" class=\"option\">{{ option.Value__c }}</option>\n    <option *ngIf=\"errorMessage\" value=\"\" disabled hidden>{{ errorMessage }}</option>\n</select>\n\n<ng-select  *ngIf=\"fromShengel\"\n            [class]=\"invalidFieldIds.includes(id) ? 'shengel-custom-select invalid' : 'shengel-custom-select'\"\n            [(ngModel)]=\"selectedValue\" \n            [placeholder]=\"placeholder\"\n            (change)=\"selectChange($event)\"\n            [id]=\"id\">\n  <ng-option *ngFor=\"let option of options\" [value]=\"option\">{{ this.apiMeta !== undefined ? option[labelField] : option.Value__c  }}</ng-option> \n  <!-- <ng-option *ngIf=\"errorMessage\"  value=\"\" disabled hidden>{{ errorMessage }}</ng-option> -->\n</ng-select>\n<span *ngIf=\"error || invalidFieldIds.includes(id)\" class=\"error-msg\">Required*</span>\n"]}
|
|
@@ -65,7 +65,7 @@ export class SearchBoxComponent {
|
|
|
65
65
|
this.apiResponse(apiObj.endpoint).subscribe((apiResponse) => {
|
|
66
66
|
let response = apiResponse[apiObj.variable];
|
|
67
67
|
let results = [];
|
|
68
|
-
for (let i = 0; i < response.length; i++) {
|
|
68
|
+
for (let i = 0; i < response.length; i++) { // VD NOV23 - updated the search keys
|
|
69
69
|
if (response[i].firstName?.toLowerCase() === keyword?.toLowerCase() || response[i].lastName?.toLowerCase() === keyword?.toLowerCase()) {
|
|
70
70
|
console.log('pushing ' + response[i].firstName);
|
|
71
71
|
results.push(response[i]);
|
|
@@ -103,4 +103,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImpo
|
|
|
103
103
|
}], searchValueChange: [{
|
|
104
104
|
type: Output
|
|
105
105
|
}] } });
|
|
106
|
-
//# 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":"AAAA,OAAO,EACL,SAAS,EAIT,KAAK,EACL,MAAM,EACN,YAAY,EAGZ,SAAS,GACV,MAAM,eAAe,CAAC;AASvB,OAAO,EAAE,aAAa,EAAE,MAAM,2BAA2B,CAAC;;;;;;;;AAO1D,MAAM,OAAO,kBAAkB;IAsBnB;IACA;IACA;IACA;IAxBD,eAAe,CAAS;IACd,IAAI,CAAC;IAEf,QAAQ,CAAC;IACT,OAAO,CAAS;IAChB,EAAE,CAAS;IACV,iBAAiB,GAAgC,IAAI,YAAY,EAAiB,CAAC;IAC5F,MAAM,CAAK;IAEL,UAAU,CAAS;IACnB,YAAY,GAAU,EAAE,CAAC;IACzB,aAAa,GAAW,EAAE,CAAC;IAC3B,SAAS,CAAM;IACf,UAAU,GAAG,KAAK,CAAC;IACnB,QAAQ,GAAG,KAAK,CAAC;IACjB,cAAc,GAAG,IAAI,CAAC;IACrB,EAAE,CAAc;IAChB,IAAI,GAAW,KAAK,CAAC;IACrB,GAAG,GAAW,EAAE,CAAC;IAEzB,YACU,SAA4B,EAC5B,WAAwB,EACxB,KAAqB,EACrB,IAAgB,EACxB,EAAc;QAJN,cAAS,GAAT,SAAS,CAAmB;QAC5B,gBAAW,GAAX,WAAW,CAAa;QACxB,UAAK,GAAL,KAAK,CAAgB;QACrB,SAAI,GAAJ,IAAI,CAAY;IAEtB,CAAC;IAEL,QAAQ;IAER,CAAC;IAED,SAAS;QACP,UAAU,CAAC,GAAE,EAAE;YACb,IAAI,CAAC,YAAY,GAAG,EAAE,CAAC;QACzB,CAAC,EAAE,IAAI,CAAC,CAAC;IACX,CAAC;IAED,kBAAkB,CAAC,KAAK;QACtB,IAAG,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,EAAC;YAC/B,IAAI,CAAC,cAAc,GAAC,IAAI,CAAC;YACzB,IAAI,CAAC,YAAY,GAAC,EAAE,CAAC;YACrB,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC;YACxC,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;YACxB,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;SACxC;aAAM;YACL,IAAI,CAAC,cAAc,GAAC,KAAK,CAAC;YAC1B,IAAI,CAAC,YAAY,GAAG,EAAE,CAAC;YACvB,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC;SACvB;IACH,CAAC;IAEM,WAAW,CAAC,OAAe;QAChC,OAAO,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC;IAChC,CAAC;IAEM,aAAa,GAAG,CAAC,OAAe,EAAE,EAAE;QACzC,IAAG,IAAI,CAAC,OAAO,KAAK,SAAS,EAAE;YAC9B,IAAI,MAAM,GAAY,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;YAC9C,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,SAAS,CAAC,CAAC,WAAW,EAAE,EAAE;gBAC1D,IAAI,QAAQ,GAAG,WAAW,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC;gBAC9C,IAAI,OAAO,GAAC,EAAE,CAAC;gBACf,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,QAAQ,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;oBACxC,IAAG,QAAQ,CAAC,CAAC,CAAC,CAAC,SAAS,EAAE,WAAW,EAAE,KAAK,OAAO,EAAE,WAAW,EAAE,IAAI,QAAQ,CAAC,CAAC,CAAC,CAAC,QAAQ,EAAE,WAAW,EAAE,KAAK,OAAO,EAAE,WAAW,EAAE,EAAE;wBACpI,OAAO,CAAC,GAAG,CAAC,UAAU,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC;wBAChD,OAAO,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC;qBAC3B;iBACF;gBACD,IAAI,CAAC,QAAQ,GAAG,CAAC,CAAC,OAAO,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;gBACtC,IAAI,CAAC,YAAY,GAAG,OAAO,CAAC;YAC9B,CAAC,CAAC,CAAA;SACH;IACD,CAAC,CAAA;IAEM,SAAS,CAAC,KAAK;QACpB,4DAA4D;QAC5D,IAAI,MAAM,GAAG,IAAI,aAAa,EAAE,CAAC,CAAC,oCAAoC;QACtE,MAAM,CAAC,cAAc,GAAG,IAAI,CAAC,EAAE,CAAC;QAChC,MAAM,CAAC,QAAQ,GAAG,KAAK,CAAC;QACxB,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IACtC,CAAC;wGAjFU,kBAAkB;4FAAlB,kBAAkB,6SC3B/B,40EAmDA;;4FDxBa,kBAAkB;kBAL9B,SAAS;+BACE,gBAAgB;iNAKjB,eAAe;sBAAvB,KAAK;gBACa,IAAI;sBAAtB,SAAS;uBAAC,MAAM;gBAER,QAAQ;sBAAhB,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACG,EAAE;sBAAV,KAAK;gBACI,iBAAiB;sBAA1B,MAAM","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\";\nimport { HttpClient, HttpHeaders } from '@angular/common/http';\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\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\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    private http: HttpClient,\n    el: ElementRef\n  ) { }\n\n  ngOnInit(): void {\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\n  public apiResponse(keyword: string): Observable<any> {\n    return this.http.get(keyword);\n  }\n\n  public getSourceData = (keyword: string) => {\n    if(this.apiMeta !== undefined) {\n     let apiObj: APIMeta = JSON.parse(this.apiMeta);\n      this.apiResponse(apiObj.endpoint).subscribe((apiResponse) => {\n        let response = apiResponse[apiObj.variable];\n      let results=[];\n      for (let i = 0; i < response.length; i++) {\n        if(response[i].firstName?.toLowerCase() === keyword?.toLowerCase() || response[i].lastName?.toLowerCase() === keyword?.toLowerCase()) {\n          console.log('pushing ' + response[i].firstName);\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 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        <!-- <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 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.title}}</h4>\n                    <div class=\"show-for-medium\" style=\" white-space: nowrap;\n                    overflow: hidden;text-overflow: ellipsis;\" > {{item.description}}\n                    </div>\n                    <div *ngIf=\"item.price\"  class=\"drop-list\">\n                        {{item.price.toFixed(2)}}\n                    </div>\n                </div>\n            </div>\n        </div> -->\n        <table class=\"table table-striped table-bordered\">\n            <thead>\n              <tr>\n                <th>First Name</th>\n                <th>Last Name</th>\n                <th>Division</th>\n                <th>Number Plate</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"]}
|
|
106
|
+
//# 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":"AAAA,OAAO,EACL,SAAS,EAIT,KAAK,EACL,MAAM,EACN,YAAY,EAGZ,SAAS,GACV,MAAM,eAAe,CAAC;AASvB,OAAO,EAAE,aAAa,EAAE,MAAM,2BAA2B,CAAC;;;;;;;;AAO1D,MAAM,OAAO,kBAAkB;IAsBnB;IACA;IACA;IACA;IAxBD,eAAe,CAAS;IACd,IAAI,CAAC;IAEf,QAAQ,CAAC;IACT,OAAO,CAAS;IAChB,EAAE,CAAS;IACV,iBAAiB,GAAgC,IAAI,YAAY,EAAiB,CAAC;IAC5F,MAAM,CAAK;IAEL,UAAU,CAAS;IACnB,YAAY,GAAU,EAAE,CAAC;IACzB,aAAa,GAAW,EAAE,CAAC;IAC3B,SAAS,CAAM;IACf,UAAU,GAAG,KAAK,CAAC;IACnB,QAAQ,GAAG,KAAK,CAAC;IACjB,cAAc,GAAG,IAAI,CAAC;IACrB,EAAE,CAAc;IAChB,IAAI,GAAW,KAAK,CAAC;IACrB,GAAG,GAAW,EAAE,CAAC;IAEzB,YACU,SAA4B,EAC5B,WAAwB,EACxB,KAAqB,EACrB,IAAgB,EACxB,EAAc;QAJN,cAAS,GAAT,SAAS,CAAmB;QAC5B,gBAAW,GAAX,WAAW,CAAa;QACxB,UAAK,GAAL,KAAK,CAAgB;QACrB,SAAI,GAAJ,IAAI,CAAY;IAEtB,CAAC;IAEL,QAAQ;IAER,CAAC;IAED,SAAS;QACP,UAAU,CAAC,GAAE,EAAE;YACb,IAAI,CAAC,YAAY,GAAG,EAAE,CAAC;QACzB,CAAC,EAAE,IAAI,CAAC,CAAC;IACX,CAAC;IAED,kBAAkB,CAAC,KAAK;QACtB,IAAG,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,EAAC;YAC/B,IAAI,CAAC,cAAc,GAAC,IAAI,CAAC;YACzB,IAAI,CAAC,YAAY,GAAC,EAAE,CAAC;YACrB,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC;YACxC,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;YACxB,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;SACxC;aAAM;YACL,IAAI,CAAC,cAAc,GAAC,KAAK,CAAC;YAC1B,IAAI,CAAC,YAAY,GAAG,EAAE,CAAC;YACvB,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC;SACvB;IACH,CAAC;IAEM,WAAW,CAAC,OAAe;QAChC,OAAO,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC;IAChC,CAAC;IAEM,aAAa,GAAG,CAAC,OAAe,EAAE,EAAE;QACzC,IAAG,IAAI,CAAC,OAAO,KAAK,SAAS,EAAE;YAC9B,IAAI,MAAM,GAAY,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;YAC9C,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,SAAS,CAAC,CAAC,WAAW,EAAE,EAAE;gBAC1D,IAAI,QAAQ,GAAG,WAAW,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC;gBAC9C,IAAI,OAAO,GAAC,EAAE,CAAC;gBACf,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,QAAQ,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE,EAAE,qCAAqC;oBAC/E,IAAG,QAAQ,CAAC,CAAC,CAAC,CAAC,SAAS,EAAE,WAAW,EAAE,KAAK,OAAO,EAAE,WAAW,EAAE,IAAI,QAAQ,CAAC,CAAC,CAAC,CAAC,QAAQ,EAAE,WAAW,EAAE,KAAK,OAAO,EAAE,WAAW,EAAE,EAAE;wBACpI,OAAO,CAAC,GAAG,CAAC,UAAU,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC;wBAChD,OAAO,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC;qBAC3B;iBACF;gBACD,IAAI,CAAC,QAAQ,GAAG,CAAC,CAAC,OAAO,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;gBACtC,IAAI,CAAC,YAAY,GAAG,OAAO,CAAC;YAC9B,CAAC,CAAC,CAAA;SACH;IACD,CAAC,CAAA;IAEM,SAAS,CAAC,KAAK;QACpB,4DAA4D;QAC5D,IAAI,MAAM,GAAG,IAAI,aAAa,EAAE,CAAC,CAAC,oCAAoC;QACtE,MAAM,CAAC,cAAc,GAAG,IAAI,CAAC,EAAE,CAAC;QAChC,MAAM,CAAC,QAAQ,GAAG,KAAK,CAAC;QACxB,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IACtC,CAAC;wGAjFU,kBAAkB;4FAAlB,kBAAkB,6SC3B/B,40EAmDA;;4FDxBa,kBAAkB;kBAL9B,SAAS;+BACE,gBAAgB;iNAKjB,eAAe;sBAAvB,KAAK;gBACa,IAAI;sBAAtB,SAAS;uBAAC,MAAM;gBAER,QAAQ;sBAAhB,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACG,EAAE;sBAAV,KAAK;gBACI,iBAAiB;sBAA1B,MAAM","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\";\nimport { HttpClient, HttpHeaders } from '@angular/common/http';\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\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\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    private http: HttpClient,\n    el: ElementRef\n  ) { }\n\n  ngOnInit(): void {\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\n  public apiResponse(keyword: string): Observable<any> {\n    return this.http.get(keyword);\n  }\n\n  public getSourceData = (keyword: string) => {\n    if(this.apiMeta !== undefined) {\n     let apiObj: APIMeta = JSON.parse(this.apiMeta);\n      this.apiResponse(apiObj.endpoint).subscribe((apiResponse) => {\n        let response = apiResponse[apiObj.variable];\n      let results=[];\n      for (let i = 0; i < response.length; i++) { // VD NOV23 - updated the search keys\n        if(response[i].firstName?.toLowerCase() === keyword?.toLowerCase() || response[i].lastName?.toLowerCase() === keyword?.toLowerCase()) {\n          console.log('pushing ' + response[i].firstName);\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 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        <!-- <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 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.title}}</h4>\n                    <div class=\"show-for-medium\" style=\" white-space: nowrap;\n                    overflow: hidden;text-overflow: ellipsis;\" > {{item.description}}\n                    </div>\n                    <div *ngIf=\"item.price\"  class=\"drop-list\">\n                        {{item.price.toFixed(2)}}\n                    </div>\n                </div>\n            </div>\n        </div> -->\n        <table class=\"table table-striped table-bordered\">\n            <thead>\n              <tr>\n                <th>First Name</th>\n                <th>Last Name</th>\n                <th>Division</th>\n                <th>Number Plate</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"]}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
export {};
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXBpbWV0YS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL254dC1hcHAvc3JjL2xpYi9pbnRlcmZhY2VzL2FwaW1ldGEudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBpbnRlcmZhY2UgQVBJTWV0YSB7XG4gICAgLy8gVkQgTk92MjMgLSBhZGRlZCB2YXJpYWJsZXMgZm9yIGRlcGVuZGVudCB1cGRhdGVcbiAgICBzb3VyY2VRdWVzdGlvbklkOnN0cmluZztcbiAgICB2YWx1ZUZpZWxkOnN0cmluZztcbiAgICBsYWJlbEZpZWxkOnN0cmluZztcbiAgICBlbmRwb2ludDogc3RyaW5nO1xuICAgIHZhcmlhYmxlOiBzdHJpbmc7XG4gICAgZmllbGQ6IHN0cmluZztcblxufVxuIl19
|
|
@@ -29,6 +29,7 @@ import { CustomLabelComponent } from './components/custom-label/custom-label.com
|
|
|
29
29
|
import { TableAppendixComponent } from './components/table-appendix/table-appendix.component';
|
|
30
30
|
import { CustomDateComponent } from './components/custom-date/custom-date.component';
|
|
31
31
|
import { CustomTimeComponent } from './components/custom-time/custom-time.component';
|
|
32
|
+
import { CustomButtonComponent } from './components/custom-button/custom-button.component';
|
|
32
33
|
import * as i0 from "@angular/core";
|
|
33
34
|
import * as i1 from "ng-circle-progress";
|
|
34
35
|
// export const MY_CUSTOM_FORMATS = {
|
|
@@ -56,7 +57,8 @@ export class NxtAppModule {
|
|
|
56
57
|
CustomLabelComponent,
|
|
57
58
|
TableAppendixComponent,
|
|
58
59
|
CustomDateComponent,
|
|
59
|
-
CustomTimeComponent
|
|
60
|
+
CustomTimeComponent,
|
|
61
|
+
CustomButtonComponent], imports: [CommonModule, FormsModule,
|
|
60
62
|
MyDatePickerModule,
|
|
61
63
|
OwlDateTimeModule,
|
|
62
64
|
OwlNativeDateTimeModule,
|
|
@@ -183,7 +185,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImpo
|
|
|
183
185
|
CustomLabelComponent,
|
|
184
186
|
TableAppendixComponent,
|
|
185
187
|
CustomDateComponent,
|
|
186
|
-
CustomTimeComponent
|
|
188
|
+
CustomTimeComponent,
|
|
189
|
+
CustomButtonComponent
|
|
187
190
|
],
|
|
188
191
|
imports: [
|
|
189
192
|
CommonModule, FormsModule,
|
|
@@ -288,4 +291,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImpo
|
|
|
288
291
|
// ]
|
|
289
292
|
}]
|
|
290
293
|
}] });
|
|
291
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"nxt-app.module.js","sourceRoot":"","sources":["../../../../projects/nxt-app/src/lib/nxt-app.module.ts"],"names":[],"mappings":"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","sourcesContent":["import { NgModule, CUSTOM_ELEMENTS_SCHEMA } from '@angular/core';\nimport { NxtAppComponent } from './nxt-app.component';\nimport { QuestionnaireComponent } from './pages/questionnaire/questionnaire.component';\nimport { CommonModule } from \"@angular/common\";\nimport { FormsModule,ReactiveFormsModule } from '@angular/forms';\nimport { MyDatePickerModule } from 'mydatepicker';\nimport { NgCircleProgressModule } from 'ng-circle-progress';\nimport { NgxSpinnerModule } from \"ngx-spinner\";\n//import { AgmCoreModule } from '@agm/core';\nimport { GOOGLE_MAP_API_KEY } from '../lib/sample';\nimport { PickLocationComponent } from './components/pick-location/pick-location.component';\nimport { NgSelectModule } from '@ng-select/ng-select';\nimport { CustomInputComponent } from './components/custom-input/custom-input.component';\nimport { CustomTextAreaComponent } from './components/custom-text-area/custom-text-area.component';\nimport { CustomTableComponent } from './components/custom-table/custom-table.component';\nimport { DropdownWithFlagComponent } from './components/dropdown-with-flag/dropdown-with-flag.component';\nimport { OwlDateTimeModule,OwlNativeDateTimeModule } from 'ng-pick-datetime';\n\n//import { OWL_MOMENT_DATE_TIME_ADAPTER_OPTIONS } from 'ng-pick-datetime/date-time/adapter/moment-adapter/moment-date-time-adapter.class';\nimport { CustomDatePickerComponent } from './components/custom-date-picker/custom-date-picker.component';\nimport { CustomDropdownComponent } from './components/custom-dropdown/custom-dropdown.component';\nimport { HttpClientModule } from '@angular/common/http';\nimport { BookletComponent } from './pages/booklet/booklet.component';\nimport { GoogleMapsModule } from '@angular/google-maps';\nimport { SearchBoxComponent } from './components/search-box/search-box.component';\nimport { QuestionbookComponent } from './pages/questionbook/questionbook.component';\nimport { FileUploadComponent } from './components/file-upload/file-upload.component';\nimport { SummaryPageComponent } from './pages/summary-page/summary-page.component';\nimport { FileViewComponent } from './components/file-view/file-view.component';\nimport { DependentTableComponent } from './components/dependent-table/dependent-table.component';\nimport { CustomLabelComponent } from './components/custom-label/custom-label.component';\nimport { TableAppendixComponent } from './components/table-appendix/table-appendix.component';\nimport { CustomDateComponent } from './components/custom-date/custom-date.component';\nimport { CustomTimeComponent } from './components/custom-time/custom-time.component';\n\n// export const MY_CUSTOM_FORMATS = {\n//   fullPickerInput: 'DD/MM/YYYY HH:mm:ss',\n//   useUtc: true,\n// };\n\n@NgModule({\n  declarations: [NxtAppComponent, \n    QuestionnaireComponent,\n    PickLocationComponent,\n    CustomInputComponent,\n    CustomTextAreaComponent,\n    CustomTableComponent,\n    CustomDatePickerComponent,\n    DropdownWithFlagComponent,\n    CustomDropdownComponent,\n    BookletComponent,\n    SearchBoxComponent,\n    QuestionbookComponent,\n    FileUploadComponent,\n    SummaryPageComponent,\n    FileViewComponent,\n    DependentTableComponent,\n    CustomLabelComponent,\n    TableAppendixComponent,\n    CustomDateComponent,\n    CustomTimeComponent\n  ],\n  imports: [\n    CommonModule, FormsModule,\n    MyDatePickerModule,\n    OwlDateTimeModule,\n    OwlNativeDateTimeModule,\n    HttpClientModule,\n    NgSelectModule,\n    GoogleMapsModule,\n    //AgmCoreModule.forRoot({\n    //  apiKey: GOOGLE_MAP_API_KEY,\n    //  libraries: ['geometry', 'places', 'visualization', 'drawing']\n  //  }),\n    ReactiveFormsModule, NgxSpinnerModule,\n    /*NgCircleProgressModule.forRoot({\n      \"backgroundPadding\": -10,\n      \"radius\": 60,\n      \"space\": -6,\n      \"innerStrokeColor\": \"#919191\",\n      \"outerStrokeColor\": \"#db9594\",\n      \"outerStrokeGradientStopColor\": \"#e0b1b0\",\n      \"innerStrokeWidth\": 2,\n      \"backgroundGradient\": true,\n      \"backgroundColor\": \"#dd2e13\",\n      \"backgroundGradientStopColor\": \"#dd2e13\",\n      \"backgroundStroke\": \"#d3cfcf\",\n      \"title\": [\n                \n                \"%\"\n      ],\n      // titleFontSize: 12,\n      // \"subtitleFontSize\": 20,\n      \"animateTitle\": false,\n      \"animationDuration\": 1000,\n      \"showUnits\": false,\n      \"clockwise\":true\n\n      //\"backgroundStrokeWidth\": \"0\",\n\"backgroundGradient\": true,\n      //\"backgroundColor\": \"#dd2e13\",\n      \"backgroundGradientStopColor\": \"#dd2e13\",\n      \"backgroundStroke\": \"#000000\",\n      \"backgroundPadding\": -10,\n      \"radius\": 60,\n      \"unitsFontWeight\": \"600\",\n      \"unitsColor\": \"#f2f2f2\",\n      \"outerStrokeGradient\": true,\n      \"outerStrokeColor\": \"#e0b1b0\",\n      \"outerStrokeGradientStopColor\": \"#e0b1b0\",\n      \"outerStrokeLinecap\": \"inherit\",\n      \"innerStrokeColor\": \"#f6dfdf\",\n      \"title\": [\n                \n        \"%\"\n],\n      \"titleColor\": \"#e7d9d9\",\n      \"titleFontSize\": \"31\",\n      \"titleFontWeight\": \"100\",\n      \"subtitleColor\": \"#f7f7f7\",\n      \"subtitleFontSize\": \"36\",\n      \"subtitleFontWeight\": \"900\",\n      \"animateTitle\": false,\n      \"animationDuration\": 1000,\n      \"showTitle\": true,\n      \"showUnits\": true,\n      \"clockwise\": false,\n      \"startFromZero\": true,\n      \"showZeroOuterStroke\": false,\n      \"lazy\": true})*/\n\n      NgCircleProgressModule.forRoot({\n        \"backgroundGradient\": true,\n        \"backgroundColor\": \"#e29d98\",\n        \"backgroundGradientStopColor\": \"#c5281c\",\n        \"backgroundStroke\": \"#ece4e4\",\n        \"backgroundStrokeWidth\": 0,\n        \"backgroundPadding\": -10,\n        \"radius\": 60,\n        \"space\": 4,\n        \"maxPercent\": 100,\n        \"unitsFontSize\": \"35\",\n        \"unitsColor\": \"#f0ebeb\",\n        \"outerStrokeGradient\": true,\n        \"outerStrokeWidth\": 10,\n        \"outerStrokeColor\": \"#f7c0bf\",\n        \"outerStrokeGradientStopColor\": \"#f9c9c8\",\n        \"innerStrokeWidth\": 0,\n        \"titleColor\": \"#f3eded\",\n        \"titleFontSize\": \"40\",\n        \"subtitleColor\": \"#444444\",\n        \"showSubtitle\": false})\n  ],\n  schemas: [CUSTOM_ELEMENTS_SCHEMA],\n  exports: [NxtAppComponent, \n    QuestionnaireComponent,\n    BookletComponent,\n    SummaryPageComponent\n  ]\n  // providers: [\n  //   { provide: OWL_MOMENT_DATE_TIME_ADAPTER_OPTIONS, useValue: { useUtc: false } },\n  //   { provide: OWL_DATE_TIME_FORMATS, useValue: MY_CUSTOM_FORMATS },\n  // ]\n})\nexport class NxtAppModule { }\n"]}
|
|
294
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"nxt-app.module.js","sourceRoot":"","sources":["../../../../projects/nxt-app/src/lib/nxt-app.module.ts"],"names":[],"mappings":"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","sourcesContent":["import { NgModule, CUSTOM_ELEMENTS_SCHEMA } from '@angular/core';\nimport { NxtAppComponent } from './nxt-app.component';\nimport { QuestionnaireComponent } from './pages/questionnaire/questionnaire.component';\nimport { CommonModule } from \"@angular/common\";\nimport { FormsModule,ReactiveFormsModule } from '@angular/forms';\nimport { MyDatePickerModule } from 'mydatepicker';\nimport { NgCircleProgressModule } from 'ng-circle-progress';\nimport { NgxSpinnerModule } from \"ngx-spinner\";\n//import { AgmCoreModule } from '@agm/core';\nimport { GOOGLE_MAP_API_KEY } from '../lib/sample';\nimport { PickLocationComponent } from './components/pick-location/pick-location.component';\nimport { NgSelectModule } from '@ng-select/ng-select';\nimport { CustomInputComponent } from './components/custom-input/custom-input.component';\nimport { CustomTextAreaComponent } from './components/custom-text-area/custom-text-area.component';\nimport { CustomTableComponent } from './components/custom-table/custom-table.component';\nimport { DropdownWithFlagComponent } from './components/dropdown-with-flag/dropdown-with-flag.component';\nimport { OwlDateTimeModule,OwlNativeDateTimeModule } from 'ng-pick-datetime';\n\n//import { OWL_MOMENT_DATE_TIME_ADAPTER_OPTIONS } from 'ng-pick-datetime/date-time/adapter/moment-adapter/moment-date-time-adapter.class';\nimport { CustomDatePickerComponent } from './components/custom-date-picker/custom-date-picker.component';\nimport { CustomDropdownComponent } from './components/custom-dropdown/custom-dropdown.component';\nimport { HttpClientModule } from '@angular/common/http';\nimport { BookletComponent } from './pages/booklet/booklet.component';\nimport { GoogleMapsModule } from '@angular/google-maps';\nimport { SearchBoxComponent } from './components/search-box/search-box.component';\nimport { QuestionbookComponent } from './pages/questionbook/questionbook.component';\nimport { FileUploadComponent } from './components/file-upload/file-upload.component';\nimport { SummaryPageComponent } from './pages/summary-page/summary-page.component';\nimport { FileViewComponent } from './components/file-view/file-view.component';\nimport { DependentTableComponent } from './components/dependent-table/dependent-table.component';\nimport { CustomLabelComponent } from './components/custom-label/custom-label.component';\nimport { TableAppendixComponent } from './components/table-appendix/table-appendix.component';\nimport { CustomDateComponent } from './components/custom-date/custom-date.component';\nimport { CustomTimeComponent } from './components/custom-time/custom-time.component';\nimport { CustomButtonComponent } from './components/custom-button/custom-button.component';\n\n// export const MY_CUSTOM_FORMATS = {\n//   fullPickerInput: 'DD/MM/YYYY HH:mm:ss',\n//   useUtc: true,\n// };\n\n@NgModule({\n  declarations: [NxtAppComponent, \n    QuestionnaireComponent,\n    PickLocationComponent,\n    CustomInputComponent,\n    CustomTextAreaComponent,\n    CustomTableComponent,\n    CustomDatePickerComponent,\n    DropdownWithFlagComponent,\n    CustomDropdownComponent,\n    BookletComponent,\n    SearchBoxComponent,\n    QuestionbookComponent,\n    FileUploadComponent,\n    SummaryPageComponent,\n    FileViewComponent,\n    DependentTableComponent,\n    CustomLabelComponent,\n    TableAppendixComponent,\n    CustomDateComponent,\n    CustomTimeComponent,\n    CustomButtonComponent\n  ],\n  imports: [\n    CommonModule, FormsModule,\n    MyDatePickerModule,\n    OwlDateTimeModule,\n    OwlNativeDateTimeModule,\n    HttpClientModule,\n    NgSelectModule,\n    GoogleMapsModule,\n    //AgmCoreModule.forRoot({\n    //  apiKey: GOOGLE_MAP_API_KEY,\n    //  libraries: ['geometry', 'places', 'visualization', 'drawing']\n  //  }),\n    ReactiveFormsModule, NgxSpinnerModule,\n    /*NgCircleProgressModule.forRoot({\n      \"backgroundPadding\": -10,\n      \"radius\": 60,\n      \"space\": -6,\n      \"innerStrokeColor\": \"#919191\",\n      \"outerStrokeColor\": \"#db9594\",\n      \"outerStrokeGradientStopColor\": \"#e0b1b0\",\n      \"innerStrokeWidth\": 2,\n      \"backgroundGradient\": true,\n      \"backgroundColor\": \"#dd2e13\",\n      \"backgroundGradientStopColor\": \"#dd2e13\",\n      \"backgroundStroke\": \"#d3cfcf\",\n      \"title\": [\n                \n                \"%\"\n      ],\n      // titleFontSize: 12,\n      // \"subtitleFontSize\": 20,\n      \"animateTitle\": false,\n      \"animationDuration\": 1000,\n      \"showUnits\": false,\n      \"clockwise\":true\n\n      //\"backgroundStrokeWidth\": \"0\",\n\"backgroundGradient\": true,\n      //\"backgroundColor\": \"#dd2e13\",\n      \"backgroundGradientStopColor\": \"#dd2e13\",\n      \"backgroundStroke\": \"#000000\",\n      \"backgroundPadding\": -10,\n      \"radius\": 60,\n      \"unitsFontWeight\": \"600\",\n      \"unitsColor\": \"#f2f2f2\",\n      \"outerStrokeGradient\": true,\n      \"outerStrokeColor\": \"#e0b1b0\",\n      \"outerStrokeGradientStopColor\": \"#e0b1b0\",\n      \"outerStrokeLinecap\": \"inherit\",\n      \"innerStrokeColor\": \"#f6dfdf\",\n      \"title\": [\n                \n        \"%\"\n],\n      \"titleColor\": \"#e7d9d9\",\n      \"titleFontSize\": \"31\",\n      \"titleFontWeight\": \"100\",\n      \"subtitleColor\": \"#f7f7f7\",\n      \"subtitleFontSize\": \"36\",\n      \"subtitleFontWeight\": \"900\",\n      \"animateTitle\": false,\n      \"animationDuration\": 1000,\n      \"showTitle\": true,\n      \"showUnits\": true,\n      \"clockwise\": false,\n      \"startFromZero\": true,\n      \"showZeroOuterStroke\": false,\n      \"lazy\": true})*/\n\n      NgCircleProgressModule.forRoot({\n        \"backgroundGradient\": true,\n        \"backgroundColor\": \"#e29d98\",\n        \"backgroundGradientStopColor\": \"#c5281c\",\n        \"backgroundStroke\": \"#ece4e4\",\n        \"backgroundStrokeWidth\": 0,\n        \"backgroundPadding\": -10,\n        \"radius\": 60,\n        \"space\": 4,\n        \"maxPercent\": 100,\n        \"unitsFontSize\": \"35\",\n        \"unitsColor\": \"#f0ebeb\",\n        \"outerStrokeGradient\": true,\n        \"outerStrokeWidth\": 10,\n        \"outerStrokeColor\": \"#f7c0bf\",\n        \"outerStrokeGradientStopColor\": \"#f9c9c8\",\n        \"innerStrokeWidth\": 0,\n        \"titleColor\": \"#f3eded\",\n        \"titleFontSize\": \"40\",\n        \"subtitleColor\": \"#444444\",\n        \"showSubtitle\": false})\n  ],\n  schemas: [CUSTOM_ELEMENTS_SCHEMA],\n  exports: [NxtAppComponent, \n    QuestionnaireComponent,\n    BookletComponent,\n    SummaryPageComponent\n  ]\n  // providers: [\n  //   { provide: OWL_MOMENT_DATE_TIME_ADAPTER_OPTIONS, useValue: { useUtc: false } },\n  //   { provide: OWL_DATE_TIME_FORMATS, useValue: MY_CUSTOM_FORMATS },\n  // ]\n})\nexport class NxtAppModule { }\n"]}
|
|
@@ -48,8 +48,9 @@ export class BookletComponent {
|
|
|
48
48
|
ngOnInit() {
|
|
49
49
|
this.processBooklet();
|
|
50
50
|
}
|
|
51
|
+
// VD NOV23 - update the json data when bookletId and bookletJSON changes
|
|
51
52
|
ngOnChanges(simplechanges) {
|
|
52
|
-
if (simplechanges['bookletId']) {
|
|
53
|
+
if (simplechanges['bookletId'] || simplechanges['bookletJSON']) {
|
|
53
54
|
this.processBooklet();
|
|
54
55
|
}
|
|
55
56
|
// console.log('inside Questionnaire ngOnChanges');
|
|
@@ -160,11 +161,11 @@ export class BookletComponent {
|
|
|
160
161
|
this.hadleDropDownDependent.emit(event);
|
|
161
162
|
}
|
|
162
163
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: BookletComponent, deps: [{ token: i1.SalesforceService }, { token: i2.DataService }, { token: i3.StorageService }, { token: i4.ActivatedRoute }, { token: i5.DomSanitizer }, { token: i6.ChangeService }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
163
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: BookletComponent, selector: "lib-booklet", inputs: { bookletId: "bookletId", serv: "serv", tkn: "tkn", bookletJSON: "bookletJSON", dropdownDependentData: "dropdownDependentData", labelValue: "labelValue" }, outputs: { handleBookletActionEvent: "handleBookletActionEvent", handlePage: "handlePage", hadleDropDownDependent: "hadleDropDownDependent" }, usesOnChanges: true, ngImport: i0, template: "<ngx-spinner [name]=\"spinnerName\" [type]=\"spinnerType\"></ngx-spinner>\n<!-- Booklet Handling-->\n<div *ngFor=\"let qb of booklet\">\n <!-- MR Commented below code to ensure single JSON for UNCONDITIONAL Booklets -->\n <!-- <lib-questionnaire [serv]=\"serv\" [qbId]=\"qb.Id\" [tkn]=\"tkn\"></lib-questionnaire> -->\n <div *ngFor=\"let ques of qb.Questions__r.records\" [class]=\"qb.isShengel__c ? 'questiondiv1' : 'questiondiv1 padd-bottom'\">\n <div class=\"questiondiv2\">\n <div *ngIf=\"!ques.Is_Title__c\" [class]=\"qb.isShengel__c ? 'header-style' : 'question-f-size additional'\">\n <div [innerHTML]=\"getText(ques?.Question_Text__c)\"
|
|
164
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: BookletComponent, selector: "lib-booklet", inputs: { bookletId: "bookletId", serv: "serv", tkn: "tkn", bookletJSON: "bookletJSON", dropdownDependentData: "dropdownDependentData", labelValue: "labelValue" }, outputs: { handleBookletActionEvent: "handleBookletActionEvent", handlePage: "handlePage", hadleDropDownDependent: "hadleDropDownDependent" }, usesOnChanges: true, ngImport: i0, template: "<ngx-spinner [name]=\"spinnerName\" [type]=\"spinnerType\"></ngx-spinner>\n<!-- Booklet Handling-->\n<div *ngFor=\"let qb of booklet\">\n <!-- MR Commented below code to ensure single JSON for UNCONDITIONAL Booklets -->\n <!-- <lib-questionnaire [serv]=\"serv\" [qbId]=\"qb.Id\" [tkn]=\"tkn\"></lib-questionnaire> -->\n <div *ngFor=\"let ques of qb.Questions__r.records\" [class]=\"qb.isShengel__c ? 'questiondiv1' : 'questiondiv1 padd-bottom'\">\n <div class=\"questiondiv2\">\n <div *ngIf=\"!ques.Is_Title__c\" [class]=\"qb.isShengel__c ? 'header-style' : 'question-f-size additional'\">\n <!-- VD 08NOV23 - showing lable when its available-->\n <div [innerHTML]=\"getText(ques?.Question_Text__c)\" *ngIf=\"ques?.Question_Text__c\" > \n {{ ques?.Question_Text__c }}\n </div>\n </div>\n <lib-questionbook [qbItem]=\"qb\" [labelValue]=\"labelValue\" [questionItem]=\"ques\" [questions]=\"readQuestions(qb.Id)\" (handleDropDown)=\"getDropDown($event)\"></lib-questionbook>\n </div>\n </div>\n</div>\n\n<!-- Group Actions -->\n<div class=\"align-submit-row\" *ngIf=\"abItem?.Status__c != 'Completed'\">\n <div *ngFor=\"let action of actions; let i = index\">\n <button (click)=\"handleBookletActionClick(action)\" [ngClass]=\"{'first-button': i === 0, 'second-button': i === 1}\">\n {{ action.name }}\n </button>\n </div>\n</div>\n", styles: [".align-submit-row{display:flex}.align-submit-row button{margin-left:25px;background:#48B7FF;color:#fff;border:none;border-radius:5px;height:50px;width:150px}.header-style{padding:15px;background:#F8F8F8;color:#898989;border:1px solid #e8e8e8;border-top-left-radius:5px;border-top-right-radius:5px;margin-left:0;justify-content:left;font-size:15px}\n"], dependencies: [{ kind: "directive", type: i7.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i7.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i7.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i8.NgxSpinnerComponent, selector: "ngx-spinner", inputs: ["disableAnimation", "bdColor", "zIndex", "color", "type", "size", "fullScreen", "name", "template", "showSpinner"] }, { kind: "component", type: i9.QuestionbookComponent, selector: "lib-questionbook", inputs: ["qbItem", "questionItem", "questions", "errorFieldId", "labelValue", "dropDownData"], outputs: ["handleDropDown"] }] });
|
|
164
165
|
}
|
|
165
166
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: BookletComponent, decorators: [{
|
|
166
167
|
type: Component,
|
|
167
|
-
args: [{ selector: 'lib-booklet', template: "<ngx-spinner [name]=\"spinnerName\" [type]=\"spinnerType\"></ngx-spinner>\n<!-- Booklet Handling-->\n<div *ngFor=\"let qb of booklet\">\n <!-- MR Commented below code to ensure single JSON for UNCONDITIONAL Booklets -->\n <!-- <lib-questionnaire [serv]=\"serv\" [qbId]=\"qb.Id\" [tkn]=\"tkn\"></lib-questionnaire> -->\n <div *ngFor=\"let ques of qb.Questions__r.records\" [class]=\"qb.isShengel__c ? 'questiondiv1' : 'questiondiv1 padd-bottom'\">\n <div class=\"questiondiv2\">\n <div *ngIf=\"!ques.Is_Title__c\" [class]=\"qb.isShengel__c ? 'header-style' : 'question-f-size additional'\">\n <div [innerHTML]=\"getText(ques?.Question_Text__c)\"
|
|
168
|
+
args: [{ selector: 'lib-booklet', template: "<ngx-spinner [name]=\"spinnerName\" [type]=\"spinnerType\"></ngx-spinner>\n<!-- Booklet Handling-->\n<div *ngFor=\"let qb of booklet\">\n <!-- MR Commented below code to ensure single JSON for UNCONDITIONAL Booklets -->\n <!-- <lib-questionnaire [serv]=\"serv\" [qbId]=\"qb.Id\" [tkn]=\"tkn\"></lib-questionnaire> -->\n <div *ngFor=\"let ques of qb.Questions__r.records\" [class]=\"qb.isShengel__c ? 'questiondiv1' : 'questiondiv1 padd-bottom'\">\n <div class=\"questiondiv2\">\n <div *ngIf=\"!ques.Is_Title__c\" [class]=\"qb.isShengel__c ? 'header-style' : 'question-f-size additional'\">\n <!-- VD 08NOV23 - showing lable when its available-->\n <div [innerHTML]=\"getText(ques?.Question_Text__c)\" *ngIf=\"ques?.Question_Text__c\" > \n {{ ques?.Question_Text__c }}\n </div>\n </div>\n <lib-questionbook [qbItem]=\"qb\" [labelValue]=\"labelValue\" [questionItem]=\"ques\" [questions]=\"readQuestions(qb.Id)\" (handleDropDown)=\"getDropDown($event)\"></lib-questionbook>\n </div>\n </div>\n</div>\n\n<!-- Group Actions -->\n<div class=\"align-submit-row\" *ngIf=\"abItem?.Status__c != 'Completed'\">\n <div *ngFor=\"let action of actions; let i = index\">\n <button (click)=\"handleBookletActionClick(action)\" [ngClass]=\"{'first-button': i === 0, 'second-button': i === 1}\">\n {{ action.name }}\n </button>\n </div>\n</div>\n", styles: [".align-submit-row{display:flex}.align-submit-row button{margin-left:25px;background:#48B7FF;color:#fff;border:none;border-radius:5px;height:50px;width:150px}.header-style{padding:15px;background:#F8F8F8;color:#898989;border:1px solid #e8e8e8;border-top-left-radius:5px;border-top-right-radius:5px;margin-left:0;justify-content:left;font-size:15px}\n"] }]
|
|
168
169
|
}], ctorParameters: function () { return [{ type: i1.SalesforceService }, { type: i2.DataService }, { type: i3.StorageService }, { type: i4.ActivatedRoute }, { type: i5.DomSanitizer }, { type: i6.ChangeService }, { type: i0.ElementRef }]; }, propDecorators: { bookletId: [{
|
|
169
170
|
type: Input
|
|
170
171
|
}], serv: [{
|
|
@@ -184,4 +185,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImpo
|
|
|
184
185
|
}], hadleDropDownDependent: [{
|
|
185
186
|
type: Output
|
|
186
187
|
}] } });
|
|
187
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"booklet.component.js","sourceRoot":"","sources":["../../../../../../projects/nxt-app/src/lib/pages/booklet/booklet.component.ts","../../../../../../projects/nxt-app/src/lib/pages/booklet/booklet.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  SimpleChanges,\n} from \"@angular/core\";\nimport { SalesforceService } from \"../../services/salesforce.service\";\nimport { DataService } from '../../services/data.service';\nimport { ActivatedRoute, Params } from \"@angular/router\";\nimport { DomSanitizer, SafeHtml } from \"@angular/platform-browser\";\nimport { ActionMeta } from '../../interfaces/actionMeta';\nimport { Question } from \"../../wrapper\";\nimport { BookletWrapper } from \"../../model/bookletWrapper\";\nimport { StorageService } from '../../services/storage.service';\nimport { ChangeService } from \"../../services/change.service\";\n\n@Component({\n  selector: 'lib-booklet',\n  templateUrl: './booklet.component.html',\n  styleUrls: ['./booklet.component.css']\n})\nexport class BookletComponent implements OnInit {\n  @Input() bookletId: string;\n  @Input() serv: string;\n  @Input() tkn: string;\n  @Input() bookletJSON: any;\n  @Input() dropdownDependentData:any;\n  @Input() labelValue:string;\n  \n  @Output() handleBookletActionEvent: EventEmitter<any> = new EventEmitter();\n  @Output() handlePage: EventEmitter<any> = new EventEmitter();\n  @Output() hadleDropDownDependent:EventEmitter<any> = new EventEmitter();\n\n  public nxtBooklet: BookletWrapper;\n\n  public booklet: any[] = [];\n  public abItem: any = {};\n  public actions: ActionMeta[] = [];\n  public bookQuestionsMap: any = new Map();\n  private sqOptions: any = new Map();\n  public isAnswerFlag: boolean = false;\n  public spinnerName: string;\n  public spinnerType: string;\n\n  constructor(\n    private sfService: SalesforceService,\n    private dataService: DataService,\n    private storageService: StorageService,\n    private route: ActivatedRoute,\n    private sanitizer: DomSanitizer,\n    private changeService: ChangeService, \n    el: ElementRef\n  ) { \n    this.spinnerName = \"sp1\";\n    this.spinnerType = \"ball-spin-clockwise\";\n    console.log('dropdownDependentData',this.dropdownDependentData);\n  }\n\n  ngOnInit(): void {\n    this.processBooklet();\n  }\n\n  ngOnChanges(simplechanges:SimpleChanges) {\n    if(simplechanges['bookletId']){\n      this.processBooklet();\n    }\n    // console.log('inside Questionnaire ngOnChanges');\n    // console.log(this.booklet);\n    // if(this.booklet == undefined || this.booklet.length == 0) {\n    //   this.processBooklet();\n    // }\n  }\n\n  processBooklet() {\n    if (this.bookletId) {\n      if (this.bookletId.length == 18) {\n        this.readBooklet(this.bookletId);\n      }\n    } else if(this.bookletJSON) {\n      // Try to pass a value from Backend to differentiate the QuestionBook Read and AnswerBook Read\n      this.isAnswerFlag = true;\n\n      if(this.bookletJSON != null || this.bookletJSON != undefined) {\n          // Storing the API response for future use\n          this.storageService.save(this.bookletJSON);\n      }\n      \n      this.booklet = this.bookletJSON.records;\n      this.abItem = this.bookletJSON.answerbook;\n\n      // Process the Sub Question Options - This should be merged with bookQuestionsMap in future\n      for (var sq in this.bookletJSON.sqOptions) {\n        this.sqOptions.set(sq, this.bookletJSON.sqOptions[sq]);\n      }\n\n      // Process the Questions\n      for (var value in this.bookletJSON.bookQuestionsMap) {\n        this.bookQuestionsMap.set(value, this.bookletJSON.bookQuestionsMap[value]);\n      }\n\n      if(this.bookletJSON.questionbook?.Actions__c != undefined) {\n        this.actions = JSON.parse(this.bookletJSON.questionbook.Actions__c);\n      }\n    }\n  }\n\n  private readBooklet = (uuid: string) => {\n    if(this.serv == \"api\") {\n      this.dataService.getAPIData(\n        this.tkn,\n        [\"Booklet\", \"read\", uuid],\n        this.successReadBooklet,\n        this.failureReadBooklet\n      );\n    } else {\n      this.sfService.remoteAction(\n        \"NxtController.process\",\n        [\"Booklet\", \"read\", uuid],\n        this.successReadBooklet,\n        this.failureReadBooklet\n      );\n    }\n  }\n\n  private successReadBooklet = (response) => {\n    console.log('Inside the successReadBooklet');\n    // console.log(response);\n    if(response != null || response != undefined) {\n      // Storing the API response for future use\n      this.storageService.save(response);\n\n      // Try to pass a value from Backend to differentiate the QuestionBook Read and AnswerBook Read\n      // this.isAnswerFlag = true;\n      \n      this.booklet = response.records;\n      this.abItem = response.answerbook;\n\n      // Process the Sub Question Options - This should be merged with bookQuestionsMap in future\n      for (var sq in response.sqOptions) {\n        this.sqOptions.set(sq, response.sqOptions[sq]);\n      }\n\n      // Process the Questions\n      for (var value in response.bookQuestionsMap) {\n        this.bookQuestionsMap.set(value, response.bookQuestionsMap[value]);\n      }\n\n      if(response.questionbook?.Actions__c != undefined) {\n        this.actions = JSON.parse(response.questionbook.Actions__c);\n      }\n    }\n  }\n\n  private failureReadBooklet = (response) => {\n\n  }\n\n  handleBookletActionClick(action:ActionMeta) {\n    console.log(action);\n    let dataToParent = {};\n    dataToParent['action'] = action.eventtoemit;\n    dataToParent['data'] = this.storageService.get();\n    this.handleBookletActionEvent.emit(dataToParent);\n\n    // when clicking the submit button validating the required fields\n    for(let key in dataToParent['data'].bookQuestionsMap){\n      const currentBook  = dataToParent['data'].bookQuestionsMap[key];\n      currentBook.Questions__r.records.forEach(element => {\n        if(element.Error_Message__c && dataToParent['action'] == 'submit' && !element.input){\n          this.changeService.submitChange(element.Id);\n        }\n       });\n    }\n\n  }\n\n  readQuestions(qbId: string) {\n    // console.log('inside BookletComponent.readQuestions ' + qbId);\n    // console.log(this.bookQuestionsMap.size);\n    let questions = [];\n    for(var sq in this.bookQuestionsMap?.get(qbId).Questions__r.records) {\n      let q: Question = this.bookQuestionsMap?.get(qbId).Questions__r.records[sq];\n      if(q.Type__c == 'Dropdown') {\n        questions.push(this.sqOptions.get(q.Id));\n      } else {\n        questions.push(q);\n      }\n    }\n    // console.log(questions);\n    return questions;\n  }\n\n  getText(value) {\n    var doc = new DOMParser().parseFromString(value, \"text/html\");\n    //console.log( doc.documentElement.textContent);\n    return this.sanitizer.bypassSecurityTrustHtml(\n      doc.documentElement.textContent\n    );\n  }\n  getDropDown(event:any){\n    this.hadleDropDownDependent.emit(event);\n  }\n}\n","<ngx-spinner [name]=\"spinnerName\" [type]=\"spinnerType\"></ngx-spinner>\n<!-- Booklet Handling-->\n<div *ngFor=\"let qb of booklet\">\n    <!-- MR Commented below code to ensure single JSON for UNCONDITIONAL Booklets -->\n    <!-- <lib-questionnaire [serv]=\"serv\" [qbId]=\"qb.Id\" [tkn]=\"tkn\"></lib-questionnaire> -->\n    <div *ngFor=\"let ques of qb.Questions__r.records\" [class]=\"qb.isShengel__c ? 'questiondiv1' : 'questiondiv1 padd-bottom'\">\n        <div class=\"questiondiv2\">\n            <div *ngIf=\"!ques.Is_Title__c\" [class]=\"qb.isShengel__c ? 'header-style' : 'question-f-size additional'\">\n                <div [innerHTML]=\"getText(ques?.Question_Text__c)\" >\n                    {{ ques?.Question_Text__c }}\n                </div>\n            </div>\n            <lib-questionbook [qbItem]=\"qb\" [labelValue]=\"labelValue\" [questionItem]=\"ques\" [questions]=\"readQuestions(qb.Id)\"  (handleDropDown)=\"getDropDown($event)\"></lib-questionbook>\n        </div>\n    </div>\n</div>\n\n<!-- Group Actions -->\n<div class=\"align-submit-row\" *ngIf=\"abItem?.Status__c != 'Completed'\">\n    <div *ngFor=\"let action of actions; let i = index\">\n        <button (click)=\"handleBookletActionClick(action)\" [ngClass]=\"{'first-button': i === 0, 'second-button': i === 1}\">\n            {{ action.name }}\n        </button>\n    </div>\n</div>\n"]}
|
|
188
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"booklet.component.js","sourceRoot":"","sources":["../../../../../../projects/nxt-app/src/lib/pages/booklet/booklet.component.ts","../../../../../../projects/nxt-app/src/lib/pages/booklet/booklet.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  SimpleChanges,\n} from \"@angular/core\";\nimport { SalesforceService } from \"../../services/salesforce.service\";\nimport { DataService } from '../../services/data.service';\nimport { ActivatedRoute, Params } from \"@angular/router\";\nimport { DomSanitizer, SafeHtml } from \"@angular/platform-browser\";\nimport { ActionMeta } from '../../interfaces/actionMeta';\nimport { Question } from \"../../wrapper\";\nimport { BookletWrapper } from \"../../model/bookletWrapper\";\nimport { StorageService } from '../../services/storage.service';\nimport { ChangeService } from \"../../services/change.service\";\n\n@Component({\n  selector: 'lib-booklet',\n  templateUrl: './booklet.component.html',\n  styleUrls: ['./booklet.component.css']\n})\nexport class BookletComponent implements OnInit {\n  @Input() bookletId: string;\n  @Input() serv: string;\n  @Input() tkn: string;\n  @Input() bookletJSON: any;\n  @Input() dropdownDependentData:any;\n  @Input() labelValue:string;\n  \n  @Output() handleBookletActionEvent: EventEmitter<any> = new EventEmitter();\n  @Output() handlePage: EventEmitter<any> = new EventEmitter();\n  @Output() hadleDropDownDependent:EventEmitter<any> = new EventEmitter();\n\n  public nxtBooklet: BookletWrapper;\n\n  public booklet: any[] = [];\n  public abItem: any = {};\n  public actions: ActionMeta[] = [];\n  public bookQuestionsMap: any = new Map();\n  private sqOptions: any = new Map();\n  public isAnswerFlag: boolean = false;\n  public spinnerName: string;\n  public spinnerType: string;\n\n  constructor(\n    private sfService: SalesforceService,\n    private dataService: DataService,\n    private storageService: StorageService,\n    private route: ActivatedRoute,\n    private sanitizer: DomSanitizer,\n    private changeService: ChangeService, \n    el: ElementRef\n  ) { \n    this.spinnerName = \"sp1\";\n    this.spinnerType = \"ball-spin-clockwise\";\n    console.log('dropdownDependentData',this.dropdownDependentData);\n  }\n\n  ngOnInit(): void {\n    this.processBooklet();\n  }\n // VD NOV23 - update the json data when bookletId and bookletJSON changes\n  ngOnChanges(simplechanges:SimpleChanges) {\n    if(simplechanges['bookletId'] || simplechanges['bookletJSON']){\n      this.processBooklet();\n    }\n    // console.log('inside Questionnaire ngOnChanges');\n    // console.log(this.booklet);\n    // if(this.booklet == undefined || this.booklet.length == 0) {\n    //   this.processBooklet();\n    // }\n  }\n\n  processBooklet() {\n    if (this.bookletId) {\n      if (this.bookletId.length == 18) {\n        this.readBooklet(this.bookletId);\n      }\n    } else if(this.bookletJSON) {\n      // Try to pass a value from Backend to differentiate the QuestionBook Read and AnswerBook Read\n      this.isAnswerFlag = true;\n\n      if(this.bookletJSON != null || this.bookletJSON != undefined) {\n          // Storing the API response for future use\n          this.storageService.save(this.bookletJSON);\n      }\n      \n      this.booklet = this.bookletJSON.records;\n      this.abItem = this.bookletJSON.answerbook;\n\n      // Process the Sub Question Options - This should be merged with bookQuestionsMap in future\n      for (var sq in this.bookletJSON.sqOptions) {\n        this.sqOptions.set(sq, this.bookletJSON.sqOptions[sq]);\n      }\n\n      // Process the Questions\n      for (var value in this.bookletJSON.bookQuestionsMap) {\n        this.bookQuestionsMap.set(value, this.bookletJSON.bookQuestionsMap[value]);\n      }\n\n      if(this.bookletJSON.questionbook?.Actions__c != undefined) {\n        this.actions = JSON.parse(this.bookletJSON.questionbook.Actions__c);\n      }\n    }\n  }\n\n  private readBooklet = (uuid: string) => {\n    if(this.serv == \"api\") {\n      this.dataService.getAPIData(\n        this.tkn,\n        [\"Booklet\", \"read\", uuid],\n        this.successReadBooklet,\n        this.failureReadBooklet\n      );\n    } else {\n      this.sfService.remoteAction(\n        \"NxtController.process\",\n        [\"Booklet\", \"read\", uuid],\n        this.successReadBooklet,\n        this.failureReadBooklet\n      );\n    }\n  }\n\n  private successReadBooklet = (response) => {\n    console.log('Inside the successReadBooklet');\n    // console.log(response);\n    if(response != null || response != undefined) {\n      // Storing the API response for future use\n      this.storageService.save(response);\n\n      // Try to pass a value from Backend to differentiate the QuestionBook Read and AnswerBook Read\n      // this.isAnswerFlag = true;\n      \n      this.booklet = response.records;\n      this.abItem = response.answerbook;\n\n      // Process the Sub Question Options - This should be merged with bookQuestionsMap in future\n      for (var sq in response.sqOptions) {\n        this.sqOptions.set(sq, response.sqOptions[sq]);\n      }\n\n      // Process the Questions\n      for (var value in response.bookQuestionsMap) {\n        this.bookQuestionsMap.set(value, response.bookQuestionsMap[value]);\n      }\n\n      if(response.questionbook?.Actions__c != undefined) {\n        this.actions = JSON.parse(response.questionbook.Actions__c);\n      }\n    }\n  }\n\n  private failureReadBooklet = (response) => {\n\n  }\n\n  handleBookletActionClick(action:ActionMeta) {\n    console.log(action);\n    let dataToParent = {};\n    dataToParent['action'] = action.eventtoemit;\n    dataToParent['data'] = this.storageService.get();\n    this.handleBookletActionEvent.emit(dataToParent);\n\n    // when clicking the submit button validating the required fields\n    for(let key in dataToParent['data'].bookQuestionsMap){\n      const currentBook  = dataToParent['data'].bookQuestionsMap[key];\n      currentBook.Questions__r.records.forEach(element => {\n        if(element.Error_Message__c && dataToParent['action'] == 'submit' && !element.input){\n          this.changeService.submitChange(element.Id);\n        }\n       });\n    }\n\n  }\n\n  readQuestions(qbId: string) {\n    // console.log('inside BookletComponent.readQuestions ' + qbId);\n    // console.log(this.bookQuestionsMap.size);\n    let questions = [];\n    for(var sq in this.bookQuestionsMap?.get(qbId).Questions__r.records) {\n      let q: Question = this.bookQuestionsMap?.get(qbId).Questions__r.records[sq];\n      if(q.Type__c == 'Dropdown') {\n        questions.push(this.sqOptions.get(q.Id));\n      } else {\n        questions.push(q);\n      }\n    }\n    // console.log(questions);\n    return questions;\n  }\n\n  getText(value) {\n    var doc = new DOMParser().parseFromString(value, \"text/html\");\n    //console.log( doc.documentElement.textContent);\n    return this.sanitizer.bypassSecurityTrustHtml(\n      doc.documentElement.textContent\n    );\n  }\n  getDropDown(event:any){\n    this.hadleDropDownDependent.emit(event);\n  }\n}\n","<ngx-spinner [name]=\"spinnerName\" [type]=\"spinnerType\"></ngx-spinner>\n<!-- Booklet Handling-->\n<div *ngFor=\"let qb of booklet\">\n    <!-- MR Commented below code to ensure single JSON for UNCONDITIONAL Booklets -->\n    <!-- <lib-questionnaire [serv]=\"serv\" [qbId]=\"qb.Id\" [tkn]=\"tkn\"></lib-questionnaire> -->\n    <div *ngFor=\"let ques of qb.Questions__r.records\" [class]=\"qb.isShengel__c ? 'questiondiv1' : 'questiondiv1 padd-bottom'\">\n        <div class=\"questiondiv2\">\n            <div *ngIf=\"!ques.Is_Title__c\" [class]=\"qb.isShengel__c ? 'header-style' : 'question-f-size additional'\">\n                <!-- VD 08NOV23 - showing lable when its available-->\n                <div [innerHTML]=\"getText(ques?.Question_Text__c)\" *ngIf=\"ques?.Question_Text__c\" > \n                    {{ ques?.Question_Text__c }}\n                </div>\n            </div>\n            <lib-questionbook [qbItem]=\"qb\" [labelValue]=\"labelValue\" [questionItem]=\"ques\" [questions]=\"readQuestions(qb.Id)\"  (handleDropDown)=\"getDropDown($event)\"></lib-questionbook>\n        </div>\n    </div>\n</div>\n\n<!-- Group Actions -->\n<div class=\"align-submit-row\" *ngIf=\"abItem?.Status__c != 'Completed'\">\n    <div *ngFor=\"let action of actions; let i = index\">\n        <button (click)=\"handleBookletActionClick(action)\" [ngClass]=\"{'first-button': i === 0, 'second-button': i === 1}\">\n            {{ action.name }}\n        </button>\n    </div>\n</div>\n"]}
|