@rangertechnologies/ngnxt 2.0.37 → 2.0.39

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (72) hide show
  1. package/README.md +2 -2
  2. package/esm2022/lib/components/custom-date-picker/custom-date-picker.component.mjs +33 -33
  3. package/esm2022/lib/components/custom-dropdown/custom-dropdown.component.mjs +94 -82
  4. package/esm2022/lib/components/custom-input/custom-input.component.mjs +76 -76
  5. package/esm2022/lib/components/custom-table/custom-table.component.mjs +53 -53
  6. package/esm2022/lib/components/custom-text-area/custom-text-area.component.mjs +34 -34
  7. package/esm2022/lib/components/dropdown-with-flag/dropdown-with-flag.component.mjs +34 -34
  8. package/esm2022/lib/components/file-upload/file-upload.component.mjs +110 -159
  9. package/esm2022/lib/components/file-view/file-view.component.mjs +42 -0
  10. package/esm2022/lib/components/pick-location/pick-location.component.mjs +136 -136
  11. package/esm2022/lib/components/search-box/search-box.component.mjs +106 -84
  12. package/esm2022/lib/interfaces/actionMeta.mjs +2 -2
  13. package/esm2022/lib/interfaces/apimeta.mjs +2 -2
  14. package/esm2022/lib/interfaces/dependencyMeta.mjs +2 -2
  15. package/esm2022/lib/model/bookletWrapper.mjs +9 -9
  16. package/esm2022/lib/model/changeWrapper.mjs +8 -8
  17. package/esm2022/lib/model/errorWrapper.mjs +6 -6
  18. package/esm2022/lib/model/tableWrapper.mjs +16 -16
  19. package/esm2022/lib/nxt-app.component.mjs +22 -22
  20. package/esm2022/lib/nxt-app.module.mjs +276 -268
  21. package/esm2022/lib/nxt-app.service.mjs +14 -14
  22. package/esm2022/lib/pages/booklet/booklet.component.mjs +171 -159
  23. package/esm2022/lib/pages/questionbook/questionbook.component.mjs +102 -85
  24. package/esm2022/lib/pages/questionnaire/questionnaire.component.mjs +2066 -2066
  25. package/esm2022/lib/pages/summary-page/summary-page.component.mjs +70 -0
  26. package/esm2022/lib/sample.mjs +432 -432
  27. package/esm2022/lib/services/change.service.mjs +38 -33
  28. package/esm2022/lib/services/data.service.mjs +40 -40
  29. package/esm2022/lib/services/salesforce.service.mjs +46 -46
  30. package/esm2022/lib/services/shared.service.mjs +86 -0
  31. package/esm2022/lib/services/storage.service.mjs +41 -41
  32. package/esm2022/lib/wrapper.mjs +161 -161
  33. package/esm2022/public-api.mjs +11 -10
  34. package/esm2022/rangertechnologies-ngnxt.mjs +4 -4
  35. package/fesm2022/rangertechnologies-ngnxt.mjs +4105 -3899
  36. package/fesm2022/rangertechnologies-ngnxt.mjs.map +1 -1
  37. package/index.d.ts +5 -5
  38. package/lib/components/custom-date-picker/custom-date-picker.component.d.ts +14 -14
  39. package/lib/components/custom-dropdown/custom-dropdown.component.d.ts +29 -26
  40. package/lib/components/custom-input/custom-input.component.d.ts +26 -26
  41. package/lib/components/custom-table/custom-table.component.d.ts +20 -20
  42. package/lib/components/custom-text-area/custom-text-area.component.d.ts +14 -14
  43. package/lib/components/dropdown-with-flag/dropdown-with-flag.component.d.ts +14 -14
  44. package/lib/components/file-upload/file-upload.component.d.ts +24 -23
  45. package/lib/components/file-view/file-view.component.d.ts +14 -0
  46. package/lib/components/pick-location/pick-location.component.d.ts +35 -35
  47. package/lib/components/search-box/search-box.component.d.ts +40 -34
  48. package/lib/interfaces/actionMeta.d.ts +5 -5
  49. package/lib/interfaces/apimeta.d.ts +5 -5
  50. package/lib/interfaces/dependencyMeta.d.ts +5 -5
  51. package/lib/model/bookletWrapper.d.ts +5 -5
  52. package/lib/model/changeWrapper.d.ts +7 -7
  53. package/lib/model/errorWrapper.d.ts +5 -5
  54. package/lib/model/tableWrapper.d.ts +15 -15
  55. package/lib/nxt-app.component.d.ts +8 -8
  56. package/lib/nxt-app.module.d.ts +30 -28
  57. package/lib/nxt-app.service.d.ts +6 -6
  58. package/lib/pages/booklet/booklet.component.d.ts +45 -43
  59. package/lib/pages/questionbook/questionbook.component.d.ts +27 -26
  60. package/lib/pages/questionnaire/questionnaire.component.d.ts +206 -206
  61. package/lib/pages/summary-page/summary-page.component.d.ts +18 -0
  62. package/lib/sample.d.ts +10 -10
  63. package/lib/services/change.service.d.ts +16 -13
  64. package/lib/services/data.service.d.ts +9 -9
  65. package/lib/services/salesforce.service.d.ts +11 -11
  66. package/lib/services/shared.service.d.ts +11 -0
  67. package/lib/services/storage.service.d.ts +12 -12
  68. package/lib/wrapper.d.ts +161 -161
  69. package/package.json +1 -1
  70. package/public-api.d.ts +7 -6
  71. package/rangertechnologies-ngnxt-2.0.39.tgz +0 -0
  72. package/rangertechnologies-ngnxt-2.0.37.tgz +0 -0
@@ -1,14 +1,14 @@
1
- import { Injectable } from '@angular/core';
2
- import * as i0 from "@angular/core";
3
- export class NxtAppService {
4
- constructor() { }
5
- static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: NxtAppService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
6
- static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: NxtAppService, providedIn: 'root' });
7
- }
8
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: NxtAppService, decorators: [{
9
- type: Injectable,
10
- args: [{
11
- providedIn: 'root'
12
- }]
13
- }], ctorParameters: function () { return []; } });
14
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibnh0LWFwcC5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcHJvamVjdHMvbnh0LWFwcC9zcmMvbGliL254dC1hcHAuc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDOztBQUszQyxNQUFNLE9BQU8sYUFBYTtJQUV4QixnQkFBZ0IsQ0FBQzt3R0FGTixhQUFhOzRHQUFiLGFBQWEsY0FGWixNQUFNOzs0RkFFUCxhQUFhO2tCQUh6QixVQUFVO21CQUFDO29CQUNWLFVBQVUsRUFBRSxNQUFNO2lCQUNuQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuXHJcbkBJbmplY3RhYmxlKHtcclxuICBwcm92aWRlZEluOiAncm9vdCdcclxufSlcclxuZXhwb3J0IGNsYXNzIE54dEFwcFNlcnZpY2Uge1xyXG5cclxuICBjb25zdHJ1Y3RvcigpIHsgfVxyXG59XHJcbiJdfQ==
1
+ import { Injectable } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ export class NxtAppService {
4
+ constructor() { }
5
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: NxtAppService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
6
+ static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: NxtAppService, providedIn: 'root' });
7
+ }
8
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: NxtAppService, decorators: [{
9
+ type: Injectable,
10
+ args: [{
11
+ providedIn: 'root'
12
+ }]
13
+ }], ctorParameters: function () { return []; } });
14
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibnh0LWFwcC5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcHJvamVjdHMvbnh0LWFwcC9zcmMvbGliL254dC1hcHAuc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDOztBQUszQyxNQUFNLE9BQU8sYUFBYTtJQUV4QixnQkFBZ0IsQ0FBQzt3R0FGTixhQUFhOzRHQUFiLGFBQWEsY0FGWixNQUFNOzs0RkFFUCxhQUFhO2tCQUh6QixVQUFVO21CQUFDO29CQUNWLFVBQVUsRUFBRSxNQUFNO2lCQUNuQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuQEluamVjdGFibGUoe1xuICBwcm92aWRlZEluOiAncm9vdCdcbn0pXG5leHBvcnQgY2xhc3MgTnh0QXBwU2VydmljZSB7XG5cbiAgY29uc3RydWN0b3IoKSB7IH1cbn1cbiJdfQ==
@@ -1,159 +1,171 @@
1
- import { Component, Input, Output, EventEmitter, } from "@angular/core";
2
- import * as i0 from "@angular/core";
3
- import * as i1 from "../../services/salesforce.service";
4
- import * as i2 from "../../services/data.service";
5
- import * as i3 from "../../services/storage.service";
6
- import * as i4 from "@angular/router";
7
- import * as i5 from "@angular/platform-browser";
8
- import * as i6 from "@angular/common";
9
- import * as i7 from "ngx-spinner";
10
- import * as i8 from "../questionbook/questionbook.component";
11
- export class BookletComponent {
12
- sfService;
13
- dataService;
14
- storageService;
15
- route;
16
- sanitizer;
17
- bookletId;
18
- serv;
19
- tkn;
20
- bookletJSON;
21
- handleBookletActionEvent = new EventEmitter();
22
- handlePage = new EventEmitter();
23
- nxtBooklet;
24
- booklet = [];
25
- abItem = {};
26
- actions = [];
27
- bookQuestionsMap = new Map();
28
- sqOptions = new Map();
29
- isAnswerFlag = false;
30
- spinnerName;
31
- spinnerType;
32
- constructor(sfService, dataService, storageService, route, sanitizer, el) {
33
- this.sfService = sfService;
34
- this.dataService = dataService;
35
- this.storageService = storageService;
36
- this.route = route;
37
- this.sanitizer = sanitizer;
38
- this.spinnerName = "sp1";
39
- this.spinnerType = "ball-spin-clockwise";
40
- }
41
- ngOnInit() {
42
- this.processBooklet();
43
- }
44
- ngOnChanges() {
45
- // console.log('inside Questionnaire ngOnChanges');
46
- console.log(this.booklet);
47
- if (this.booklet == undefined || this.booklet.length == 0) {
48
- this.processBooklet();
49
- }
50
- }
51
- processBooklet() {
52
- if (this.bookletId) {
53
- if (this.bookletId.length == 18) {
54
- this.readBooklet(this.bookletId);
55
- }
56
- }
57
- else if (this.bookletJSON) {
58
- // Try to pass a value from Backend to differentiate the QuestionBook Read and AnswerBook Read
59
- this.isAnswerFlag = true;
60
- if (this.bookletJSON != null || this.bookletJSON != undefined) {
61
- // Storing the API response for future use
62
- this.storageService.save(this.bookletJSON);
63
- }
64
- this.booklet = this.bookletJSON.records;
65
- this.abItem = this.bookletJSON.answerbook;
66
- // Process the Sub Question Options - This should be merged with bookQuestionsMap in future
67
- for (var sq in this.bookletJSON.sqOptions) {
68
- this.sqOptions.set(sq, this.bookletJSON.sqOptions[sq]);
69
- }
70
- // Process the Questions
71
- for (var value in this.bookletJSON.bookQuestionsMap) {
72
- this.bookQuestionsMap.set(value, this.bookletJSON.bookQuestionsMap[value]);
73
- }
74
- if (this.bookletJSON.questionbook?.Actions__c != undefined) {
75
- this.actions = JSON.parse(this.bookletJSON.questionbook.Actions__c);
76
- }
77
- }
78
- }
79
- readBooklet = (uuid) => {
80
- if (this.serv == "api") {
81
- this.dataService.getAPIData(this.tkn, ["Booklet", "read", uuid], this.successReadBooklet, this.failureReadBooklet);
82
- }
83
- else {
84
- this.sfService.remoteAction("NxtController.process", ["Booklet", "read", uuid], this.successReadBooklet, this.failureReadBooklet);
85
- }
86
- };
87
- successReadBooklet = (response) => {
88
- console.log('Inside the successReadBooklet');
89
- // console.log(response);
90
- if (response != null || response != undefined) {
91
- // Storing the API response for future use
92
- this.storageService.save(response);
93
- // Try to pass a value from Backend to differentiate the QuestionBook Read and AnswerBook Read
94
- // this.isAnswerFlag = true;
95
- this.booklet = response.records;
96
- this.abItem = response.answerbook;
97
- // Process the Sub Question Options - This should be merged with bookQuestionsMap in future
98
- for (var sq in response.sqOptions) {
99
- this.sqOptions.set(sq, response.sqOptions[sq]);
100
- }
101
- // Process the Questions
102
- for (var value in response.bookQuestionsMap) {
103
- this.bookQuestionsMap.set(value, response.bookQuestionsMap[value]);
104
- }
105
- if (response.questionbook?.Actions__c != undefined) {
106
- this.actions = JSON.parse(response.questionbook.Actions__c);
107
- }
108
- }
109
- };
110
- failureReadBooklet = (response) => {
111
- };
112
- handleBookletActionClick(action) {
113
- console.log(action);
114
- let dataToParent = {};
115
- dataToParent['action'] = action.eventtoemit;
116
- dataToParent['data'] = this.storageService.get();
117
- this.handleBookletActionEvent.emit(dataToParent);
118
- }
119
- readQuestions(qbId) {
120
- // console.log('inside BookletComponent.readQuestions ' + qbId);
121
- // console.log(this.bookQuestionsMap.size);
122
- let questions = [];
123
- for (var sq in this.bookQuestionsMap?.get(qbId).Questions__r.records) {
124
- let q = this.bookQuestionsMap?.get(qbId).Questions__r.records[sq];
125
- if (q.Type__c == 'Dropdown') {
126
- questions.push(this.sqOptions.get(q.Id));
127
- }
128
- else {
129
- questions.push(q);
130
- }
131
- }
132
- // console.log(questions);
133
- return questions;
134
- }
135
- getText(value) {
136
- var doc = new DOMParser().parseFromString(value, "text/html");
137
- //console.log( doc.documentElement.textContent);
138
- return this.sanitizer.bypassSecurityTrustHtml(doc.documentElement.textContent);
139
- }
140
- 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: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component });
141
- 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" }, outputs: { handleBookletActionEvent: "handleBookletActionEvent", handlePage: "handlePage" }, usesOnChanges: true, ngImport: i0, template: "<ngx-spinner [name]=\"spinnerName\" [type]=\"spinnerType\"></ngx-spinner>\r\n<!-- Booklet Handling-->\r\n<div *ngFor=\"let qb of booklet\">\r\n <!-- MR Commented below code to ensure single JSON for UNCONDITIONAL Booklets -->\r\n <!-- <lib-questionnaire [serv]=\"serv\" [qbId]=\"qb.Id\" [tkn]=\"tkn\"></lib-questionnaire> -->\r\n\r\n <div *ngFor=\"let ques of qb.Questions__r.records\" [class]=\"qb.isShengel__c ? 'questiondiv1' : 'questiondiv1 padd-bottom'\">\r\n <div class=\"questiondiv2\">\r\n <div *ngIf=\"!ques.Is_Title__c\" [class]=\"qb.isShengel__c ? 'header-style' : 'question-f-size additional'\">\r\n <div [innerHTML]=\"getText(ques?.Question_Text__c)\" >\r\n {{ ques?.Question_Text__c }}\r\n </div>\r\n </div>\r\n <lib-questionbook [qbItem]=\"qb\" [questionItem]=\"ques\" [questions]=\"readQuestions(qb.Id)\"></lib-questionbook>\r\n </div>\r\n </div>\r\n</div>\r\n\r\n<!-- Group Actions -->\r\n<div class=\"align-submit-row\" *ngIf=\"abItem.Status__c != 'Completed'\">\r\n <div *ngFor=\"let action of actions\">\r\n <button (click)=\"handleBookletActionClick(action)\">\r\n {{ action.name }}\r\n </button>\r\n </div>\r\n</div>\r\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: i6.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i7.NgxSpinnerComponent, selector: "ngx-spinner", inputs: ["disableAnimation", "bdColor", "zIndex", "color", "type", "size", "fullScreen", "name", "template", "showSpinner"] }, { kind: "component", type: i8.QuestionbookComponent, selector: "lib-questionbook", inputs: ["qbItem", "questionItem", "questions"] }] });
142
- }
143
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: BookletComponent, decorators: [{
144
- type: Component,
145
- args: [{ selector: 'lib-booklet', template: "<ngx-spinner [name]=\"spinnerName\" [type]=\"spinnerType\"></ngx-spinner>\r\n<!-- Booklet Handling-->\r\n<div *ngFor=\"let qb of booklet\">\r\n <!-- MR Commented below code to ensure single JSON for UNCONDITIONAL Booklets -->\r\n <!-- <lib-questionnaire [serv]=\"serv\" [qbId]=\"qb.Id\" [tkn]=\"tkn\"></lib-questionnaire> -->\r\n\r\n <div *ngFor=\"let ques of qb.Questions__r.records\" [class]=\"qb.isShengel__c ? 'questiondiv1' : 'questiondiv1 padd-bottom'\">\r\n <div class=\"questiondiv2\">\r\n <div *ngIf=\"!ques.Is_Title__c\" [class]=\"qb.isShengel__c ? 'header-style' : 'question-f-size additional'\">\r\n <div [innerHTML]=\"getText(ques?.Question_Text__c)\" >\r\n {{ ques?.Question_Text__c }}\r\n </div>\r\n </div>\r\n <lib-questionbook [qbItem]=\"qb\" [questionItem]=\"ques\" [questions]=\"readQuestions(qb.Id)\"></lib-questionbook>\r\n </div>\r\n </div>\r\n</div>\r\n\r\n<!-- Group Actions -->\r\n<div class=\"align-submit-row\" *ngIf=\"abItem.Status__c != 'Completed'\">\r\n <div *ngFor=\"let action of actions\">\r\n <button (click)=\"handleBookletActionClick(action)\">\r\n {{ action.name }}\r\n </button>\r\n </div>\r\n</div>\r\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"] }]
146
- }], ctorParameters: function () { return [{ type: i1.SalesforceService }, { type: i2.DataService }, { type: i3.StorageService }, { type: i4.ActivatedRoute }, { type: i5.DomSanitizer }, { type: i0.ElementRef }]; }, propDecorators: { bookletId: [{
147
- type: Input
148
- }], serv: [{
149
- type: Input
150
- }], tkn: [{
151
- type: Input
152
- }], bookletJSON: [{
153
- type: Input
154
- }], handleBookletActionEvent: [{
155
- type: Output
156
- }], handlePage: [{
157
- type: Output
158
- }] } });
159
- //# 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 {\r\n  Component,\r\n  OnInit,\r\n  OnChanges,\r\n  Inject,\r\n  Input,\r\n  Output,\r\n  EventEmitter,\r\n  ViewEncapsulation,\r\n  ElementRef,\r\n} from \"@angular/core\";\r\nimport { SalesforceService } from \"../../services/salesforce.service\";\r\nimport { DataService } from '../../services/data.service';\r\nimport { ActivatedRoute, Params } from \"@angular/router\";\r\nimport { DomSanitizer, SafeHtml } from \"@angular/platform-browser\";\r\nimport { ActionMeta } from '../../interfaces/actionMeta';\r\nimport { Question } from \"../../wrapper\";\r\nimport { BookletWrapper } from \"../../model/bookletWrapper\";\r\nimport { StorageService } from '../../services/storage.service';\r\n\r\n@Component({\r\n  selector: 'lib-booklet',\r\n  templateUrl: './booklet.component.html',\r\n  styleUrls: ['./booklet.component.css']\r\n})\r\nexport class BookletComponent implements OnInit {\r\n  @Input() bookletId: string;\r\n  @Input() serv: string;\r\n  @Input() tkn: string;\r\n  @Input() bookletJSON: any;\r\n  \r\n  @Output() handleBookletActionEvent: EventEmitter<any> = new EventEmitter();\r\n  @Output() handlePage: EventEmitter<any> = new EventEmitter();\r\n\r\n  public nxtBooklet: BookletWrapper;\r\n\r\n  public booklet: any[] = [];\r\n  public abItem: any = {};\r\n  public actions: ActionMeta[] = [];\r\n  public bookQuestionsMap: any = new Map();\r\n  private sqOptions: any = new Map();\r\n  public isAnswerFlag: boolean = false;\r\n  public spinnerName: string;\r\n  public spinnerType: string;\r\n\r\n  constructor(\r\n    private sfService: SalesforceService,\r\n    private dataService: DataService,\r\n    private storageService: StorageService,\r\n    private route: ActivatedRoute,\r\n    private sanitizer: DomSanitizer,\r\n    el: ElementRef\r\n  ) { \r\n    this.spinnerName = \"sp1\";\r\n    this.spinnerType = \"ball-spin-clockwise\";\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    this.processBooklet();\r\n  }\r\n\r\n  ngOnChanges() {\r\n    // console.log('inside Questionnaire ngOnChanges');\r\n    console.log(this.booklet);\r\n    if(this.booklet == undefined || this.booklet.length == 0) {\r\n      this.processBooklet();\r\n    }\r\n  }\r\n\r\n  processBooklet() {\r\n    if (this.bookletId) {\r\n      if (this.bookletId.length == 18) {\r\n        this.readBooklet(this.bookletId);\r\n      }\r\n    } else if(this.bookletJSON) {\r\n      // Try to pass a value from Backend to differentiate the QuestionBook Read and AnswerBook Read\r\n      this.isAnswerFlag = true;\r\n\r\n      if(this.bookletJSON != null || this.bookletJSON != undefined) {\r\n          // Storing the API response for future use\r\n          this.storageService.save(this.bookletJSON);\r\n      }\r\n      \r\n      this.booklet = this.bookletJSON.records;\r\n      this.abItem = this.bookletJSON.answerbook;\r\n\r\n      // Process the Sub Question Options - This should be merged with bookQuestionsMap in future\r\n      for (var sq in this.bookletJSON.sqOptions) {\r\n        this.sqOptions.set(sq, this.bookletJSON.sqOptions[sq]);\r\n      }\r\n\r\n      // Process the Questions\r\n      for (var value in this.bookletJSON.bookQuestionsMap) {\r\n        this.bookQuestionsMap.set(value, this.bookletJSON.bookQuestionsMap[value]);\r\n      }\r\n\r\n      if(this.bookletJSON.questionbook?.Actions__c != undefined) {\r\n        this.actions = JSON.parse(this.bookletJSON.questionbook.Actions__c);\r\n      }\r\n    }\r\n  }\r\n\r\n  private readBooklet = (uuid: string) => {\r\n    if(this.serv == \"api\") {\r\n      this.dataService.getAPIData(\r\n        this.tkn,\r\n        [\"Booklet\", \"read\", uuid],\r\n        this.successReadBooklet,\r\n        this.failureReadBooklet\r\n      );\r\n    } else {\r\n      this.sfService.remoteAction(\r\n        \"NxtController.process\",\r\n        [\"Booklet\", \"read\", uuid],\r\n        this.successReadBooklet,\r\n        this.failureReadBooklet\r\n      );\r\n    }\r\n  }\r\n\r\n  private successReadBooklet = (response) => {\r\n    console.log('Inside the successReadBooklet');\r\n    // console.log(response);\r\n    if(response != null || response != undefined) {\r\n      // Storing the API response for future use\r\n      this.storageService.save(response);\r\n\r\n      // Try to pass a value from Backend to differentiate the QuestionBook Read and AnswerBook Read\r\n      // this.isAnswerFlag = true;\r\n      \r\n      this.booklet = response.records;\r\n      this.abItem = response.answerbook;\r\n\r\n      // Process the Sub Question Options - This should be merged with bookQuestionsMap in future\r\n      for (var sq in response.sqOptions) {\r\n        this.sqOptions.set(sq, response.sqOptions[sq]);\r\n      }\r\n\r\n      // Process the Questions\r\n      for (var value in response.bookQuestionsMap) {\r\n        this.bookQuestionsMap.set(value, response.bookQuestionsMap[value]);\r\n      }\r\n\r\n      if(response.questionbook?.Actions__c != undefined) {\r\n        this.actions = JSON.parse(response.questionbook.Actions__c);\r\n      }\r\n    }\r\n  }\r\n\r\n  private failureReadBooklet = (response) => {\r\n\r\n  }\r\n\r\n  handleBookletActionClick(action:ActionMeta) {\r\n    console.log(action);\r\n    let dataToParent = {};\r\n    dataToParent['action'] = action.eventtoemit;\r\n    dataToParent['data'] = this.storageService.get();\r\n    this.handleBookletActionEvent.emit(dataToParent);\r\n  }\r\n\r\n  readQuestions(qbId: string) {\r\n    // console.log('inside BookletComponent.readQuestions ' + qbId);\r\n    // console.log(this.bookQuestionsMap.size);\r\n    let questions = [];\r\n    for(var sq in this.bookQuestionsMap?.get(qbId).Questions__r.records) {\r\n      let q: Question = this.bookQuestionsMap?.get(qbId).Questions__r.records[sq];\r\n      if(q.Type__c == 'Dropdown') {\r\n        questions.push(this.sqOptions.get(q.Id));\r\n      } else {\r\n        questions.push(q);\r\n      }\r\n    }\r\n    // console.log(questions);\r\n    return questions;\r\n  }\r\n\r\n  getText(value) {\r\n    var doc = new DOMParser().parseFromString(value, \"text/html\");\r\n    //console.log( doc.documentElement.textContent);\r\n    return this.sanitizer.bypassSecurityTrustHtml(\r\n      doc.documentElement.textContent\r\n    );\r\n  }\r\n}\r\n","<ngx-spinner [name]=\"spinnerName\" [type]=\"spinnerType\"></ngx-spinner>\r\n<!-- Booklet Handling-->\r\n<div *ngFor=\"let qb of booklet\">\r\n    <!-- MR Commented below code to ensure single JSON for UNCONDITIONAL Booklets -->\r\n    <!-- <lib-questionnaire [serv]=\"serv\" [qbId]=\"qb.Id\" [tkn]=\"tkn\"></lib-questionnaire> -->\r\n\r\n    <div *ngFor=\"let ques of qb.Questions__r.records\" [class]=\"qb.isShengel__c ? 'questiondiv1' : 'questiondiv1 padd-bottom'\">\r\n        <div class=\"questiondiv2\">\r\n            <div *ngIf=\"!ques.Is_Title__c\" [class]=\"qb.isShengel__c ? 'header-style' : 'question-f-size additional'\">\r\n                <div [innerHTML]=\"getText(ques?.Question_Text__c)\" >\r\n                    {{ ques?.Question_Text__c }}\r\n                </div>\r\n            </div>\r\n            <lib-questionbook [qbItem]=\"qb\" [questionItem]=\"ques\" [questions]=\"readQuestions(qb.Id)\"></lib-questionbook>\r\n        </div>\r\n    </div>\r\n</div>\r\n\r\n<!-- Group Actions -->\r\n<div class=\"align-submit-row\" *ngIf=\"abItem.Status__c != 'Completed'\">\r\n    <div *ngFor=\"let action of actions\">\r\n        <button (click)=\"handleBookletActionClick(action)\">\r\n            {{ action.name }}\r\n        </button>\r\n    </div>\r\n</div>\r\n"]}
1
+ import { Component, Input, Output, EventEmitter, } from "@angular/core";
2
+ import * as i0 from "@angular/core";
3
+ import * as i1 from "../../services/salesforce.service";
4
+ import * as i2 from "../../services/data.service";
5
+ import * as i3 from "../../services/storage.service";
6
+ import * as i4 from "@angular/router";
7
+ import * as i5 from "@angular/platform-browser";
8
+ import * as i6 from "../../services/change.service";
9
+ import * as i7 from "@angular/common";
10
+ import * as i8 from "ngx-spinner";
11
+ import * as i9 from "../questionbook/questionbook.component";
12
+ export class BookletComponent {
13
+ sfService;
14
+ dataService;
15
+ storageService;
16
+ route;
17
+ sanitizer;
18
+ changeService;
19
+ bookletId;
20
+ serv;
21
+ tkn;
22
+ bookletJSON;
23
+ handleBookletActionEvent = new EventEmitter();
24
+ handlePage = new EventEmitter();
25
+ nxtBooklet;
26
+ booklet = [];
27
+ abItem = {};
28
+ actions = [];
29
+ bookQuestionsMap = new Map();
30
+ sqOptions = new Map();
31
+ isAnswerFlag = false;
32
+ spinnerName;
33
+ spinnerType;
34
+ constructor(sfService, dataService, storageService, route, sanitizer, changeService, el) {
35
+ this.sfService = sfService;
36
+ this.dataService = dataService;
37
+ this.storageService = storageService;
38
+ this.route = route;
39
+ this.sanitizer = sanitizer;
40
+ this.changeService = changeService;
41
+ this.spinnerName = "sp1";
42
+ this.spinnerType = "ball-spin-clockwise";
43
+ }
44
+ ngOnInit() {
45
+ this.processBooklet();
46
+ }
47
+ ngOnChanges() {
48
+ // console.log('inside Questionnaire ngOnChanges');
49
+ console.log(this.booklet);
50
+ if (this.booklet == undefined || this.booklet.length == 0) {
51
+ this.processBooklet();
52
+ }
53
+ }
54
+ processBooklet() {
55
+ if (this.bookletId) {
56
+ if (this.bookletId.length == 18) {
57
+ this.readBooklet(this.bookletId);
58
+ }
59
+ }
60
+ else if (this.bookletJSON) {
61
+ // Try to pass a value from Backend to differentiate the QuestionBook Read and AnswerBook Read
62
+ this.isAnswerFlag = true;
63
+ if (this.bookletJSON != null || this.bookletJSON != undefined) {
64
+ // Storing the API response for future use
65
+ this.storageService.save(this.bookletJSON);
66
+ }
67
+ this.booklet = this.bookletJSON.records;
68
+ this.abItem = this.bookletJSON.answerbook;
69
+ // Process the Sub Question Options - This should be merged with bookQuestionsMap in future
70
+ for (var sq in this.bookletJSON.sqOptions) {
71
+ this.sqOptions.set(sq, this.bookletJSON.sqOptions[sq]);
72
+ }
73
+ // Process the Questions
74
+ for (var value in this.bookletJSON.bookQuestionsMap) {
75
+ this.bookQuestionsMap.set(value, this.bookletJSON.bookQuestionsMap[value]);
76
+ }
77
+ if (this.bookletJSON.questionbook?.Actions__c != undefined) {
78
+ this.actions = JSON.parse(this.bookletJSON.questionbook.Actions__c);
79
+ }
80
+ }
81
+ }
82
+ readBooklet = (uuid) => {
83
+ if (this.serv == "api") {
84
+ this.dataService.getAPIData(this.tkn, ["Booklet", "read", uuid], this.successReadBooklet, this.failureReadBooklet);
85
+ }
86
+ else {
87
+ this.sfService.remoteAction("NxtController.process", ["Booklet", "read", uuid], this.successReadBooklet, this.failureReadBooklet);
88
+ }
89
+ };
90
+ successReadBooklet = (response) => {
91
+ console.log('Inside the successReadBooklet');
92
+ // console.log(response);
93
+ if (response != null || response != undefined) {
94
+ // Storing the API response for future use
95
+ this.storageService.save(response);
96
+ // Try to pass a value from Backend to differentiate the QuestionBook Read and AnswerBook Read
97
+ // this.isAnswerFlag = true;
98
+ this.booklet = response.records;
99
+ this.abItem = response.answerbook;
100
+ // Process the Sub Question Options - This should be merged with bookQuestionsMap in future
101
+ for (var sq in response.sqOptions) {
102
+ this.sqOptions.set(sq, response.sqOptions[sq]);
103
+ }
104
+ // Process the Questions
105
+ for (var value in response.bookQuestionsMap) {
106
+ this.bookQuestionsMap.set(value, response.bookQuestionsMap[value]);
107
+ }
108
+ if (response.questionbook?.Actions__c != undefined) {
109
+ this.actions = JSON.parse(response.questionbook.Actions__c);
110
+ }
111
+ }
112
+ };
113
+ failureReadBooklet = (response) => {
114
+ };
115
+ handleBookletActionClick(action) {
116
+ console.log(action);
117
+ let dataToParent = {};
118
+ dataToParent['action'] = action.eventtoemit;
119
+ dataToParent['data'] = this.storageService.get();
120
+ this.handleBookletActionEvent.emit(dataToParent);
121
+ // when clicking the submit button validating the required fields
122
+ for (let key in dataToParent['data'].bookQuestionsMap) {
123
+ const currentBook = dataToParent['data'].bookQuestionsMap[key];
124
+ currentBook.Questions__r.records.forEach(element => {
125
+ if (element.Error_Message__c && dataToParent['action'] == 'submit' && !element.input) {
126
+ this.changeService.submitChange(element.Id);
127
+ }
128
+ });
129
+ }
130
+ }
131
+ readQuestions(qbId) {
132
+ // console.log('inside BookletComponent.readQuestions ' + qbId);
133
+ // console.log(this.bookQuestionsMap.size);
134
+ let questions = [];
135
+ for (var sq in this.bookQuestionsMap?.get(qbId).Questions__r.records) {
136
+ let q = this.bookQuestionsMap?.get(qbId).Questions__r.records[sq];
137
+ if (q.Type__c == 'Dropdown') {
138
+ questions.push(this.sqOptions.get(q.Id));
139
+ }
140
+ else {
141
+ questions.push(q);
142
+ }
143
+ }
144
+ // console.log(questions);
145
+ return questions;
146
+ }
147
+ getText(value) {
148
+ var doc = new DOMParser().parseFromString(value, "text/html");
149
+ //console.log( doc.documentElement.textContent);
150
+ return this.sanitizer.bypassSecurityTrustHtml(doc.documentElement.textContent);
151
+ }
152
+ 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 });
153
+ 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" }, outputs: { handleBookletActionEvent: "handleBookletActionEvent", handlePage: "handlePage" }, 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)\" >\n {{ ques?.Question_Text__c }}\n </div>\n </div>\n <lib-questionbook [qbItem]=\"qb\" [questionItem]=\"ques\" [questions]=\"readQuestions(qb.Id)\"></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}.first-button{background:transparent!important;border:none;outline:none;border-radius:0!important;color:#007bff!important}.second-button{background:#3c91f9!important;border:none;outline:none;border-radius:0!important;margin-right:26px}.align-submit-row{justify-content:flex-end}.align-submit-row button{margin-left:0!important}.header-style{color:#212529!important}\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"] }] });
154
+ }
155
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: BookletComponent, decorators: [{
156
+ type: Component,
157
+ 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)\" >\n {{ ques?.Question_Text__c }}\n </div>\n </div>\n <lib-questionbook [qbItem]=\"qb\" [questionItem]=\"ques\" [questions]=\"readQuestions(qb.Id)\"></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}.first-button{background:transparent!important;border:none;outline:none;border-radius:0!important;color:#007bff!important}.second-button{background:#3c91f9!important;border:none;outline:none;border-radius:0!important;margin-right:26px}.align-submit-row{justify-content:flex-end}.align-submit-row button{margin-left:0!important}.header-style{color:#212529!important}\n"] }]
158
+ }], 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: [{
159
+ type: Input
160
+ }], serv: [{
161
+ type: Input
162
+ }], tkn: [{
163
+ type: Input
164
+ }], bookletJSON: [{
165
+ type: Input
166
+ }], handleBookletActionEvent: [{
167
+ type: Output
168
+ }], handlePage: [{
169
+ type: Output
170
+ }] } });
171
+ //# 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} 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  \n  @Output() handleBookletActionEvent: EventEmitter<any> = new EventEmitter();\n  @Output() handlePage: 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  }\n\n  ngOnInit(): void {\n    this.processBooklet();\n  }\n\n  ngOnChanges() {\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}\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\" [questionItem]=\"ques\" [questions]=\"readQuestions(qb.Id)\"></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"]}