@rangertechnologies/ngnxt 2.1.5 → 2.1.7

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.
@@ -24,6 +24,7 @@ export class BookletComponent {
24
24
  bookletJSON;
25
25
  dropdownDependentData;
26
26
  labelValue;
27
+ token;
27
28
  handleBookletActionEvent = new EventEmitter();
28
29
  handlePage = new EventEmitter();
29
30
  hadleDropDownDependent = new EventEmitter();
@@ -39,6 +40,7 @@ export class BookletComponent {
39
40
  // HA 19DEC23 langDirection variable is created to assign the direction as class
40
41
  langDirection = 'ltr'; // HA 28DEC23 making ltr as default direction
41
42
  answerList = []; // HA 11-JAN-24 Answerlist to store the minimal value
43
+ inputForQuestions = {}; // HA 18-JAN-24 To insert the endpoint value to the question
42
44
  constructor(sfService, dataService, storageService, route, sanitizer, changeService, el, i18nService) {
43
45
  this.sfService = sfService;
44
46
  this.dataService = dataService;
@@ -52,6 +54,19 @@ export class BookletComponent {
52
54
  console.log('dropdownDependentData', this.dropdownDependentData);
53
55
  }
54
56
  ngOnInit() {
57
+ // HA 18-JAN-24 Dummy Static data for testing
58
+ // this.inputForQuestions = {
59
+ // "_id": "659ed002ed51bb8061544255",
60
+ // "companyId": "5ullh1BWpYqnvzKh9L",
61
+ // "name": "Al Yasmine",
62
+ // "code": "check",
63
+ // "status": "In-Progress",
64
+ // "createdAt": "2024-01-10T17:12:34.686Z",
65
+ // "updatedAt": "2024-01-10T19:53:08.135Z",
66
+ // "__v": 0,
67
+ // "owner": "check",
68
+ // "customer": "check"
69
+ // };
55
70
  this.processBooklet();
56
71
  }
57
72
  // VD NOV23 - update the json data when bookletId and bookletJSON changes
@@ -111,6 +126,8 @@ export class BookletComponent {
111
126
  var style = JSON.parse(JSON.parse(JSON.stringify(this.bookletJSON?.records[0]?.Style__c)));
112
127
  this.langDirection = style?.direction;
113
128
  }
129
+ // HA 18-JAN-24 The condition is used for Bind-In Logic
130
+ this.handleCompleteBooklet(this.bookletJSON);
114
131
  }
115
132
  readBooklet = (uuid) => {
116
133
  if (this.serv == "api") {
@@ -155,20 +172,39 @@ export class BookletComponent {
155
172
  failureReadBooklet = (response) => {
156
173
  };
157
174
  handleBookletActionClick(action) {
175
+ // HA 19JAN24 Action changes
158
176
  this.answerList = [];
159
177
  console.log(action);
160
178
  let dataToParent = {};
161
- dataToParent['action'] = action.eventtoemit;
162
- dataToParent['data'] = this.storageService.get();
163
- // HA 17JAN24 nxtId to dataParent object
164
- dataToParent['nxtId'] = Object.keys(this.bookletJSON?.bookQuestionsMap)[0];
165
- // HA 11-JAN-24 Minimizing the value which has to be passed to the server
166
- if (Object.keys(dataToParent['data'].bookQuestionsMap).length === 0) { // HA 11-JAN-24 If condition to load booklet
167
- this.handleBook(dataToParent['data'].questionbook.Questions__r);
179
+ if (!(action.eventtoemit === 'close')) {
180
+ dataToParent['action'] = action.eventtoemit;
181
+ // HA 18-JAN-24 Sending the complete json data also
182
+ dataToParent['jsonBook'] = this.storageService.get();
183
+ // HA 17JAN24 nxtId to dataParent object
184
+ dataToParent['nxtId'] = Object.keys(this.bookletJSON?.bookQuestionsMap)[0];
185
+ // HA 11-JAN-24 Minimizing the value which has to be passed to the server
186
+ this.handleCompleteBooklet(dataToParent['jsonBook']);
187
+ dataToParent['data'] = this.answerList ? this.answerList : dataToParent['data'];
188
+ this.handleBookletActionEvent.emit(dataToParent);
189
+ // when clicking the submit button validating the required fields
190
+ for (let key in dataToParent['jsonBook'].bookQuestionsMap) {
191
+ const currentBook = dataToParent['jsonBook'].bookQuestionsMap[key];
192
+ currentBook.Questions__r.records.forEach(element => {
193
+ if (element.Error_Message__c && dataToParent['action'] == 'submit' && !element.input) {
194
+ this.changeService.submitChange(element.Id);
195
+ }
196
+ });
197
+ }
198
+ }
199
+ }
200
+ // HA 18-JAN-24 handleCompleteBooklet is to simplify the logic
201
+ handleCompleteBooklet(completeBooklet) {
202
+ if (Object.keys(completeBooklet?.bookQuestionsMap ?? {}).length === 0) { // HA 11-JAN-24 If condition to load booklet
203
+ this.handleBook(completeBooklet?.questionbook?.Questions__r);
168
204
  }
169
205
  else { // HA 11-JAN-24 To load book questions
170
- for (const key in dataToParent['data'].bookQuestionsMap) {
171
- const val = dataToParent['data'].bookQuestionsMap[key];
206
+ for (const key in completeBooklet.bookQuestionsMap) {
207
+ const val = completeBooklet.bookQuestionsMap[key];
172
208
  if (val.Type__c === 'Book') {
173
209
  this.handleBook(val.Questions__r);
174
210
  }
@@ -177,21 +213,10 @@ export class BookletComponent {
177
213
  }
178
214
  }
179
215
  }
180
- dataToParent['data'] = this.answerList;
181
- this.handleBookletActionEvent.emit(dataToParent);
182
- // when clicking the submit button validating the required fields
183
- for (let key in dataToParent['data'].bookQuestionsMap) {
184
- const currentBook = dataToParent['data'].bookQuestionsMap[key];
185
- currentBook.Questions__r.records.forEach(element => {
186
- if (element.Error_Message__c && dataToParent['action'] == 'submit' && !element.input) {
187
- this.changeService.submitChange(element.Id);
188
- }
189
- });
190
- }
191
216
  }
192
217
  // HA 11-JAN-24 handleBook loads the Book
193
218
  handleBook(quesList) {
194
- quesList.records.forEach(element => {
219
+ quesList?.records.forEach(element => {
195
220
  if (element.Type__c === 'Book') {
196
221
  element.qbItem.Questions__r.records.forEach(ques => {
197
222
  this.handleQues(ques);
@@ -204,14 +229,34 @@ export class BookletComponent {
204
229
  }
205
230
  // HA 11-JAN-24 handleQues to load question
206
231
  handleQues(ques) {
207
- const question = {};
208
- question['id'] = ques.Id;
209
- // question['Question__c'] = ques.Question__c;
210
- question['input'] = ques.input;
211
- question['Type__c'] = ques.Type__c;
212
- question['Question_No__c'] = ques.Question_No__c;
213
- question['referenceField'] = ques?.referenceField;
214
- this.answerList.push(question);
232
+ // HA 19-JAN-24 If condition is for bind-in, correction
233
+ if (this.inputForQuestions.length > 0) {
234
+ for (let [key, value] of Object.entries(this.inputForQuestions)) {
235
+ if (ques.Reference_Field__c === key) {
236
+ if (ques.Type__c === 'Dropdown') {
237
+ this.sqOptions.forEach(element => {
238
+ if (element['Reference_Field__c'] === key) {
239
+ element['input'] = ques.input = value;
240
+ element['selectedValue'] = ques.selectedValue = value;
241
+ }
242
+ });
243
+ }
244
+ else {
245
+ ques.input = value;
246
+ }
247
+ }
248
+ }
249
+ }
250
+ else {
251
+ const question = {};
252
+ question['id'] = ques.Id;
253
+ // question['Question__c'] = ques.Question__c;
254
+ question['input'] = ques.input;
255
+ question['Type__c'] = ques.Type__c;
256
+ question['Question_No__c'] = ques.Question_No__c;
257
+ question['Reference_Field__c'] = ques?.Reference_Field__c;
258
+ this.answerList.push(question);
259
+ }
215
260
  }
216
261
  readQuestions(qbId) {
217
262
  // console.log('inside BookletComponent.readQuestions ' + qbId);
@@ -238,11 +283,11 @@ export class BookletComponent {
238
283
  this.hadleDropDownDependent.emit(event);
239
284
  }
240
285
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", 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 }, { token: i7.I18nService }], target: i0.ɵɵFactoryTarget.Component });
241
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", 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<!-- HA 19DEC23 For Direction -->\n<div *ngFor=\"let qb of booklet\" [ngClass]=\"langDirection\">\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 <!-- HA 28DEC23 Below If logic is to load from booklet -->\n <div *ngIf=\"qb.Questions__r?.records; else elseBlock\">\n <div *ngFor=\"let ques of qb.Questions__r.records\" [class]=\"qb.isShengel__c ? 'questiondiv1' : 'questiondiv1 padd-bottom'\">\n <div class=\"questiondiv2\">\n <!-- HA 17JAN24 - Is title is enabled so that based on the boolean div will be visible -->\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 <!-- HA 28DEC23 Below else logic is to load from books or questions -->\n <ng-template #elseBlock>\n <div [class]=\"qb.isShengel__c ? 'questiondiv1' : 'questiondiv1 padd-bottom'\">\n <div class=\"questiondiv2\">\n <div *ngIf=\"!qb.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(qb?.Question_Text__c)\" *ngIf=\"qb?.Question_Text__c\" > \n {{ qb?.Question_Text__c }}\n {{ qb?.Title__c }}\n </div>\n </div>\n <lib-questionbook [qbItem]=\"qb\" [labelValue]=\"labelValue\" [questionItem]=\"qb\" [questions]=\"readQuestions(qb.Id)\" (handleDropDown)=\"getDropDown($event)\"></lib-questionbook>\n </div>\n </div>\n </ng-template>\n</div>\n\n<!-- Group Actions -->\n<!-- HA 19DEC23 For Direction -->\n<div class=\"align-submit-row\" *ngIf=\"abItem?.Status__c != 'Completed'\" [ngClass]=\"langDirection\">\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}.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: i8.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i8.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i8.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i9.NgxSpinnerComponent, selector: "ngx-spinner", inputs: ["disableAnimation", "bdColor", "zIndex", "color", "type", "size", "fullScreen", "name", "template", "showSpinner"] }, { kind: "component", type: i10.QuestionbookComponent, selector: "lib-questionbook", inputs: ["qbItem", "questionItem", "questions", "errorFieldId", "labelValue", "dropDownData"], outputs: ["handleDropDown", "hadleDropDownDependent"] }] });
286
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: BookletComponent, selector: "lib-booklet", inputs: { bookletId: "bookletId", serv: "serv", tkn: "tkn", bookletJSON: "bookletJSON", dropdownDependentData: "dropdownDependentData", labelValue: "labelValue", token: "token", inputForQuestions: "inputForQuestions" }, outputs: { handleBookletActionEvent: "handleBookletActionEvent", handlePage: "handlePage", hadleDropDownDependent: "hadleDropDownDependent" }, usesOnChanges: true, ngImport: i0, template: "<ngx-spinner [name]=\"spinnerName\" [type]=\"spinnerType\"></ngx-spinner>\n<!-- Booklet Handling-->\n<!-- HA 19DEC23 For Direction -->\n<div *ngFor=\"let qb of booklet\" [ngClass]=\"langDirection\">\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 <!-- HA 28DEC23 Below If logic is to load from booklet -->\n <div *ngIf=\"qb.Questions__r?.records; else elseBlock\">\n <div *ngFor=\"let ques of qb.Questions__r.records\" [class]=\"qb.isShengel__c ? 'questiondiv1' : 'questiondiv1 padd-bottom'\">\n <div class=\"questiondiv2\">\n <!-- HA 17JAN24 - Is title is enabled so that based on the boolean div will be visible -->\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> <!-- VD 19JAN24 - getting token as input -->\n <lib-questionbook [qbItem]=\"qb\" [token]=\"token\" [labelValue]=\"labelValue\" [questionItem]=\"ques\" [questions]=\"readQuestions(qb.Id)\" (handleDropDown)=\"getDropDown($event)\"></lib-questionbook>\n </div>\n </div>\n </div>\n <!-- HA 28DEC23 Below else logic is to load from books or questions -->\n <ng-template #elseBlock>\n <div [class]=\"qb.isShengel__c ? 'questiondiv1' : 'questiondiv1 padd-bottom'\">\n <div class=\"questiondiv2\">\n <div *ngIf=\"!qb.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(qb?.Question_Text__c)\" *ngIf=\"qb?.Question_Text__c\" > \n {{ qb?.Question_Text__c }}\n {{ qb?.Title__c }}\n </div>\n </div> <!-- VD 19JAN24 - getting token as input -->\n <lib-questionbook [qbItem]=\"qb\" [token]=\"token\" [labelValue]=\"labelValue\" [questionItem]=\"qb\" [questions]=\"readQuestions(qb.Id)\" (handleDropDown)=\"getDropDown($event)\"></lib-questionbook>\n </div>\n </div>\n </ng-template>\n</div>\n\n<!-- Group Actions -->\n<!-- HA 19DEC23 For Direction -->\n<div class=\"align-submit-row\" *ngIf=\"abItem?.Status__c != 'Completed'\" [ngClass]=\"langDirection\">\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}.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}.rtl{flex-direction:row-reverse}\n"], dependencies: [{ kind: "directive", type: i8.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i8.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i8.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i9.NgxSpinnerComponent, selector: "ngx-spinner", inputs: ["disableAnimation", "bdColor", "zIndex", "color", "type", "size", "fullScreen", "name", "template", "showSpinner"] }, { kind: "component", type: i10.QuestionbookComponent, selector: "lib-questionbook", inputs: ["qbItem", "questionItem", "questions", "errorFieldId", "labelValue", "token", "dropDownData"], outputs: ["handleDropDown", "hadleDropDownDependent"] }] });
242
287
  }
243
288
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: BookletComponent, decorators: [{
244
289
  type: Component,
245
- args: [{ selector: 'lib-booklet', template: "<ngx-spinner [name]=\"spinnerName\" [type]=\"spinnerType\"></ngx-spinner>\n<!-- Booklet Handling-->\n<!-- HA 19DEC23 For Direction -->\n<div *ngFor=\"let qb of booklet\" [ngClass]=\"langDirection\">\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 <!-- HA 28DEC23 Below If logic is to load from booklet -->\n <div *ngIf=\"qb.Questions__r?.records; else elseBlock\">\n <div *ngFor=\"let ques of qb.Questions__r.records\" [class]=\"qb.isShengel__c ? 'questiondiv1' : 'questiondiv1 padd-bottom'\">\n <div class=\"questiondiv2\">\n <!-- HA 17JAN24 - Is title is enabled so that based on the boolean div will be visible -->\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 <!-- HA 28DEC23 Below else logic is to load from books or questions -->\n <ng-template #elseBlock>\n <div [class]=\"qb.isShengel__c ? 'questiondiv1' : 'questiondiv1 padd-bottom'\">\n <div class=\"questiondiv2\">\n <div *ngIf=\"!qb.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(qb?.Question_Text__c)\" *ngIf=\"qb?.Question_Text__c\" > \n {{ qb?.Question_Text__c }}\n {{ qb?.Title__c }}\n </div>\n </div>\n <lib-questionbook [qbItem]=\"qb\" [labelValue]=\"labelValue\" [questionItem]=\"qb\" [questions]=\"readQuestions(qb.Id)\" (handleDropDown)=\"getDropDown($event)\"></lib-questionbook>\n </div>\n </div>\n </ng-template>\n</div>\n\n<!-- Group Actions -->\n<!-- HA 19DEC23 For Direction -->\n<div class=\"align-submit-row\" *ngIf=\"abItem?.Status__c != 'Completed'\" [ngClass]=\"langDirection\">\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}.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"] }]
290
+ args: [{ selector: 'lib-booklet', template: "<ngx-spinner [name]=\"spinnerName\" [type]=\"spinnerType\"></ngx-spinner>\n<!-- Booklet Handling-->\n<!-- HA 19DEC23 For Direction -->\n<div *ngFor=\"let qb of booklet\" [ngClass]=\"langDirection\">\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 <!-- HA 28DEC23 Below If logic is to load from booklet -->\n <div *ngIf=\"qb.Questions__r?.records; else elseBlock\">\n <div *ngFor=\"let ques of qb.Questions__r.records\" [class]=\"qb.isShengel__c ? 'questiondiv1' : 'questiondiv1 padd-bottom'\">\n <div class=\"questiondiv2\">\n <!-- HA 17JAN24 - Is title is enabled so that based on the boolean div will be visible -->\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> <!-- VD 19JAN24 - getting token as input -->\n <lib-questionbook [qbItem]=\"qb\" [token]=\"token\" [labelValue]=\"labelValue\" [questionItem]=\"ques\" [questions]=\"readQuestions(qb.Id)\" (handleDropDown)=\"getDropDown($event)\"></lib-questionbook>\n </div>\n </div>\n </div>\n <!-- HA 28DEC23 Below else logic is to load from books or questions -->\n <ng-template #elseBlock>\n <div [class]=\"qb.isShengel__c ? 'questiondiv1' : 'questiondiv1 padd-bottom'\">\n <div class=\"questiondiv2\">\n <div *ngIf=\"!qb.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(qb?.Question_Text__c)\" *ngIf=\"qb?.Question_Text__c\" > \n {{ qb?.Question_Text__c }}\n {{ qb?.Title__c }}\n </div>\n </div> <!-- VD 19JAN24 - getting token as input -->\n <lib-questionbook [qbItem]=\"qb\" [token]=\"token\" [labelValue]=\"labelValue\" [questionItem]=\"qb\" [questions]=\"readQuestions(qb.Id)\" (handleDropDown)=\"getDropDown($event)\"></lib-questionbook>\n </div>\n </div>\n </ng-template>\n</div>\n\n<!-- Group Actions -->\n<!-- HA 19DEC23 For Direction -->\n<div class=\"align-submit-row\" *ngIf=\"abItem?.Status__c != 'Completed'\" [ngClass]=\"langDirection\">\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}.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}.rtl{flex-direction:row-reverse}\n"] }]
246
291
  }], ctorParameters: function () { return [{ type: i1.SalesforceService }, { type: i2.DataService }, { type: i3.StorageService }, { type: i4.ActivatedRoute }, { type: i5.DomSanitizer }, { type: i6.ChangeService }, { type: i0.ElementRef }, { type: i7.I18nService }]; }, propDecorators: { bookletId: [{
247
292
  type: Input
248
293
  }], serv: [{
@@ -255,11 +300,15 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
255
300
  type: Input
256
301
  }], labelValue: [{
257
302
  type: Input
303
+ }], token: [{
304
+ type: Input
258
305
  }], handleBookletActionEvent: [{
259
306
  type: Output
260
307
  }], handlePage: [{
261
308
  type: Output
262
309
  }], hadleDropDownDependent: [{
263
310
  type: Output
311
+ }], inputForQuestions: [{
312
+ type: Input
264
313
  }] } });
265
- //# 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// HA 19DEC23 imported translation service\nimport { I18nService } from \"../../i18n.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  // HA 19DEC23 langDirection variable is created to assign the direction as class\n  langDirection = 'ltr'; // HA 28DEC23 making ltr as default direction\n  answerList = []; // HA 11-JAN-24 Answerlist to store the minimal value\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    public i18nService: I18nService\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      // HA 28DEC23 this applies for booklet\n      // HA 17JAN24 Added ternary operator to avoid undefined scenario\n      if(Object.keys(this.bookletJSON?.bookQuestionsMap).length > 0){\n        for (var value in this.bookletJSON.bookQuestionsMap) {\n          this.bookQuestionsMap.set(value, this.bookletJSON.bookQuestionsMap[value]);\n        }\n      }\n      // HA 28DEC23 this applies for book or questions\n      else{\n        var value = '';\n        value = this.bookletJSON.records[0].Id;\n        this.bookQuestionsMap.set(value, this.bookletJSON.questionbook);\n      }\n\n      if(this.bookletJSON.questionbook?.Actions__c != undefined) {\n        this.actions = JSON.parse(this.bookletJSON.questionbook.Actions__c);\n      }\n    }\n    // HA 19DEC23 langDirection variable value assigning\n    if(this.bookletJSON?.questionbook?.Style__c){\n      var style = JSON.parse(JSON.parse(JSON.stringify(this.bookletJSON?.questionbook?.Style__c)));\n      this.langDirection = style?.direction;\n    }\n    else if(this.bookletJSON?.records[0]?.Style__c){\n      var style = JSON.parse(JSON.parse(JSON.stringify(this.bookletJSON?.records[0]?.Style__c)));\n      this.langDirection = style?.direction;\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    // HA 19DEC23 langDirection variable value assigning\n    if(response?.questionbook?.Style__c){\n      var style = JSON.parse(JSON.parse(JSON.stringify(response?.questionbook?.Style__c)));\n      this.langDirection = style?.direction;\n    }\n    else if(response?.records[0]?.Style__c){\n      var style = JSON.parse(JSON.parse(JSON.stringify(response?.records[0]?.Style__c)));\n      this.langDirection = style?.direction;\n    }\n  }\n\n  private failureReadBooklet = (response) => {\n\n  }\n\n  handleBookletActionClick(action:ActionMeta) {\n    this.answerList = [];\n    console.log(action);\n    let dataToParent = {};\n    dataToParent['action'] = action.eventtoemit;\n    dataToParent['data'] = this.storageService.get();\n    // HA 17JAN24 nxtId to dataParent object\n    dataToParent['nxtId'] = Object.keys(this.bookletJSON?.bookQuestionsMap)[0];\n    // HA 11-JAN-24 Minimizing the value which has to be passed to the server\n    if(Object.keys(dataToParent['data'].bookQuestionsMap).length === 0){ // HA 11-JAN-24 If condition to load booklet\n      this.handleBook(dataToParent['data'].questionbook.Questions__r);\n    }\n    else{ // HA 11-JAN-24 To load book questions\n      for (const key in dataToParent['data'].bookQuestionsMap) {\n        const val = dataToParent['data'].bookQuestionsMap[key];\n        if(val.Type__c === 'Book'){\n          this.handleBook(val.Questions__r);\n        }\n        else{\n          this.handleQues(val);\n        }\n      }\n    }\n    dataToParent['data'] = this.answerList;\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  // HA 11-JAN-24 handleBook loads the Book\n  handleBook(quesList: any){\n    quesList.records.forEach(element => {\n      if(element.Type__c === 'Book'){\n        element.qbItem.Questions__r.records.forEach(ques => {\n          this.handleQues(ques);\n        });\n      }\n      else{\n        this.handleQues(element);\n      }\n    });\n  }\n\n  // HA 11-JAN-24 handleQues to load question\n  handleQues(ques: any){\n    const question = {};\n    question['id'] = ques.Id;\n    // question['Question__c'] = ques.Question__c;\n    question['input'] = ques.input;\n    question['Type__c'] = ques.Type__c;\n    question['Question_No__c'] = ques.Question_No__c;\n    question['referenceField'] = ques?.referenceField;\n    this.answerList.push(question);\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<!-- HA 19DEC23 For Direction -->\n<div *ngFor=\"let qb of booklet\" [ngClass]=\"langDirection\">\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    <!-- HA 28DEC23 Below If logic is to load from booklet  -->\n    <div *ngIf=\"qb.Questions__r?.records; else elseBlock\">\n        <div *ngFor=\"let ques of qb.Questions__r.records\" [class]=\"qb.isShengel__c ? 'questiondiv1' : 'questiondiv1 padd-bottom'\">\n            <div class=\"questiondiv2\">\n                <!-- HA 17JAN24 - Is title is enabled so that based on the boolean div will be visible -->\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    <!-- HA 28DEC23 Below else logic is to load from books or questions -->\n    <ng-template #elseBlock>\n        <div [class]=\"qb.isShengel__c ? 'questiondiv1' : 'questiondiv1 padd-bottom'\">\n            <div class=\"questiondiv2\">\n                <div *ngIf=\"!qb.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(qb?.Question_Text__c)\" *ngIf=\"qb?.Question_Text__c\" > \n                        {{ qb?.Question_Text__c }}\n                        {{ qb?.Title__c }}\n                    </div>\n                </div>\n                <lib-questionbook [qbItem]=\"qb\" [labelValue]=\"labelValue\" [questionItem]=\"qb\" [questions]=\"readQuestions(qb.Id)\"  (handleDropDown)=\"getDropDown($event)\"></lib-questionbook>\n            </div>\n        </div>\n    </ng-template>\n</div>\n\n<!-- Group Actions -->\n<!-- HA 19DEC23 For Direction -->\n<div class=\"align-submit-row\" *ngIf=\"abItem?.Status__c != 'Completed'\" [ngClass]=\"langDirection\">\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"]}
314
+ //# 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// HA 19DEC23 imported translation service\nimport { I18nService } from \"../../i18n.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  @Input() token:string;\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  // HA 19DEC23 langDirection variable is created to assign the direction as class\n  langDirection = 'ltr'; // HA 28DEC23 making ltr as default direction\n  answerList = []; // HA 11-JAN-24 Answerlist to store the minimal value\n  @Input() inputForQuestions: any = {}; // HA 18-JAN-24 To insert the endpoint value to the question\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    public i18nService: I18nService\n  ) { \n    this.spinnerName = \"sp1\";\n    this.spinnerType = \"ball-spin-clockwise\";\n    console.log('dropdownDependentData',this.dropdownDependentData);\n  }\n\n  ngOnInit(): void {\n    // HA 18-JAN-24 Dummy Static data for testing\n    // this.inputForQuestions = {\n    //   \"_id\": \"659ed002ed51bb8061544255\",\n    //   \"companyId\": \"5ullh1BWpYqnvzKh9L\",\n    //   \"name\": \"Al Yasmine\",\n    //   \"code\": \"check\",\n    //   \"status\": \"In-Progress\",\n    //   \"createdAt\": \"2024-01-10T17:12:34.686Z\",\n    //   \"updatedAt\": \"2024-01-10T19:53:08.135Z\",\n    //   \"__v\": 0,\n    //   \"owner\": \"check\",\n    //   \"customer\": \"check\"\n    // };\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      // HA 28DEC23 this applies for booklet\n      // HA 17JAN24 Added ternary operator to avoid undefined scenario\n      if(Object.keys(this.bookletJSON?.bookQuestionsMap).length > 0){\n        for (var value in this.bookletJSON.bookQuestionsMap) {\n          this.bookQuestionsMap.set(value, this.bookletJSON.bookQuestionsMap[value]);\n        }\n      }\n      // HA 28DEC23 this applies for book or questions\n      else{\n        var value = '';\n        value = this.bookletJSON.records[0].Id;\n        this.bookQuestionsMap.set(value, this.bookletJSON.questionbook);\n      }\n\n      if(this.bookletJSON.questionbook?.Actions__c != undefined) {\n        this.actions = JSON.parse(this.bookletJSON.questionbook.Actions__c);\n      }\n    }\n    // HA 19DEC23 langDirection variable value assigning\n    if(this.bookletJSON?.questionbook?.Style__c){\n      var style = JSON.parse(JSON.parse(JSON.stringify(this.bookletJSON?.questionbook?.Style__c)));\n      this.langDirection = style?.direction;\n    }\n    else if(this.bookletJSON?.records[0]?.Style__c){\n      var style = JSON.parse(JSON.parse(JSON.stringify(this.bookletJSON?.records[0]?.Style__c)));\n      this.langDirection = style?.direction;\n    }\n\n    // HA 18-JAN-24 The condition is used for Bind-In Logic \n    this.handleCompleteBooklet(this.bookletJSON);\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    // HA 19DEC23 langDirection variable value assigning\n    if(response?.questionbook?.Style__c){\n      var style = JSON.parse(JSON.parse(JSON.stringify(response?.questionbook?.Style__c)));\n      this.langDirection = style?.direction;\n    }\n    else if(response?.records[0]?.Style__c){\n      var style = JSON.parse(JSON.parse(JSON.stringify(response?.records[0]?.Style__c)));\n      this.langDirection = style?.direction;\n    }\n  }\n\n  private failureReadBooklet = (response) => {\n\n  }\n\n  handleBookletActionClick(action:ActionMeta) {\n    // HA 19JAN24 Action changes\n    this.answerList = [];\n    console.log(action);\n    let dataToParent = {};\n    if(!(action.eventtoemit === 'close')){\n      dataToParent['action'] = action.eventtoemit;\n      // HA 18-JAN-24 Sending the complete json data also \n      dataToParent['jsonBook'] = this.storageService.get();\n      // HA 17JAN24 nxtId to dataParent object\n      dataToParent['nxtId'] = Object.keys(this.bookletJSON?.bookQuestionsMap)[0];\n      // HA 11-JAN-24 Minimizing the value which has to be passed to the server\n      this.handleCompleteBooklet(dataToParent['jsonBook']);\n      dataToParent['data'] = this.answerList ? this.answerList : dataToParent['data'];\n      this.handleBookletActionEvent.emit(dataToParent);\n      // when clicking the submit button validating the required fields\n      for(let key in dataToParent['jsonBook'].bookQuestionsMap){\n        const currentBook  = dataToParent['jsonBook'].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  // HA 18-JAN-24 handleCompleteBooklet is to simplify the logic\n  handleCompleteBooklet(completeBooklet){\n    if(Object.keys(completeBooklet?.bookQuestionsMap ?? {}).length === 0){ // HA 11-JAN-24 If condition to load booklet\n      this.handleBook(completeBooklet?.questionbook?.Questions__r);\n    }\n    else{ // HA 11-JAN-24 To load book questions\n      for (const key in completeBooklet.bookQuestionsMap) {\n        const val = completeBooklet.bookQuestionsMap[key];\n        if(val.Type__c === 'Book'){\n          this.handleBook(val.Questions__r);\n        }\n        else{\n          this.handleQues(val);\n        }\n      }\n    }\n  }\n\n  // HA 11-JAN-24 handleBook loads the Book\n  handleBook(quesList: any){\n    quesList?.records.forEach(element => {\n      if(element.Type__c === 'Book'){\n        element.qbItem.Questions__r.records.forEach(ques => {\n          this.handleQues(ques);\n        });\n      }\n      else{\n        this.handleQues(element);\n      }\n    });\n  }\n\n  // HA 11-JAN-24 handleQues to load question\n  handleQues(ques: any){\n    // HA 19-JAN-24 If condition is for bind-in, correction\n    if(this.inputForQuestions.length > 0){\n      for(let [key, value] of Object.entries(this.inputForQuestions)){\n        if(ques.Reference_Field__c === key){\n          if(ques.Type__c === 'Dropdown'){\n            this.sqOptions.forEach(element => {\n              if(element['Reference_Field__c'] === key){\n                element['input'] = ques.input = value;\n                element['selectedValue'] = ques.selectedValue = value;\n              }\n            });\n          }\n          else{\n            ques.input = value;\n          }\n        }\n      }\n    }\n    else{\n      const question = {};\n      question['id'] = ques.Id;\n      // question['Question__c'] = ques.Question__c;\n      question['input'] = ques.input;\n      question['Type__c'] = ques.Type__c;\n      question['Question_No__c'] = ques.Question_No__c;\n      question['Reference_Field__c'] = ques?.Reference_Field__c;\n      this.answerList.push(question);\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<!-- HA 19DEC23 For Direction -->\n<div *ngFor=\"let qb of booklet\" [ngClass]=\"langDirection\">\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    <!-- HA 28DEC23 Below If logic is to load from booklet  -->\n    <div *ngIf=\"qb.Questions__r?.records; else elseBlock\">\n        <div *ngFor=\"let ques of qb.Questions__r.records\" [class]=\"qb.isShengel__c ? 'questiondiv1' : 'questiondiv1 padd-bottom'\">\n            <div class=\"questiondiv2\">\n                <!-- HA 17JAN24 - Is title is enabled so that based on the boolean div will be visible -->\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> <!-- VD 19JAN24 - getting token as input -->\n                <lib-questionbook [qbItem]=\"qb\" [token]=\"token\" [labelValue]=\"labelValue\" [questionItem]=\"ques\" [questions]=\"readQuestions(qb.Id)\"  (handleDropDown)=\"getDropDown($event)\"></lib-questionbook>\n            </div>\n        </div>\n    </div>\n    <!-- HA 28DEC23 Below else logic is to load from books or questions -->\n    <ng-template #elseBlock>\n        <div [class]=\"qb.isShengel__c ? 'questiondiv1' : 'questiondiv1 padd-bottom'\">\n            <div class=\"questiondiv2\">\n                <div *ngIf=\"!qb.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(qb?.Question_Text__c)\" *ngIf=\"qb?.Question_Text__c\" > \n                        {{ qb?.Question_Text__c }}\n                        {{ qb?.Title__c }}\n                    </div>\n                </div> <!-- VD 19JAN24 - getting token as input -->\n                <lib-questionbook [qbItem]=\"qb\" [token]=\"token\" [labelValue]=\"labelValue\" [questionItem]=\"qb\" [questions]=\"readQuestions(qb.Id)\"  (handleDropDown)=\"getDropDown($event)\"></lib-questionbook>\n            </div>\n        </div>\n    </ng-template>\n</div>\n\n<!-- Group Actions -->\n<!-- HA 19DEC23 For Direction -->\n<div class=\"align-submit-row\" *ngIf=\"abItem?.Status__c != 'Completed'\" [ngClass]=\"langDirection\">\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"]}