@rangertechnologies/ngnxt 2.0.27

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 (45) hide show
  1. package/README.md +24 -0
  2. package/esm2022/lib/components/custom-date-picker/custom-date-picker.component.mjs +33 -0
  3. package/esm2022/lib/components/custom-dropdown/custom-dropdown.component.mjs +73 -0
  4. package/esm2022/lib/components/custom-input/custom-input.component.mjs +46 -0
  5. package/esm2022/lib/components/custom-table/custom-table.component.mjs +51 -0
  6. package/esm2022/lib/components/custom-text-area/custom-text-area.component.mjs +34 -0
  7. package/esm2022/lib/components/dropdown-with-flag/dropdown-with-flag.component.mjs +34 -0
  8. package/esm2022/lib/components/pick-location/pick-location.component.mjs +134 -0
  9. package/esm2022/lib/components/search-box/search-box.component.mjs +84 -0
  10. package/esm2022/lib/interfaces/apimeta.mjs +2 -0
  11. package/esm2022/lib/nxt-app.component.mjs +22 -0
  12. package/esm2022/lib/nxt-app.module.mjs +262 -0
  13. package/esm2022/lib/nxt-app.service.mjs +14 -0
  14. package/esm2022/lib/pages/booklet/booklet.component.mjs +79 -0
  15. package/esm2022/lib/pages/questionnaire/questionnaire.component.mjs +2131 -0
  16. package/esm2022/lib/sample.mjs +433 -0
  17. package/esm2022/lib/services/data.service.mjs +40 -0
  18. package/esm2022/lib/services/salesforce.service.mjs +46 -0
  19. package/esm2022/lib/wrapper.mjs +165 -0
  20. package/esm2022/public-api.mjs +10 -0
  21. package/esm2022/rangertechnologies-ngnxt.mjs +5 -0
  22. package/fesm2022/rangertechnologies-ngnxt.mjs +3610 -0
  23. package/fesm2022/rangertechnologies-ngnxt.mjs.map +1 -0
  24. package/index.d.ts +5 -0
  25. package/lib/components/custom-date-picker/custom-date-picker.component.d.ts +14 -0
  26. package/lib/components/custom-dropdown/custom-dropdown.component.d.ts +23 -0
  27. package/lib/components/custom-input/custom-input.component.d.ts +18 -0
  28. package/lib/components/custom-table/custom-table.component.d.ts +23 -0
  29. package/lib/components/custom-text-area/custom-text-area.component.d.ts +14 -0
  30. package/lib/components/dropdown-with-flag/dropdown-with-flag.component.d.ts +14 -0
  31. package/lib/components/pick-location/pick-location.component.d.ts +38 -0
  32. package/lib/components/search-box/search-box.component.d.ts +34 -0
  33. package/lib/interfaces/apimeta.d.ts +5 -0
  34. package/lib/nxt-app.component.d.ts +8 -0
  35. package/lib/nxt-app.module.d.ts +26 -0
  36. package/lib/nxt-app.service.d.ts +6 -0
  37. package/lib/pages/booklet/booklet.component.d.ts +29 -0
  38. package/lib/pages/questionnaire/questionnaire.component.d.ts +207 -0
  39. package/lib/sample.d.ts +10 -0
  40. package/lib/services/data.service.d.ts +9 -0
  41. package/lib/services/salesforce.service.d.ts +11 -0
  42. package/lib/wrapper.d.ts +164 -0
  43. package/package.json +43 -0
  44. package/public-api.d.ts +6 -0
  45. package/rangertechnologies-ngnxt-2.0.27.tgz +0 -0
@@ -0,0 +1,2131 @@
1
+ import { Component, Input, Output, EventEmitter, ViewEncapsulation, } from "@angular/core";
2
+ import * as moment from 'moment';
3
+ import { Question, AnswerWrapper, ErrorWrapper, OptionValue, AttachmentWrapper, Attachment, LocalQuestion } from "../../wrapper";
4
+ import { DTQUESTION, TESTQB, } from "../../sample";
5
+ import * as i0 from "@angular/core";
6
+ import * as i1 from "../../services/salesforce.service";
7
+ import * as i2 from "../../services/data.service";
8
+ import * as i3 from "@angular/router";
9
+ import * as i4 from "@angular/platform-browser";
10
+ import * as i5 from "ngx-spinner";
11
+ import * as i6 from "@angular/forms";
12
+ import * as i7 from "ngx-device-detector";
13
+ import * as i8 from "@angular/common";
14
+ import * as i9 from "mydatepicker";
15
+ import * as i10 from "ng-circle-progress";
16
+ import * as i11 from "../../components/pick-location/pick-location.component";
17
+ import * as i12 from "../../components/custom-input/custom-input.component";
18
+ import * as i13 from "../../components/custom-text-area/custom-text-area.component";
19
+ import * as i14 from "../../components/custom-table/custom-table.component";
20
+ import * as i15 from "../../components/custom-date-picker/custom-date-picker.component";
21
+ import * as i16 from "../../components/dropdown-with-flag/dropdown-with-flag.component";
22
+ import * as i17 from "../../components/custom-dropdown/custom-dropdown.component";
23
+ export class QuestionnaireComponent {
24
+ sfService;
25
+ dataService;
26
+ route;
27
+ sanitizer;
28
+ spinner;
29
+ _formBuilder;
30
+ deviceService;
31
+ qbId;
32
+ insuranceStartDate;
33
+ serv;
34
+ tkn;
35
+ handleEvent = new EventEmitter();
36
+ handlePage = new EventEmitter();
37
+ params;
38
+ deviceInfo = null;
39
+ abItem;
40
+ qbItem;
41
+ questionItem;
42
+ answerWrap;
43
+ // CONDITIONAL TYPES
44
+ radioFlag = false;
45
+ dataFlag = false;
46
+ // OPTIONONLY TYPES
47
+ dropdownFlag = false;
48
+ checkboxFlag = false;
49
+ // UNCONDITIONAL TYPES
50
+ textFlag = false;
51
+ taFlag = false;
52
+ dtFlag = false;
53
+ timeFlag = false;
54
+ dateFlag = false;
55
+ fileFlag = false;
56
+ emailFlag = false;
57
+ numberFlag = false;
58
+ alphanumericFlag = false;
59
+ bookFlag = false;
60
+ listFlag = false;
61
+ //Back button
62
+ backButtonFlag = false;
63
+ optionValues = [];
64
+ subQuestions = [];
65
+ inpValue;
66
+ answerMap = new Map();
67
+ dateMap = new Map();
68
+ selectedhourMap = new Map();
69
+ selectedminuteMap = new Map();
70
+ attachmentsMap = new Map();
71
+ sqOptions = new Map();
72
+ subAnsMap = new Map();
73
+ localSubQuestions = [];
74
+ questionStack = [];
75
+ questionName = [];
76
+ attachments = [];
77
+ attachmentIdList = [];
78
+ attachmentId = "";
79
+ attachment;
80
+ allowedFileExtension;
81
+ fileExceededLimit = false;
82
+ fileTypeIncorrect = false;
83
+ back = false;
84
+ backicon = false;
85
+ check;
86
+ pop;
87
+ localDate;
88
+ currentName;
89
+ pathquestion;
90
+ percent;
91
+ count;
92
+ taFocusOut = false;
93
+ notValidAccNum = false;
94
+ splCCBackClick = false;
95
+ summary = [];
96
+ localSubQMap = new Map();
97
+ keyIndex = 0;
98
+ //public sques: string;
99
+ selDate = {};
100
+ selectDate;
101
+ today = new Date();
102
+ el;
103
+ innerhtml;
104
+ possibilities;
105
+ innerhtml1;
106
+ summaryData = [];
107
+ tableData1 = [
108
+ {
109
+ label: 'Fire Extinguisher',
110
+ imageSrc: 'https://media.istockphoto.com/id/943776434/vector/fire-extinguisher-icon-vector.jpg?s=612x612&w=0&k=20&c=KVaDxuV2TV7fdwn09Tg9HeF3MNyoJC5k2YqSAzpStDY=',
111
+ altText: 'extinguisher',
112
+ name: 'FireEstinguisher',
113
+ value: 'YES'
114
+ },
115
+ {
116
+ label: ' Fire Blanket',
117
+ imageSrc: 'https://media.istockphoto.com/id/943776434/vector/fire-extinguisher-icon-vector.jpg?s=612x612&w=0&k=20&c=KVaDxuV2TV7fdwn09Tg9HeF3MNyoJC5k2YqSAzpStDY=',
118
+ altText: 'fireBlanket',
119
+ name: 'fireBlanket',
120
+ value: 'YES'
121
+ },
122
+ {
123
+ label: 'Illumination',
124
+ imageSrc: 'https://media.istockphoto.com/id/943776434/vector/fire-extinguisher-icon-vector.jpg?s=612x612&w=0&k=20&c=KVaDxuV2TV7fdwn09Tg9HeF3MNyoJC5k2YqSAzpStDY=',
125
+ altText: 'fireBlailluminationnket',
126
+ name: 'illumination',
127
+ value: 'YES'
128
+ },
129
+ {
130
+ label: 'Ventilation',
131
+ imageSrc: 'https://media.istockphoto.com/id/943776434/vector/fire-extinguisher-icon-vector.jpg?s=612x612&w=0&k=20&c=KVaDxuV2TV7fdwn09Tg9HeF3MNyoJC5k2YqSAzpStDY=',
132
+ altText: 'Ventilation',
133
+ name: 'Ventilation',
134
+ value: 'YES'
135
+ }
136
+ ];
137
+ tableData2 = [
138
+ {
139
+ label: 'Head Protection',
140
+ imageSrc: 'https://media.istockphoto.com/id/943776434/vector/fire-extinguisher-icon-vector.jpg?s=612x612&w=0&k=20&c=KVaDxuV2TV7fdwn09Tg9HeF3MNyoJC5k2YqSAzpStDY=',
141
+ altText: 'extinguisher',
142
+ name: 'check1',
143
+ value: 'YES'
144
+ },
145
+ {
146
+ label: 'Welding Hood',
147
+ imageSrc: 'https://media.istockphoto.com/id/943776434/vector/fire-extinguisher-icon-vector.jpg?s=612x612&w=0&k=20&c=KVaDxuV2TV7fdwn09Tg9HeF3MNyoJC5k2YqSAzpStDY=',
148
+ altText: 'fireBlanket',
149
+ name: 'check2',
150
+ value: 'YES'
151
+ },
152
+ {
153
+ label: 'Eye Protection',
154
+ imageSrc: 'https://media.istockphoto.com/id/943776434/vector/fire-extinguisher-icon-vector.jpg?s=612x612&w=0&k=20&c=KVaDxuV2TV7fdwn09Tg9HeF3MNyoJC5k2YqSAzpStDY=',
155
+ altText: 'Protection',
156
+ name: 'Protection',
157
+ value: 'YES'
158
+ },
159
+ {
160
+ label: 'Hearing Protection',
161
+ imageSrc: 'https://media.istockphoto.com/id/943776434/vector/fire-extinguisher-icon-vector.jpg?s=612x612&w=0&k=20&c=KVaDxuV2TV7fdwn09Tg9HeF3MNyoJC5k2YqSAzpStDY=',
162
+ altText: 'Hearing',
163
+ name: 'Hearing',
164
+ value: 'YES'
165
+ }
166
+ ];
167
+ hours = [
168
+ "01",
169
+ "02",
170
+ "03",
171
+ "04",
172
+ "05",
173
+ "06",
174
+ "07",
175
+ "08",
176
+ "09",
177
+ "10",
178
+ "11",
179
+ "12",
180
+ ];
181
+ minutes = [
182
+ "00",
183
+ "01",
184
+ "02",
185
+ "03",
186
+ "04",
187
+ "05",
188
+ "06",
189
+ "07",
190
+ "08",
191
+ "09",
192
+ "10",
193
+ "11",
194
+ "12",
195
+ "13",
196
+ "14",
197
+ "15",
198
+ "16",
199
+ "17",
200
+ "18",
201
+ "19",
202
+ "20",
203
+ "21",
204
+ "22",
205
+ "23",
206
+ "24",
207
+ "25",
208
+ "26",
209
+ "27",
210
+ "28",
211
+ "29",
212
+ "30",
213
+ "31",
214
+ "32",
215
+ "33",
216
+ "34",
217
+ "35",
218
+ "36",
219
+ "37",
220
+ "38",
221
+ "39",
222
+ "40",
223
+ "41",
224
+ "42",
225
+ "43",
226
+ "44",
227
+ "45",
228
+ "46",
229
+ "47",
230
+ "48",
231
+ "49",
232
+ "50",
233
+ "51",
234
+ "52",
235
+ "53",
236
+ "54",
237
+ "55",
238
+ "56",
239
+ "57",
240
+ "58",
241
+ "59",
242
+ ];
243
+ selectedHour = "";
244
+ selectedMinute = "";
245
+ selectedMeridiem = "";
246
+ valueName = "";
247
+ valueName1 = "";
248
+ bookFlagAccept;
249
+ recordId;
250
+ currentQuestionId;
251
+ spinnerType;
252
+ spinnerName;
253
+ nextValue = '';
254
+ start_date;
255
+ //search component
256
+ tempoAddress = [];
257
+ selectedValue;
258
+ selectedPostalcode;
259
+ selectedProvince;
260
+ selectedCity;
261
+ selectedArea;
262
+ localaddress = [];
263
+ allAddress = [];
264
+ PostalCode;
265
+ places = [];
266
+ province = [];
267
+ // REQ-01 PROGRESS BAR
268
+ progressStyle = "0%";
269
+ answerCount = 0;
270
+ indexCount = 0;
271
+ addFlag = true;
272
+ myDatePickerOptions = {};
273
+ individualBookButton;
274
+ constructor(sfService, dataService, route, sanitizer, spinner, _formBuilder,
275
+ //private dbService: NgxIndexedDBService,
276
+ deviceService, el) {
277
+ this.sfService = sfService;
278
+ this.dataService = dataService;
279
+ this.route = route;
280
+ this.sanitizer = sanitizer;
281
+ this.spinner = spinner;
282
+ this._formBuilder = _formBuilder;
283
+ this.deviceService = deviceService;
284
+ this.spinnerName = "sp1";
285
+ this.spinnerType = "ball-spin-clockwise";
286
+ }
287
+ onDateChanged(event) {
288
+ //console.log('Inside the onDateChanged');
289
+ //to change the border color
290
+ if (this.qbItem.Progress_Bar__c) {
291
+ //console.log('Inside the progressBar cond');
292
+ this.inpValue =
293
+ event.date.day + "/" + event.date.month + "/" + event.date.year;
294
+ if (this.questionItem.Type__c == "Book") {
295
+ this.selectDate = event.date.day + "/" + event.date.month + "/" + event.date.year;
296
+ }
297
+ }
298
+ else {
299
+ //console.log('Inside the ELSE of progressBar cond');
300
+ if (this.questionItem.Type__c == "Book") {
301
+ this.selectDate = event.date.day + "-" + event.date.month + "-" + event.date.year;
302
+ }
303
+ this.inpValue =
304
+ event.date.year + "-" + event.date.month + "-" + event.date.day;
305
+ }
306
+ const htmlElement = window.document.getElementsByClassName("mydp");
307
+ htmlElement
308
+ .item(0)
309
+ .setAttribute("style", "border-color:#87be1c;width:100%");
310
+ this.dateMap.set(this.questionItem.Id, event);
311
+ if (event.date.day === 0 &&
312
+ event.date.month === 0 &&
313
+ event.date.year === 0) {
314
+ this.dateMap.delete(this.questionItem.Id);
315
+ this.answerMap.delete(this.questionItem.Id);
316
+ }
317
+ //console.log('this.inpValue = '+this.inpValue);
318
+ //console.log('this.selectDate = '+this.selectDate);
319
+ }
320
+ ngOnInit() {
321
+ this.deviceInfo = this.deviceService.getDeviceInfo();
322
+ this.route.queryParams.subscribe((params) => {
323
+ if (params['id']) {
324
+ this.individualBookButton = true;
325
+ }
326
+ else if (params['bookletId']) {
327
+ this.individualBookButton = false;
328
+ }
329
+ });
330
+ console.log('Inside the ngOnInit');
331
+ // console.log("RNXT-Claim");
332
+ this.inpValue = "";
333
+ this.selectedMeridiem = "AM";
334
+ this.processQB();
335
+ //console.log(localStorage.getItem('address'));
336
+ if (localStorage.getItem("address")) {
337
+ this.localaddress = JSON.parse(localStorage.getItem("address"));
338
+ //console.log('Length='+this.localaddress.length);
339
+ this.allAddress = this.localaddress.filter((item, index) => {
340
+ if (this.localaddress.indexOf(item) == index) {
341
+ return item;
342
+ }
343
+ });
344
+ this.allAddress.sort(function (a, b) {
345
+ return a.zipCode - b.zipCode;
346
+ });
347
+ }
348
+ else if (this.deviceInfo.os === 'iOS') {
349
+ let openRequest = indexedDB.open("addressDB");
350
+ openRequest.onsuccess = (event) => {
351
+ const targetNew = event.target;
352
+ let dbNew = targetNew.result;
353
+ const requestNew = dbNew.transaction('addressTable')
354
+ .objectStore('addressTable')
355
+ .get(1);
356
+ requestNew.onsuccess = () => {
357
+ const tempVar = requestNew.result;
358
+ this.localaddress = JSON.parse(tempVar.wholeAddressString);
359
+ this.allAddress = this.localaddress.filter((item, index) => {
360
+ if (this.localaddress.indexOf(item) == index) {
361
+ return item;
362
+ }
363
+ });
364
+ this.allAddress.sort(function (a, b) {
365
+ return a.zipCode - b.zipCode;
366
+ });
367
+ };
368
+ };
369
+ }
370
+ }
371
+ ngOnChanges() {
372
+ //console.log('inside Questionnaire ngOnChanges');
373
+ this.processQB();
374
+ }
375
+ date_TimeMap() {
376
+ this.selectedhourMap.set(this.questionItem.Id, this.selectedHour);
377
+ this.selectedminuteMap.set(this.questionItem.Id, this.selectedMinute);
378
+ }
379
+ day() {
380
+ this.myDatePickerOptions = {
381
+ dateFormat: "dd.mm.yyyy",
382
+ sunHighlight: false,
383
+ disableDateRanges: [],
384
+ showClearDateBtn: false,
385
+ disableSince: {
386
+ year: 0,
387
+ month: 0,
388
+ day: 0,
389
+ },
390
+ disableUntil: {
391
+ year: 0,
392
+ month: 0,
393
+ day: 0,
394
+ },
395
+ showTodayBtn: false,
396
+ dayLabels: {
397
+ su: "Dom",
398
+ mo: "Lun",
399
+ tu: "Mar",
400
+ we: "Mié",
401
+ th: "Jue",
402
+ fr: "Vie",
403
+ sa: "Sáb",
404
+ },
405
+ monthLabels: {
406
+ 1: "Ene",
407
+ 2: "Feb",
408
+ 3: "Mar",
409
+ 4: "Abr",
410
+ 5: "Mayo",
411
+ 6: "Jun",
412
+ 7: "Jul",
413
+ 8: "Ago",
414
+ 9: "Sep",
415
+ 10: "Oct",
416
+ 11: "Nov",
417
+ 12: "Dic",
418
+ },
419
+ };
420
+ }
421
+ change() {
422
+ const htmlElement = window.document.getElementsByClassName("mydp");
423
+ if (this.selDate === null || this.inpValue.length === 0) {
424
+ htmlElement
425
+ .item(0)
426
+ .setAttribute("style", "width:100%;border: 1px solid red");
427
+ }
428
+ else {
429
+ htmlElement
430
+ .item(0)
431
+ .setAttribute("style", "border: 1px solid #87be1c ;width:100%");
432
+ }
433
+ }
434
+ processQB() {
435
+ //console.log('ProcessQB');
436
+ //this.qbItem
437
+ //console.log(this.qbId);
438
+ //console.log('Version in process is 8bf11efa7f91a391d957bf6b5078edc7e656b67c');
439
+ if (this.qbId) {
440
+ if (this.qbId.length == 18) {
441
+ this.readQuestionBook(this.qbId);
442
+ }
443
+ else {
444
+ //console.log('Inside the else part');
445
+ //console.log('Setting the Question Directly for testing');
446
+ this.questionItem = DTQUESTION;
447
+ this.qbItem = TESTQB;
448
+ this.processQuestion();
449
+ }
450
+ }
451
+ }
452
+ trimLastDummy(input) {
453
+ return (input = input.substring(0, input.length - 6));
454
+ }
455
+ getProperTime(def, input) {
456
+ return input === "" ? def : input;
457
+ }
458
+ //Summary Question Clickable Logic
459
+ handleEditClick(value) {
460
+ this.backicon = false;
461
+ if (this.abItem?.Status__c == "Pending") {
462
+ if (value == null) {
463
+ return;
464
+ }
465
+ this.readQuestion(value);
466
+ //console.log(' in side summaryopen'+ this.summary.length);
467
+ //Assign question stack length from summary part
468
+ var arrayLength = this.questionStack.length;
469
+ var lengthValue = this.questionStack.indexOf(value);
470
+ for (let i = arrayLength; i > lengthValue; i--) {
471
+ this.questionStack.pop();
472
+ }
473
+ if (this.qbItem.Progress_Bar__c === true) {
474
+ var arrayLength1 = this.questionName.length;
475
+ for (let j = arrayLength1; j > lengthValue; j--) {
476
+ this.questionName.pop();
477
+ }
478
+ }
479
+ this.summary = [];
480
+ this.summaryData = [];
481
+ }
482
+ }
483
+ handleNextClick() {
484
+ this.backButtonFlag = false;
485
+ this.AnswerSave();
486
+ }
487
+ AnswerSave() {
488
+ //this.updateProgress();
489
+ if (this.currentQuestionId === null) {
490
+ return;
491
+ }
492
+ var questionTxt = '';
493
+ this.clearError();
494
+ this.handleEvent.emit(this.qbItem.Next_Tracking_ID__c);
495
+ this.recordId = null;
496
+ var cQuestion = new Question();
497
+ cQuestion = this.questionItem;
498
+ // Create an array of objects to store the values
499
+ for (var i = 0; i < this.questionItem.Questions__r.records.length; i++) {
500
+ if (this.questionItem.Questions__r.records[i].Question_Text__c) {
501
+ var questionText = this.questionItem.Questions__r.records[i].Question_Text__c.replace(/<[^>]+>/g, ''); // Remove HTML tags from the Question_Text__c value
502
+ }
503
+ else {
504
+ questionText = 'undefined';
505
+ }
506
+ const input = this.questionItem.Questions__r.records[i].input;
507
+ const obj = { [questionText]: input }; // Create an object with the questionText as the key and the input as the value
508
+ this.summaryData.push(obj); // Add the object to the data array
509
+ }
510
+ var typ = cQuestion.Type__c;
511
+ // this.sques += cQuestion.Question__c + '@@##$$';
512
+ var quesValue = cQuestion.Question_Text__c;
513
+ var mailformat = "^[^.][a-zA-Z0-9!#$%&'*+-/=?^_`{|}~]+[^.]@[^-][a-zA-Z0-9.-]+[^-].[a-zA-Z]{2,}$";
514
+ // Process Inputs
515
+ if (this.checkboxFlag) {
516
+ this.inpValue = "";
517
+ // Save all the selected options in the inpValue
518
+ for (var ov of this.optionValues.filter((item) => item.checked)) {
519
+ this.inpValue += ov.Value__c + "@@##$$";
520
+ this.recordId = ov.Next_Question__c;
521
+ }
522
+ this.inpValue = this.trimLastDummy(this.inpValue);
523
+ }
524
+ else if (this.emailFlag) {
525
+ if (this.inpValue && this.inpValue.match(mailformat)) {
526
+ this.recordId = this.questionItem.Next_Question__c;
527
+ }
528
+ else {
529
+ this.questionItem.error = new ErrorWrapper();
530
+ return;
531
+ }
532
+ }
533
+ else if (this.alphanumericFlag) {
534
+ var isNotValidAccNum = this.isNotValidAccNumber(this.inpValue);
535
+ if (isNotValidAccNum) {
536
+ this.notValidAccNum = true;
537
+ this.recordId = this.questionItem.Next_Question__c;
538
+ return;
539
+ }
540
+ this.notValidAccNum = false;
541
+ }
542
+ else if (this.numberFlag) {
543
+ if (this.inpValue) {
544
+ this.recordId = this.questionItem.Next_Question__c;
545
+ }
546
+ else {
547
+ this.questionItem.error = new ErrorWrapper();
548
+ return;
549
+ }
550
+ }
551
+ else if (this.bookFlag) {
552
+ //console.log(this.questionItem.Type__c)
553
+ //console.log('Inside the bookFlag cond');
554
+ //console.log('this.inpValue = '+this.inpValue);
555
+ //console.log('this.selectDate = '+this.selectDate);
556
+ //console.log('this.selDate = ');
557
+ //console.log(this.selDate);
558
+ this.inpValue = "";
559
+ var hasMissingInput = false;
560
+ for (var item of this.questionItem.Questions__r.records) {
561
+ var count = 0;
562
+ if (item.Type__c == "Date" || item.Type__c == "Time") {
563
+ //this one
564
+ this.change();
565
+ if (item.Type__c == "Date") {
566
+ //console.log('Inside the date type cond = '+this.selectDate);
567
+ this.inpValue = this.selectDate;
568
+ //console.log(this.inpValue)
569
+ //console.log(this.selectDate)
570
+ }
571
+ if (item.Type__c == "Time") {
572
+ //console.log(this.selectedHour+this.selectedMeridiem+this.selectedMinute)
573
+ if (this.questionItem.X24_Hours__c === false) {
574
+ this.questionItem.input =
575
+ (this.selectedMeridiem === "PM" && this.selectedHour != "12"
576
+ ? Number(this.selectedHour) + 12
577
+ : this.selectedHour) +
578
+ ":" +
579
+ this.selectedMinute + " PM";
580
+ if (this.selectedMeridiem === "AM" && this.selectedHour === "12") {
581
+ this.questionItem.input = "00" + ":" + this.selectedMinute + " AM";
582
+ }
583
+ if (this.qbItem.Progress_Bar__c) {
584
+ if (this.selectDate) {
585
+ this.inpValue = this.selectDate + " " + this.questionItem.input;
586
+ }
587
+ else {
588
+ this.inpValue = " " + this.questionItem.input;
589
+ }
590
+ }
591
+ else {
592
+ if (this.selectDate) {
593
+ this.inpValue = this.selectDate + " " + this.questionItem.input;
594
+ }
595
+ else {
596
+ this.inpValue = " " + this.questionItem.input;
597
+ }
598
+ }
599
+ }
600
+ if (this.questionItem.X24_Hours__c === true) {
601
+ this.questionItem.input =
602
+ this.selectedHour + ":" + this.selectedMinute;
603
+ if (this.qbItem.Progress_Bar__c) {
604
+ this.inpValue = this.questionItem.input;
605
+ }
606
+ else {
607
+ this.inpValue = this.questionItem.input;
608
+ }
609
+ }
610
+ }
611
+ if (this.selDate === null || this.selDate === undefined || !this.inpValue || !this.selectedHour || !this.selectedMinute || !this.selectDate) {
612
+ //console.log('Inside the null condition of input');
613
+ this.questionItem.error = new ErrorWrapper();
614
+ const htmlElement = window.document.getElementsByClassName("mydp");
615
+ htmlElement
616
+ .item(0)
617
+ .setAttribute("style", "width:100%;border-bottom: 1px solid red !important;");
618
+ return;
619
+ }
620
+ this.date_TimeMap();
621
+ }
622
+ if (item.Type__c == "Text" && item.Question__c === 'Población') {
623
+ for (var loc of this.localaddress) {
624
+ if ((this.selectedPostalcode == loc.zipCode) && (this.selectedValue == loc.country) && (this.selectedCity == loc.town)) {
625
+ item.input = this.selectedCity;
626
+ break;
627
+ }
628
+ else if (count == this.localaddress.length - 1) {
629
+ //console.log('error form city')
630
+ item.error = new ErrorWrapper();
631
+ hasMissingInput = true;
632
+ return;
633
+ }
634
+ count++;
635
+ }
636
+ //console.log('testin values=='+item.input)
637
+ }
638
+ // if(item.Type__c === 'Location' && Array.isArray(item.input) && item.input.every((input) => input !== undefined)){
639
+ // const inputValues = "answerString: " + item.input ;
640
+ // item.input = inputValues;
641
+ // }
642
+ if (item.Type__c == "Text" && item.Question__c === 'Código postal') {
643
+ for (var loc of this.localaddress) {
644
+ if (loc.zipCode == this.selectedPostalcode) {
645
+ //console.log('testing zipcode value*****'+ this.selectedPostalcode)
646
+ item.input = this.selectedPostalcode;
647
+ break;
648
+ }
649
+ else if (count == this.localaddress.length - 1) {
650
+ //console.log('error form')
651
+ item.error = new ErrorWrapper();
652
+ hasMissingInput = true;
653
+ return;
654
+ }
655
+ count++;
656
+ }
657
+ //console.log('testin values=='+item.input)
658
+ }
659
+ if (item.Type__c == "Text" && item.Question__c === 'Provincia') {
660
+ for (var loc of this.localaddress) {
661
+ if (loc.province == this.selectedProvince) {
662
+ //console.log('******testing province value'+ this.selectedProvince)
663
+ item.input = this.selectedProvince;
664
+ break;
665
+ }
666
+ else if (count == this.localaddress.length - 1) {
667
+ //console.log('error form')
668
+ item.error = new ErrorWrapper();
669
+ hasMissingInput = true;
670
+ return;
671
+ }
672
+ count++;
673
+ }
674
+ //console.log('testin values=='+item.input)
675
+ }
676
+ if (!item.Is_Optional__c &&
677
+ // ((item.Type__c != "File" && !item.input && item.Type__c != 'Date' && item.Type__c != 'Time') ||
678
+ // (item.Type__c == "File" && this.attachments.length == 0))
679
+ (item.Type__c == "File" && this.attachments.length == 0)) {
680
+ item.error = new ErrorWrapper();
681
+ hasMissingInput = true;
682
+ }
683
+ if (item.Type__c == "Radio") {
684
+ if (!item.input) {
685
+ item.error = new ErrorWrapper();
686
+ hasMissingInput = true;
687
+ }
688
+ }
689
+ if (item.Type__c == "Dropdown") {
690
+ if (!item.input) {
691
+ item.input = "";
692
+ item.error = new ErrorWrapper();
693
+ hasMissingInput = true;
694
+ }
695
+ }
696
+ if (item.Type__c == "Email") {
697
+ if (item.input && item.input.match(mailformat)) {
698
+ this.recordId = cQuestion.Next_Question__c;
699
+ }
700
+ else {
701
+ item.error = new ErrorWrapper();
702
+ hasMissingInput = true;
703
+ }
704
+ }
705
+ if (item.Type__c == "File" && this.attachments.length > 0) {
706
+ for (var attachmentItem of this.attachments) {
707
+ this.inpValue +=
708
+ attachmentItem.attachmentId +
709
+ "@#$" +
710
+ attachmentItem.attachmentName +
711
+ ",";
712
+ if (item.input == this.inpValue) {
713
+ this.recordId = cQuestion.Next_Question__c;
714
+ //console.log('inside' + recordId);
715
+ }
716
+ }
717
+ // this.attachments = [];
718
+ } //item.input == this.inpValue;
719
+ this.inpValue += (item.input != undefined ? item.input : "") + "@@##$$";
720
+ questionTxt += item.Question__c + "@@##$$";
721
+ //console.log('inside book1' + this.inpValue)
722
+ }
723
+ if (hasMissingInput) {
724
+ return;
725
+ }
726
+ this.inpValue = this.trimLastDummy(this.inpValue);
727
+ questionTxt = questionTxt ? this.trimLastDummy(questionTxt) : questionTxt;
728
+ }
729
+ else if (this.listFlag) {
730
+ this.inpValue = '';
731
+ var hasMissingInput = false;
732
+ if (this.localSubQMap.has(this.questionItem.Id)) {
733
+ this.subAnsMap = new Map();
734
+ for (var localQues of this.localSubQMap.get(this.questionItem.Id)) {
735
+ if (!localQues.input) {
736
+ localQues.error = new ErrorWrapper();
737
+ hasMissingInput = true;
738
+ }
739
+ if (!this.subAnsMap.has(localQues.Id)) {
740
+ // console.log('inside ans map')
741
+ this.subAnsMap.set(localQues.Id, localQues.input);
742
+ }
743
+ else {
744
+ // console.log('inside ans map else')
745
+ this.subAnsMap.set(localQues.Id, this.subAnsMap.get(localQues.Id) + '$$@@##' + localQues.input);
746
+ }
747
+ }
748
+ if (hasMissingInput) {
749
+ //console.log('file two')
750
+ return;
751
+ }
752
+ this.subAnsMap.forEach((value, key) => {
753
+ // console.log('inside Map' );
754
+ // console.log(value);
755
+ this.inpValue += (value != undefined ? value : '') + '@@##$$';
756
+ });
757
+ this.inpValue = this.trimLastDummy(this.inpValue);
758
+ }
759
+ }
760
+ else if (this.dropdownFlag) {
761
+ if (this.inpValue.length <= 1) {
762
+ this.inpValue = ".";
763
+ this.questionItem.error = new ErrorWrapper();
764
+ }
765
+ }
766
+ else if (this.dtFlag && this.dateFlag && this.timeFlag) {
767
+ //this one
768
+ this.change();
769
+ if (this.inpValue) {
770
+ this.selectedHour = this.getProperTime("12", this.selectedHour);
771
+ this.selectedMinute = this.getProperTime("00", this.selectedMinute);
772
+ this.selectedMeridiem = this.getProperTime("AM", this.selectedMeridiem);
773
+ //console.log(this.inpValue.length);
774
+ if (this.questionItem.X24_Hours__c === false) {
775
+ this.questionItem.input =
776
+ (this.selectedMeridiem === "PM" && this.selectedHour != "12"
777
+ ? Number(this.selectedHour) + 12
778
+ : this.selectedHour) +
779
+ ":" +
780
+ this.selectedMinute + " PM";
781
+ if (this.selectedMeridiem === "AM" && this.selectedHour === "12") {
782
+ this.questionItem.input = "00" + ":" + this.selectedMinute + " AM";
783
+ }
784
+ if (this.qbItem.Progress_Bar__c) {
785
+ this.inpValue = this.inpValue + " " + this.questionItem.input;
786
+ }
787
+ else {
788
+ this.inpValue = this.inpValue + "T" + this.questionItem.input;
789
+ }
790
+ }
791
+ if (this.questionItem.X24_Hours__c === true) {
792
+ this.questionItem.input =
793
+ this.selectedHour + ":" + this.selectedMinute;
794
+ if (this.qbItem.Progress_Bar__c) {
795
+ this.inpValue = this.inpValue + " " + this.questionItem.input;
796
+ }
797
+ else {
798
+ this.inpValue = this.inpValue + "T" + this.questionItem.input;
799
+ }
800
+ }
801
+ if (this.qbItem.Progress_Bar__c) {
802
+ //console.log("ans => " + this.inpValue);
803
+ var date1 = this.inpValue.split(" ");
804
+ date1 = date1[0].split("/");
805
+ date1 = [date1[2], date1[1], date1[0]].join("-");
806
+ date1 = new Date(date1);
807
+ //console.log(date1)
808
+ var date2 = this.insuranceStartDate.split(" ");
809
+ date2 = new Date(date2[0]);
810
+ //console.log(date2);
811
+ if (date1 < date2) {
812
+ this.questionItem.error = new ErrorWrapper();
813
+ this.questionItem.error.errorMsg =
814
+ "No es posible dar de alta la reclamación debido a que la fecha del incidente es anterior a la fecha de contratación de la póliza";
815
+ //console.log('inside')
816
+ return;
817
+ }
818
+ }
819
+ if (this.selDate === null || !this.inpValue) {
820
+ this.questionItem.error = new ErrorWrapper();
821
+ return;
822
+ }
823
+ this.date_TimeMap();
824
+ }
825
+ }
826
+ else if (this.timeFlag && this.dtFlag && !this.dateFlag) {
827
+ this.date_TimeMap();
828
+ if (this.questionItem.X24_Hours__c === false) {
829
+ this.inpValue =
830
+ (this.selectedMeridiem === "PM" && this.selectedHour != "12"
831
+ ? Number(this.selectedHour) + 12
832
+ : this.selectedHour) +
833
+ ":" +
834
+ this.selectedMinute;
835
+ }
836
+ else {
837
+ this.inpValue = this.selectedHour + ":" + this.selectedMinute;
838
+ }
839
+ if (this.inpValue.length < 5) {
840
+ this.questionItem.error = new ErrorWrapper();
841
+ return;
842
+ }
843
+ }
844
+ else if (this.dateFlag && this.dtFlag && !this.timeFlag) {
845
+ this.change();
846
+ if (this.inpValue.length < 7 || this.selDate === null) {
847
+ this.questionItem.error = new ErrorWrapper();
848
+ return;
849
+ }
850
+ }
851
+ else if (this.fileFlag) {
852
+ //console.log('four')
853
+ this.inpValue = "";
854
+ if (this.attachments.length > 0) {
855
+ for (var attachmentItem of this.attachments) {
856
+ this.inpValue +=
857
+ attachmentItem.attachmentId +
858
+ "@#$" +
859
+ attachmentItem.attachmentName +
860
+ ",";
861
+ }
862
+ //console.log('inside filesss' + this.inpValue);
863
+ this.inpValue = this.inpValue.substr(0, this.inpValue.length - 1);
864
+ }
865
+ else {
866
+ this.questionItem.error = new ErrorWrapper();
867
+ return;
868
+ }
869
+ }
870
+ // Check for the answer before saving to the DB
871
+ if (!this.questionItem.Is_Optional__c && !this.inpValue) {
872
+ // Show error that the question must be answered
873
+ this.questionItem.error = new ErrorWrapper();
874
+ return;
875
+ }
876
+ // Save the Answer in the DB
877
+ this.answerWrap = new AnswerWrapper();
878
+ this.answerWrap.abId = this.abItem.Id;
879
+ this.answerWrap.quesId = cQuestion.Id;
880
+ this.answerWrap.quesValue = quesValue;
881
+ this.answerWrap.qTyp = typ;
882
+ this.answerWrap.ansValue = this.inpValue;
883
+ this.answerWrap.groupText = cQuestion.Group__c;
884
+ this.answerWrap.ansValue = this.inpValue;
885
+ console.log('this.answerWrap.qTyp', this.answerWrap.qTyp);
886
+ if (this.answerWrap.qTyp == "Alphanumeric") {
887
+ this.answerWrap.ansValue = 'ES' + this.inpValue;
888
+ // console.log('Bank condition');
889
+ // console.log(this.answerWrap.ansValue);
890
+ }
891
+ /*if (cQuestion.Type__c == 'Book'){
892
+ for (var qb of cQuestion.Questions__r.records){
893
+ //console.log(qb.Question__c+'****'+"@@##$$")
894
+ }
895
+ }*/
896
+ //this.answerWrap.squesValue = cQuestion.Question__c;
897
+ this.answerWrap.squesValue = questionTxt ? questionTxt : cQuestion.Question__c;
898
+ this.saveAnswer();
899
+ }
900
+ next() {
901
+ var cQuestion = new Question();
902
+ cQuestion = this.questionItem;
903
+ var typ = cQuestion.Type__c;
904
+ // If no error then move to next steps
905
+ if (this.questionItem.error) {
906
+ return;
907
+ }
908
+ this.questionStack.push(cQuestion.Id);
909
+ // this.questionName.push(cQuestion.Name);
910
+ // CONDITIONAL vs OPTIONONLY & UNCONDITIONAL
911
+ if (cQuestion.RecordType.Name == "CONDITIONAL") {
912
+ for (var cOpt of cQuestion.Question_Options__r.records) {
913
+ // Radio / Data
914
+ //console.log('Option => ' + cOpt.Value__c + ' matching with ' + ansVal);
915
+ if (cOpt.Value__c == this.inpValue) {
916
+ //console.log('Match Found using ' + cOpt.Next_Question__c);
917
+ this.recordId = cOpt.Next_Question__c;
918
+ //console.log('conditional record id'+ this.recordId);
919
+ }
920
+ }
921
+ // Could be of type Data and existing value
922
+ if (this.recordId && typ == "Data") {
923
+ this.recordId = cQuestion.Next_Question__c;
924
+ }
925
+ }
926
+ else if (cQuestion.RecordType.Name == "OPTIONONLY") {
927
+ // OPTIONONLY logic
928
+ this.recordId = cQuestion.Next_Question__c;
929
+ }
930
+ else if (cQuestion.RecordType.Name == "UNCONDITIONAL") {
931
+ //Unconditional logic
932
+ //console.log("inside unconditional");
933
+ //inside Book Type
934
+ if (cQuestion.Type__c == "Book" && cQuestion.Question_No__c != '6') {
935
+ //console.log("inside book");
936
+ for (let opt of cQuestion.Questions__r.records) {
937
+ //console.log(opt.Type__c);
938
+ if (opt.Type__c == "Dropdown" || opt.Type__c == "Radio") {
939
+ for (var opt1 of opt.Question_Options__r.records) {
940
+ if (this.valueName == opt1.Value__c) {
941
+ this.recordId = opt1.Next_Question__c || cQuestion.Next_Question__c;
942
+ }
943
+ else {
944
+ //console.log('Else'+this.recordId)
945
+ this.recordId = cQuestion.Next_Question__c;
946
+ }
947
+ }
948
+ }
949
+ else {
950
+ this.recordId = cQuestion.Next_Question__c;
951
+ }
952
+ }
953
+ }
954
+ else if (cQuestion.Type__c == "Book" && cQuestion.Question_No__c == '6') {
955
+ for (let opt of cQuestion.Questions__r.records) {
956
+ if (opt.Type__c == "Dropdown" || opt.Type__c == "Radio") {
957
+ for (var opt1 of opt.Question_Options__r.records) {
958
+ if (this.valueName == opt1.Value__c) {
959
+ this.recordId = opt1.Next_Question__c;
960
+ }
961
+ }
962
+ }
963
+ }
964
+ }
965
+ else {
966
+ this.recordId = cQuestion.Next_Question__c;
967
+ }
968
+ }
969
+ // CATEGORIZATION
970
+ //this.stepperCateg();
971
+ // Calling the progres bar update function
972
+ this.answerCount++;
973
+ this.updateProgress();
974
+ // CATEGORIZATION
975
+ //this.stepperCateg();
976
+ if (this.recordId) {
977
+ //console.log('Before Calling readQuestion() using ' + recordId);
978
+ this.readQuestion(this.recordId);
979
+ this.pop = true;
980
+ }
981
+ else {
982
+ this.pop = false;
983
+ //console.log('Summary Page Logic');
984
+ // Reset the Variables
985
+ this.inpValue = "";
986
+ this.answerWrap = new AnswerWrapper();
987
+ this.optionValues = [];
988
+ this.subQuestions = [];
989
+ this.resetFlag(typ);
990
+ this.questionItem = null;
991
+ // Show Summary
992
+ for (var q of this.questionStack) {
993
+ //console.log('Handling Question => ' + q);
994
+ var ansWrap = this.answerMap.get(q);
995
+ if (ansWrap) {
996
+ //console.log('Handling Answer for ' + ansWrap.quesId + ' of type ' + ansWrap.qTyp);
997
+ if (ansWrap.qTyp == 'File' || ansWrap.qTyp == 'Book' || ansWrap.qTyp == 'List' || ansWrap.qTyp == 'Checkbox') {
998
+ var newStr = '';
999
+ for (var ansStr of ansWrap.ansValue.split('@@##$$')) {
1000
+ for (var ansStr1 of ansStr.split('$$@@##')) {
1001
+ // if(ansStr1.includes('answerString')){ //remove the answer string
1002
+ // const withoutAnswerString = ansStr1.replace("answerString: ", "");
1003
+ // ansStr1 = withoutAnswerString;
1004
+ // }
1005
+ if (ansStr1.length > 0) {
1006
+ if (newStr.length == 0) {
1007
+ newStr = ansStr1;
1008
+ }
1009
+ else {
1010
+ newStr += '; ' + ansStr1; //comma(,) changed as semi colon(;) because of address contains comma(,)
1011
+ if (this.attachmentsMap.has(ansWrap.quesId)) {
1012
+ for (var att of this.attachmentsMap.get(ansWrap.quesId)) {
1013
+ newStr = newStr.replace(att.attachmentId, '');
1014
+ }
1015
+ }
1016
+ newStr = (newStr.replace(',,', ', ')).replace(', ,', ', ');
1017
+ newStr = newStr.startsWith(',') ? newStr.substring(1, newStr.length) : (newStr.endsWith(',') ? newStr.substring(0, newStr.length - 1) : newStr);
1018
+ }
1019
+ }
1020
+ }
1021
+ }
1022
+ ansWrap.ansValue = newStr;
1023
+ }
1024
+ this.summary.push(ansWrap);
1025
+ this.backicon = true;
1026
+ }
1027
+ }
1028
+ }
1029
+ }
1030
+ getText(value) {
1031
+ var doc = new DOMParser().parseFromString(value, "text/html");
1032
+ //console.log( doc.documentElement.textContent);
1033
+ return this.sanitizer.bypassSecurityTrustHtml(doc.documentElement.textContent);
1034
+ }
1035
+ handleBackClick() {
1036
+ this.back = true;
1037
+ if (this.pop === true) {
1038
+ this.questionName.pop();
1039
+ }
1040
+ this.handleEvent.emit(this.qbItem.Back_Tracking_ID__c);
1041
+ var cQuestion = new Question();
1042
+ cQuestion = this.questionItem;
1043
+ if (cQuestion.Question_No__c == '1') {
1044
+ this.handleEvent.emit(this.qbItem.Back__c);
1045
+ }
1046
+ this.answerCount--;
1047
+ this.updateProgress();
1048
+ // CATEGORIZATION
1049
+ //this.stepperCateg();
1050
+ if (this.summary) {
1051
+ //console.log('summary true');
1052
+ this.summary = [];
1053
+ }
1054
+ if (this.summaryData) {
1055
+ this.summaryData = [];
1056
+ }
1057
+ // Read the previous question from DB
1058
+ this.readQuestion(this.questionStack.pop());
1059
+ //console.log(this.questionStack);
1060
+ }
1061
+ handleBackClickNew() {
1062
+ this.handleEvent.emit(this.qbItem.Edit__c);
1063
+ }
1064
+ //updating status once Q&A completed.
1065
+ updateAnswerBook = (uuid) => {
1066
+ if (this.serv == "api") {
1067
+ this.dataService.getAPIData(this.tkn, ["AnswerBook", "Update", uuid], this.successupdateAB, this.failureupdateAB);
1068
+ }
1069
+ else {
1070
+ this.sfService.remoteAction("NxtController.process", ["AnswerBook", "Update", uuid], this.successupdateAB, this.failureupdateAB);
1071
+ }
1072
+ };
1073
+ successupdateAB = (response) => {
1074
+ console.log(response);
1075
+ // //console.log('status success')
1076
+ this.abItem.Status__c = "Completed";
1077
+ };
1078
+ failureupdateAB = (response) => {
1079
+ //console.log('status failed')
1080
+ };
1081
+ readQuestionBook = (uuid) => {
1082
+ if (this.serv == "api") {
1083
+ this.dataService.getAPIData(this.tkn, ["QuestionBook", "read", uuid], this.successReadBook, this.failureReadBook);
1084
+ }
1085
+ else {
1086
+ this.sfService.remoteAction("NxtController.process", ["QuestionBook", "read", uuid], this.successReadBook, this.failureReadBook);
1087
+ }
1088
+ };
1089
+ successReadBook = (response) => {
1090
+ console.log('Inside the successReadBook');
1091
+ console.log(response);
1092
+ if (response != null || response != undefined) {
1093
+ this.qbItem = response.questionbook;
1094
+ this.abItem = response.answerbook;
1095
+ }
1096
+ // console.log('readingQuestion using ' + this.qbItem);
1097
+ if (this.abItem?.Status__c == "Pending") {
1098
+ if (this.abItem.Answers__r == null ||
1099
+ this.abItem.Answers__r.records.length == 0) {
1100
+ this.readQuestion(this.qbItem.First_Question__c);
1101
+ }
1102
+ else {
1103
+ // Populate the existing answers
1104
+ var lastQuestionId = "";
1105
+ for (var ansObject of this.abItem.Answers__r.records) {
1106
+ lastQuestionId = ansObject.Question_Ref__c;
1107
+ this.questionStack.push(ansObject.Question_Ref__c);
1108
+ this.answerMap.set(ansObject.Question_Ref__c, {
1109
+ quesValue: ansObject.Question_Rich_Text__c,
1110
+ ansValue: ansObject.Answer_Long__c,
1111
+ quesId: ansObject.Question_Ref__c,
1112
+ qTyp: ansObject.Question_Type__c,
1113
+ groupText: ansObject.Question_Group_Text__c,
1114
+ });
1115
+ //console.log(this.questionStack)
1116
+ if (ansObject.Question_Type__c == "Book") {
1117
+ var av1 = ansObject.Answer_Long__c.split("@@##$$");
1118
+ // //console.log("book log");
1119
+ // //console.log("bookid" + av1[0]);
1120
+ this.attachmentsMap.set(ansObject.Question_Ref__c, [
1121
+ { attachmentName: av1[1], attachmentId: av1[0] },
1122
+ ]);
1123
+ // //console.log(this.attachmentsMap);
1124
+ }
1125
+ else if (ansObject.Question_Type__c == "File") {
1126
+ // //console.log("inside if");
1127
+ var attList;
1128
+ var att;
1129
+ for (var attVar of ansObject.Answer_Long__c.split(",")) {
1130
+ var attIdName = attVar.split("@@##$$");
1131
+ att.attachmentName = attIdName[1];
1132
+ att.attachmentId = attIdName[0];
1133
+ attList.push(att);
1134
+ }
1135
+ this.attachmentsMap.set(ansObject.Question_Ref__c, attList);
1136
+ // //console.log(this.attachmentsMap);
1137
+ }
1138
+ }
1139
+ this.questionStack.pop();
1140
+ //console.log(this.answerMap);
1141
+ // Read the last answered question
1142
+ this.readQuestion(lastQuestionId);
1143
+ }
1144
+ }
1145
+ else if (this.abItem?.Status__c == "Completed") {
1146
+ this.handleEvent.emit("Summaryupdated");
1147
+ // Temporary Fix for duplicate answers on the summary.
1148
+ this.summary = [];
1149
+ this.percent = 100;
1150
+ this.progressStyle = "100%";
1151
+ for (var answer of this.abItem.Answers__r.records) {
1152
+ //console.log(answer.Question_Group_Text__c);
1153
+ //console.log('repeat');
1154
+ //console.log(answer.Question_Rich_Text__c);
1155
+ var answers = {};
1156
+ if (answer.Question_Type__c == "File") {
1157
+ var files = "";
1158
+ var fIndex = 0;
1159
+ var fileList = answer.Answer_Long__c.split(",");
1160
+ for (var fileIdName of fileList) {
1161
+ var fileName = fileIdName.split("@#$");
1162
+ if (fIndex == 0) {
1163
+ files = fileName[1];
1164
+ }
1165
+ else {
1166
+ files = files + " ," + fileName[1];
1167
+ }
1168
+ fIndex++;
1169
+ }
1170
+ answers = {
1171
+ groupText: answer.Question_Group_Text__c,
1172
+ quesValue: answer.Question_Rich_Text__c,
1173
+ ansValue: files,
1174
+ };
1175
+ this.summary.push(answers);
1176
+ }
1177
+ else if (answer.Question_Type__c == "Book") {
1178
+ /* var quesNo=0;
1179
+ if(answer.Answer_Long__c.includes("@@##$$")){
1180
+ //console.log('line 1223');
1181
+ for (var bqAnswerValue of answer.Answer_Long__c.split("@@##$$")) {
1182
+ var quesValue=answer.Question_Text__c.split("@@##$$");
1183
+ answers = {};
1184
+ answers = {
1185
+ // groupText:answer.Question_Text__c,
1186
+ quesValue: "&lt;p&gt;"+ quesValue[quesNo]+"&lt;p&gt;",
1187
+ ansValue: bqAnswerValue,
1188
+ };
1189
+ quesNo++;
1190
+ this.summary.push(answers);
1191
+ }
1192
+ }*/
1193
+ if (answer.Answer_Long__c.includes("@@##$$")) {
1194
+ var answervalues = answer.Answer_Long__c.split("@@##$$");
1195
+ //console.log('value')
1196
+ answers = {
1197
+ //groupText:answer.Question_Group_Text__c,
1198
+ quesValue: answer.Question_Rich_Text__c,
1199
+ ansValue: answervalues,
1200
+ };
1201
+ //console.log(answers)
1202
+ this.summary.push(answers);
1203
+ }
1204
+ else {
1205
+ answers = {
1206
+ //groupText:answer.Question_Group_Text__c,
1207
+ quesValue: answer.Question_Rich_Text__c,
1208
+ ansValue: answer.Answer_Long__c,
1209
+ };
1210
+ this.summary.push(answers);
1211
+ }
1212
+ }
1213
+ else {
1214
+ // var ans1 = answer.Answer_Long__c.split("@@##$$");
1215
+ answers = {
1216
+ //groupText:answer.Question_Group_Text__c,
1217
+ quesValue: answer.Question_Rich_Text__c,
1218
+ ansValue: answer.Answer_Long__c,
1219
+ };
1220
+ this.summary.push(answers);
1221
+ }
1222
+ }
1223
+ }
1224
+ };
1225
+ failureReadBook = (response) => {
1226
+ console.log('Inside the failureReadBook');
1227
+ console.log(response);
1228
+ };
1229
+ readAnswerbook = (uuid) => {
1230
+ if (this.serv = "api") {
1231
+ this.dataService.getAPIData(this.tkn, ["AnswerBook", "read", uuid], this.successAnswerBookRead, this.failureAnswerBookRead);
1232
+ }
1233
+ else {
1234
+ this.sfService.remoteAction("NxtController.process", ["AnswerBook", "read", uuid], this.successAnswerBookRead, this.failureAnswerBookRead);
1235
+ }
1236
+ };
1237
+ successAnswerBookRead = (response) => {
1238
+ if (this.abItem?.Status__c == "Completed") {
1239
+ for (var answer of this.abItem.Answers__r.records) {
1240
+ var av = answer.Answer_Long__c.split("@@##$$");
1241
+ var answers = { quesValue: answer.Question_Rich_Text__c, ansValue: av, groupText: answer.Question_Group_Text__c };
1242
+ //console.log(answers)
1243
+ this.summary.push(answers);
1244
+ }
1245
+ this.handleEvent.emit("Summaryupdated");
1246
+ }
1247
+ };
1248
+ failureAnswerBookRead = (response) => {
1249
+ //console.log('inside failureread');
1250
+ //console.log(response);
1251
+ };
1252
+ readQuestion = (uuid) => {
1253
+ if (this.serv == "api") {
1254
+ this.dataService.getAPIData(this.tkn, ["Question", "read", uuid], this.successRead, this.failureRead);
1255
+ }
1256
+ else {
1257
+ this.sfService.remoteAction("NxtController.process", ["Question", "read", uuid], this.successRead, this.failureRead);
1258
+ }
1259
+ };
1260
+ successRead = (response) => {
1261
+ // console.log('Inside the successRead new');
1262
+ // console.log(response);
1263
+ // console.log(this.questionItem);
1264
+ // Reset the Variables
1265
+ if (this.questionItem) {
1266
+ this.inpValue = "";
1267
+ this.answerWrap = new AnswerWrapper();
1268
+ this.optionValues = [];
1269
+ this.subQuestions = [];
1270
+ this.resetFlag(this.questionItem.Type__c);
1271
+ }
1272
+ this.questionItem = response.question;
1273
+ // console.log(this.questionItem);
1274
+ if (this.questionItem.Type__c === 'Alphanumeric') {
1275
+ this.splCCBackClick = true;
1276
+ }
1277
+ this.currentQuestionId = this.questionItem.Id;
1278
+ this.handlePage.emit(this.questionItem.Tracking_ID__c);
1279
+ // Handle the subQuestion options
1280
+ if (response.sqOptions) {
1281
+ //var newRecords = [];
1282
+ for (var q of this.questionItem.Questions__r.records) {
1283
+ //console.log(q.Name);
1284
+ var sq = response.sqOptions[q.Id];
1285
+ if (sq) {
1286
+ //console.log('found options for subquestion ' + q.Name);
1287
+ if (!q.Question_Options__r) {
1288
+ q.Question_Options__r = sq.Question_Options__r;
1289
+ }
1290
+ }
1291
+ }
1292
+ }
1293
+ this.processQuestion();
1294
+ this.innerhtml = this.sanitizer.bypassSecurityTrustHtml(this.questionItem.Additional_Rich__c);
1295
+ this.trackId();
1296
+ };
1297
+ trackId() {
1298
+ var qtrackId = this.questionItem.Tracking_ID__c;
1299
+ //console.log('trackId-question'+qtrackId);
1300
+ }
1301
+ failureRead = (response) => {
1302
+ //console.log('inside failureread');
1303
+ //console.log(response);
1304
+ };
1305
+ saveAnswer = () => {
1306
+ // Set the Answer Number based on the Question Stack Length
1307
+ if (this.inpValue != ".") {
1308
+ this.currentQuestionId = null;
1309
+ }
1310
+ this.answerWrap.ansNumber = this.questionStack.length + 1;
1311
+ if (this.serv == "api") {
1312
+ this.dataService.getAPIData(this.tkn, ["Answer", "create", JSON.stringify(this.answerWrap)], this.successSave, this.failureSave);
1313
+ }
1314
+ else {
1315
+ this.sfService.remoteAction("NxtController.process", ["Answer", "create", JSON.stringify(this.answerWrap)], this.successSave, this.failureSave);
1316
+ }
1317
+ };
1318
+ htmlDecode(input) {
1319
+ var doc = new DOMParser().parseFromString(input, "text/html");
1320
+ return doc.documentElement.textContent;
1321
+ }
1322
+ successSave = (response) => {
1323
+ if (response.status == "success") {
1324
+ //this.abItem = response.answerbook;
1325
+ this.answerMap.set(response.answer.quesId, response.answer);
1326
+ }
1327
+ else {
1328
+ this.questionItem.error = new ErrorWrapper();
1329
+ this.questionItem.error.errorMsg = response.error.errorMsg;
1330
+ }
1331
+ if (!this.backButtonFlag) {
1332
+ this.next();
1333
+ }
1334
+ };
1335
+ failureSave = (response) => {
1336
+ //console.log('inside failureSave');
1337
+ //console.log(response);
1338
+ };
1339
+ processQuestion = () => {
1340
+ // console.log('Inside the processQuestion');
1341
+ // console.log('splCCBackClick = '+this.splCCBackClick);
1342
+ // console.log(this.questionStack);
1343
+ //console.log(this.questionItem);
1344
+ this.pop = true;
1345
+ // if(!this.back){
1346
+ // this.questionName.push(this.questionItem.Name)
1347
+ // }
1348
+ if (this.qbItem.Progress_Bar__c === true) {
1349
+ if (!this.back) {
1350
+ this.questionName.push(this.questionItem.Name);
1351
+ }
1352
+ this.back = false;
1353
+ if (this.questionName[0] === this.questionName[1]) {
1354
+ this.questionName.pop();
1355
+ }
1356
+ this.currentName = this.questionItem.Name;
1357
+ this.pathquestion = this.questionName.indexOf(this.currentName);
1358
+ this.possibilities = this.qbItem.Possibilities__c;
1359
+ }
1360
+ this.myDatePickerOptions;
1361
+ this.day();
1362
+ //console.log('processing question ' + this.questionItem.Name + ' existing answers are ' + this.answerMap.size); // => ' + JSON.stringify(this.questionItem));
1363
+ // Set the Flags to show right fields
1364
+ this.setFlag(this.questionItem.Type__c);
1365
+ //console.log('After the setFlag method dtFlag = '+this.dtFlag);
1366
+ // Check the existing answer from answerMap
1367
+ if (this.answerMap.has(this.questionItem.Id)) {
1368
+ // //console.log("existing answer found for this.questionItem.Name");
1369
+ var eAnswer = this.answerMap.get(this.questionItem.Id);
1370
+ // Get the existing answer from the Map
1371
+ this.inpValue = eAnswer.ansValue;
1372
+ //console.log('inpValue has been set to ' + this.inpValue);
1373
+ if (this.attachmentsMap.has(this.questionItem.Id)) {
1374
+ this.attachments = this.attachmentsMap.get(this.questionItem.Id);
1375
+ }
1376
+ }
1377
+ else {
1378
+ //console.log('inside removing attachment array');
1379
+ this.attachments = [];
1380
+ }
1381
+ // console.log(this.inpValue);
1382
+ if (this.splCCBackClick && this.inpValue && this.inpValue.includes('ES')) {
1383
+ // console.log('Inside the if cond');
1384
+ this.splCCBackClick = false;
1385
+ this.inpValue = this.inpValue.replace('ES', '');
1386
+ }
1387
+ if (this.checkboxFlag) {
1388
+ // Set the Options for Checkbox
1389
+ this.setOptions(this.questionItem.Question_Options__r.records);
1390
+ }
1391
+ else if (this.bookFlag) {
1392
+ //console.log('Inise the expected bookFlag cond');
1393
+ //console.log('dtFlag = '+this.dtFlag);
1394
+ this.setSubQuestions(this.questionItem.Questions__r.records);
1395
+ }
1396
+ else if (this.listFlag) {
1397
+ // Set the LocalSubQuestions
1398
+ // console.log('inside list flag');
1399
+ // console.log(this.questionItem.Questions__r.records);
1400
+ // console.log(this.abItem.Questions__r.records);
1401
+ if (!this.localSubQMap.has(this.questionItem.Id)) {
1402
+ this.setSubQuestions(this.questionItem.Questions__r.records);
1403
+ }
1404
+ }
1405
+ else if (this.dtFlag) {
1406
+ //console.log('Inise the unexpected dtFlag cond');
1407
+ this.selectedHour = "";
1408
+ this.selectedMinute = "";
1409
+ this.selDate = "";
1410
+ // 2021-5-16T00:00
1411
+ if (this.dateMap.has(this.questionItem.Id)) {
1412
+ this.selDate = this.dateMap.get(this.questionItem.Id);
1413
+ }
1414
+ if (this.selectedhourMap.has(this.questionItem.Id)) {
1415
+ this.selectedHour = this.selectedhourMap.get(this.questionItem.Id);
1416
+ }
1417
+ if (this.selectedminuteMap.has(this.questionItem.Id)) {
1418
+ this.selectedMinute = this.selectedminuteMap.get(this.questionItem.Id);
1419
+ }
1420
+ if (this.questionItem.X24_Hours__c === true) {
1421
+ this.hours.push("13", "14", "15", "16", "17", "18", "19", "20", "21", "22", "23", "00");
1422
+ }
1423
+ if (this.questionItem.X24_Hours__c === false) {
1424
+ this.hours = this.hours.slice(0, 12);
1425
+ }
1426
+ if (this.dtFlag && this.inpValue) {
1427
+ var dtVal = this.inpValue.split("T");
1428
+ var dtval0 = this.inpValue.split(" ");
1429
+ this.inpValue = dtVal[0];
1430
+ this.inpValue = dtval0[0];
1431
+ this.questionItem.input = dtVal[1];
1432
+ this.questionItem.input = dtval0[1];
1433
+ }
1434
+ if (this.questionItem.Is_Date_Backward__c ||
1435
+ this.questionItem.Is_Date_Forward__c) {
1436
+ if (this.questionItem.Is_Date_Backward__c === true) {
1437
+ this.myDatePickerOptions.disableSince = {
1438
+ year: this.today.getFullYear(),
1439
+ month: this.today.getMonth() + 1,
1440
+ day: this.today.getDate() + 1,
1441
+ };
1442
+ }
1443
+ if (this.questionItem.Is_Date_Forward__c === true) {
1444
+ this.myDatePickerOptions.disableUntil = {
1445
+ year: this.today.getFullYear(),
1446
+ month: this.today.getMonth() + 1,
1447
+ day: this.today.getDate(),
1448
+ };
1449
+ }
1450
+ }
1451
+ }
1452
+ else if (this.fileFlag) {
1453
+ this.fileUI();
1454
+ // logic
1455
+ this.allowedFileExtension =
1456
+ this.questionItem.Allowed_File_Extensions__c.split(";");
1457
+ //console.log(this.allowedFileExtension);
1458
+ }
1459
+ if (this.qbItem.Progress_Bar__c === true) {
1460
+ this.updateProgress();
1461
+ }
1462
+ };
1463
+ setFlag(typ) {
1464
+ //console.log('inside setFlag for ' + typ);
1465
+ if (typ) {
1466
+ // Set the Flags
1467
+ if (typ == "Text") {
1468
+ this.textFlag = true;
1469
+ //this.numberFlag = true;
1470
+ }
1471
+ else if (typ == "Number") {
1472
+ this.numberFlag = true;
1473
+ }
1474
+ else if (typ == "AlphaNumeric") {
1475
+ this.alphanumericFlag = true;
1476
+ /*if(this.inpValue.length === 0){
1477
+ this.inpValue='ES'
1478
+ }*/
1479
+ }
1480
+ else if (typ == "Email") {
1481
+ this.emailFlag = true;
1482
+ }
1483
+ else if (typ == "File") {
1484
+ this.fileFlag = true;
1485
+ }
1486
+ else if (typ == "DateTime") {
1487
+ this.dtFlag = true;
1488
+ this.timeFlag = true;
1489
+ this.dateFlag = true;
1490
+ }
1491
+ else if (typ == "TextArea") {
1492
+ this.taFlag = true;
1493
+ }
1494
+ else if (typ == "Radio") {
1495
+ this.radioFlag = true;
1496
+ }
1497
+ else if (typ == "Dropdown") {
1498
+ this.dropdownFlag = true;
1499
+ }
1500
+ else if (typ == "Checkbox") {
1501
+ this.checkboxFlag = true;
1502
+ }
1503
+ else if (typ == "Book") {
1504
+ this.bookFlag = true;
1505
+ }
1506
+ else if (typ == 'List') {
1507
+ this.listFlag = true;
1508
+ }
1509
+ else if (typ == "Time") {
1510
+ //console.log('Inside the Time cond');
1511
+ this.dtFlag = true;
1512
+ this.timeFlag = true;
1513
+ //console.log(this.dtFlag);
1514
+ }
1515
+ else if (typ == "Date") {
1516
+ //console.log('Inside the Date cond');
1517
+ this.dtFlag = true;
1518
+ this.dateFlag = true;
1519
+ //console.log(this.dtFlag);
1520
+ }
1521
+ }
1522
+ }
1523
+ resetFlag(typ) {
1524
+ if (typ) {
1525
+ // Set the Flags
1526
+ if (typ == "Text") {
1527
+ this.textFlag = false;
1528
+ //this.numberFlag = false;
1529
+ }
1530
+ else if (typ == "Number") {
1531
+ this.numberFlag = false;
1532
+ }
1533
+ else if (typ == "Alphanumeric") {
1534
+ this.alphanumericFlag = false;
1535
+ }
1536
+ else if (typ == "Email") {
1537
+ this.emailFlag = false;
1538
+ }
1539
+ else if (typ == "File") {
1540
+ this.fileFlag = false;
1541
+ }
1542
+ else if (typ == "DateTime") {
1543
+ this.dtFlag = false;
1544
+ this.dateFlag = false;
1545
+ this.timeFlag = false;
1546
+ }
1547
+ else if (typ == "TextArea") {
1548
+ this.taFlag = false;
1549
+ }
1550
+ else if (typ == "Radio") {
1551
+ this.radioFlag = false;
1552
+ }
1553
+ else if (typ == "Dropdown") {
1554
+ this.dropdownFlag = false;
1555
+ }
1556
+ else if (typ == "Checkbox") {
1557
+ this.checkboxFlag = false;
1558
+ }
1559
+ else if (typ == "Book") {
1560
+ this.bookFlag = false;
1561
+ }
1562
+ else if (typ == 'List') {
1563
+ this.listFlag = false;
1564
+ }
1565
+ else if (typ == "Time") {
1566
+ this.dtFlag = false;
1567
+ this.timeFlag = false;
1568
+ }
1569
+ else if (typ == "Date") {
1570
+ this.dtFlag = false;
1571
+ this.dateFlag = false;
1572
+ }
1573
+ }
1574
+ }
1575
+ setOptions(records) {
1576
+ for (var opt of records) {
1577
+ var ov = new OptionValue();
1578
+ ov.Id = opt.Id;
1579
+ ov.Name = opt.Name;
1580
+ ov.Value__c = opt.Value__c;
1581
+ ov.Next_Question__c = opt.Next_Question__c;
1582
+ ov.checked = false;
1583
+ if (this.inpValue &&
1584
+ this.inpValue.split("@@##$$").includes(opt.Value__c)) {
1585
+ ov.checked = true;
1586
+ }
1587
+ this.optionValues.push(ov);
1588
+ }
1589
+ }
1590
+ Dropdown(event, ques) {
1591
+ ques.input = event; // here when using the ng-select got event as value
1592
+ }
1593
+ setSubQuestions(records) {
1594
+ // console.log('inside setSubQuestions');
1595
+ // console.log(records);
1596
+ var qaMap = new Map();
1597
+ // console.log(this.inpValue);
1598
+ if (this.inpValue) {
1599
+ var aIndex = 0;
1600
+ // search changed as semi colon because of address contains comma
1601
+ if ((this.inpValue.search("; ") == -1)) {
1602
+ // const withoutAnswerString = this.inpValue.replace("answerString: ", ""); //remove the answer string
1603
+ // this.inpValue = withoutAnswerString;
1604
+ this.inpValue = this.inpValue + '@@##$$';
1605
+ for (var ansStr of this.inpValue.split("@@##$$")) {
1606
+ aIndex++;
1607
+ qaMap.set(aIndex, ansStr);
1608
+ //console.log('Setting the qaMap for ' + aIndex + ' with ' + ansStr);
1609
+ }
1610
+ }
1611
+ else {
1612
+ for (var ansStr of this.inpValue.split("; ")) {
1613
+ aIndex++;
1614
+ qaMap.set(aIndex, ansStr);
1615
+ //console.log('Setting the qaMap ' + aIndex + ' with ' + ansStr);
1616
+ }
1617
+ }
1618
+ }
1619
+ // console.log('after setting values from inpvalue qa map are');
1620
+ // console.log(qaMap);
1621
+ for (var ques of records) {
1622
+ if (ques.Type__c == "File") {
1623
+ this.valueName1 = ques.Allowed_File_Extensions__c;
1624
+ //console.log(this.valueName1);
1625
+ }
1626
+ var ans = '';
1627
+ if (qaMap.has(ques.Question_No__c)) {
1628
+ ques.input = qaMap.get(ques.Question_No__c);
1629
+ // console.log('after fetching map values');
1630
+ // console.log(ques.input);
1631
+ if (ques.input.indexOf('$$@@##') > 0) {
1632
+ // console.log('answer supposed to be trimmed');
1633
+ // console.log(ques.input);
1634
+ ans = ques.input.substring(ques.input.indexOf('$$@@##') + 6, ques.input.length);
1635
+ // console.log(ans);
1636
+ ques.input = ques.input.substring(0, ques.input.indexOf('$$@@##'));
1637
+ // console.log(ques.input);
1638
+ }
1639
+ }
1640
+ if ((ques.Type__c === "Date") && (ques.Is_Date_Backward__c || ques.Is_Date_Forward__c)) {
1641
+ //console.log('Inside the date backward/forward cond');
1642
+ if (ques.Is_Date_Backward__c === true) {
1643
+ //console.log('Inside the Is_Date_Backward__c');
1644
+ this.myDatePickerOptions.disableSince = {
1645
+ year: this.today.getFullYear(),
1646
+ month: this.today.getMonth() + 1,
1647
+ day: this.today.getDate() + 1,
1648
+ };
1649
+ }
1650
+ if (ques.Is_Date_Forward__c === true) {
1651
+ //console.log('Inside the Is_Date_Forward__c');
1652
+ this.myDatePickerOptions.disableUntil = {
1653
+ year: this.today.getFullYear(),
1654
+ month: this.today.getMonth() + 1,
1655
+ day: this.today.getDate(),
1656
+ };
1657
+ }
1658
+ //console.log(this.myDatePickerOptions);
1659
+ }
1660
+ this.subQuestions.push(ques);
1661
+ for (var i = 0; i < this.subQuestions.length; i++) {
1662
+ // to show/hide the dependent dropdown only field using the dropDownOnly boolean
1663
+ if (this.subQuestions[i].Size__c == 4) {
1664
+ this.subQuestions[i].dropDownOnly = true;
1665
+ }
1666
+ else {
1667
+ this.subQuestions[i].dropDownOnly = false;
1668
+ }
1669
+ }
1670
+ if (ans != '') {
1671
+ for (var an of (ans.split('$$@@##'))) {
1672
+ var sQ = new Question();
1673
+ Object.assign(sQ, ques);
1674
+ sQ.input = an;
1675
+ this.subQuestions.push(sQ);
1676
+ }
1677
+ }
1678
+ }
1679
+ if (this.valueName1 != null && this.valueName1.length > 0) {
1680
+ this.bookFlagAccept = this.valueName1.split(";");
1681
+ //console.log(this.subQuestions);
1682
+ }
1683
+ this.structLocalSubQuestion(null);
1684
+ }
1685
+ optionChange(selValue) {
1686
+ let radioTrackingId = "";
1687
+ for (var opt of this.questionItem.Question_Options__r.records) {
1688
+ //console.log('optionChange TrackingId'+opt.Tracking_ID__c);
1689
+ if (opt.Value__c == selValue) {
1690
+ //console.log('inside if'+opt.Tracking_ID__c)
1691
+ radioTrackingId = opt.Tracking_ID__c;
1692
+ }
1693
+ }
1694
+ this.handleEvent.emit(radioTrackingId);
1695
+ this.clearError();
1696
+ // //console.log('inside optionChange using ' + selValue);
1697
+ this.inpValue = selValue;
1698
+ }
1699
+ clearError() {
1700
+ if (this.questionItem.error) {
1701
+ this.questionItem.error = null;
1702
+ }
1703
+ }
1704
+ clearLocalSubQuesError(quesId) {
1705
+ quesId.error = null;
1706
+ }
1707
+ inputValidate(e) {
1708
+ var keyCode = e.keyCode || e.which;
1709
+ // Only ASCII character in that range allowed
1710
+ var ASCIICode = (e.which) ? e.which : e.keyCode;
1711
+ if (ASCIICode > 31 && (ASCIICode < 48 || ASCIICode > 57)) {
1712
+ return false;
1713
+ }
1714
+ else {
1715
+ return true;
1716
+ }
1717
+ }
1718
+ CCOnChange(inpValue) {
1719
+ if (inpValue.length == 2) {
1720
+ this.inpValue += " ";
1721
+ }
1722
+ else if (inpValue.length == 7) {
1723
+ this.inpValue += " ";
1724
+ }
1725
+ else if (inpValue.length == 12) {
1726
+ this.inpValue += " ";
1727
+ }
1728
+ else if (inpValue.length == 17) {
1729
+ this.inpValue += " ";
1730
+ }
1731
+ else if (inpValue.length == 22) {
1732
+ this.inpValue += " ";
1733
+ }
1734
+ }
1735
+ isNotValidAccNumber(s) {
1736
+ s = s.replace(/\s+/g, "");
1737
+ s = 'ES' + s;
1738
+ var isNotValidStr = false;
1739
+ if (s.length == 24) {
1740
+ for (var i = 0; i < s.length; i++) {
1741
+ if (i <= 1 && /[a-zA-Z]/.test(s.charAt(i))) {
1742
+ //console.log("Valid char: " + s.charAt(i));
1743
+ }
1744
+ else if (i > 1 && /[0-9]/.test(s.charAt(i))) {
1745
+ //console.log("Valid numeric: " + s.charAt(i));
1746
+ }
1747
+ else {
1748
+ isNotValidStr = true;
1749
+ //console.log("Not a valid char");
1750
+ }
1751
+ }
1752
+ }
1753
+ else {
1754
+ isNotValidStr = true;
1755
+ //console.log("Not a valid acc number");
1756
+ }
1757
+ return isNotValidStr;
1758
+ }
1759
+ clearSQError(quesId) {
1760
+ var sqList = this.subQuestions.filter((item) => item.Id == quesId);
1761
+ for (var sq of sqList) {
1762
+ sq.error = null;
1763
+ }
1764
+ }
1765
+ uploadFile(event, ques) {
1766
+ //console.log('inside upload');
1767
+ this.clearError();
1768
+ this.fileTypeIncorrect = false;
1769
+ var local = this;
1770
+ local.attachment = event.target.files[0];
1771
+ // Validate the file extension
1772
+ //console.log(local.attachment);
1773
+ let fileNameWithType = local.attachment && local.attachment.name.toLowerCase();
1774
+ if (!fileNameWithType.endsWith(".jpg") &&
1775
+ !fileNameWithType.endsWith(".png") &&
1776
+ !fileNameWithType.endsWith(".pdf") &&
1777
+ !fileNameWithType.endsWith(".jpeg") &&
1778
+ !fileNameWithType.endsWith(".heic") &&
1779
+ !fileNameWithType.endsWith(".heif") &&
1780
+ !fileNameWithType.endsWith(".JPG") &&
1781
+ !fileNameWithType.endsWith(".PNG") &&
1782
+ !fileNameWithType.endsWith(".PDF") &&
1783
+ !fileNameWithType.endsWith(".JPEG") &&
1784
+ !fileNameWithType.endsWith(".HEIC") &&
1785
+ !fileNameWithType.endsWith(".HEIF")) {
1786
+ local.fileTypeIncorrect = true;
1787
+ }
1788
+ // Return when the file type is incorrect
1789
+ if (local.fileTypeIncorrect) {
1790
+ return;
1791
+ }
1792
+ let fileContent;
1793
+ var reader = new FileReader();
1794
+ reader.onload = function () {
1795
+ fileContent = reader.result;
1796
+ local.fileExceededLimit = local.attachment.size > 3242880; //Validating file size
1797
+ // Upload the file to Salesforce when the limit is within range
1798
+ if (!local.fileExceededLimit) {
1799
+ let fileWrapper = new AttachmentWrapper();
1800
+ fileWrapper.parentId = local.abItem.Id;
1801
+ fileWrapper.fileName = local.attachment.name;
1802
+ fileWrapper.fileContent = fileContent;
1803
+ local.createAttachment(fileWrapper);
1804
+ ques.input = fileWrapper.fileName;
1805
+ }
1806
+ };
1807
+ this.spinner.show(this.spinnerName);
1808
+ reader.readAsDataURL(event.target.files[0]);
1809
+ }
1810
+ successAttachmentCreate = (response) => {
1811
+ let createdAttachment = new Attachment(response.attachmentId, response.attachmentName, this.attachment.lastModifiedDate);
1812
+ this.attachments.push(createdAttachment);
1813
+ this.attachmentsMap.set(this.questionItem.Id, this.attachments);
1814
+ this.spinner.hide(this.spinnerName);
1815
+ };
1816
+ successAttachmentDelete = (response) => {
1817
+ for (let i = 0; i < this.attachments.length; i++) {
1818
+ if (this.attachments[i].attachmentId === this.attachmentId) {
1819
+ this.attachments.splice(i, 1);
1820
+ }
1821
+ }
1822
+ };
1823
+ failureAttachmentCreate = (response) => {
1824
+ //console.log('inside failureAttachmentCreate');
1825
+ };
1826
+ failureAttachmentDelete = (response) => {
1827
+ //console.log('inside failureAttachmentDelete');
1828
+ };
1829
+ handleSubmitClick() {
1830
+ this.handleEvent.emit(this.qbItem.Submit_Tracking_ID__c);
1831
+ this.updateAnswerBook(this.abItem.Id);
1832
+ }
1833
+ handleCancelClick() {
1834
+ this.handleEvent.emit(this.qbItem.Cancel_Tracking_ID__c);
1835
+ }
1836
+ createAttachment = (fileWrapper) => {
1837
+ if (this.serv == "api") {
1838
+ this.dataService.getAPIData(this.tkn, ["Attachment", "create", JSON.stringify(fileWrapper)], this.successAttachmentCreate, this.failureAttachmentCreate);
1839
+ }
1840
+ else {
1841
+ this.sfService.remoteAction("NxtController.process", ["Attachment", "create", JSON.stringify(fileWrapper)], this.successAttachmentCreate, this.failureAttachmentCreate);
1842
+ }
1843
+ };
1844
+ deleteAttachment(attachmentId) {
1845
+ this.attachmentId = attachmentId;
1846
+ this.handleEvent.emit("deleteAttachment");
1847
+ this.deleteSFAttachment(attachmentId);
1848
+ }
1849
+ deleteSFAttachment = (fileId) => {
1850
+ if (this.serv == "api") {
1851
+ this.dataService.getAPIData(this.tkn, ["Attachment", "delete", fileId], this.successAttachmentDelete, this.failureAttachmentDelete);
1852
+ }
1853
+ else {
1854
+ this.sfService.remoteAction("NxtController.process", ["Attachment", "delete", fileId], this.successAttachmentDelete, this.failureAttachmentDelete);
1855
+ }
1856
+ };
1857
+ getFileName(fileNamewithIdandType) {
1858
+ //truncate file path
1859
+ var fileNameWithType = fileNamewithIdandType.substr(fileNamewithIdandType.indexOf("::::") + 4);
1860
+ return fileNameWithType; //fileNameWithType.replace(/^(.*(\/|\\))(.+)$/, '$3');
1861
+ }
1862
+ fileUI() {
1863
+ if (this.attachments.length === 0) {
1864
+ }
1865
+ }
1866
+ //Update function for categorization
1867
+ // stepperCateg() {
1868
+ // this.firstFormGroup = this._formBuilder.group({
1869
+ // firstCtrl: ['', Validators.required]
1870
+ // });
1871
+ // this.secondFormGroup = this._formBuilder.group({
1872
+ // secondCtrl: ['', Validators.required]
1873
+ // });
1874
+ // }
1875
+ // Update Function for the Progress Bar
1876
+ updateProgress() {
1877
+ if (this.qbItem.Progress_Bar__c === true) {
1878
+ let j = [];
1879
+ for (let i = 0; i < this.possibilities.total; i++) {
1880
+ var pathposs = Object.values(this.possibilities.paths[i].questions);
1881
+ if (pathposs[this.pathquestion] === this.currentName) {
1882
+ j.push(i);
1883
+ this.check = true;
1884
+ }
1885
+ else {
1886
+ this.check = false;
1887
+ }
1888
+ }
1889
+ if (j.length === 1) {
1890
+ this.count = j[0];
1891
+ }
1892
+ if (j.length > 1) {
1893
+ var width = 90 * (this.questionStack.length / this.possibilities.maxQuestions);
1894
+ this.progressStyle = Math.round(width) + "%";
1895
+ }
1896
+ else if (j.length === 1) {
1897
+ var width = 90 *
1898
+ (this.questionStack.length /
1899
+ this.possibilities.paths[this.count].count);
1900
+ this.progressStyle = Math.round(width) + "%";
1901
+ }
1902
+ this.percent = +Math.round(width);
1903
+ }
1904
+ }
1905
+ townName(area) {
1906
+ this.selectedValue = area.town;
1907
+ //console.log('this value='+this.selectedValue)
1908
+ this.tempoAddress = [];
1909
+ }
1910
+ getTownLocal() {
1911
+ this.tempoAddress = [];
1912
+ if (this.selectedValue.length > 0) {
1913
+ for (var val of this.localaddress) {
1914
+ if (val.town.substring(0, this.selectedValue.length) == this.selectedValue) {
1915
+ //console.log(val.country)
1916
+ this.tempoAddress.push(val);
1917
+ //console.log('tempoAddress'+this.tempoAddress)
1918
+ if (this.tempoAddress.length == 6) {
1919
+ break;
1920
+ }
1921
+ }
1922
+ }
1923
+ }
1924
+ document.getElementById("selectList").style.display = "block";
1925
+ this.setSearchListWidth();
1926
+ }
1927
+ clearList() {
1928
+ setTimeout(() => {
1929
+ this.tempoAddress = [];
1930
+ }, 500);
1931
+ }
1932
+ setSearchListWidth() {
1933
+ //to resize search list based on the screen size
1934
+ const searchBoxWidth = window.document.getElementById("autocomplete-input").offsetWidth;
1935
+ document.getElementById("selectList").style.width = searchBoxWidth + "px";
1936
+ }
1937
+ getCode() {
1938
+ this.tempoAddress = [];
1939
+ if (this.selectedPostalcode.length > 0) {
1940
+ for (var val of this.allAddress) {
1941
+ if (val.zipCode.substring(0, this.selectedPostalcode.length) == this.selectedPostalcode) {
1942
+ //console.log(val.country)
1943
+ this.tempoAddress.push(val);
1944
+ //console.log('tempoAddress'+this.tempoAddress)
1945
+ if (this.tempoAddress.length == 6) {
1946
+ break;
1947
+ }
1948
+ }
1949
+ }
1950
+ }
1951
+ document.getElementById("selectList").style.display = "block";
1952
+ this.setSearchListWidth();
1953
+ }
1954
+ getPostalcode(value) {
1955
+ this.places = [];
1956
+ this.province = [];
1957
+ var province;
1958
+ var town;
1959
+ this.selectedPostalcode = value.zipCode;
1960
+ this.selectedValue = value.country;
1961
+ this.tempoAddress = [];
1962
+ for (var val of this.localaddress) {
1963
+ if (this.selectedPostalcode == val.zipCode) {
1964
+ this.places.push(val);
1965
+ this.province.push(val);
1966
+ this.selectedValue = val.country;
1967
+ province = val.province;
1968
+ town = val.town;
1969
+ }
1970
+ }
1971
+ if (this.places.length == 1) {
1972
+ this.selectedProvince = province;
1973
+ this.selectedCity = town;
1974
+ }
1975
+ else if (this.places.length > 1 || this.places.length == 0) {
1976
+ this.selectedCity = '';
1977
+ this.selectedProvince = '';
1978
+ }
1979
+ }
1980
+ closeDropdown() {
1981
+ if (this.selectedPostalcode.length == 5) {
1982
+ this.getPostalcode({ zipCode: this.selectedPostalcode });
1983
+ }
1984
+ setTimeout(() => {
1985
+ document.getElementById('selectList').style.display = "none";
1986
+ }, 500);
1987
+ }
1988
+ //Plus button implementation.
1989
+ structLocalSubQuestion(ques) {
1990
+ // console.log('inside structLocalSubQuestion');
1991
+ for (var i = 0; i < this.subQuestions.length; i++) {
1992
+ var localSubQuestion = new LocalQuestion();
1993
+ localSubQuestion.Id = this.subQuestions[i].Id;
1994
+ localSubQuestion.Name = this.subQuestions[i].Name;
1995
+ localSubQuestion.Question__c = this.subQuestions[i].Question__c;
1996
+ localSubQuestion.Question_Text__c = this.subQuestions[i].Question_Text__c;
1997
+ localSubQuestion.Type__c = this.subQuestions[i].Type__c;
1998
+ localSubQuestion.Title__c = this.subQuestions[i].Title__c;
1999
+ localSubQuestion.SubTitle__c = this.subQuestions[i].SubTitle__c;
2000
+ localSubQuestion.Is_Optional__c = this.subQuestions[i].Is_Optional__c;
2001
+ localSubQuestion.Error_Message__c = this.subQuestions[i].Error_Message__c;
2002
+ localSubQuestion.Next_Question__c = this.subQuestions[i].Next_Question__c;
2003
+ localSubQuestion.Group__c = this.subQuestions[i].Group__c;
2004
+ localSubQuestion.Question_No__c = this.subQuestions[i].Question_No__c;
2005
+ localSubQuestion.Allowed_File_Extensions__c = this.subQuestions[i].Allowed_File_Extensions__c;
2006
+ localSubQuestion.uniqueSubQId = '' + this.subQuestions[i].Id + i;
2007
+ localSubQuestion.input = this.subQuestions[i].input;
2008
+ this.localSubQuestions.push(localSubQuestion);
2009
+ }
2010
+ // console.log('final local sub questions');
2011
+ // console.log(this.localSubQuestions);
2012
+ // console.log(this.questionItem.Id);
2013
+ this.localSubQMap.set(this.questionItem.Id, this.localSubQuestions);
2014
+ this.localSubQuestions = [];
2015
+ // console.log('final key localSubQMap map');
2016
+ // console.log(this.localSubQMap);
2017
+ }
2018
+ addInputBox(question, index) {
2019
+ var arra = this.localSubQMap.get(this.questionItem.Id);
2020
+ var qIndex = arra.indexOf(question);
2021
+ var ques = new LocalQuestion();
2022
+ Object.assign(ques, question);
2023
+ //console.log((ques.uniqueSubQId).substring(18, (ques.uniqueSubQId).length)+1);
2024
+ if (this.keyIndex == index) {
2025
+ ques.uniqueSubQId = ques.Id + (String(index + 1));
2026
+ this.keyIndex++;
2027
+ }
2028
+ else {
2029
+ this.keyIndex++;
2030
+ ques.uniqueSubQId = ques.Id + (String(this.keyIndex));
2031
+ }
2032
+ ques.input = '';
2033
+ arra.splice(qIndex + 1, 0, ques);
2034
+ this.localSubQMap.set(this.questionItem.Id, arra);
2035
+ //console.log(this.localSubQMap);
2036
+ }
2037
+ removeAddress(quesUniqueId, qName) {
2038
+ //console.log(quesUniqueId)
2039
+ var val = this.localSubQMap.get(this.questionItem.Id);
2040
+ var keyindex = 0;
2041
+ for (let i = 0; i < val.length; i++) {
2042
+ if (val[i].Name == qName) {
2043
+ keyindex++;
2044
+ }
2045
+ }
2046
+ if (this.localSubQMap.has(this.questionItem.Id) && keyindex > 1) {
2047
+ var reorder = val.filter((item) => item.uniqueSubQId !== quesUniqueId);
2048
+ this.localSubQMap.set(this.questionItem.Id, reorder);
2049
+ keyindex--;
2050
+ }
2051
+ }
2052
+ getLocalSubQuestions(id) {
2053
+ return this.localSubQMap.get(id);
2054
+ }
2055
+ //Single Add button functionality for List type
2056
+ Add(question) {
2057
+ this.addFlag = false;
2058
+ var arra = this.localSubQMap.get(this.questionItem.Id);
2059
+ var index = arra.length;
2060
+ var a = arra.slice(-1).pop();
2061
+ this.indexCount = a.Question_No__c;
2062
+ for (var i = 0; i < this.indexCount; i++) {
2063
+ var ques = new LocalQuestion();
2064
+ Object.assign(ques, question[i]);
2065
+ this.keyIndex++;
2066
+ ques.uniqueSubQId = ques.Id + (String(this.keyIndex));
2067
+ ques.input = '';
2068
+ arra.splice(index + (this.indexCount - 1), 0, ques);
2069
+ this.localSubQMap.set(this.questionItem.Id, arra);
2070
+ }
2071
+ this.addFlag = true;
2072
+ }
2073
+ handleLocationSelected(location, ques) {
2074
+ ques.input = location;
2075
+ }
2076
+ selectedInput(input, ques) {
2077
+ ques.input = input;
2078
+ }
2079
+ handleTextareaValueChange(value) {
2080
+ console.log('Selected text-area text:', value);
2081
+ }
2082
+ getData(data) {
2083
+ console.log('table data', data);
2084
+ }
2085
+ dependentChange(value) {
2086
+ this.nextValue = value;
2087
+ }
2088
+ displayDate(dateSelected, ques) {
2089
+ // Parse the date string using moment and assign it to this.selectedDate
2090
+ ques.input = moment(dateSelected.value, 'YYYY-MM-DD HH:mm:ss').format('YYYY-MM-DD HH:mm:ss').toString();
2091
+ }
2092
+ getKey(item) {
2093
+ return Object.keys(item)[0];
2094
+ }
2095
+ getValue(item) {
2096
+ return Object.values(item)[0];
2097
+ }
2098
+ // In the parent component class
2099
+ getTableData(ques) {
2100
+ // Return a new array to ensure each table instance has its own separate array
2101
+ if (ques.Name === 'QN-02251') {
2102
+ ques.tableDataValue = this.tableData1;
2103
+ ques.tableHeader = 'Safety Precautions';
2104
+ return [...ques.tableDataValue];
2105
+ }
2106
+ else {
2107
+ ques.tableDataValue = this.tableData2;
2108
+ ques.tableHeader = 'Personal Protective Equipments';
2109
+ return [...ques.tableDataValue];
2110
+ }
2111
+ }
2112
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: QuestionnaireComponent, deps: [{ token: i1.SalesforceService }, { token: i2.DataService }, { token: i3.ActivatedRoute }, { token: i4.DomSanitizer }, { token: i5.NgxSpinnerService }, { token: i6.UntypedFormBuilder }, { token: i7.DeviceDetectorService }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component });
2113
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: QuestionnaireComponent, selector: "lib-questionnaire", inputs: { qbId: "qbId", insuranceStartDate: "insuranceStartDate", serv: "serv", tkn: "tkn" }, outputs: { handleEvent: "handleEvent", handlePage: "handlePage" }, usesOnChanges: true, ngImport: i0, template: "<!-- Spinner -->\n<ngx-spinner [name]=\"spinnerName\" [type]=\"spinnerType\"></ngx-spinner>\n\n<!-- Back Processing -->\n<div *ngIf=\"backicon == false\" >\n <div class=\"backicon\" [style.visibility]=\"questionStack.length >0 ? 'visible' : 'hidden'\">\n <button (click)=\"handleBackClick()\" [class]=\" abItem?.Status__c == 'Completed' ? 'summary-volver':'app-back1'\">\n <img class=\"icon-arrow-back\" src=\"https://rnxt.s3.amazonaws.com/MytIcon/icon-arrow-back.png\" alt=\"Scroll down\"> {{ qbItem?.Back__c }}\n </button>\n </div>\n</div>\n\n<!-- Question Hanlding -->\n<div *ngIf=\"questionItem\" [class]=\"qbItem.isShengel__c ? 'questiondiv1' : 'questiondiv1 padd-bottom'\">\n <!-- Progress Bar & Title -->\n <div *ngIf=\"questionItem.Title__c && qbItem.Progress_Bar__c\">\n <h1 class=\"header1\">{{ questionItem?.Title__c }}</h1>\n <div class=\"header2\">{{ questionItem?.SubTitle__c }}</div>\n </div>\n\n <!-- Progress & Grouping -->\n <div [ngClass]=\"{ questiondiv2: !qbItem?.Progress_Bar__c }\">\n <!-- Pie Chart Progress -->\n <div [ngClass]=\"{ bgColor: qbItem?.Progress_Bar__c }\">\n <div id=\"progress\" *ngIf=\"qbItem?.Progress_Bar__c\">\n <circle-progress class=\"titlebar\" [percent]=\"this.percent\" [radius]=\"40\" [space]=\"-4\" [outerStrokeWidth]=\"4\"\n [innerStrokeWidth]=\"4\" [outerStrokeColor]=\"'#e0b1b0'\" [innerStrokeColor]=\"'#e7e8ea'\" [animation]=\"true\" [backgroundPadding]= \"0\"\n [backgroundColor]= \"'#dd2e13'\" [backgroundGradientStopColor]=\"'#f9bfbd'\" [titleColor]=\"'#f3eded'\" \n class=\"ng-star-inserted\" [title]=\"this.percent+'%'\" [showSubtitle]=\"false\" [showBackground]=\"true\" [animationDuration]=\"300\"\n [startFromZero]=\"false\" [responsive]=\"false\" >\n </circle-progress>\n </div>\n </div>\n\n <!-- Show the Group/Module related to the Progress -->\n <div *ngIf=\"questionItem.Group__c && qbItem.Progress_Bar__c\"\n [ngClass]=\"{ questionalign: !qbItem?.Progress_Bar__c }\">\n <div class=\"largeTitle\">\n <h3 class=\"myt-font6 myt-text3\">\n {{ questionItem?.Group__c }}\n </h3>\n <div *ngIf=\"questionItem.Sub_Text__c != '\u00BFEn qu\u00E9 pa\u00EDs ocurri\u00F3?'\" class=\"myt-font5 myt-text1\">{{questionItem?.Sub_Text__c}}</div>\n <div *ngIf=\"questionItem.Sub_Text__c === '\u00BFEn qu\u00E9 pa\u00EDs ocurri\u00F3?'\" class=\"myt-font10 myt-text2\">{{questionItem?.Sub_Text__c}}</div>\n </div>\n </div>\n </div>\n\n <!-- Question Handling -->\n <div class=\"questiondiv2\">\n <!-- Title -->\n <div *ngIf=\"questionItem.Is_Title__c\">\n <div *ngIf=\"questionItem.Type__c != 'Book' && questionItem.Question_No__c!='6' && questionItem.Question_No__c!='9'\"> \n <h3 class=\"questionalign myt-font3 myt-align myt-text4\" [innerHTML]=\"getText(questionItem?.Question_Text__c)\">\n {{questionItem?.Question_Text__c}}\n </h3>\n </div>\n </div>\n <div *ngIf=\"!questionItem.Is_Title__c\" [class]=\"qbItem.isShengel__c ? 'header-style additional' : 'question-f-size additional'\">\n <div [innerHTML]=\"getText(questionItem?.Question_Text__c)\" >\n {{ questionItem?.Question_Text__c }}\n </div>\n </div>\n\n <!-- This should be removed with Custom Styling - MR - 11AUG23 -->\n <div *ngIf=\"questionItem.Type__c == 'Book'\">\n <div *ngIf=\"questionItem.Question_No__c=='6'\">\n <h3 class=\"myt-321\" [innerHTML]=\"getText(questionItem?.Question_Text__c)\">\n {{ questionItem?.Question_Text__c }}\n </h3>\n </div>\n </div>\n \n <!-- This should be removed with Custom Styling - MR - 11AUG23 -->\n <div *ngIf=\"questionItem.Type__c == 'File' \">\n <div *ngIf=\"questionItem.Question_No__c=='9'\">\n <h3 class=\"myt-345\" [innerHTML]=\"getText(questionItem?.Question_Text__c)\">\n {{questionItem?.Question_Text__c}}\n </h3>\n </div>\n </div>\n </div>\n\n <!-- Additional Info -->\n <!-- The below code can be written effectively nested ngIf for Rich Text & Other onw for Progress Bar -->\n <div *ngIf=\"questionItem.Additional_Rich__c && qbItem.Progress_Bar__c\" >\n <div\n class=\"additional \" [innerHTML]=\"innerhtml\">\n </div>\n </div>\n <div *ngIf=\"questionItem.Additional_Rich__c && !qbItem.Progress_Bar__c\">\n <div class=\"info-alert ques-alert1\">\n <i class=\"fa fa-info fa-3x iposition icolor\" aria-hidden=\"true\"></i>\n <div class=\"infodiv\" [innerHTML]=\"innerhtml\"></div>\n </div>\n </div>\n\n <!-- Dropdown-->\n <div *ngIf=\"dropdownFlag\" >\n <div class=\"dis-flex\">\n <select \n [ngClass]=\"{\n 'dt-line myt-align3 myt-align2 dpDown dropbox down1 myt-dropbox myt-border-r myt-font1': qbItem?.Progress_Bar__c,\n 'custom-select': !qbItem?.Progress_Bar__c\n }\" class=\"mr-sm-2 dd-height dropbox \" id=\"dropdown\" [(ngModel)]=\"inpValue\" (change)=\"clearError()\" style.border-color=\"{{\n this.questionItem?.error ? 'red' : inpValue?.length > 0 ? '#fff' : ''\n }}\" style.color=\"{{ questionItem?.error ? 'red' : '' }}\" style=\"margin-left: 21.5rem !important;\">\n <option *ngFor=\"let opt of questionItem.Question_Options__r.records\" class=\"option\" value=\"{{ opt.Value__c }}\">\n {{ opt.Value__c }}\n </option>\n <option value=\".\" disabled hidden>Bitte treffen Sie eine Auswahl</option>\n </select>\n </div>\n </div>\n\n <!-- Radio -->\n <div *ngIf=\"radioFlag || dataFlag\" class=\"\">\n <div *ngIf=\"this.questionItem.error\" class=\"cond-div2\">\n {{ questionItem?.Error_Message__c }}\n </div>\n <div class=\"dis-flex\">\n <div *ngFor=\"let opt of questionItem.Question_Options__r.records\" class=\"radio radioOption\" >\n <label class=\"radiocontainer container myt-font4\">{{ opt.Value__c }}\n <input type=\"radio\" [id]=\"opt.Id\" [(ngModel)]=\"inpValue\" name=\"inpValue\" value=\"{{ opt.Value__c }}\"\n (change)=\"optionChange(opt.Value__c)\" />\n <span class=\"checkmark\"></span>\n </label>\n </div>\n </div>\n </div>\n\n <!-- Checkbox -->\n <div *ngIf=\"checkboxFlag\" class=\"\">\n <div *ngIf=\"this.questionItem.error\" class=\"cond-div2\">\n {{ questionItem?.Error_Message__c }}\n </div>\n <div class=\"dis-flex\">\n <div *ngFor=\"let item of optionValues\" class=\"radio col-md-6 optiondiv\">\n <label class=\" container1 \" >{{ item.Value__c }}\n <input type=\"checkbox\" [id]=\"item.Id\" [(ngModel)]=\"item.checked\" (click)=\"clearError()\" />\n <span class='checkmark1'></span>\n </label>\n </div>\n </div>\n </div>\n\n <!-- Text -->\n <div *ngIf=\"textFlag\" class=\"col-md-12 myt-book1\">\n <div class=\"col-md-12\" class=\"dis-flex myt-align1\" [class]=\"'col-md-' + questionItem?.Size__c + ' paddingnone'\">\n <input type=\"text\" [(ngModel)]=\"inpValue\" [ngClass]=\"{\n 'boxoutline myt-font1 myt-book1': qbItem?.Progress_Bar__c,\n textBox1: !qbItem?.Progress_Bar__c\n }\" id=\"text-input-id\" required=\"\" (focus)=\"clearError()\" style.border-color=\"{{\n this.questionItem?.error\n ? 'red'\n : inpValue?.length > 0\n ? '#87be1c'\n : ''\n }}\" oninput=\"this.value=this.value.replace(/[^a-zA-Z0-9\\s.:;,?]/g,'');\" />\n <i class=\"fa fa-check check-icon\" aria-hidden=\"true\" *ngIf=\"inpValue?.length > 0\"></i>\n </div>\n </div>\n\n <!-- Text Area -->\n <div *ngIf=\"taFlag\" class=\"col-md-12\">\n <div class=\"dis-flex\">\n <textarea class=\"ta-input\" id=\"ta-input-id\" [(ngModel)]=\"inpValue\" (click)=\"clearError()\" style.border-color=\"{{\n this.questionItem?.error\n ? 'red'\n : inpValue?.length > 0 && taFocusOut\n ? '#87be1c'\n : ''\n }}\" (focusout)=\"taFocusOut = true\"\n oninput=\"this.value=this.value.replace(/[^a-zA-Z0-9\\s.:;,?]/g,'');\"></textarea>\n <i class=\"fa fa-check check-icon\" aria-hidden=\"true\" *ngIf=\"inpValue?.length > 0 && taFocusOut\"></i>\n </div>\n </div>\n\n <!-- CC Number Format -->\n <div *ngIf=\"numberFlag\" class=\"col-md-12\">\n <div class=\"dis-flex\">\n <input type=\"Text\" placeholder=\"0000 0000 0000 0000 0000 0000\" [ngClass]=\"{ boxoutline: qbItem?.Progress_Bar__c }\"\n [(ngModel)]=\"inpValue\" id=\"number-input-id\" (ngModelChange)=\"CCOnChange($event)\" required=\"\" maxlength=\"29\"\n (focus)=\"clearError()\" oninput=\"this.value=this.value.replace(/[^0-9 ]/g,'');\"\n style=\"width:-webkit-fill-available;\" style.border-color=\"{{\n this.questionItem.error\n ? 'red'\n : inpValue?.length > 0\n ? '#87be1c'\n : ''\n }}\" />\n <i class=\"fa fa-check\" aria-hidden=\"true\" style=\"color: #87be1c; margin-left: -2rem; z-index: 1; padding: 5px;\"\n *ngIf=\"inpValue?.length > 0\"></i>\n </div>\n </div>\n <!-- END-->\n\n <!-- AlphaNumeric -->\n <div *ngIf=\"alphanumericFlag\" class=\"col-md-12\"> <!--UI not completed-->\n <div style=\"position:relative;\">\n <input type=text placeholder=\"0 of 0\" style=\"padding:5px 5px 5px 150px;\" id=\"youridhere\"/>\n </div>\n </div>\n\n <!-- Email -->\n <div *ngIf=\"emailFlag\" class=\"col-md-12\">\n <div class=\"dis-flex\">\n <input type=\"email\" [ngClass]=\"{ boxoutline: qbItem?.Progress_Bar__c }\" [(ngModel)]=\"inpValue\" id=\"email-input-id\"\n required=\"\" (focus)=\"clearError()\" style.border-color=\"{{\n this.questionItem.error\n ? 'red'\n : inpValue?.length > 0\n ? '#87be1c'\n : ''\n }}\" />\n <i class=\"fa fa-check\" aria-hidden=\"true\" style=\"color: #87be1c; margin-left: -2rem; z-index: 1; padding: 5px\"\n *ngIf=\"inpValue?.length > 0\"></i>\n </div>\n </div>\n\n <!-- DateTime -->\n <div *ngIf=\"dtFlag\" class=\"col-md-12 paddingZero myt-time1\" >\n <!-- Error Handling -->\n <div class=\"col-md-12\" *ngIf=\"questionItem.error\" style=\"font-size: 18px;\n color: red;\">{{questionItem?.error?.errorMsg}}</div>\n\n <!-- Date -->\n <div *ngIf=\"dateFlag\">\n <div class=\"col-md-12 paddingBottom\">\n <label class=\"date-time colorf\">{{ questionItem?.Date_Text__c }}</label>\n <div class=\"dis-flex\">\n <my-date-picker name=\"mydate\" [options]=\"myDatePickerOptions\" id=\"date\" style=\"font-size: 18px !important;\" (dateChanged)=\"onDateChanged($event)\"\n [(ngModel)]=\"selDate\" class=\"date-picker\" placeholder=\"Seleccione fecha\" (focus)=\"clearError()\">\n </my-date-picker>\n </div>\n </div>\n </div>\n\n <!-- Time -->\n <div *ngIf=\"timeFlag\">\n <div class=\"col-md-12 paddingBottom\">\n <label class=\"date-time colorf\">{{ questionItem?.Time_Text__c }}</label>\n <div class=\"dis-flex\">\n <div [ngClass]=\"{'dt-line date-line dt-time': qbItem?.Progress_Bar__c,\n dateandTime: !qbItem?.Progress_Bar__c}\" \n id=\"dateandTime\" [style.border-color]=\"questionItem?.error ? 'red': questionItem?.input?.length > 0 ? '' : ''\"\n (focus)=\"(clearSQError) \">\n <select name=\"hours\" class=\"datetime showHour myt-time myt-hour\" [(ngModel)]=\"selectedHour\" id=\"hour\"\n (focus)=\"clearError()\">\n <option value=\"\">HH</option>\n <option [value]=\"hour\" *ngFor=\"let hour of hours\">\n {{ hour }}\n </option>\n </select>\n <span class=\"colon\"> : </span>\n <select name=\"minutes\" class=\"datetime showminute myt-time\" [(ngModel)]=\"selectedMinute\" id=\"minute\"\n (focus)=\"clearError()\">\n <option value=\"\">MM</option>\n <option [value]=\"minute\" *ngFor=\"let minute of minutes\">\n {{ minute }}\n </option>\n </select>\n <div [ngClass]=\"{ colon1: qbItem?.Progress_Bar__c }\" *ngIf=\"questionItem?.X24_Hours__c == false\">\n <span class=\"colon\"> : </span>\n <select name=\"AM/PM\" class=\"myt-time\" [(ngModel)]=\"selectedMeridiem\" id=\"meridiem\">\n <option value=\"AM\">AM</option>\n <option value=\"PM\">PM</option>\n </select>\n <!-- <div [ngClass]=\"{'': qbItem.Progress_Bar__c, 'dateandTime': !qbItem.Progress_Bar__c}\"></div> -->\n </div>\n </div>\n </div>\n </div>\n <i class=\"fa check-icon3\" aria-hidden=\"true\" *ngIf=\"questionItem?.input?.length > 0\"></i>\n </div>\n </div>\n\n <!-- Attachment / File -->\n <div *ngIf=\"fileFlag\">\n <div *ngIf=\"!qbItem.Progress_Bar__c\">\n <div class=\"info-alert\" style.border-color=\"{{ this.questionItem?.error ? 'red' : '' }}\">\n <label class=\"picture-upload\" for=\"file-upload\">\n <span class=\"picture-upload-child\">\n <i class=\"fa fa-file-image-o fa-5x icolor\" aria-hidden=\"true\"></i>\n </span>\n <span class=\"fa fa-plus fa-2x picture-upload-child pic-upload icolor\">\n <i class=\"\" aria-hidden=\"true\"></i>\n </span>\n </label>\n </div>\n <input id=\"file-upload\" type=\"file\" accept=\"{{ allowedFileExtension }}\" (change)=\"uploadFile($event)\" />\n </div>\n <ul *ngIf=\"\n attachments?.length > 0 &&\n questionItem?.Type__c === 'File' &&\n !qbItem?.Progress_Bar__c\n \" class=\"attach-ulist col-md-12\">\n <li *ngFor=\"let attachment of attachments\" class=\"align-l\">\n {{ attachment.attachmentName\n }}<span class=\"attach-list\" (click)=\"deleteAttachment(attachment.attachmentId)\">X</span>\n </li>\n </ul>\n\n <!-- Attachment Progress -->\n <div *ngIf=\"qbItem.Progress_Bar__c\">\n <div *ngFor=\"let attachment of attachments\" class=\"file-uploading-box\">\n <!--<img src=\"https://rnxt.s3.amazonaws.com/MytIcon/icon-doc-img%402x.png\" class=\"icon-edit1\" />-->\n <span class=\"uploading-file-name \">{{ attachment.attachmentName }}</span>\n <img src=\"https://rnxt.s3.amazonaws.com/MytIcon/icon-delete%402x.png\" class=\"deleteIcon\"\n (click)=\"deleteAttachment(attachment.attachmentId)\" />\n </div>\n <div class=\"file-upload-box\" style.border-color=\"{{ this.questionItem.error ? 'red' : '' }}\">\n \n <!--<img src=\"https://rnxt.s3.amazonaws.com/MytIcon/icon-doc-img%402x.png\" class=\"icon-edit1\" />-->\n <span class=\"f-Name\" [innerHTML]=\"getText(questionItem?.Question_Text__c)\"> {{ questionItem?.Question_Text__c}}</span>\n <label class=\"file-label \">\n <img src=\"https://rnxt.s3.amazonaws.com/MytIcon/file-upload.png\" class=\"file-icon\"/>\n <input name=\"attachment\" type=\"file\" placeholder=\"Ticket kaufen\" multiple\n accept=\".pdf, .png, .jpg, .jpeg, .heic, .application/pdf\" (change)=\"uploadFile($event)\"\n class=\"file-upload-btn\">\n </label>\n </div>\n </div>\n </div>\n\n <!-- Book -->\n <div *ngIf=\"bookFlag\">\n <div [class]=\"qbItem.isShengel__c ? 'form-group content-box' : 'form-group'\">\n <div class=\"form-row\">\n <div class=\"col-md-12\" *ngIf=\"questionItem.error\" style=\"font-size: 18px;\n color: red;\">{{questionItem?.error?.errorMsg}}</div>\n <div [class]=\"qbItem.isShengel__c ? '' : 'myt-align3'\" [class]=\"qbItem.isShengel__c ? 'col-lg-' + ques.Size__c + ' paddingnone' : 'col-md-' + ques.Size__c + ' paddingnone'\"\n *ngFor=\"let ques of subQuestions;let i = index\">\n <div [ngClass]=\"{ down2: qbItem?.Progress_Bar__c }\">\n <span [class]=\"qbItem.isShengel__c ? 'dis-flex shengel-myt-font3 myt-font7' : 'dis-flex myt-font3 myt-font7' \">{{ ques?.Question__c }}</span>\n </div>\n <div class=\"col-md-12 paddingZero myt-dateTimeNew\" *ngIf=\"ques.Type__c === 'Time' || ques.Type__c === 'Date'\">\n <div *ngIf=\"ques.Type__c === 'Date'\">\n <div class=\"col-md-12 paddingBottom\">\n <label class=\"date-time colorf\">{{ questionItem?.Date_Text__c }}</label>\n <div class=\"dis-flex dateandtime\">\n <my-date-picker name=\"mydate\" [options]=\"myDatePickerOptions\" id=\"date\" style=\"font-size: 18px !important;\" (dateChanged)=\"onDateChanged($event)\"\n [(ngModel)]=\"selDate\" class=\"date-picker\" placeholder=\"Seleccione fecha\" (focus)=\"clearError()\" >\n </my-date-picker>\n </div>\n </div>\n </div>\n <div *ngIf=\"ques.Type__c === 'Time'\">\n <div class=\"col-md-12 paddingBottom\">\n <label class=\"date-time colorf\">{{ questionItem?.Time_Text__c }}</label>\n <div class=\"dis-flex dateandtime\">\n <div [ngClass]=\"{'dt-line date-line dt-time': qbItem?.Progress_Bar__c,\n dateandTime: !qbItem?.Progress_Bar__c}\" \n id=\"dateandTime\" [style.border-color]=\"questionItem?.error ? 'red': questionItem?.input?.length > 0 ? '' : ''\"\n (focus)=\"(clearSQError) \">\n <select name=\"hours\" class=\"datetime showHour myt-time myt-hour\" [(ngModel)]=\"selectedHour\" id=\"hour\"\n (focus)=\"clearError()\">\n <option value=\"\">HH</option>\n <option [value]=\"hour\" *ngFor=\"let hour of hours\">\n {{ hour }}\n </option>\n </select>\n <span class=\"colon\"> : </span>\n <select name=\"minutes\" class=\"datetime showminute myt-time\" [(ngModel)]=\"selectedMinute\" id=\"minute\"\n (focus)=\"clearError()\">\n <option value=\"\">MM</option>\n <option [value]=\"minute\" *ngFor=\"let minute of minutes\">\n {{ minute }}\n </option>\n </select>\n <div [ngClass]=\"{ colon1: qbItem?.Progress_Bar__c }\" *ngIf=\"questionItem.X24_Hours__c == false\">\n <span class=\"colon\"> : </span>\n <select name=\"AM/PM\" class=\"myt-time\" [(ngModel)]=\"selectedMeridiem\" id=\"meridiem\">\n <option value=\"AM\">AM</option>\n <option value=\"PM\">PM</option>\n </select>\n </div>\n </div>\n </div>\n </div>\n </div>\n </div>\n <div *ngIf=\"ques.Type__c === 'DateTime'\">\n <app-custom-date-picker [minDate]=\"ques.minDate\" [date]=\"ques.input\" (dateChange)=\"displayDate($event,ques)\"></app-custom-date-picker>\n </div>\n <div *ngIf=\"ques.Type__c === 'Text'\">\n <app-custom-input\n [fromShengel]=\"qbItem.isShengel__c\"\n [value]=\"ques.input\"\n [ngClassValue]=\"{\n 'dis-flex dt-line date-line bookText boxoutline myt-font1': qbItem.Progress_Bar__c,\n textBox: !qbItem.Progress_Bar__c\n }\"\n [idValue]=\"ques.Id\"\n [focusEvent]=\"clearSQError(ques.Id)\"\n [error]=\"ques.error\"\n [placeholder]=\"ques.Question__c\"\n (inputValue)=\"selectedInput($event,ques)\">\n </app-custom-input>\n </div>\n <div *ngIf=\"ques.Type__c === 'Location'\">\n <!-- for pick location -->\n <app-pick-location [address]=\"ques.input\" (locationSelected)=\"handleLocationSelected($event,ques)\"></app-pick-location>\n </div>\n <!-- for text area -->\n <div *ngIf=\"ques.Type__c === 'TextArea'\">\n <app-custom-text-area [value]=\"ques.input\" [rows]=\"3\" [error]=\"ques.error\" [placeholder]=\"ques.Question__c \" (textareaValueChange)=\"handleTextareaValueChange($event)\"></app-custom-text-area>\n </div>\n <!-- for to data table we use 'data' type question -->\n <div *ngIf=\"ques.Type__c === 'Data'\">\n <app-custom-table [tableHeader]=\"ques.tableHeader\" [tableData]=\"getTableData(ques)\" [tableIndex]=\"i\" (tableDataChange)=\"getData($event)\"></app-custom-table>\n </div>\n\n <div *ngIf=\"ques.Type__c === 'Email'\">\n <input type=\"email\" [(ngModel)]=\"ques.input\" [id]=\"ques.Id\" required=\"\" (focus)=\"clearSQError(ques.Id)\"\n style.border-color=\"{{ ques.error ? 'red' : '' }}\" placeholder=\"{{ ques.Question__c }}\" />\n </div>\n\n <div *ngIf=\"ques.Type__c === 'File'\">\n <div *ngIf=\"!qbItem.Progress_Bar__c\">\n <label class=\"picture-upload custom-file-upload bgcolor-w\" for=\"file-upload\">\n <span class=\"picture-upload-child\">\n <i class=\"fa fa-file-image-o fa-5x icolor\" aria-hidden=\"true\"></i>\n </span>\n <span class=\"\n fa fa-plus fa-2x\n picture-upload-child\n pic-upload\n icolor\n \">\n <i class=\"\" aria-hidden=\"true\"></i>\n </span>\n </label>\n <input id=\"file-upload\" type=\"file\" accept=\"{{ bookFlagAccept }}\" (change)=\"uploadFile($event,ques)\" />\n </div>\n\n <ul *ngIf=\"\n attachments?.length > 0 &&\n ques.Type__c === 'File' &&\n !qbItem.Progress_Bar__c\n \" class=\"attach-ulist col-md-12\">\n <li *ngFor=\"let attachment of attachments\" class=\"align-l\">\n {{ attachment.attachmentName\n }}<span class=\"attach-list\" (click)=\"deleteAttachment(attachment.attachmentId)\">X</span>\n </li>\n </ul>\n <div class=\"myt-box\" *ngIf=\"qbItem.Progress_Bar__c\">\n\n <div *ngFor=\"let attachment of attachments\" class=\"file-uploading-box\">\n <img src=\"https://rnxt.s3.amazonaws.com/MytIcon/icon-doc-img%402x.png\" class=\"icon-edit1\" />\n <span class=\"uploading-file-name myt-font1 font-weight: normal;\"> {{ attachment.attachmentName }}</span>\n <img src=\"https://rnxt.s3.amazonaws.com/MytIcon/icon-delete%402x.png\" class=\"deleteIcon\"\n (click)=\"deleteAttachment(attachment.attachmentId)\" />\n </div>\n <div class=\"file-upload-box\" style.border-color=\"{{ this.questionItem.error ? 'red' : '' }}\">\n <img src=\"https://rnxt.s3.amazonaws.com/MytIcon/icon-doc-img%402x.png\" class=\"icon-edit1\" />\n <span class=\"f-Name\">{{ ques?.Question__c }}</span>\n <label class=\"file-label \">\n <span style=\"color: #c5281c;text-decoration:underline\">\n Adjuntar\n </span>\n <input name=\"attachment\" type=\"file\" placeholder=\"Ticket kaufen\" multiple\n accept=\".pdf, .png, .jpg, .jpeg, .heic, .application/pdf\" (change)=\"uploadFile($event,ques)\"\n class=\"file-upload-btn\">\n </label>\n </div>\n </div>\n </div>\n\n <!-- Dropdown -->\n <div *ngIf=\"ques.Type__c === 'Dropdown'\" class=\"\">\n <!-- for common dropdown -->\n <app-custom-dropdown [fromShengel]=\"qbItem.isShengel__c\"\n [options]=\"ques.Question_Options__r.records\"\n [apiMeta]=\"ques.Sub_Text__c\"\n [id]=\"ques.Name\"\n [selectedValue]=\"ques.input\"\n [placeholder]=\"'---Select---'\"\n [errorMessage]=\"ques.Error_Message__c\"\n [error]=\"ques.error\"\n (valueChange)=\"Dropdown($event, ques); clearSQError(ques.Id)\">\n </app-custom-dropdown>\n <app-dropdown-with-flag *ngIf=\"ques.isDependentPicklist && !ques.dropDownOnly\" [certified]=\"ques.certifiedFlag\" [JobPerformerCertificates]=\"ques.certificateList\" (flagDropDownChange)=\"dependentChange($event)\"></app-dropdown-with-flag>\n <i class=\"fa fa-check \" aria-hidden=\"true\" *ngIf=\"questionItem?.input?.length > 0\"></i>\n </div> \n </div>\n </div>\n </div>\n </div>\n\n <!--List start-->\n <div *ngIf=\"listFlag\">\n <div class=\"form-group\">\n <div class=\"form-row\">\n <div class=\"col-md-12\" *ngIf=\"questionItem.error\" style=\"font-size: 18px;\n color: red;\">{{questionItem?.error?.errorMsg}}</div>\n <div class=\"myt-align3\" [class]=\"'col-md-' + ques.Size__c + ' paddingnone'\"\n *ngFor=\"let ques of getLocalSubQuestions(questionItem.Id);let i = index\">\n <div>\n <span class=\"dis-flex myt-font3 myt-font7\">{{ ques?.Question__c }}</span>\n </div>\n <div *ngIf=\"ques.Type__c === 'Text'\">\n <input type=\"text\" [(ngModel)]=\"ques.input\" [ngClass]=\"{\n 'dis-flex dt-line date-line bookText boxoutline myt-font1': qbItem.Progress_Bar__c,\n textBox: !qbItem.Progress_Bar__c\n }\" id=\"text\" [id]=\"ques.uniqueSubQId\" required=\"\" (focus)=\"clearLocalSubQuesError(ques)\"\n style.border-color=\"{{ ques.error ? 'red' : '' }}\" placeholder=\"{{ ques.Question__c }}\"\n oninput=\"this.value=this.value.replace(/[^a-zA-Z0-9\\s.:;,?]/g,'');\" />\n </div>\n </div>\n <div class=\"\" *ngIf=\"addFlag\">\n <button (click)=\"Add(getLocalSubQuestions(questionItem.Id))\" class=\"btn\"><i class=\"fa fa-plus\" ></i>Add</button>\n </div>\n </div>\n </div>\n </div>\n <!--List End-->\n\n <!-- Actions -->\n <div *ngIf=\"individualBookButton\" class=\"flexer\">\n <!-- Backward / Back -->\n <div class=\"backbutton\" [ngClass]=\"{ 'col-md-6': !qbItem.Progress_Bar__c }\"\n [style.visibility]=\"questionStack.length > 0 ? 'visible' : 'hidden'\">\n <div [ngClass]=\"{}\">\n <button [ngClass]=\"{\n 'left-bt': qbItem.Progress_Bar__c,\n 'nxt-btn btn-primary btn-lg btn-block btn-back-color':\n !qbItem.Progress_Bar__c\n }\" (click)=\"handleBackClick()\">\n {{ qbItem?.Back__c }}\n </button>\n </div>\n </div>\n\n <!-- Forward / Next -->\n <div [ngClass]=\"{ 'col-md-6': !qbItem.Progress_Bar__c }\">\n <div>\n <button [ngClass]=\"{\n 'rusty': qbItem.Progress_Bar__c,\n 'nxt-btn btn-primary btn-lg btn-block btn-back-color':\n !qbItem.Progress_Bar__c\n }\" (click)=\"handleNextClick()\">\n {{ qbItem.Next__c }}\n </button>\n </div>\n </div>\n </div>\n</div>\n\n<!-- Summary -->\n<div *ngIf=\"summary && summary.length > 0\" height=\"100% !important\" class=\"col-md-12\" [ngClass]=\"{\n 'col-md-12':!qbItem.Progress_Bar__c\n }\">\n <h1 class=\"header1 summarypadd\" >{{ qbItem.SubTitle__c }}</h1> \n <div id=\"progress2\" *ngIf=\"!qbItem.Progress_Bar__c && this.abItem.Status__c != 'Completed' \">\n <div [ngClass]=\"{ 'full-summary': qbItem.Progress_Bar__c }\">\n <div *ngFor=\"let qa of summary\">\n <div [ngClass]=\"{ non: qbItem.Progress_Bar__c }\">\n <div [ngClass]=\"{ summary: !qbItem.Progress_Bar__c }\">\n <div *ngIf=\"!qbItem.Edit__c\"\n [ngClass]=\"{ 'question': this.abItem.Status__c != 'Completed' }\">\n <a [ngClass]=\"{ asum: this.abItem.Status__c === 'Completed' }\" (click)=\"handleEditClick(qa.quesId)\"\n [innerHTML]=\"getText(qa.quesValue)\">{{ qa.quesValue }}</a>\n </div>\n <div *ngIf=\"qbItem.Edit__c\"\n [ngClass]=\"{ 'question': this.abItem.Status__c != 'Completed' }\">\n <div [ngClass]=\"{ 'question': this.abItem.Status__c === 'Completed' }\"\n [innerHTML]=\"getText(qa.quesValue)\">\n {{ qa.quesValue }}\n </div>\n </div>\n <div class=\"answer\" >\n <div *ngIf=\"qa.qTyp === 'File'\">\n <img src=\"https://rnxt.s3.amazonaws.com/MytIcon/icon-doc-img%401.png\" class=\"icon-edit-summary\" />\n {{ qa.ansValue }}\n </div>\n <div *ngIf=\"qa.qTyp != 'File'\">{{ qa.ansValue }}</div>\n <div *ngIf=\"qbItem.Edit__c && this.abItem.Status__c != 'Completed'\" style=\"background: #dedddd;\">\n <button class=\"edit\" (click)=\"handleEditClick(qa.quesId)\">\n <img *ngIf=\"deviceInfo.os === 'iOS'\" src=\"https://rnxt.s3.amazonaws.com/MytIcon/icon-edit%402x.png\" style=\"width:50%!important;\" class=\"icon-editios\"/>\n <img *ngIf=\"deviceInfo.os !== 'iOS'\" src=\"https://rnxt.s3.amazonaws.com/MytIcon/icon-edit%402x.png\" class=\"icon-edit\" />\n </button>\n </div>\n </div>\n </div>\n </div>\n </div>\n </div>\n </div>\n\n <div *ngIf=\"this.abItem.Status__c === 'Completed'\" class=\"col-lg-12\">\n <div class=\"panel-group panel-group-joined\" id=\"ePTW-details\">\n <div class=\"panel panel-default\">\n <div class=\"panel-heading\">\n <h4 class=\"panel-title\">\n <a data-toggle=\"collapse\" data-parent=\"#ePTW-details\" href=\"#collapseOne\" class=\"collapsed\">\n PTW Details\n </a>\n </h4>\n </div>\n <div id=\"collapseOne\" class=\"panel-collapse collapse\">\n <div class=\"panel-body\">\n <div class=\"row\">\n <ng-container *ngFor=\"let item of summaryData; let i = index\">\n <ng-container *ngIf=\"i % 2 === 0\">\n <div class=\"col-lg-6 m-b-30\">\n <label>{{ getKey(item) }}</label>\n <p class=\"font-size\">{{ getValue(item) || 'N/A' }}</p>\n </div>\n <div class=\"col-lg-6\" *ngIf=\"summaryData[i + 1]\">\n <label>{{ getKey(summaryData[i + 1]) }}</label>\n <p class=\"font-size\">{{ getValue(summaryData[i + 1]) || 'N/A' }}</p>\n </div>\n </ng-container>\n </ng-container>\n </div>\n </div>\n </div>\n </div>\n </div>\n </div>\n\n <div id=\"progress2\" *ngIf=\"qbItem.Progress_Bar__c \">\n <div [ngClass]=\"{'bgColor summary-top' : qbItem.Progress_Bar__c }\" >\n <div id=\"progress-summary\" *ngIf=\"qbItem.Progress_Bar__c\">\n <circle-progress class=\"titlebar\" [percent]=\"this.percent\" [radius]=\"40\" [space]=\"-4\" [outerStrokeWidth]=\"4\"\n [innerStrokeWidth]=\"4\" [outerStrokeColor]=\"'#e0b1b0'\" [innerStrokeColor]=\"'#e7e8ea'\" [animation]=\"true\" [backgroundPadding]= \"0\"\n [backgroundColor]= \"'#dd2e13'\" [backgroundGradientStopColor]=\"'#f9bfbd'\" [titleColor]=\"'#f3eded'\" \n class=\"ng-star-inserted\" [title]=\"this.percent+'%'\" [showSubtitle]=\"false\" [showBackground]=\"true\" [animationDuration]=\"300\"\n [startFromZero]=\"false\" [responsive]=\"false\" >\n </circle-progress>\n \n <div *ngIf=\"qbItem.Summary_Text__c && qbItem.Progress_Bar__c\" \n [ngClass]=\"{ summaryTitle: qbItem.Progress_Bar__c }\">\n <h3 class=\"subTitle\" >{{ qbItem.Summary_Text__c }}</h3>\n <div *ngIf=\"abItem.Status__c != 'Completed'\" class=\"subTitle1\" >{{ qbItem.Summary_Sub_Text__c}}</div>\n </div>\n </div>\n <div *ngIf=\"!qbItem.Progress_Bar__c\">\n <h3 class=\"summary-h\">\n {{ qbItem.Summary_Text__c }}\n </h3>\n </div>\n </div>\n <div [ngClass]=\"{ 'full-summary': qbItem.Progress_Bar__c }\">\n <div class=\"summary-groupText myt-font2\">\n <!-- <p>Informe de da\u00F1o</p> -->\n </div>\n <div *ngFor=\"let qa of summary\" >\n <div [ngClass]=\"{ non: qbItem.Progress_Bar__c }\">\n <div [ngClass]=\"{ summary: this.abItem.Status__c != 'Completed' && !qbItem.Progress_Bar__c }\">\n <div *ngIf=\"!qbItem.Edit__c\"\n [ngClass]=\"{ 'question sum-ques myt-font3 myt-font8': this.abItem.Status__c != 'Completed' }\">\n <a [ngClass]=\"{ asum: this.abItem.Status__c === 'Completed' }\" (click)=\"handleEditClick(qa.quesId)\"\n [innerHTML]=\"getText(qa.quesValue)\">{{ qa.quesValue }}</a>\n </div>\n <div *ngIf=\"qbItem.Edit__c\"\n [ngClass]=\"{ 'sum-ques question myt-font3 myt-font8': this.abItem.Status__c != 'Completed' }\">\n <div [ngClass]=\"{ 'sum-ques1 question1 summary-completed myt-font3 myt-font8': this.abItem.Status__c === 'Completed' }\"\n [innerHTML]=\"getText(qa.quesValue)\">\n {{ qa.quesValue }}\n </div>\n </div>\n <div *ngIf=\"qbItem.Edit__c && this.abItem.Status__c != 'Completed'\" style=\"background: #dedddd;\">\n <button class=\"edit\" (click)=\"handleEditClick(qa.quesId)\">\n <img *ngIf=\"deviceInfo.os === 'iOS'\" src=\"https://rnxt.s3.amazonaws.com/MytIcon/icon-edit%402x.png\" style=\"width:50%!important;\" class=\"icon-editios\"/>\n <img *ngIf=\"deviceInfo.os !== 'iOS'\" src=\"https://rnxt.s3.amazonaws.com/MytIcon/icon-edit%402x.png\" class=\"icon-edit\" />\n </button>\n </div>\n \n <div class=\"answer \" >\n <div *ngIf=\"qa.qTyp === 'File'\">\n <img src=\"https://rnxt.s3.amazonaws.com/MytIcon/icon-doc-img%401.png\" class=\"icon-edit-summary\" />\n {{ qa.ansValue }}\n </div>\n <div *ngIf=\"qa.qTyp != 'File'\">\n {{ qa.ansValue }}\n </div>\n </div>\n </div>\n </div>\n </div>\n </div>\n </div>\n\n <!-- Answer Book -->\n <div class=\"flexer1\" *ngIf=\"abItem\">\n <div class=\"\" *ngIf=\"abItem.Status__c == 'Completed'\">\n <div class=\"col-md-12\">\n <button [ngClass]=\"{'btn-text': qbItem.Progress_Bar__c,\n 'nxt-btn btn-primary btn-lg btn-block btn-back-color': !qbItem.Progress_Bar__c}\"\n (click)=\"handleCancelClick()\">\n {{ qbItem.Cancel__c }}\n </button>\n </div>\n </div>\n </div>\n\n <!-- Group Actions -->\n <div class=\"align-edit-submit\" *ngIf=\"abItem.Status__c != 'Completed'\">\n <div class=\"col-md-6\">\n <button [ngClass]=\"{ 'btn-text2': qbItem.Progress_Bar__c,\n 'nxt-btn btn-primary btn-lg btn-block btn-back-color': !qbItem.Progress_Bar__c }\" \n (click)=\"handleSubmitClick()\">\n {{ qbItem.Submit__c }}\n </button>\n </div>\n <div class=\"col-md-6\">\n <button [ngClass]=\"{'grey': qbItem.Progress_Bar__c,\n 'nxt-btn btn-primary btn-lg btn-block btn-back-color': !qbItem.Progress_Bar__c}\" \n (click)=\"handleBackClickNew()\">\n {{ qbItem.Edit__c }}\n </button>\n </div>\n </div>\n\n</div>", styles: [".rusty{width:235px;background-color:#cd2810;color:#fff;text-align:center;font-size:24px;height:60px;margin-left:0%;margin-top:11%;cursor:pointer}.edit{background-color:#dedddd;border:none;color:#c5281c;text-decoration:underline;margin-left:50%;font-size:16px;vertical-align:super;font-weight:700}.icon-edit{width:15px;height:18px;margin:0 6px 1px -13%}.icon-edit1,.icon-edit-summary{width:29px;height:28px}.questiondiv1{padding-left:25px;padding-right:25px;padding-top:3%}.questiondiv2{padding-top:0;padding-bottom:20px;padding-left:11px}.align-edit-submit{display:flex;flex-direction:column;align-items:center}.questiondiv2{padding-left:0!important;padding-bottom:0!important}@media screen and (min-width: 689px){#progress,#progress-summary{padding-left:12px}.backicon{display:none}.dt-time{background-position:98%!important}}.bgColor{text-align:center;background-color:#dedddd}.questionalign{text-align:center;padding-right:4%;margin-bottom:4px;margin-top:2rem;color:#560d05}.largeTitle{padding-left:16px;padding-top:12px}.question-f-size{font-size:.7rem}.non{background-color:#dedddd}.circle{margin-left:25px}.titlebar{padding-left:10%;padding-top:1%;padding-right:10%}.infodiv{padding-left:2rem;overflow:hidden}.info-alert{border:1px solid #e6e6e6;border-radius:5px;padding:.5em;margin-left:15px;margin-right:15px;margin-bottom:1rem;display:flex}.addtional-info{margin-left:-33px;margin-top:-21px;font-size:16px;font-weight:400;font-stretch:normal;font-style:normal;color:#6f7072;font-family:Helvetica}.ques-alert1{margin-bottom:1rem;display:flex}.iposition{margin-left:3rem}.col-md-1,.col-md-10,.col-md-11,.col-md-12,.col-md-2,.col-md-3,.col-md-4,.col-md-5,.col-md-6,.col-md-7,.col-md-8,.col-md-9{position:relative;padding:20px;float:center;width:100%}.col-md-12{padding:0!important}.nxt-btn{border-radius:.3rem;font-size:1.25rem;line-height:1.5;padding:.5rem 1rem;width:100%;cursor:pointer;outline:0}.cond-div2{color:red;font-weight:700;padding-bottom:3%}.radiotext{margin-top:-30px}.radiocontainer{display:flex;flex-direction:row-reverse;border:1px solid none;border-radius:.3em;padding:0;align-items:center;text-align:center;cursor:pointer;font-family:Rubik,Helvetica Neue,Helvetica,Roboto,Arial,sans-serif;color:#a3a2a2}.radioOption{display:flex;align-content:flex-start;margin-top:-16px;width:6%}.checkmark{left:47.5%;height:20px;margin-right:7px;width:20px;background-color:#fff0;border-radius:50%;border:1px solid grey}.myt-time{width:-moz-fit-content!important;width:fit-content!important;background-image:none;background:#dedddd;margin:0;padding:0;border:none;font-size:15px;letter-spacing:1px}.showminute{padding-left:5px;margin-top:0%}.myt-time1{margin-top:-32px;margin-left:-15px}.myt-dateTimeNew{margin-left:-14px}.myt-hour{width:-moz-fit-content;width:fit-content}.date-time{padding:0;margin:0;text-align:left}.dateandTime{border:1px solid #d2d4d6;position:relative;display:flex;border-radius:2px;background-image:url(https://dynamic-css1.s3.ap-south-1.amazonaws.com/External+css/time.svg);background-size:25px;background-repeat:no-repeat;background-position:99% center;background-color:#fff;height:37px}.date-line{border-bottom:1px solid #fff}.dt-time{width:57%;margin-left:2.3%;text-align:left;background-image:url(https://rnxt.s3.amazonaws.com/MytIcon/icon-clock%402x.png)!important;background-size:25px!important;background-repeat:no-repeat!important;background:#dedddd}.date-picker{width:57%;margin-left:2.5%;height:44px;border-radius:5px}.datetime:focus{border:none;box-shadow:none}#meridiem{margin-top:-2px;border:hidden}.dis-flex{display:flex;justify-content:center}.textBox{width:100%;height:36px}.textBox1{width:100%;height:36px;margin-left:-17px}.option{color:#767676}.paddingnone{padding-bottom:0%}.paddingZero{padding:0}.summary-h{text-align:left;padding-bottom:15px}.summary{display:flex;flex-direction:column;align-items:flex-start;border-bottom:2px solid #fff}.asum{color:#6f7072;margin-top:5%;padding-left:3%}.question{padding:10px;font-size:14px;color:#007bff}.question1{margin-left:14rem;background:#dedddd;color:#560d05;font-size:15px;padding-bottom:20px;text-align:left}.answer{display:flex;align-items:baseline;padding:5px 5px 10px;font-size:14px;font-weight:400;word-wrap:break-word;width:97%;justify-content:space-between}.answer1{max-width:55%;margin-left:auto;margin-right:auto;color:#a3a2a2;margin-top:0%;padding-bottom:0;font-size:14px;font-weight:400;word-wrap:break-word;text-align:left;background:#dedddd;border-bottom:1px solid #fff}.myt-font{font-size:20px}.myt-font1{width:16rem;font-size:14px;font-weight:400}.myt-font2{font-size:18px}.myt-font3,.myt-font4{font-size:14px}.myt-font5{margin-top:-18px;font-weight:400;font-size:14px;color:#560d05}.myt-font6{font-size:20px;font-weight:700;color:#c5281c;text-align:center}.myt-font10{font-weight:400;font-size:14px;color:#560d05;margin-top:10px}.myt-font7{display:flex;justify-content:flex-start;padding-left:20.5%;font-weight:100;color:#560d05}.myt-font8{font-weight:400}.dpDown:focus-visible{outline:none}.summaryTitle{padding-left:0%;padding-top:4%}.summary-groupText{width:55%;margin:auto auto -2%;text-align:left;font-weight:700;padding-top:0%;padding-bottom:0%;background-color:#dedddd;color:#c5281c}.sum-ques{width:55%;margin:auto}.sum-ques1{width:59%;margin:auto}.header-style{padding:15px!important;background:#F8F8F8;color:#898989!important;border:1px solid #e8e8e8;border-top-left-radius:5px;border-top-right-radius:5px;margin-left:0!important;justify-content:left!important;font-size:15px!important}.form-group.content-box{background:#ffffff;padding:40px;border:1px solid #e8e8e8;border-bottom-left-radius:5px;border-bottom-right-radius:5px}.shengel-myt-font3{padding-bottom:5px;padding-top:5px;padding-right:15px;padding-left:2px!important;color:#9a9a9a!important;font-size:14px!important;font-weight:400!important}.file-upload-btn{display:none;border-bottom:groove}.file-upload-box{max-width:45%;margin-left:29.5%;height:auto;padding:16px;display:flex;border:2px;border-bottom:1px solid #fff;background-color:#dedddd;justify-content:space-between;color:#d8d8d8}.file-label{cursor:pointer;color:#c5281c;text-decoration:underline}.file-uploading-box{font-size:14px;font-weight:400;max-width:45%;margin-left:29.5%;height:56px;padding:16px;display:flex;border:2px;background-color:#dedddd;justify-content:space-between;margin-bottom:0;color:#d8d8d8}.uploading-file-name{color:#6f7072}.deleteIcon{cursor:pointer;height:24px}.file-icon{max-width:24px;height:26px}.picture-upload{height:200px;width:200px;position:relative;border:1px solid #ccc;display:flex;padding:6px 12px;cursor:pointer;background-color:#fff;align-items:center}.colon{line-height:42px;padding:0;margin-top:10%;color:#6f7072}.colon1{display:contents}.subTitle{color:#c5281c;font-weight:600;margin-top:-3%}.subTitle1{color:#560d05;font-size:14px;font-weight:500}.check-icon{color:#87be1c;margin-left:-2rem;z-index:1;padding:5px;margin-top:.4rem}.check-icon2{color:#87be1c;margin-left:-4rem;z-index:1;margin-top:.6rem;line-height:3}.check-icon3{color:#87be1c;margin-left:-4rem;z-index:1;margin-top:3rem}.align-l{text-align:left;padding:1% 2% 2%;margin-bottom:-5%;margin-top:-1%}.attach-ulist{list-style-type:none;margin-left:0;margin-bottom:.7rem}.attach-list{float:right;cursor:pointer;padding:0}.icolor{color:#99b5ce}.picture-upload-child{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.tspan:nth-child(1){font-size:25px;font-weight:700}.tspan:nth-child(2){display:none}.pic-upload{position:absolute;top:15%;left:85%;transform:translate(-50%,-50%)}.btn-block+.btn-block{margin-top:.5rem}input[type=submit].btn-block,input[type=reset].btn-block,input[type=button].btn-block{width:100%}.btn-lg,.btn-group-lg>.btn{padding:.5rem 1rem;font-size:1.25rem;line-height:1.5;border-radius:.3rem}.btn-lg+.dropdown-toggle-split,.btn-group-lg>.btn+.dropdown-toggle-split{padding-right:.75rem;padding-left:.75rem}.btn-primary:hover{color:#fff}.btn-primary:focus,.btn-primary.focus{color:#fff;box-shadow:0 0 0 .2rem #268fff80}.btn-primary.disabled,.btn-primary:disabled{color:#fff}.btn-primary:not(:disabled):not(.disabled):active,.btn-primary:not(:disabled):not(.disabled).active,.show>.btn-primary.dropdown-toggle{color:#fff}.btn-primary:not(:disabled):not(.disabled):active:focus,.btn-primary:not(:disabled):not(.disabled).active:focus,.show>.btn-primary.dropdown-toggle:focus{box-shadow:0 0 0 .2rem #268fff80}.btn-back-color{display:block;width:100%;padding:.5rem 1rem;font-size:1.25rem;line-height:1.5;text-align:center;border-radius:.3rem;margin:0}.fa-plus:hover{color:#87be1c}.fa-plus{color:#99b5ce}.btn-primary{border-color:#007bff}.ques-Title{text-align:left;font-size:24px}.grey{width:38%;height:56px;margin:0px 0px 0px 0rem;padding:14px 0 17px;background-color:#cd2810;color:#fff;font-size:24px}.btn-text{width:330px;font-size:24px;background-color:#cd2810;color:#fff;height:60px;margin-left:auto;margin-top:0;cursor:pointer;border-radius:40px}.btn-text2{width:21rem;font-size:24px;background-color:#cd2810;border:none;color:#fff;height:60px;margin-left:17rem;margin-right:17rem;margin-top:10px;cursor:pointer;border-radius:40px}.flexer{max-width:100%;width:100%;display:flex;justify-content:center}.flexer1{max-width:100%;width:100%;display:flex;justify-content:center;margin-top:32px}.btn-r{right:0rem}.down{margin-left:0;width:57%}.down1{width:16rem;margin-left:0rem;background-color:#dedddd}.down2{margin-top:0%;padding-left:11px}.dropbox{margin-left:21.5rem}.myt-dropbox{background-image:url(https://rnxt.s3.amazonaws.com/MytIcon/down-red.png);background-origin:content-box;background-position:right -.9rem center;background-repeat:no-repeat;background-size:35px 33px;padding-right:1.35rem;background-color:#dedddd}.boxoutline{outline:transparent;background-color:#dedddd}.left-bt{width:238px;background-color:#cd2810;color:#fff;padding:0;text-align:center;font-size:24px;cursor:pointer;height:60px;margin-top:125px;margin-bottom:4rem;margin-left:-234px}.townArea{text-align:left;height:43px;padding-left:15px}.townArea:hover{background-color:#9e9e9e2e}.listFlow{font-weight:400;color:#767676;z-index:2;position:absolute;background:#dedddd;box-shadow:0 2px 5px #00000040}.myt-radio input[type=radio]:checked:after{background-color:#c5281c}.full-summary{margin-top:4%}.container-radio input{display:none;position:absolute;opacity:0;cursor:pointer}.container-radio input:checked~.checkmark{background-color:#fff0}.checkmark:after{content:\"\";display:none}.container-radio input:checked~.checkmark:after{display:block}.container-radio .checkmark:after{top:3px;left:3px;width:12px;margin:3px;height:12px;border-radius:50%;background:#C5281C}.f-Name{color:#6f7072;font-size:14px;font-weight:400;word-break:break-word}.summary-top{margin-top:4%}.myt-border-r{border-top:none;border-left:none;border-right:none;border-radius:0}.myt-align{margin-left:4%;line-height:2}.myt-align1{margin-left:-29px}.myt-align2{margin-left:-15px}.myt-align3{width:100%}.myt-book1{margin-top:-20px}.colorf{color:#555}.bookText{width:57%;margin-left:21.5%;background-color:#dedddd}.book{width:32.6%;margin-left:34%;background-color:#dedddd}.summary-completed{padding-left:2%;margin-top:20px}.town{margin:0;background-color:#dedddd}.town-drop{margin:auto;width:57%}.questiondiv1.padd-bottom{padding-bottom:6rem!important;padding-top:2rem!important}@media (max-width: 1090px){.icon-edit{margin:0 6px -3px -13%!important}}@media (max-width: 768px){.col-md-1,.col-md-10,.col-md-11,.col-md-12,.col-md-2,.col-md-3,.col-md-4,.col-md-5,.col-md-6,.col-md-7,.col-md-8,.col-md-9{float:center}.col-md-12{width:100%}.col-md-11{width:91.66666667%}.col-md-10{width:83.33333333%}.col-md-9{width:75%}.col-md-8{width:66.66666667%}.col-md-7{width:58.33333333%}.col-md-6{width:50%}.col-md-5{width:41.66666667%}.col-md-4{width:33.33333333%}.col-md-3{width:25%}.col-md-2{width:16.66666667%}.col-md-1{width:8.33333333%}}@media (max-width: 768px){.radioOption{width:8%}.grey{width:78%;margin-left:17.5rem;height:68px!important;font-size:20px!important;font-weight:700!important}.answer{margin-top:-4%!important}}@media screen and (max-width: 672px){.header1{font-size:23px!important}.summarypadd{padding-top:50px!important}.answer{margin-top:-5%!important}.icon-edit{margin:0 6px 0 -13%!important}.subTitle1{width:95%!important}.additional{margin-left:6%!important;padding:0!important}.container1{margin-left:-35%}.town-drop{margin:auto;width:100%!important}.dis-flex{display:flex;justify-content:left}.check{display:inherit;width:-moz-max-content;width:max-content;margin-left:6%}.rusty{width:28rem;margin-left:0rem;height:68px!important;font-size:20px!important;font-weight:700!important;margin-bottom:37px}.left-bt{width:28rem;margin-left:-28rem;height:68px!important;font-size:20px!important;font-weight:700!important}.questionalign{text-align:center}.questionalign{margin-top:1rem!important}.largeTitle{padding-left:0!important}.myt-align{margin-left:0%!important}.myt-text1{margin-top:-22px}.myt-text2{margin-top:-20px}.myt-text3{margin-bottom:21px}.date-picker,.dt-time{width:100%}.showminute{margin-top:-.5%}.radioOption{width:auto;margin-top:0;margin-left:7%;margin-right:-3%}.checkmark{left:3.8rem}.myt-font7{padding-left:0rem;margin-left:-1.5%}.down,.bookText,.book{width:100%;margin-left:0rem}.town{margin-left:0rem;width:100%}.file-upload-box,.file-uploading-box{max-width:85%;margin-left:20px}.question{margin-left:0rem}.btn-text2{width:28rem;margin-right:0rem;margin-left:0;height:68px!important;font-size:20px!important;font-weight:700!important}.grey{width:28rem;margin:-21px 0 0;height:68px!important;font-size:20px!important;font-weight:700!important}}@media screen and (max-width: 580px){.rusty{width:27rem;height:68px!important;font-size:20px!important;font-weight:700!important}.left-bt{width:27rem;margin-left:-27rem;height:68px!important;font-size:20px!important;font-weight:700!important}.container1{margin-left:-24%}.showminute{margin-top:.5%}.bookText,.book{width:100%;margin-left:0rem}.btn-text2{width:27rem;margin-right:0rem;margin-left:0;height:68px!important;font-size:20px!important;font-weight:700!important}.grey{width:27rem;margin:-21px 0 0;height:68px!important;font-size:20px!important;font-weight:700!important}.btn-text{width:27rem;height:68px!important;font-size:20px!important;font-weight:700!important}}@media screen and (max-width: 672px){.questiondiv1{padding:0}}@media screen and (max-width: 525px){.rusty{width:26rem;height:68px!important;font-size:20px!important;font-weight:700!important}.container1{margin-left:-9%}.left-bt{width:26rem;margin-left:-26rem;height:68px!important;font-size:20px!important;font-weight:700!important}.dateandtime{padding-left:10px!important}}@media screen and (max-width: 480px){.answer{margin-top:-7%!important}.icon-edit{margin:0 6px 4px -35%!important}.rusty{width:25rem;height:68px!important;font-size:20px!important;font-weight:700!important}.left-bt{width:25rem;margin-left:-25rem;height:68px!important;font-size:20px!important;font-weight:700!important}.file-upload-box,.file-uploading-box{max-width:89%}}@media screen and (max-width: 420px){.answer{margin-top:-9%!important}.icon-edit{margin:-9px 1px 4px 4%!important}.rusty,.btn-text{width:21rem;height:68px!important;font-size:20px!important;font-weight:700!important}.left-bt{width:21rem;margin-left:-21rem;height:68px!important;font-size:20px!important;font-weight:700!important}.container1{margin-left:0%}.file-upload-box,.file-uploading-box{max-width:100%}.myt-dateTimeNew{margin-left:-10px!important}.form-row{padding-left:8px!important}.dateandtime{padding-left:0!important}.dt-time{padding-left:.8%!important}.myt-font7{padding-left:0rem;margin-left:-3.5%}.grey{width:21rem;margin:-21px 0 0;height:68px!important;font-size:20px!important;font-weight:700!important}.btn-text2{width:21rem;margin-right:0rem;margin-left:0;height:68px!important;font-size:20px!important;font-weight:700!important}}@media screen and (max-width: 368px){.icon-edit{margin:0 6px 3px 35%!important}.icon-editios{margin-bottom:4px}.rusty{width:19rem;height:68px!important;font-size:20px!important;font-weight:700!important}.left-bt{width:19rem;margin-left:-19rem;height:68px!important;font-size:20px!important;font-weight:700!important}.container1{margin-left:15%}.radiotext{margin-top:-45px}.file-upload-box,.file-uploading-box{max-width:100%}.grey{width:19rem;margin:-21px 0 0;height:68px!important;font-size:20px!important;font-weight:700!important}.btn-text2{width:19rem;margin-right:0rem;margin-left:0;height:68px!important;font-size:20px!important;font-weight:700!important}.btn-text{width:19rem;height:68px!important;font-size:20px!important;font-weight:700!important}}.mydp .selection{padding:0!important}.text-border{border-top:none;border-left:none;border-right:none;border-radius:0;border-bottom:1px solid #fff!important;background-color:#dedddd}.additional{display:flex;font-size:20px;text-align:left;font-weight:200;margin-left:4%;justify-content:center;color:#3e3e3c;padding:0 30%}.check{display:block}.header2{font-size:20px;font-weight:300;text-align:center;font-stretch:normal;font-style:normal;line-height:1.5;letter-spacing:normal;color:#560d05;max-width:1100px;margin:auto;padding-bottom:10px}.header1{font-size:32px;font-weight:700;text-align:center;font-stretch:normal;font-style:normal;line-height:1.25;letter-spacing:normal;color:#dd2e13}.container1{display:inline-grid;position:relative;cursor:pointer;font-size:20px;-webkit-user-select:none;-moz-user-select:none;user-select:none}.container1 input{position:absolute;opacity:0;cursor:pointer;height:0;width:0}.checkmark1{position:absolute;top:1px;left:-35%;height:21px;width:21px;background-color:#eee}.container1:hover input~.checkmark1{background-color:#ccc}.container1 input:checked~.checkmark1{content:\"\";background-image:url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIxNiIgaGVpZ2h0PSIxMiIgdmlld0JveD0iMCAwIDE2IDEyIj4gIDxwYXRoIGZpbGw9IiM4N0JFMUMiIGZpbGwtcnVsZT0iZXZlbm9kZCIgZD0iTTEyLjI0Mjk1NjUsMTcuNTcyNzczOCBMMjAuOTg1NTM0Nyw5LjEzMjYxNTg1IEMyMS4xNjg1NDM3LDguOTU1OTM3NDEgMjEuNDYyMTgwNyw4Ljk1NTc3NDM2IDIxLjY0NTM5MzYsOS4xMzIyNDk0NCBMMjIuODU5MTUxMywxMC4zMDEzNzAxIEMyMy4wNDY5NDk2LDEwLjQ4MjI2MiAyMy4wNDY5NDk2LDEwLjc3OTA1NjMgMjIuODU5MTUxMywxMC45NTk5NDgyIEwxMi41NzMwNjk2LDIwLjg2Nzc1MDYgQzEyLjM5MDAwNDcsMjEuMDQ0MDgzMSAxMi4wOTY2NTU2LDIxLjA0NDA4MzEgMTEuOTEzNTkwNiwyMC44Njc3NTA2IEw3LjE0MDg0ODc3LDE2LjI3MDUzMDMgQzYuOTU0MTc0MjgsMTYuMDkwNzIwOSA2Ljk1Mjg5MDU1LDE1Ljc5NjA5NTggNy4xMzc5OTEzMywxNS42MTQ3MjgyIEw4LjMzMTE3Njc5LDE0LjQ0NTYwNzUgQzguNTEzODA2NDgsMTQuMjY2NjYxMiA4LjgwOTMzMDgzLDE0LjI2NTQyMjYgOC45OTM1MTMyMiwxNC40NDI4MzE1IEwxMi4yNDI5NTY1LDE3LjU3Mjc3MzggWiIgdHJhbnNmb3JtPSJ0cmFuc2xhdGUoLTcgLTkpIi8+PC9zdmc+);background-position:.17rem .3rem;background-repeat:no-repeat;background-color:#d2d4d6;width:21px;height:21px}.checkmark1:after{content:\"\";position:absolute;display:none}.container1 input:checked~.checkmark1:after{display:block}.container1 .checkmark1:after{left:9px;top:5px;width:5px;height:10px;border-width:0 3px 3px 0}.bottomspace1{padding-bottom:14px!important}.myt-321{font-size:20px;font-weight:700;color:#c5281c;margin-top:11px}.myt-345{display:none}.panel{-moz-box-shadow:0px 1px 2px 0px rgba(0,0,0,.1);-webkit-box-shadow:0px 1px 2px 0px rgba(0,0,0,.1);border-radius:0;border:none;box-shadow:0 1px 2px #0000001a;margin-bottom:20px}.panel .panel-body{padding:20px}.panel-heading{border-radius:0;border:none!important;padding:10px 20px}.panel-default>.panel-heading{background-color:#fafafa;border-bottom:none;color:#2a323c;border:1px solid #e3e3e3!important}.panel-title{margin-bottom:0;margin-top:0;font-family:Rubik,sans-serif;font-weight:400}.panel-footer{background:#fafafa;border-top:0}.panel-color .panel-title{color:#fff}.panel-primary>.panel-heading{background-color:#03a9f4}.panel-success>.panel-heading{background-color:#01ba9a}.panel-info>.panel-heading{background-color:#18bae2}.panel-warning>.panel-heading{background-color:#f8ca4e}.panel-danger>.panel-heading{background-color:#f62f37}.panel-dark>.panel-heading{background-color:#2a323c;color:#fff}.panel-fill{border-radius:3px}.panel-fill .panel-heading{background-color:transparent;color:#fff;border-bottom:1px solid rgba(255,255,255,.5)!important}.panel-fill .panel-body{color:#ffffffd9}.panel-fill.panel-default .panel-body{color:#666}.panel-fill.panel-default .panel-heading{background-color:transparent;color:#333;border-bottom:1px solid rgba(0,0,0,.1)!important}.panel-fill.panel-primary{background-color:#03a9f4}.panel-fill.panel-success{background-color:#01ba9a}.panel-fill.panel-info{background-color:#18bae2}.panel-fill.panel-warning{background-color:#f8ca4e}.panel-fill.panel-danger{background-color:#f62f37}.panel-fill.panel-dark{background-color:#2a323c}.panel-group .panel .panel-heading a[data-toggle=collapse].collapsed:before{content:\"\\f0d7\"}.panel-group .panel .panel-heading .accordion-toggle.collapsed:before{content:\"\\f0d7\"}.panel-group .panel .panel-heading a[data-toggle=collapse]{display:block}.panel-group .panel .panel-heading a[data-toggle=collapse]:before{content:\"\\f0d8\";display:block;float:right;font-family:FontAwesome;font-size:14px;text-align:right;width:25px}.panel-group .panel .panel-heading .accordion-toggle{display:block}.panel-group .panel .panel-heading .accordion-toggle:before{content:\"\\f068\";display:block;float:right;font-family:FontAwesome;font-size:14px;text-align:right;width:25px}.panel-group .panel .panel-heading+.panel-collapse .panel-body{border-top:none!important;border:1px solid #e3e3e3}.panel-group .panel-heading{padding:12px 26px}.panel-group.panel-group-joined .panel+.panel{border-top:1px solid #eeeeee;margin-top:0}.panel-group-joined .panel-group .panel+.panel{border-top:1px solid #eeeeee;margin-top:0}.panel-body label{color:#9a9a9a;font-size:14px;font-weight:400;display:inline-block;max-width:100%;margin-bottom:5px}.font-size{font-size:14px}.panel-title>.small,.panel-title>.small>a,.panel-title>a,.panel-title>small,.panel-title>small>a{color:inherit;text-decoration:none}.panel-title{font-size:16px}@media (min-width: 300px) and (max-width: 399px){.selbtngroup{padding-left:1.3%!important}}@media (min-width: 400px) and (max-width: 480px){.selbtngroup{padding-left:.9%!important}}@media (min-width: 481px) and (max-width: 580px){.selbtngroup{padding-left:.2%!important}}@media screen and (min-width: 871px){.selbtngroup{padding-right:4px!important}}@media screen and (max-width: 689px){.answer{max-width:95%!important;margin-left:0!important;margin-right:15px}#progress2{margin-left:8.5px!important}.edit{margin-left:85%!important;margin-bottom:0%!important}.sum-ques,.sum-ques1{width:100%!important;margin:auto}.summary-completed{padding-left:0!important;padding-bottom:17px;margin-top:9px}.summary-top{margin-top:10%}.subTitle1{font-size:18px!important;line-height:1.38!important;text-align:center;letter-spacing:normal;color:#560d05!important;font-weight:300}.backbutton{display:none}.rusty{margin-bottom:37px}}@media screen and (min-width: 1024px){.ES-style{position:absolute;left:7px;font-size:.9rem;color:#555;top:9px}}@media screen and (max-width: 1024px){.ES-style{position:absolute;left:.6rem;font-size:.95rem;color:#555;top:.57rem}}@media screen and (max-width: 689px){.app-back1{line-height:1.5;cursor:pointer;width:100%;max-width:1200px;margin-right:auto;margin-left:-10px;display:flex;font-family:Helvetica;font-size:21px;font-weight:700;align-items:center;font-stretch:normal;font-style:normal;letter-spacing:normal;color:#dd2e13;z-index:1;position:fixed;background-color:#dedddd;border-radius:0!important;margin-top:-12px;padding-top:.8rem}.header1{padding-top:75px}.dt-time{background-position:100%!important}}.summary-volver{display:none}@media ((min-width: 1200px)){.form-row{display:flex;flex-wrap:wrap}}\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: "directive", type: i6.NgSelectOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i6.ɵNgSelectMultipleOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i6.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i6.CheckboxControlValueAccessor, selector: "input[type=checkbox][formControlName],input[type=checkbox][formControl],input[type=checkbox][ngModel]" }, { kind: "directive", type: i6.SelectControlValueAccessor, selector: "select:not([multiple])[formControlName],select:not([multiple])[formControl],select:not([multiple])[ngModel]", inputs: ["compareWith"] }, { kind: "directive", type: i6.RadioControlValueAccessor, selector: "input[type=radio][formControlName],input[type=radio][formControl],input[type=radio][ngModel]", inputs: ["name", "formControlName", "value"] }, { kind: "directive", type: i6.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i6.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i6.MaxLengthValidator, selector: "[maxlength][formControlName],[maxlength][formControl],[maxlength][ngModel]", inputs: ["maxlength"] }, { kind: "directive", type: i6.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i9.MyDatePicker, selector: "my-date-picker", inputs: ["placeholder", "locale", "disabled", "options", "defaultMonth", "selDate", "selector"], outputs: ["dateChanged", "inputFieldChanged", "calendarViewChanged", "calendarToggle", "inputFocusBlur"], exportAs: ["mydatepicker"] }, { kind: "component", type: i5.NgxSpinnerComponent, selector: "ngx-spinner", inputs: ["disableAnimation", "bdColor", "zIndex", "color", "type", "size", "fullScreen", "name", "template", "showSpinner"] }, { kind: "component", type: i10.CircleProgressComponent, selector: "circle-progress", inputs: ["name", "class", "backgroundGradient", "backgroundColor", "backgroundGradientStopColor", "backgroundOpacity", "backgroundStroke", "backgroundStrokeWidth", "backgroundPadding", "radius", "space", "percent", "toFixed", "maxPercent", "renderOnClick", "units", "unitsFontSize", "unitsFontWeight", "unitsColor", "outerStrokeGradient", "outerStrokeWidth", "outerStrokeColor", "outerStrokeGradientStopColor", "outerStrokeLinecap", "innerStrokeColor", "innerStrokeWidth", "titleFormat", "title", "titleColor", "titleFontSize", "titleFontWeight", "subtitleFormat", "subtitle", "subtitleColor", "subtitleFontSize", "subtitleFontWeight", "imageSrc", "imageHeight", "imageWidth", "animation", "animateTitle", "animateSubtitle", "animationDuration", "showTitle", "showSubtitle", "showUnits", "showImage", "showBackground", "showInnerStroke", "clockwise", "responsive", "startFromZero", "showZeroOuterStroke", "lazy", "options"], outputs: ["onClick"] }, { kind: "component", type: i11.PickLocationComponent, selector: "app-pick-location", inputs: ["address"], outputs: ["locationSelected"] }, { kind: "component", type: i12.CustomInputComponent, selector: "app-custom-input", inputs: ["value", "disabled", "placeholder", "error", "fromShengel", "ngClassValue", "idValue", "focusEvent"], outputs: ["inputValue"] }, { kind: "component", type: i13.CustomTextAreaComponent, selector: "app-custom-text-area", inputs: ["value", "placeholder", "rows", "error"], outputs: ["textareaValueChange"] }, { kind: "component", type: i14.CustomTableComponent, selector: "app-custom-table", inputs: ["tableHeader", "tableData", "tableIndex"], outputs: ["tableDataChange"] }, { kind: "component", type: i15.CustomDatePickerComponent, selector: "app-custom-date-picker", inputs: ["date", "minDate", "maxDate"], outputs: ["dateChange"] }, { kind: "component", type: i16.DropdownWithFlagComponent, selector: "app-dropdown-with-flag", inputs: ["certified", "JobPerformerCertificates"], outputs: ["flagDropDownChange"] }, { kind: "component", type: i17.CustomDropdownComponent, selector: "app-custom-dropdown", inputs: ["options", "placeholder", "apiMeta", "selectedValue", "progressBar", "id", "errorMessage", "error", "fromShengel"], outputs: ["valueChange"] }], encapsulation: i0.ViewEncapsulation.None });
2114
+ }
2115
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: QuestionnaireComponent, decorators: [{
2116
+ type: Component,
2117
+ args: [{ selector: "lib-questionnaire", encapsulation: ViewEncapsulation.None, template: "<!-- Spinner -->\n<ngx-spinner [name]=\"spinnerName\" [type]=\"spinnerType\"></ngx-spinner>\n\n<!-- Back Processing -->\n<div *ngIf=\"backicon == false\" >\n <div class=\"backicon\" [style.visibility]=\"questionStack.length >0 ? 'visible' : 'hidden'\">\n <button (click)=\"handleBackClick()\" [class]=\" abItem?.Status__c == 'Completed' ? 'summary-volver':'app-back1'\">\n <img class=\"icon-arrow-back\" src=\"https://rnxt.s3.amazonaws.com/MytIcon/icon-arrow-back.png\" alt=\"Scroll down\"> {{ qbItem?.Back__c }}\n </button>\n </div>\n</div>\n\n<!-- Question Hanlding -->\n<div *ngIf=\"questionItem\" [class]=\"qbItem.isShengel__c ? 'questiondiv1' : 'questiondiv1 padd-bottom'\">\n <!-- Progress Bar & Title -->\n <div *ngIf=\"questionItem.Title__c && qbItem.Progress_Bar__c\">\n <h1 class=\"header1\">{{ questionItem?.Title__c }}</h1>\n <div class=\"header2\">{{ questionItem?.SubTitle__c }}</div>\n </div>\n\n <!-- Progress & Grouping -->\n <div [ngClass]=\"{ questiondiv2: !qbItem?.Progress_Bar__c }\">\n <!-- Pie Chart Progress -->\n <div [ngClass]=\"{ bgColor: qbItem?.Progress_Bar__c }\">\n <div id=\"progress\" *ngIf=\"qbItem?.Progress_Bar__c\">\n <circle-progress class=\"titlebar\" [percent]=\"this.percent\" [radius]=\"40\" [space]=\"-4\" [outerStrokeWidth]=\"4\"\n [innerStrokeWidth]=\"4\" [outerStrokeColor]=\"'#e0b1b0'\" [innerStrokeColor]=\"'#e7e8ea'\" [animation]=\"true\" [backgroundPadding]= \"0\"\n [backgroundColor]= \"'#dd2e13'\" [backgroundGradientStopColor]=\"'#f9bfbd'\" [titleColor]=\"'#f3eded'\" \n class=\"ng-star-inserted\" [title]=\"this.percent+'%'\" [showSubtitle]=\"false\" [showBackground]=\"true\" [animationDuration]=\"300\"\n [startFromZero]=\"false\" [responsive]=\"false\" >\n </circle-progress>\n </div>\n </div>\n\n <!-- Show the Group/Module related to the Progress -->\n <div *ngIf=\"questionItem.Group__c && qbItem.Progress_Bar__c\"\n [ngClass]=\"{ questionalign: !qbItem?.Progress_Bar__c }\">\n <div class=\"largeTitle\">\n <h3 class=\"myt-font6 myt-text3\">\n {{ questionItem?.Group__c }}\n </h3>\n <div *ngIf=\"questionItem.Sub_Text__c != '\u00BFEn qu\u00E9 pa\u00EDs ocurri\u00F3?'\" class=\"myt-font5 myt-text1\">{{questionItem?.Sub_Text__c}}</div>\n <div *ngIf=\"questionItem.Sub_Text__c === '\u00BFEn qu\u00E9 pa\u00EDs ocurri\u00F3?'\" class=\"myt-font10 myt-text2\">{{questionItem?.Sub_Text__c}}</div>\n </div>\n </div>\n </div>\n\n <!-- Question Handling -->\n <div class=\"questiondiv2\">\n <!-- Title -->\n <div *ngIf=\"questionItem.Is_Title__c\">\n <div *ngIf=\"questionItem.Type__c != 'Book' && questionItem.Question_No__c!='6' && questionItem.Question_No__c!='9'\"> \n <h3 class=\"questionalign myt-font3 myt-align myt-text4\" [innerHTML]=\"getText(questionItem?.Question_Text__c)\">\n {{questionItem?.Question_Text__c}}\n </h3>\n </div>\n </div>\n <div *ngIf=\"!questionItem.Is_Title__c\" [class]=\"qbItem.isShengel__c ? 'header-style additional' : 'question-f-size additional'\">\n <div [innerHTML]=\"getText(questionItem?.Question_Text__c)\" >\n {{ questionItem?.Question_Text__c }}\n </div>\n </div>\n\n <!-- This should be removed with Custom Styling - MR - 11AUG23 -->\n <div *ngIf=\"questionItem.Type__c == 'Book'\">\n <div *ngIf=\"questionItem.Question_No__c=='6'\">\n <h3 class=\"myt-321\" [innerHTML]=\"getText(questionItem?.Question_Text__c)\">\n {{ questionItem?.Question_Text__c }}\n </h3>\n </div>\n </div>\n \n <!-- This should be removed with Custom Styling - MR - 11AUG23 -->\n <div *ngIf=\"questionItem.Type__c == 'File' \">\n <div *ngIf=\"questionItem.Question_No__c=='9'\">\n <h3 class=\"myt-345\" [innerHTML]=\"getText(questionItem?.Question_Text__c)\">\n {{questionItem?.Question_Text__c}}\n </h3>\n </div>\n </div>\n </div>\n\n <!-- Additional Info -->\n <!-- The below code can be written effectively nested ngIf for Rich Text & Other onw for Progress Bar -->\n <div *ngIf=\"questionItem.Additional_Rich__c && qbItem.Progress_Bar__c\" >\n <div\n class=\"additional \" [innerHTML]=\"innerhtml\">\n </div>\n </div>\n <div *ngIf=\"questionItem.Additional_Rich__c && !qbItem.Progress_Bar__c\">\n <div class=\"info-alert ques-alert1\">\n <i class=\"fa fa-info fa-3x iposition icolor\" aria-hidden=\"true\"></i>\n <div class=\"infodiv\" [innerHTML]=\"innerhtml\"></div>\n </div>\n </div>\n\n <!-- Dropdown-->\n <div *ngIf=\"dropdownFlag\" >\n <div class=\"dis-flex\">\n <select \n [ngClass]=\"{\n 'dt-line myt-align3 myt-align2 dpDown dropbox down1 myt-dropbox myt-border-r myt-font1': qbItem?.Progress_Bar__c,\n 'custom-select': !qbItem?.Progress_Bar__c\n }\" class=\"mr-sm-2 dd-height dropbox \" id=\"dropdown\" [(ngModel)]=\"inpValue\" (change)=\"clearError()\" style.border-color=\"{{\n this.questionItem?.error ? 'red' : inpValue?.length > 0 ? '#fff' : ''\n }}\" style.color=\"{{ questionItem?.error ? 'red' : '' }}\" style=\"margin-left: 21.5rem !important;\">\n <option *ngFor=\"let opt of questionItem.Question_Options__r.records\" class=\"option\" value=\"{{ opt.Value__c }}\">\n {{ opt.Value__c }}\n </option>\n <option value=\".\" disabled hidden>Bitte treffen Sie eine Auswahl</option>\n </select>\n </div>\n </div>\n\n <!-- Radio -->\n <div *ngIf=\"radioFlag || dataFlag\" class=\"\">\n <div *ngIf=\"this.questionItem.error\" class=\"cond-div2\">\n {{ questionItem?.Error_Message__c }}\n </div>\n <div class=\"dis-flex\">\n <div *ngFor=\"let opt of questionItem.Question_Options__r.records\" class=\"radio radioOption\" >\n <label class=\"radiocontainer container myt-font4\">{{ opt.Value__c }}\n <input type=\"radio\" [id]=\"opt.Id\" [(ngModel)]=\"inpValue\" name=\"inpValue\" value=\"{{ opt.Value__c }}\"\n (change)=\"optionChange(opt.Value__c)\" />\n <span class=\"checkmark\"></span>\n </label>\n </div>\n </div>\n </div>\n\n <!-- Checkbox -->\n <div *ngIf=\"checkboxFlag\" class=\"\">\n <div *ngIf=\"this.questionItem.error\" class=\"cond-div2\">\n {{ questionItem?.Error_Message__c }}\n </div>\n <div class=\"dis-flex\">\n <div *ngFor=\"let item of optionValues\" class=\"radio col-md-6 optiondiv\">\n <label class=\" container1 \" >{{ item.Value__c }}\n <input type=\"checkbox\" [id]=\"item.Id\" [(ngModel)]=\"item.checked\" (click)=\"clearError()\" />\n <span class='checkmark1'></span>\n </label>\n </div>\n </div>\n </div>\n\n <!-- Text -->\n <div *ngIf=\"textFlag\" class=\"col-md-12 myt-book1\">\n <div class=\"col-md-12\" class=\"dis-flex myt-align1\" [class]=\"'col-md-' + questionItem?.Size__c + ' paddingnone'\">\n <input type=\"text\" [(ngModel)]=\"inpValue\" [ngClass]=\"{\n 'boxoutline myt-font1 myt-book1': qbItem?.Progress_Bar__c,\n textBox1: !qbItem?.Progress_Bar__c\n }\" id=\"text-input-id\" required=\"\" (focus)=\"clearError()\" style.border-color=\"{{\n this.questionItem?.error\n ? 'red'\n : inpValue?.length > 0\n ? '#87be1c'\n : ''\n }}\" oninput=\"this.value=this.value.replace(/[^a-zA-Z0-9\\s.:;,?]/g,'');\" />\n <i class=\"fa fa-check check-icon\" aria-hidden=\"true\" *ngIf=\"inpValue?.length > 0\"></i>\n </div>\n </div>\n\n <!-- Text Area -->\n <div *ngIf=\"taFlag\" class=\"col-md-12\">\n <div class=\"dis-flex\">\n <textarea class=\"ta-input\" id=\"ta-input-id\" [(ngModel)]=\"inpValue\" (click)=\"clearError()\" style.border-color=\"{{\n this.questionItem?.error\n ? 'red'\n : inpValue?.length > 0 && taFocusOut\n ? '#87be1c'\n : ''\n }}\" (focusout)=\"taFocusOut = true\"\n oninput=\"this.value=this.value.replace(/[^a-zA-Z0-9\\s.:;,?]/g,'');\"></textarea>\n <i class=\"fa fa-check check-icon\" aria-hidden=\"true\" *ngIf=\"inpValue?.length > 0 && taFocusOut\"></i>\n </div>\n </div>\n\n <!-- CC Number Format -->\n <div *ngIf=\"numberFlag\" class=\"col-md-12\">\n <div class=\"dis-flex\">\n <input type=\"Text\" placeholder=\"0000 0000 0000 0000 0000 0000\" [ngClass]=\"{ boxoutline: qbItem?.Progress_Bar__c }\"\n [(ngModel)]=\"inpValue\" id=\"number-input-id\" (ngModelChange)=\"CCOnChange($event)\" required=\"\" maxlength=\"29\"\n (focus)=\"clearError()\" oninput=\"this.value=this.value.replace(/[^0-9 ]/g,'');\"\n style=\"width:-webkit-fill-available;\" style.border-color=\"{{\n this.questionItem.error\n ? 'red'\n : inpValue?.length > 0\n ? '#87be1c'\n : ''\n }}\" />\n <i class=\"fa fa-check\" aria-hidden=\"true\" style=\"color: #87be1c; margin-left: -2rem; z-index: 1; padding: 5px;\"\n *ngIf=\"inpValue?.length > 0\"></i>\n </div>\n </div>\n <!-- END-->\n\n <!-- AlphaNumeric -->\n <div *ngIf=\"alphanumericFlag\" class=\"col-md-12\"> <!--UI not completed-->\n <div style=\"position:relative;\">\n <input type=text placeholder=\"0 of 0\" style=\"padding:5px 5px 5px 150px;\" id=\"youridhere\"/>\n </div>\n </div>\n\n <!-- Email -->\n <div *ngIf=\"emailFlag\" class=\"col-md-12\">\n <div class=\"dis-flex\">\n <input type=\"email\" [ngClass]=\"{ boxoutline: qbItem?.Progress_Bar__c }\" [(ngModel)]=\"inpValue\" id=\"email-input-id\"\n required=\"\" (focus)=\"clearError()\" style.border-color=\"{{\n this.questionItem.error\n ? 'red'\n : inpValue?.length > 0\n ? '#87be1c'\n : ''\n }}\" />\n <i class=\"fa fa-check\" aria-hidden=\"true\" style=\"color: #87be1c; margin-left: -2rem; z-index: 1; padding: 5px\"\n *ngIf=\"inpValue?.length > 0\"></i>\n </div>\n </div>\n\n <!-- DateTime -->\n <div *ngIf=\"dtFlag\" class=\"col-md-12 paddingZero myt-time1\" >\n <!-- Error Handling -->\n <div class=\"col-md-12\" *ngIf=\"questionItem.error\" style=\"font-size: 18px;\n color: red;\">{{questionItem?.error?.errorMsg}}</div>\n\n <!-- Date -->\n <div *ngIf=\"dateFlag\">\n <div class=\"col-md-12 paddingBottom\">\n <label class=\"date-time colorf\">{{ questionItem?.Date_Text__c }}</label>\n <div class=\"dis-flex\">\n <my-date-picker name=\"mydate\" [options]=\"myDatePickerOptions\" id=\"date\" style=\"font-size: 18px !important;\" (dateChanged)=\"onDateChanged($event)\"\n [(ngModel)]=\"selDate\" class=\"date-picker\" placeholder=\"Seleccione fecha\" (focus)=\"clearError()\">\n </my-date-picker>\n </div>\n </div>\n </div>\n\n <!-- Time -->\n <div *ngIf=\"timeFlag\">\n <div class=\"col-md-12 paddingBottom\">\n <label class=\"date-time colorf\">{{ questionItem?.Time_Text__c }}</label>\n <div class=\"dis-flex\">\n <div [ngClass]=\"{'dt-line date-line dt-time': qbItem?.Progress_Bar__c,\n dateandTime: !qbItem?.Progress_Bar__c}\" \n id=\"dateandTime\" [style.border-color]=\"questionItem?.error ? 'red': questionItem?.input?.length > 0 ? '' : ''\"\n (focus)=\"(clearSQError) \">\n <select name=\"hours\" class=\"datetime showHour myt-time myt-hour\" [(ngModel)]=\"selectedHour\" id=\"hour\"\n (focus)=\"clearError()\">\n <option value=\"\">HH</option>\n <option [value]=\"hour\" *ngFor=\"let hour of hours\">\n {{ hour }}\n </option>\n </select>\n <span class=\"colon\"> : </span>\n <select name=\"minutes\" class=\"datetime showminute myt-time\" [(ngModel)]=\"selectedMinute\" id=\"minute\"\n (focus)=\"clearError()\">\n <option value=\"\">MM</option>\n <option [value]=\"minute\" *ngFor=\"let minute of minutes\">\n {{ minute }}\n </option>\n </select>\n <div [ngClass]=\"{ colon1: qbItem?.Progress_Bar__c }\" *ngIf=\"questionItem?.X24_Hours__c == false\">\n <span class=\"colon\"> : </span>\n <select name=\"AM/PM\" class=\"myt-time\" [(ngModel)]=\"selectedMeridiem\" id=\"meridiem\">\n <option value=\"AM\">AM</option>\n <option value=\"PM\">PM</option>\n </select>\n <!-- <div [ngClass]=\"{'': qbItem.Progress_Bar__c, 'dateandTime': !qbItem.Progress_Bar__c}\"></div> -->\n </div>\n </div>\n </div>\n </div>\n <i class=\"fa check-icon3\" aria-hidden=\"true\" *ngIf=\"questionItem?.input?.length > 0\"></i>\n </div>\n </div>\n\n <!-- Attachment / File -->\n <div *ngIf=\"fileFlag\">\n <div *ngIf=\"!qbItem.Progress_Bar__c\">\n <div class=\"info-alert\" style.border-color=\"{{ this.questionItem?.error ? 'red' : '' }}\">\n <label class=\"picture-upload\" for=\"file-upload\">\n <span class=\"picture-upload-child\">\n <i class=\"fa fa-file-image-o fa-5x icolor\" aria-hidden=\"true\"></i>\n </span>\n <span class=\"fa fa-plus fa-2x picture-upload-child pic-upload icolor\">\n <i class=\"\" aria-hidden=\"true\"></i>\n </span>\n </label>\n </div>\n <input id=\"file-upload\" type=\"file\" accept=\"{{ allowedFileExtension }}\" (change)=\"uploadFile($event)\" />\n </div>\n <ul *ngIf=\"\n attachments?.length > 0 &&\n questionItem?.Type__c === 'File' &&\n !qbItem?.Progress_Bar__c\n \" class=\"attach-ulist col-md-12\">\n <li *ngFor=\"let attachment of attachments\" class=\"align-l\">\n {{ attachment.attachmentName\n }}<span class=\"attach-list\" (click)=\"deleteAttachment(attachment.attachmentId)\">X</span>\n </li>\n </ul>\n\n <!-- Attachment Progress -->\n <div *ngIf=\"qbItem.Progress_Bar__c\">\n <div *ngFor=\"let attachment of attachments\" class=\"file-uploading-box\">\n <!--<img src=\"https://rnxt.s3.amazonaws.com/MytIcon/icon-doc-img%402x.png\" class=\"icon-edit1\" />-->\n <span class=\"uploading-file-name \">{{ attachment.attachmentName }}</span>\n <img src=\"https://rnxt.s3.amazonaws.com/MytIcon/icon-delete%402x.png\" class=\"deleteIcon\"\n (click)=\"deleteAttachment(attachment.attachmentId)\" />\n </div>\n <div class=\"file-upload-box\" style.border-color=\"{{ this.questionItem.error ? 'red' : '' }}\">\n \n <!--<img src=\"https://rnxt.s3.amazonaws.com/MytIcon/icon-doc-img%402x.png\" class=\"icon-edit1\" />-->\n <span class=\"f-Name\" [innerHTML]=\"getText(questionItem?.Question_Text__c)\"> {{ questionItem?.Question_Text__c}}</span>\n <label class=\"file-label \">\n <img src=\"https://rnxt.s3.amazonaws.com/MytIcon/file-upload.png\" class=\"file-icon\"/>\n <input name=\"attachment\" type=\"file\" placeholder=\"Ticket kaufen\" multiple\n accept=\".pdf, .png, .jpg, .jpeg, .heic, .application/pdf\" (change)=\"uploadFile($event)\"\n class=\"file-upload-btn\">\n </label>\n </div>\n </div>\n </div>\n\n <!-- Book -->\n <div *ngIf=\"bookFlag\">\n <div [class]=\"qbItem.isShengel__c ? 'form-group content-box' : 'form-group'\">\n <div class=\"form-row\">\n <div class=\"col-md-12\" *ngIf=\"questionItem.error\" style=\"font-size: 18px;\n color: red;\">{{questionItem?.error?.errorMsg}}</div>\n <div [class]=\"qbItem.isShengel__c ? '' : 'myt-align3'\" [class]=\"qbItem.isShengel__c ? 'col-lg-' + ques.Size__c + ' paddingnone' : 'col-md-' + ques.Size__c + ' paddingnone'\"\n *ngFor=\"let ques of subQuestions;let i = index\">\n <div [ngClass]=\"{ down2: qbItem?.Progress_Bar__c }\">\n <span [class]=\"qbItem.isShengel__c ? 'dis-flex shengel-myt-font3 myt-font7' : 'dis-flex myt-font3 myt-font7' \">{{ ques?.Question__c }}</span>\n </div>\n <div class=\"col-md-12 paddingZero myt-dateTimeNew\" *ngIf=\"ques.Type__c === 'Time' || ques.Type__c === 'Date'\">\n <div *ngIf=\"ques.Type__c === 'Date'\">\n <div class=\"col-md-12 paddingBottom\">\n <label class=\"date-time colorf\">{{ questionItem?.Date_Text__c }}</label>\n <div class=\"dis-flex dateandtime\">\n <my-date-picker name=\"mydate\" [options]=\"myDatePickerOptions\" id=\"date\" style=\"font-size: 18px !important;\" (dateChanged)=\"onDateChanged($event)\"\n [(ngModel)]=\"selDate\" class=\"date-picker\" placeholder=\"Seleccione fecha\" (focus)=\"clearError()\" >\n </my-date-picker>\n </div>\n </div>\n </div>\n <div *ngIf=\"ques.Type__c === 'Time'\">\n <div class=\"col-md-12 paddingBottom\">\n <label class=\"date-time colorf\">{{ questionItem?.Time_Text__c }}</label>\n <div class=\"dis-flex dateandtime\">\n <div [ngClass]=\"{'dt-line date-line dt-time': qbItem?.Progress_Bar__c,\n dateandTime: !qbItem?.Progress_Bar__c}\" \n id=\"dateandTime\" [style.border-color]=\"questionItem?.error ? 'red': questionItem?.input?.length > 0 ? '' : ''\"\n (focus)=\"(clearSQError) \">\n <select name=\"hours\" class=\"datetime showHour myt-time myt-hour\" [(ngModel)]=\"selectedHour\" id=\"hour\"\n (focus)=\"clearError()\">\n <option value=\"\">HH</option>\n <option [value]=\"hour\" *ngFor=\"let hour of hours\">\n {{ hour }}\n </option>\n </select>\n <span class=\"colon\"> : </span>\n <select name=\"minutes\" class=\"datetime showminute myt-time\" [(ngModel)]=\"selectedMinute\" id=\"minute\"\n (focus)=\"clearError()\">\n <option value=\"\">MM</option>\n <option [value]=\"minute\" *ngFor=\"let minute of minutes\">\n {{ minute }}\n </option>\n </select>\n <div [ngClass]=\"{ colon1: qbItem?.Progress_Bar__c }\" *ngIf=\"questionItem.X24_Hours__c == false\">\n <span class=\"colon\"> : </span>\n <select name=\"AM/PM\" class=\"myt-time\" [(ngModel)]=\"selectedMeridiem\" id=\"meridiem\">\n <option value=\"AM\">AM</option>\n <option value=\"PM\">PM</option>\n </select>\n </div>\n </div>\n </div>\n </div>\n </div>\n </div>\n <div *ngIf=\"ques.Type__c === 'DateTime'\">\n <app-custom-date-picker [minDate]=\"ques.minDate\" [date]=\"ques.input\" (dateChange)=\"displayDate($event,ques)\"></app-custom-date-picker>\n </div>\n <div *ngIf=\"ques.Type__c === 'Text'\">\n <app-custom-input\n [fromShengel]=\"qbItem.isShengel__c\"\n [value]=\"ques.input\"\n [ngClassValue]=\"{\n 'dis-flex dt-line date-line bookText boxoutline myt-font1': qbItem.Progress_Bar__c,\n textBox: !qbItem.Progress_Bar__c\n }\"\n [idValue]=\"ques.Id\"\n [focusEvent]=\"clearSQError(ques.Id)\"\n [error]=\"ques.error\"\n [placeholder]=\"ques.Question__c\"\n (inputValue)=\"selectedInput($event,ques)\">\n </app-custom-input>\n </div>\n <div *ngIf=\"ques.Type__c === 'Location'\">\n <!-- for pick location -->\n <app-pick-location [address]=\"ques.input\" (locationSelected)=\"handleLocationSelected($event,ques)\"></app-pick-location>\n </div>\n <!-- for text area -->\n <div *ngIf=\"ques.Type__c === 'TextArea'\">\n <app-custom-text-area [value]=\"ques.input\" [rows]=\"3\" [error]=\"ques.error\" [placeholder]=\"ques.Question__c \" (textareaValueChange)=\"handleTextareaValueChange($event)\"></app-custom-text-area>\n </div>\n <!-- for to data table we use 'data' type question -->\n <div *ngIf=\"ques.Type__c === 'Data'\">\n <app-custom-table [tableHeader]=\"ques.tableHeader\" [tableData]=\"getTableData(ques)\" [tableIndex]=\"i\" (tableDataChange)=\"getData($event)\"></app-custom-table>\n </div>\n\n <div *ngIf=\"ques.Type__c === 'Email'\">\n <input type=\"email\" [(ngModel)]=\"ques.input\" [id]=\"ques.Id\" required=\"\" (focus)=\"clearSQError(ques.Id)\"\n style.border-color=\"{{ ques.error ? 'red' : '' }}\" placeholder=\"{{ ques.Question__c }}\" />\n </div>\n\n <div *ngIf=\"ques.Type__c === 'File'\">\n <div *ngIf=\"!qbItem.Progress_Bar__c\">\n <label class=\"picture-upload custom-file-upload bgcolor-w\" for=\"file-upload\">\n <span class=\"picture-upload-child\">\n <i class=\"fa fa-file-image-o fa-5x icolor\" aria-hidden=\"true\"></i>\n </span>\n <span class=\"\n fa fa-plus fa-2x\n picture-upload-child\n pic-upload\n icolor\n \">\n <i class=\"\" aria-hidden=\"true\"></i>\n </span>\n </label>\n <input id=\"file-upload\" type=\"file\" accept=\"{{ bookFlagAccept }}\" (change)=\"uploadFile($event,ques)\" />\n </div>\n\n <ul *ngIf=\"\n attachments?.length > 0 &&\n ques.Type__c === 'File' &&\n !qbItem.Progress_Bar__c\n \" class=\"attach-ulist col-md-12\">\n <li *ngFor=\"let attachment of attachments\" class=\"align-l\">\n {{ attachment.attachmentName\n }}<span class=\"attach-list\" (click)=\"deleteAttachment(attachment.attachmentId)\">X</span>\n </li>\n </ul>\n <div class=\"myt-box\" *ngIf=\"qbItem.Progress_Bar__c\">\n\n <div *ngFor=\"let attachment of attachments\" class=\"file-uploading-box\">\n <img src=\"https://rnxt.s3.amazonaws.com/MytIcon/icon-doc-img%402x.png\" class=\"icon-edit1\" />\n <span class=\"uploading-file-name myt-font1 font-weight: normal;\"> {{ attachment.attachmentName }}</span>\n <img src=\"https://rnxt.s3.amazonaws.com/MytIcon/icon-delete%402x.png\" class=\"deleteIcon\"\n (click)=\"deleteAttachment(attachment.attachmentId)\" />\n </div>\n <div class=\"file-upload-box\" style.border-color=\"{{ this.questionItem.error ? 'red' : '' }}\">\n <img src=\"https://rnxt.s3.amazonaws.com/MytIcon/icon-doc-img%402x.png\" class=\"icon-edit1\" />\n <span class=\"f-Name\">{{ ques?.Question__c }}</span>\n <label class=\"file-label \">\n <span style=\"color: #c5281c;text-decoration:underline\">\n Adjuntar\n </span>\n <input name=\"attachment\" type=\"file\" placeholder=\"Ticket kaufen\" multiple\n accept=\".pdf, .png, .jpg, .jpeg, .heic, .application/pdf\" (change)=\"uploadFile($event,ques)\"\n class=\"file-upload-btn\">\n </label>\n </div>\n </div>\n </div>\n\n <!-- Dropdown -->\n <div *ngIf=\"ques.Type__c === 'Dropdown'\" class=\"\">\n <!-- for common dropdown -->\n <app-custom-dropdown [fromShengel]=\"qbItem.isShengel__c\"\n [options]=\"ques.Question_Options__r.records\"\n [apiMeta]=\"ques.Sub_Text__c\"\n [id]=\"ques.Name\"\n [selectedValue]=\"ques.input\"\n [placeholder]=\"'---Select---'\"\n [errorMessage]=\"ques.Error_Message__c\"\n [error]=\"ques.error\"\n (valueChange)=\"Dropdown($event, ques); clearSQError(ques.Id)\">\n </app-custom-dropdown>\n <app-dropdown-with-flag *ngIf=\"ques.isDependentPicklist && !ques.dropDownOnly\" [certified]=\"ques.certifiedFlag\" [JobPerformerCertificates]=\"ques.certificateList\" (flagDropDownChange)=\"dependentChange($event)\"></app-dropdown-with-flag>\n <i class=\"fa fa-check \" aria-hidden=\"true\" *ngIf=\"questionItem?.input?.length > 0\"></i>\n </div> \n </div>\n </div>\n </div>\n </div>\n\n <!--List start-->\n <div *ngIf=\"listFlag\">\n <div class=\"form-group\">\n <div class=\"form-row\">\n <div class=\"col-md-12\" *ngIf=\"questionItem.error\" style=\"font-size: 18px;\n color: red;\">{{questionItem?.error?.errorMsg}}</div>\n <div class=\"myt-align3\" [class]=\"'col-md-' + ques.Size__c + ' paddingnone'\"\n *ngFor=\"let ques of getLocalSubQuestions(questionItem.Id);let i = index\">\n <div>\n <span class=\"dis-flex myt-font3 myt-font7\">{{ ques?.Question__c }}</span>\n </div>\n <div *ngIf=\"ques.Type__c === 'Text'\">\n <input type=\"text\" [(ngModel)]=\"ques.input\" [ngClass]=\"{\n 'dis-flex dt-line date-line bookText boxoutline myt-font1': qbItem.Progress_Bar__c,\n textBox: !qbItem.Progress_Bar__c\n }\" id=\"text\" [id]=\"ques.uniqueSubQId\" required=\"\" (focus)=\"clearLocalSubQuesError(ques)\"\n style.border-color=\"{{ ques.error ? 'red' : '' }}\" placeholder=\"{{ ques.Question__c }}\"\n oninput=\"this.value=this.value.replace(/[^a-zA-Z0-9\\s.:;,?]/g,'');\" />\n </div>\n </div>\n <div class=\"\" *ngIf=\"addFlag\">\n <button (click)=\"Add(getLocalSubQuestions(questionItem.Id))\" class=\"btn\"><i class=\"fa fa-plus\" ></i>Add</button>\n </div>\n </div>\n </div>\n </div>\n <!--List End-->\n\n <!-- Actions -->\n <div *ngIf=\"individualBookButton\" class=\"flexer\">\n <!-- Backward / Back -->\n <div class=\"backbutton\" [ngClass]=\"{ 'col-md-6': !qbItem.Progress_Bar__c }\"\n [style.visibility]=\"questionStack.length > 0 ? 'visible' : 'hidden'\">\n <div [ngClass]=\"{}\">\n <button [ngClass]=\"{\n 'left-bt': qbItem.Progress_Bar__c,\n 'nxt-btn btn-primary btn-lg btn-block btn-back-color':\n !qbItem.Progress_Bar__c\n }\" (click)=\"handleBackClick()\">\n {{ qbItem?.Back__c }}\n </button>\n </div>\n </div>\n\n <!-- Forward / Next -->\n <div [ngClass]=\"{ 'col-md-6': !qbItem.Progress_Bar__c }\">\n <div>\n <button [ngClass]=\"{\n 'rusty': qbItem.Progress_Bar__c,\n 'nxt-btn btn-primary btn-lg btn-block btn-back-color':\n !qbItem.Progress_Bar__c\n }\" (click)=\"handleNextClick()\">\n {{ qbItem.Next__c }}\n </button>\n </div>\n </div>\n </div>\n</div>\n\n<!-- Summary -->\n<div *ngIf=\"summary && summary.length > 0\" height=\"100% !important\" class=\"col-md-12\" [ngClass]=\"{\n 'col-md-12':!qbItem.Progress_Bar__c\n }\">\n <h1 class=\"header1 summarypadd\" >{{ qbItem.SubTitle__c }}</h1> \n <div id=\"progress2\" *ngIf=\"!qbItem.Progress_Bar__c && this.abItem.Status__c != 'Completed' \">\n <div [ngClass]=\"{ 'full-summary': qbItem.Progress_Bar__c }\">\n <div *ngFor=\"let qa of summary\">\n <div [ngClass]=\"{ non: qbItem.Progress_Bar__c }\">\n <div [ngClass]=\"{ summary: !qbItem.Progress_Bar__c }\">\n <div *ngIf=\"!qbItem.Edit__c\"\n [ngClass]=\"{ 'question': this.abItem.Status__c != 'Completed' }\">\n <a [ngClass]=\"{ asum: this.abItem.Status__c === 'Completed' }\" (click)=\"handleEditClick(qa.quesId)\"\n [innerHTML]=\"getText(qa.quesValue)\">{{ qa.quesValue }}</a>\n </div>\n <div *ngIf=\"qbItem.Edit__c\"\n [ngClass]=\"{ 'question': this.abItem.Status__c != 'Completed' }\">\n <div [ngClass]=\"{ 'question': this.abItem.Status__c === 'Completed' }\"\n [innerHTML]=\"getText(qa.quesValue)\">\n {{ qa.quesValue }}\n </div>\n </div>\n <div class=\"answer\" >\n <div *ngIf=\"qa.qTyp === 'File'\">\n <img src=\"https://rnxt.s3.amazonaws.com/MytIcon/icon-doc-img%401.png\" class=\"icon-edit-summary\" />\n {{ qa.ansValue }}\n </div>\n <div *ngIf=\"qa.qTyp != 'File'\">{{ qa.ansValue }}</div>\n <div *ngIf=\"qbItem.Edit__c && this.abItem.Status__c != 'Completed'\" style=\"background: #dedddd;\">\n <button class=\"edit\" (click)=\"handleEditClick(qa.quesId)\">\n <img *ngIf=\"deviceInfo.os === 'iOS'\" src=\"https://rnxt.s3.amazonaws.com/MytIcon/icon-edit%402x.png\" style=\"width:50%!important;\" class=\"icon-editios\"/>\n <img *ngIf=\"deviceInfo.os !== 'iOS'\" src=\"https://rnxt.s3.amazonaws.com/MytIcon/icon-edit%402x.png\" class=\"icon-edit\" />\n </button>\n </div>\n </div>\n </div>\n </div>\n </div>\n </div>\n </div>\n\n <div *ngIf=\"this.abItem.Status__c === 'Completed'\" class=\"col-lg-12\">\n <div class=\"panel-group panel-group-joined\" id=\"ePTW-details\">\n <div class=\"panel panel-default\">\n <div class=\"panel-heading\">\n <h4 class=\"panel-title\">\n <a data-toggle=\"collapse\" data-parent=\"#ePTW-details\" href=\"#collapseOne\" class=\"collapsed\">\n PTW Details\n </a>\n </h4>\n </div>\n <div id=\"collapseOne\" class=\"panel-collapse collapse\">\n <div class=\"panel-body\">\n <div class=\"row\">\n <ng-container *ngFor=\"let item of summaryData; let i = index\">\n <ng-container *ngIf=\"i % 2 === 0\">\n <div class=\"col-lg-6 m-b-30\">\n <label>{{ getKey(item) }}</label>\n <p class=\"font-size\">{{ getValue(item) || 'N/A' }}</p>\n </div>\n <div class=\"col-lg-6\" *ngIf=\"summaryData[i + 1]\">\n <label>{{ getKey(summaryData[i + 1]) }}</label>\n <p class=\"font-size\">{{ getValue(summaryData[i + 1]) || 'N/A' }}</p>\n </div>\n </ng-container>\n </ng-container>\n </div>\n </div>\n </div>\n </div>\n </div>\n </div>\n\n <div id=\"progress2\" *ngIf=\"qbItem.Progress_Bar__c \">\n <div [ngClass]=\"{'bgColor summary-top' : qbItem.Progress_Bar__c }\" >\n <div id=\"progress-summary\" *ngIf=\"qbItem.Progress_Bar__c\">\n <circle-progress class=\"titlebar\" [percent]=\"this.percent\" [radius]=\"40\" [space]=\"-4\" [outerStrokeWidth]=\"4\"\n [innerStrokeWidth]=\"4\" [outerStrokeColor]=\"'#e0b1b0'\" [innerStrokeColor]=\"'#e7e8ea'\" [animation]=\"true\" [backgroundPadding]= \"0\"\n [backgroundColor]= \"'#dd2e13'\" [backgroundGradientStopColor]=\"'#f9bfbd'\" [titleColor]=\"'#f3eded'\" \n class=\"ng-star-inserted\" [title]=\"this.percent+'%'\" [showSubtitle]=\"false\" [showBackground]=\"true\" [animationDuration]=\"300\"\n [startFromZero]=\"false\" [responsive]=\"false\" >\n </circle-progress>\n \n <div *ngIf=\"qbItem.Summary_Text__c && qbItem.Progress_Bar__c\" \n [ngClass]=\"{ summaryTitle: qbItem.Progress_Bar__c }\">\n <h3 class=\"subTitle\" >{{ qbItem.Summary_Text__c }}</h3>\n <div *ngIf=\"abItem.Status__c != 'Completed'\" class=\"subTitle1\" >{{ qbItem.Summary_Sub_Text__c}}</div>\n </div>\n </div>\n <div *ngIf=\"!qbItem.Progress_Bar__c\">\n <h3 class=\"summary-h\">\n {{ qbItem.Summary_Text__c }}\n </h3>\n </div>\n </div>\n <div [ngClass]=\"{ 'full-summary': qbItem.Progress_Bar__c }\">\n <div class=\"summary-groupText myt-font2\">\n <!-- <p>Informe de da\u00F1o</p> -->\n </div>\n <div *ngFor=\"let qa of summary\" >\n <div [ngClass]=\"{ non: qbItem.Progress_Bar__c }\">\n <div [ngClass]=\"{ summary: this.abItem.Status__c != 'Completed' && !qbItem.Progress_Bar__c }\">\n <div *ngIf=\"!qbItem.Edit__c\"\n [ngClass]=\"{ 'question sum-ques myt-font3 myt-font8': this.abItem.Status__c != 'Completed' }\">\n <a [ngClass]=\"{ asum: this.abItem.Status__c === 'Completed' }\" (click)=\"handleEditClick(qa.quesId)\"\n [innerHTML]=\"getText(qa.quesValue)\">{{ qa.quesValue }}</a>\n </div>\n <div *ngIf=\"qbItem.Edit__c\"\n [ngClass]=\"{ 'sum-ques question myt-font3 myt-font8': this.abItem.Status__c != 'Completed' }\">\n <div [ngClass]=\"{ 'sum-ques1 question1 summary-completed myt-font3 myt-font8': this.abItem.Status__c === 'Completed' }\"\n [innerHTML]=\"getText(qa.quesValue)\">\n {{ qa.quesValue }}\n </div>\n </div>\n <div *ngIf=\"qbItem.Edit__c && this.abItem.Status__c != 'Completed'\" style=\"background: #dedddd;\">\n <button class=\"edit\" (click)=\"handleEditClick(qa.quesId)\">\n <img *ngIf=\"deviceInfo.os === 'iOS'\" src=\"https://rnxt.s3.amazonaws.com/MytIcon/icon-edit%402x.png\" style=\"width:50%!important;\" class=\"icon-editios\"/>\n <img *ngIf=\"deviceInfo.os !== 'iOS'\" src=\"https://rnxt.s3.amazonaws.com/MytIcon/icon-edit%402x.png\" class=\"icon-edit\" />\n </button>\n </div>\n \n <div class=\"answer \" >\n <div *ngIf=\"qa.qTyp === 'File'\">\n <img src=\"https://rnxt.s3.amazonaws.com/MytIcon/icon-doc-img%401.png\" class=\"icon-edit-summary\" />\n {{ qa.ansValue }}\n </div>\n <div *ngIf=\"qa.qTyp != 'File'\">\n {{ qa.ansValue }}\n </div>\n </div>\n </div>\n </div>\n </div>\n </div>\n </div>\n\n <!-- Answer Book -->\n <div class=\"flexer1\" *ngIf=\"abItem\">\n <div class=\"\" *ngIf=\"abItem.Status__c == 'Completed'\">\n <div class=\"col-md-12\">\n <button [ngClass]=\"{'btn-text': qbItem.Progress_Bar__c,\n 'nxt-btn btn-primary btn-lg btn-block btn-back-color': !qbItem.Progress_Bar__c}\"\n (click)=\"handleCancelClick()\">\n {{ qbItem.Cancel__c }}\n </button>\n </div>\n </div>\n </div>\n\n <!-- Group Actions -->\n <div class=\"align-edit-submit\" *ngIf=\"abItem.Status__c != 'Completed'\">\n <div class=\"col-md-6\">\n <button [ngClass]=\"{ 'btn-text2': qbItem.Progress_Bar__c,\n 'nxt-btn btn-primary btn-lg btn-block btn-back-color': !qbItem.Progress_Bar__c }\" \n (click)=\"handleSubmitClick()\">\n {{ qbItem.Submit__c }}\n </button>\n </div>\n <div class=\"col-md-6\">\n <button [ngClass]=\"{'grey': qbItem.Progress_Bar__c,\n 'nxt-btn btn-primary btn-lg btn-block btn-back-color': !qbItem.Progress_Bar__c}\" \n (click)=\"handleBackClickNew()\">\n {{ qbItem.Edit__c }}\n </button>\n </div>\n </div>\n\n</div>", styles: [".rusty{width:235px;background-color:#cd2810;color:#fff;text-align:center;font-size:24px;height:60px;margin-left:0%;margin-top:11%;cursor:pointer}.edit{background-color:#dedddd;border:none;color:#c5281c;text-decoration:underline;margin-left:50%;font-size:16px;vertical-align:super;font-weight:700}.icon-edit{width:15px;height:18px;margin:0 6px 1px -13%}.icon-edit1,.icon-edit-summary{width:29px;height:28px}.questiondiv1{padding-left:25px;padding-right:25px;padding-top:3%}.questiondiv2{padding-top:0;padding-bottom:20px;padding-left:11px}.align-edit-submit{display:flex;flex-direction:column;align-items:center}.questiondiv2{padding-left:0!important;padding-bottom:0!important}@media screen and (min-width: 689px){#progress,#progress-summary{padding-left:12px}.backicon{display:none}.dt-time{background-position:98%!important}}.bgColor{text-align:center;background-color:#dedddd}.questionalign{text-align:center;padding-right:4%;margin-bottom:4px;margin-top:2rem;color:#560d05}.largeTitle{padding-left:16px;padding-top:12px}.question-f-size{font-size:.7rem}.non{background-color:#dedddd}.circle{margin-left:25px}.titlebar{padding-left:10%;padding-top:1%;padding-right:10%}.infodiv{padding-left:2rem;overflow:hidden}.info-alert{border:1px solid #e6e6e6;border-radius:5px;padding:.5em;margin-left:15px;margin-right:15px;margin-bottom:1rem;display:flex}.addtional-info{margin-left:-33px;margin-top:-21px;font-size:16px;font-weight:400;font-stretch:normal;font-style:normal;color:#6f7072;font-family:Helvetica}.ques-alert1{margin-bottom:1rem;display:flex}.iposition{margin-left:3rem}.col-md-1,.col-md-10,.col-md-11,.col-md-12,.col-md-2,.col-md-3,.col-md-4,.col-md-5,.col-md-6,.col-md-7,.col-md-8,.col-md-9{position:relative;padding:20px;float:center;width:100%}.col-md-12{padding:0!important}.nxt-btn{border-radius:.3rem;font-size:1.25rem;line-height:1.5;padding:.5rem 1rem;width:100%;cursor:pointer;outline:0}.cond-div2{color:red;font-weight:700;padding-bottom:3%}.radiotext{margin-top:-30px}.radiocontainer{display:flex;flex-direction:row-reverse;border:1px solid none;border-radius:.3em;padding:0;align-items:center;text-align:center;cursor:pointer;font-family:Rubik,Helvetica Neue,Helvetica,Roboto,Arial,sans-serif;color:#a3a2a2}.radioOption{display:flex;align-content:flex-start;margin-top:-16px;width:6%}.checkmark{left:47.5%;height:20px;margin-right:7px;width:20px;background-color:#fff0;border-radius:50%;border:1px solid grey}.myt-time{width:-moz-fit-content!important;width:fit-content!important;background-image:none;background:#dedddd;margin:0;padding:0;border:none;font-size:15px;letter-spacing:1px}.showminute{padding-left:5px;margin-top:0%}.myt-time1{margin-top:-32px;margin-left:-15px}.myt-dateTimeNew{margin-left:-14px}.myt-hour{width:-moz-fit-content;width:fit-content}.date-time{padding:0;margin:0;text-align:left}.dateandTime{border:1px solid #d2d4d6;position:relative;display:flex;border-radius:2px;background-image:url(https://dynamic-css1.s3.ap-south-1.amazonaws.com/External+css/time.svg);background-size:25px;background-repeat:no-repeat;background-position:99% center;background-color:#fff;height:37px}.date-line{border-bottom:1px solid #fff}.dt-time{width:57%;margin-left:2.3%;text-align:left;background-image:url(https://rnxt.s3.amazonaws.com/MytIcon/icon-clock%402x.png)!important;background-size:25px!important;background-repeat:no-repeat!important;background:#dedddd}.date-picker{width:57%;margin-left:2.5%;height:44px;border-radius:5px}.datetime:focus{border:none;box-shadow:none}#meridiem{margin-top:-2px;border:hidden}.dis-flex{display:flex;justify-content:center}.textBox{width:100%;height:36px}.textBox1{width:100%;height:36px;margin-left:-17px}.option{color:#767676}.paddingnone{padding-bottom:0%}.paddingZero{padding:0}.summary-h{text-align:left;padding-bottom:15px}.summary{display:flex;flex-direction:column;align-items:flex-start;border-bottom:2px solid #fff}.asum{color:#6f7072;margin-top:5%;padding-left:3%}.question{padding:10px;font-size:14px;color:#007bff}.question1{margin-left:14rem;background:#dedddd;color:#560d05;font-size:15px;padding-bottom:20px;text-align:left}.answer{display:flex;align-items:baseline;padding:5px 5px 10px;font-size:14px;font-weight:400;word-wrap:break-word;width:97%;justify-content:space-between}.answer1{max-width:55%;margin-left:auto;margin-right:auto;color:#a3a2a2;margin-top:0%;padding-bottom:0;font-size:14px;font-weight:400;word-wrap:break-word;text-align:left;background:#dedddd;border-bottom:1px solid #fff}.myt-font{font-size:20px}.myt-font1{width:16rem;font-size:14px;font-weight:400}.myt-font2{font-size:18px}.myt-font3,.myt-font4{font-size:14px}.myt-font5{margin-top:-18px;font-weight:400;font-size:14px;color:#560d05}.myt-font6{font-size:20px;font-weight:700;color:#c5281c;text-align:center}.myt-font10{font-weight:400;font-size:14px;color:#560d05;margin-top:10px}.myt-font7{display:flex;justify-content:flex-start;padding-left:20.5%;font-weight:100;color:#560d05}.myt-font8{font-weight:400}.dpDown:focus-visible{outline:none}.summaryTitle{padding-left:0%;padding-top:4%}.summary-groupText{width:55%;margin:auto auto -2%;text-align:left;font-weight:700;padding-top:0%;padding-bottom:0%;background-color:#dedddd;color:#c5281c}.sum-ques{width:55%;margin:auto}.sum-ques1{width:59%;margin:auto}.header-style{padding:15px!important;background:#F8F8F8;color:#898989!important;border:1px solid #e8e8e8;border-top-left-radius:5px;border-top-right-radius:5px;margin-left:0!important;justify-content:left!important;font-size:15px!important}.form-group.content-box{background:#ffffff;padding:40px;border:1px solid #e8e8e8;border-bottom-left-radius:5px;border-bottom-right-radius:5px}.shengel-myt-font3{padding-bottom:5px;padding-top:5px;padding-right:15px;padding-left:2px!important;color:#9a9a9a!important;font-size:14px!important;font-weight:400!important}.file-upload-btn{display:none;border-bottom:groove}.file-upload-box{max-width:45%;margin-left:29.5%;height:auto;padding:16px;display:flex;border:2px;border-bottom:1px solid #fff;background-color:#dedddd;justify-content:space-between;color:#d8d8d8}.file-label{cursor:pointer;color:#c5281c;text-decoration:underline}.file-uploading-box{font-size:14px;font-weight:400;max-width:45%;margin-left:29.5%;height:56px;padding:16px;display:flex;border:2px;background-color:#dedddd;justify-content:space-between;margin-bottom:0;color:#d8d8d8}.uploading-file-name{color:#6f7072}.deleteIcon{cursor:pointer;height:24px}.file-icon{max-width:24px;height:26px}.picture-upload{height:200px;width:200px;position:relative;border:1px solid #ccc;display:flex;padding:6px 12px;cursor:pointer;background-color:#fff;align-items:center}.colon{line-height:42px;padding:0;margin-top:10%;color:#6f7072}.colon1{display:contents}.subTitle{color:#c5281c;font-weight:600;margin-top:-3%}.subTitle1{color:#560d05;font-size:14px;font-weight:500}.check-icon{color:#87be1c;margin-left:-2rem;z-index:1;padding:5px;margin-top:.4rem}.check-icon2{color:#87be1c;margin-left:-4rem;z-index:1;margin-top:.6rem;line-height:3}.check-icon3{color:#87be1c;margin-left:-4rem;z-index:1;margin-top:3rem}.align-l{text-align:left;padding:1% 2% 2%;margin-bottom:-5%;margin-top:-1%}.attach-ulist{list-style-type:none;margin-left:0;margin-bottom:.7rem}.attach-list{float:right;cursor:pointer;padding:0}.icolor{color:#99b5ce}.picture-upload-child{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.tspan:nth-child(1){font-size:25px;font-weight:700}.tspan:nth-child(2){display:none}.pic-upload{position:absolute;top:15%;left:85%;transform:translate(-50%,-50%)}.btn-block+.btn-block{margin-top:.5rem}input[type=submit].btn-block,input[type=reset].btn-block,input[type=button].btn-block{width:100%}.btn-lg,.btn-group-lg>.btn{padding:.5rem 1rem;font-size:1.25rem;line-height:1.5;border-radius:.3rem}.btn-lg+.dropdown-toggle-split,.btn-group-lg>.btn+.dropdown-toggle-split{padding-right:.75rem;padding-left:.75rem}.btn-primary:hover{color:#fff}.btn-primary:focus,.btn-primary.focus{color:#fff;box-shadow:0 0 0 .2rem #268fff80}.btn-primary.disabled,.btn-primary:disabled{color:#fff}.btn-primary:not(:disabled):not(.disabled):active,.btn-primary:not(:disabled):not(.disabled).active,.show>.btn-primary.dropdown-toggle{color:#fff}.btn-primary:not(:disabled):not(.disabled):active:focus,.btn-primary:not(:disabled):not(.disabled).active:focus,.show>.btn-primary.dropdown-toggle:focus{box-shadow:0 0 0 .2rem #268fff80}.btn-back-color{display:block;width:100%;padding:.5rem 1rem;font-size:1.25rem;line-height:1.5;text-align:center;border-radius:.3rem;margin:0}.fa-plus:hover{color:#87be1c}.fa-plus{color:#99b5ce}.btn-primary{border-color:#007bff}.ques-Title{text-align:left;font-size:24px}.grey{width:38%;height:56px;margin:0px 0px 0px 0rem;padding:14px 0 17px;background-color:#cd2810;color:#fff;font-size:24px}.btn-text{width:330px;font-size:24px;background-color:#cd2810;color:#fff;height:60px;margin-left:auto;margin-top:0;cursor:pointer;border-radius:40px}.btn-text2{width:21rem;font-size:24px;background-color:#cd2810;border:none;color:#fff;height:60px;margin-left:17rem;margin-right:17rem;margin-top:10px;cursor:pointer;border-radius:40px}.flexer{max-width:100%;width:100%;display:flex;justify-content:center}.flexer1{max-width:100%;width:100%;display:flex;justify-content:center;margin-top:32px}.btn-r{right:0rem}.down{margin-left:0;width:57%}.down1{width:16rem;margin-left:0rem;background-color:#dedddd}.down2{margin-top:0%;padding-left:11px}.dropbox{margin-left:21.5rem}.myt-dropbox{background-image:url(https://rnxt.s3.amazonaws.com/MytIcon/down-red.png);background-origin:content-box;background-position:right -.9rem center;background-repeat:no-repeat;background-size:35px 33px;padding-right:1.35rem;background-color:#dedddd}.boxoutline{outline:transparent;background-color:#dedddd}.left-bt{width:238px;background-color:#cd2810;color:#fff;padding:0;text-align:center;font-size:24px;cursor:pointer;height:60px;margin-top:125px;margin-bottom:4rem;margin-left:-234px}.townArea{text-align:left;height:43px;padding-left:15px}.townArea:hover{background-color:#9e9e9e2e}.listFlow{font-weight:400;color:#767676;z-index:2;position:absolute;background:#dedddd;box-shadow:0 2px 5px #00000040}.myt-radio input[type=radio]:checked:after{background-color:#c5281c}.full-summary{margin-top:4%}.container-radio input{display:none;position:absolute;opacity:0;cursor:pointer}.container-radio input:checked~.checkmark{background-color:#fff0}.checkmark:after{content:\"\";display:none}.container-radio input:checked~.checkmark:after{display:block}.container-radio .checkmark:after{top:3px;left:3px;width:12px;margin:3px;height:12px;border-radius:50%;background:#C5281C}.f-Name{color:#6f7072;font-size:14px;font-weight:400;word-break:break-word}.summary-top{margin-top:4%}.myt-border-r{border-top:none;border-left:none;border-right:none;border-radius:0}.myt-align{margin-left:4%;line-height:2}.myt-align1{margin-left:-29px}.myt-align2{margin-left:-15px}.myt-align3{width:100%}.myt-book1{margin-top:-20px}.colorf{color:#555}.bookText{width:57%;margin-left:21.5%;background-color:#dedddd}.book{width:32.6%;margin-left:34%;background-color:#dedddd}.summary-completed{padding-left:2%;margin-top:20px}.town{margin:0;background-color:#dedddd}.town-drop{margin:auto;width:57%}.questiondiv1.padd-bottom{padding-bottom:6rem!important;padding-top:2rem!important}@media (max-width: 1090px){.icon-edit{margin:0 6px -3px -13%!important}}@media (max-width: 768px){.col-md-1,.col-md-10,.col-md-11,.col-md-12,.col-md-2,.col-md-3,.col-md-4,.col-md-5,.col-md-6,.col-md-7,.col-md-8,.col-md-9{float:center}.col-md-12{width:100%}.col-md-11{width:91.66666667%}.col-md-10{width:83.33333333%}.col-md-9{width:75%}.col-md-8{width:66.66666667%}.col-md-7{width:58.33333333%}.col-md-6{width:50%}.col-md-5{width:41.66666667%}.col-md-4{width:33.33333333%}.col-md-3{width:25%}.col-md-2{width:16.66666667%}.col-md-1{width:8.33333333%}}@media (max-width: 768px){.radioOption{width:8%}.grey{width:78%;margin-left:17.5rem;height:68px!important;font-size:20px!important;font-weight:700!important}.answer{margin-top:-4%!important}}@media screen and (max-width: 672px){.header1{font-size:23px!important}.summarypadd{padding-top:50px!important}.answer{margin-top:-5%!important}.icon-edit{margin:0 6px 0 -13%!important}.subTitle1{width:95%!important}.additional{margin-left:6%!important;padding:0!important}.container1{margin-left:-35%}.town-drop{margin:auto;width:100%!important}.dis-flex{display:flex;justify-content:left}.check{display:inherit;width:-moz-max-content;width:max-content;margin-left:6%}.rusty{width:28rem;margin-left:0rem;height:68px!important;font-size:20px!important;font-weight:700!important;margin-bottom:37px}.left-bt{width:28rem;margin-left:-28rem;height:68px!important;font-size:20px!important;font-weight:700!important}.questionalign{text-align:center}.questionalign{margin-top:1rem!important}.largeTitle{padding-left:0!important}.myt-align{margin-left:0%!important}.myt-text1{margin-top:-22px}.myt-text2{margin-top:-20px}.myt-text3{margin-bottom:21px}.date-picker,.dt-time{width:100%}.showminute{margin-top:-.5%}.radioOption{width:auto;margin-top:0;margin-left:7%;margin-right:-3%}.checkmark{left:3.8rem}.myt-font7{padding-left:0rem;margin-left:-1.5%}.down,.bookText,.book{width:100%;margin-left:0rem}.town{margin-left:0rem;width:100%}.file-upload-box,.file-uploading-box{max-width:85%;margin-left:20px}.question{margin-left:0rem}.btn-text2{width:28rem;margin-right:0rem;margin-left:0;height:68px!important;font-size:20px!important;font-weight:700!important}.grey{width:28rem;margin:-21px 0 0;height:68px!important;font-size:20px!important;font-weight:700!important}}@media screen and (max-width: 580px){.rusty{width:27rem;height:68px!important;font-size:20px!important;font-weight:700!important}.left-bt{width:27rem;margin-left:-27rem;height:68px!important;font-size:20px!important;font-weight:700!important}.container1{margin-left:-24%}.showminute{margin-top:.5%}.bookText,.book{width:100%;margin-left:0rem}.btn-text2{width:27rem;margin-right:0rem;margin-left:0;height:68px!important;font-size:20px!important;font-weight:700!important}.grey{width:27rem;margin:-21px 0 0;height:68px!important;font-size:20px!important;font-weight:700!important}.btn-text{width:27rem;height:68px!important;font-size:20px!important;font-weight:700!important}}@media screen and (max-width: 672px){.questiondiv1{padding:0}}@media screen and (max-width: 525px){.rusty{width:26rem;height:68px!important;font-size:20px!important;font-weight:700!important}.container1{margin-left:-9%}.left-bt{width:26rem;margin-left:-26rem;height:68px!important;font-size:20px!important;font-weight:700!important}.dateandtime{padding-left:10px!important}}@media screen and (max-width: 480px){.answer{margin-top:-7%!important}.icon-edit{margin:0 6px 4px -35%!important}.rusty{width:25rem;height:68px!important;font-size:20px!important;font-weight:700!important}.left-bt{width:25rem;margin-left:-25rem;height:68px!important;font-size:20px!important;font-weight:700!important}.file-upload-box,.file-uploading-box{max-width:89%}}@media screen and (max-width: 420px){.answer{margin-top:-9%!important}.icon-edit{margin:-9px 1px 4px 4%!important}.rusty,.btn-text{width:21rem;height:68px!important;font-size:20px!important;font-weight:700!important}.left-bt{width:21rem;margin-left:-21rem;height:68px!important;font-size:20px!important;font-weight:700!important}.container1{margin-left:0%}.file-upload-box,.file-uploading-box{max-width:100%}.myt-dateTimeNew{margin-left:-10px!important}.form-row{padding-left:8px!important}.dateandtime{padding-left:0!important}.dt-time{padding-left:.8%!important}.myt-font7{padding-left:0rem;margin-left:-3.5%}.grey{width:21rem;margin:-21px 0 0;height:68px!important;font-size:20px!important;font-weight:700!important}.btn-text2{width:21rem;margin-right:0rem;margin-left:0;height:68px!important;font-size:20px!important;font-weight:700!important}}@media screen and (max-width: 368px){.icon-edit{margin:0 6px 3px 35%!important}.icon-editios{margin-bottom:4px}.rusty{width:19rem;height:68px!important;font-size:20px!important;font-weight:700!important}.left-bt{width:19rem;margin-left:-19rem;height:68px!important;font-size:20px!important;font-weight:700!important}.container1{margin-left:15%}.radiotext{margin-top:-45px}.file-upload-box,.file-uploading-box{max-width:100%}.grey{width:19rem;margin:-21px 0 0;height:68px!important;font-size:20px!important;font-weight:700!important}.btn-text2{width:19rem;margin-right:0rem;margin-left:0;height:68px!important;font-size:20px!important;font-weight:700!important}.btn-text{width:19rem;height:68px!important;font-size:20px!important;font-weight:700!important}}.mydp .selection{padding:0!important}.text-border{border-top:none;border-left:none;border-right:none;border-radius:0;border-bottom:1px solid #fff!important;background-color:#dedddd}.additional{display:flex;font-size:20px;text-align:left;font-weight:200;margin-left:4%;justify-content:center;color:#3e3e3c;padding:0 30%}.check{display:block}.header2{font-size:20px;font-weight:300;text-align:center;font-stretch:normal;font-style:normal;line-height:1.5;letter-spacing:normal;color:#560d05;max-width:1100px;margin:auto;padding-bottom:10px}.header1{font-size:32px;font-weight:700;text-align:center;font-stretch:normal;font-style:normal;line-height:1.25;letter-spacing:normal;color:#dd2e13}.container1{display:inline-grid;position:relative;cursor:pointer;font-size:20px;-webkit-user-select:none;-moz-user-select:none;user-select:none}.container1 input{position:absolute;opacity:0;cursor:pointer;height:0;width:0}.checkmark1{position:absolute;top:1px;left:-35%;height:21px;width:21px;background-color:#eee}.container1:hover input~.checkmark1{background-color:#ccc}.container1 input:checked~.checkmark1{content:\"\";background-image:url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIxNiIgaGVpZ2h0PSIxMiIgdmlld0JveD0iMCAwIDE2IDEyIj4gIDxwYXRoIGZpbGw9IiM4N0JFMUMiIGZpbGwtcnVsZT0iZXZlbm9kZCIgZD0iTTEyLjI0Mjk1NjUsMTcuNTcyNzczOCBMMjAuOTg1NTM0Nyw5LjEzMjYxNTg1IEMyMS4xNjg1NDM3LDguOTU1OTM3NDEgMjEuNDYyMTgwNyw4Ljk1NTc3NDM2IDIxLjY0NTM5MzYsOS4xMzIyNDk0NCBMMjIuODU5MTUxMywxMC4zMDEzNzAxIEMyMy4wNDY5NDk2LDEwLjQ4MjI2MiAyMy4wNDY5NDk2LDEwLjc3OTA1NjMgMjIuODU5MTUxMywxMC45NTk5NDgyIEwxMi41NzMwNjk2LDIwLjg2Nzc1MDYgQzEyLjM5MDAwNDcsMjEuMDQ0MDgzMSAxMi4wOTY2NTU2LDIxLjA0NDA4MzEgMTEuOTEzNTkwNiwyMC44Njc3NTA2IEw3LjE0MDg0ODc3LDE2LjI3MDUzMDMgQzYuOTU0MTc0MjgsMTYuMDkwNzIwOSA2Ljk1Mjg5MDU1LDE1Ljc5NjA5NTggNy4xMzc5OTEzMywxNS42MTQ3MjgyIEw4LjMzMTE3Njc5LDE0LjQ0NTYwNzUgQzguNTEzODA2NDgsMTQuMjY2NjYxMiA4LjgwOTMzMDgzLDE0LjI2NTQyMjYgOC45OTM1MTMyMiwxNC40NDI4MzE1IEwxMi4yNDI5NTY1LDE3LjU3Mjc3MzggWiIgdHJhbnNmb3JtPSJ0cmFuc2xhdGUoLTcgLTkpIi8+PC9zdmc+);background-position:.17rem .3rem;background-repeat:no-repeat;background-color:#d2d4d6;width:21px;height:21px}.checkmark1:after{content:\"\";position:absolute;display:none}.container1 input:checked~.checkmark1:after{display:block}.container1 .checkmark1:after{left:9px;top:5px;width:5px;height:10px;border-width:0 3px 3px 0}.bottomspace1{padding-bottom:14px!important}.myt-321{font-size:20px;font-weight:700;color:#c5281c;margin-top:11px}.myt-345{display:none}.panel{-moz-box-shadow:0px 1px 2px 0px rgba(0,0,0,.1);-webkit-box-shadow:0px 1px 2px 0px rgba(0,0,0,.1);border-radius:0;border:none;box-shadow:0 1px 2px #0000001a;margin-bottom:20px}.panel .panel-body{padding:20px}.panel-heading{border-radius:0;border:none!important;padding:10px 20px}.panel-default>.panel-heading{background-color:#fafafa;border-bottom:none;color:#2a323c;border:1px solid #e3e3e3!important}.panel-title{margin-bottom:0;margin-top:0;font-family:Rubik,sans-serif;font-weight:400}.panel-footer{background:#fafafa;border-top:0}.panel-color .panel-title{color:#fff}.panel-primary>.panel-heading{background-color:#03a9f4}.panel-success>.panel-heading{background-color:#01ba9a}.panel-info>.panel-heading{background-color:#18bae2}.panel-warning>.panel-heading{background-color:#f8ca4e}.panel-danger>.panel-heading{background-color:#f62f37}.panel-dark>.panel-heading{background-color:#2a323c;color:#fff}.panel-fill{border-radius:3px}.panel-fill .panel-heading{background-color:transparent;color:#fff;border-bottom:1px solid rgba(255,255,255,.5)!important}.panel-fill .panel-body{color:#ffffffd9}.panel-fill.panel-default .panel-body{color:#666}.panel-fill.panel-default .panel-heading{background-color:transparent;color:#333;border-bottom:1px solid rgba(0,0,0,.1)!important}.panel-fill.panel-primary{background-color:#03a9f4}.panel-fill.panel-success{background-color:#01ba9a}.panel-fill.panel-info{background-color:#18bae2}.panel-fill.panel-warning{background-color:#f8ca4e}.panel-fill.panel-danger{background-color:#f62f37}.panel-fill.panel-dark{background-color:#2a323c}.panel-group .panel .panel-heading a[data-toggle=collapse].collapsed:before{content:\"\\f0d7\"}.panel-group .panel .panel-heading .accordion-toggle.collapsed:before{content:\"\\f0d7\"}.panel-group .panel .panel-heading a[data-toggle=collapse]{display:block}.panel-group .panel .panel-heading a[data-toggle=collapse]:before{content:\"\\f0d8\";display:block;float:right;font-family:FontAwesome;font-size:14px;text-align:right;width:25px}.panel-group .panel .panel-heading .accordion-toggle{display:block}.panel-group .panel .panel-heading .accordion-toggle:before{content:\"\\f068\";display:block;float:right;font-family:FontAwesome;font-size:14px;text-align:right;width:25px}.panel-group .panel .panel-heading+.panel-collapse .panel-body{border-top:none!important;border:1px solid #e3e3e3}.panel-group .panel-heading{padding:12px 26px}.panel-group.panel-group-joined .panel+.panel{border-top:1px solid #eeeeee;margin-top:0}.panel-group-joined .panel-group .panel+.panel{border-top:1px solid #eeeeee;margin-top:0}.panel-body label{color:#9a9a9a;font-size:14px;font-weight:400;display:inline-block;max-width:100%;margin-bottom:5px}.font-size{font-size:14px}.panel-title>.small,.panel-title>.small>a,.panel-title>a,.panel-title>small,.panel-title>small>a{color:inherit;text-decoration:none}.panel-title{font-size:16px}@media (min-width: 300px) and (max-width: 399px){.selbtngroup{padding-left:1.3%!important}}@media (min-width: 400px) and (max-width: 480px){.selbtngroup{padding-left:.9%!important}}@media (min-width: 481px) and (max-width: 580px){.selbtngroup{padding-left:.2%!important}}@media screen and (min-width: 871px){.selbtngroup{padding-right:4px!important}}@media screen and (max-width: 689px){.answer{max-width:95%!important;margin-left:0!important;margin-right:15px}#progress2{margin-left:8.5px!important}.edit{margin-left:85%!important;margin-bottom:0%!important}.sum-ques,.sum-ques1{width:100%!important;margin:auto}.summary-completed{padding-left:0!important;padding-bottom:17px;margin-top:9px}.summary-top{margin-top:10%}.subTitle1{font-size:18px!important;line-height:1.38!important;text-align:center;letter-spacing:normal;color:#560d05!important;font-weight:300}.backbutton{display:none}.rusty{margin-bottom:37px}}@media screen and (min-width: 1024px){.ES-style{position:absolute;left:7px;font-size:.9rem;color:#555;top:9px}}@media screen and (max-width: 1024px){.ES-style{position:absolute;left:.6rem;font-size:.95rem;color:#555;top:.57rem}}@media screen and (max-width: 689px){.app-back1{line-height:1.5;cursor:pointer;width:100%;max-width:1200px;margin-right:auto;margin-left:-10px;display:flex;font-family:Helvetica;font-size:21px;font-weight:700;align-items:center;font-stretch:normal;font-style:normal;letter-spacing:normal;color:#dd2e13;z-index:1;position:fixed;background-color:#dedddd;border-radius:0!important;margin-top:-12px;padding-top:.8rem}.header1{padding-top:75px}.dt-time{background-position:100%!important}}.summary-volver{display:none}@media ((min-width: 1200px)){.form-row{display:flex;flex-wrap:wrap}}\n"] }]
2118
+ }], ctorParameters: function () { return [{ type: i1.SalesforceService }, { type: i2.DataService }, { type: i3.ActivatedRoute }, { type: i4.DomSanitizer }, { type: i5.NgxSpinnerService }, { type: i6.UntypedFormBuilder }, { type: i7.DeviceDetectorService }, { type: i0.ElementRef }]; }, propDecorators: { qbId: [{
2119
+ type: Input
2120
+ }], insuranceStartDate: [{
2121
+ type: Input
2122
+ }], serv: [{
2123
+ type: Input
2124
+ }], tkn: [{
2125
+ type: Input
2126
+ }], handleEvent: [{
2127
+ type: Output
2128
+ }], handlePage: [{
2129
+ type: Output
2130
+ }] } });
2131
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"questionnaire.component.js","sourceRoot":"","sources":["../../../../../../projects/nxt-app/src/lib/pages/questionnaire/questionnaire.component.ts","../../../../../../projects/nxt-app/src/lib/pages/questionnaire/questionnaire.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 { ActivatedRoute, Params } from \"@angular/router\";\nimport { SalesforceService } from \"../../services/salesforce.service\";\nimport { IMyDateModel, IMyDpOptions } from \"mydatepicker\";\nimport { DomSanitizer, SafeHtml } from \"@angular/platform-browser\";\nimport { UntypedFormBuilder } from \"@angular/forms\";\nimport { NgxSpinnerService } from \"ngx-spinner\";\n//import { NgxIndexedDBService, IndexDetails} from 'ngx-indexed-db';\nimport { DeviceDetectorService } from 'ngx-device-detector';\nimport * as moment from 'moment'; \nimport { DataService } from '../../services/data.service';\n\nimport {\n  Question,\n  QuestionBook,\n  AnswerBook,\n  AnswerWrapper,\n  ErrorWrapper,\n  Option,\n  OptionValue,\n  AttachmentWrapper,\n  Attachment,\n  LocalQuestion\n} from \"../../wrapper\";\n\nimport {\n  TESTQUESTION,\n  DTQUESTION,\n  FILEQUESTION,\n  TAQUESTION,\n  RADIOQUESTION,\n  CHECKQUESTION,\n  BOOKQUESTION,\n  TESTQB,\n} from \"../../sample\";\nimport { from } from \"rxjs\";\n\n@Component({\n  selector: \"lib-questionnaire\",\n  templateUrl: \"./questionnaire.component.html\",\n  encapsulation: ViewEncapsulation.None,\n  styleUrls: [\"./questionnaire.component.css\"],\n})\nexport class QuestionnaireComponent implements OnInit {\n  @Input() qbId: string;\n  @Input() insuranceStartDate: string;\n  @Input() serv: string;\n  @Input() tkn: string;\n  @Output() handleEvent = new EventEmitter();\n  @Output() handlePage: EventEmitter<any> = new EventEmitter();\n\n  params: Params;\n  public deviceInfo = null;\n  public abItem: AnswerBook;\n  public qbItem: QuestionBook;\n  public questionItem: Question;\n  public answerWrap: AnswerWrapper;\n\n  // CONDITIONAL TYPES\n  public radioFlag: boolean = false;\n  public dataFlag: boolean = false;\n\n  // OPTIONONLY TYPES\n  public dropdownFlag: boolean = false;\n  public checkboxFlag: boolean = false;\n\n  // UNCONDITIONAL TYPES\n  public textFlag: boolean = false;\n  public taFlag: boolean = false;\n  public dtFlag: boolean = false;\n  public timeFlag: boolean = false;\n  public dateFlag: boolean = false;\n  public fileFlag: boolean = false;\n  public emailFlag: boolean = false;\n  public numberFlag: boolean = false;\n  public alphanumericFlag: boolean = false;\n  public bookFlag: boolean = false;\n  public listFlag: boolean= false;\n  //Back button\n  public backButtonFlag: boolean = false;\n  public optionValues: OptionValue[] = [];\n  public subQuestions: Question[] = [];\n  public inpValue: string;\n  public answerMap = new Map();\n  public dateMap = new Map();\n  public selectedhourMap = new Map();\n  public selectedminuteMap = new Map();\n  public attachmentsMap = new Map();\n  public sqOptions = new Map();\n  public subAnsMap = new Map();\n  public localSubQuestions: LocalQuestion[] = [];\n  public questionStack = [];\n  public questionName = [];\n  public attachments: any[] = [];\n  public attachmentIdList: any[] = [];\n  public attachmentId: string = \"\";\n  public attachment: any;\n  public allowedFileExtension: string[];\n  public fileExceededLimit: boolean = false;\n  public fileTypeIncorrect: boolean = false;\n  public back: boolean = false;\n  public backicon: boolean = false;\n  public check: boolean;\n  public pop: boolean;\n  public localDate: string;\n  public currentName: string;\n  public pathquestion: number;\n  public percent: number;\n  public count: number;\n  public taFocusOut: boolean = false;\n  public notValidAccNum: boolean = false;\n  public splCCBackClick: boolean = false;\n  public summary = [];\n  public localSubQMap = new Map();\n  public keyIndex: number = 0;\n  //public sques: string;\n  public selDate: any = {};\n  public selectDate: string;\n  private today: Date = new Date();\n  private el: HTMLElement;\n  public innerhtml: any;\n  public possibilities: any;\n  public innerhtml1: any;\n  public summaryData =[];\n  \n  \n  tableData1: any[]= [\n    {\n      label: 'Fire Extinguisher',\n      imageSrc: 'https://media.istockphoto.com/id/943776434/vector/fire-extinguisher-icon-vector.jpg?s=612x612&w=0&k=20&c=KVaDxuV2TV7fdwn09Tg9HeF3MNyoJC5k2YqSAzpStDY=',\n      altText: 'extinguisher',\n      name: 'FireEstinguisher',\n      value: 'YES'\n    },\n    {\n      label: ' Fire Blanket',\n      imageSrc: 'https://media.istockphoto.com/id/943776434/vector/fire-extinguisher-icon-vector.jpg?s=612x612&w=0&k=20&c=KVaDxuV2TV7fdwn09Tg9HeF3MNyoJC5k2YqSAzpStDY=',\n      altText: 'fireBlanket',\n      name: 'fireBlanket',\n      value: 'YES'\n    },\n    {\n      label: 'Illumination',\n      imageSrc: 'https://media.istockphoto.com/id/943776434/vector/fire-extinguisher-icon-vector.jpg?s=612x612&w=0&k=20&c=KVaDxuV2TV7fdwn09Tg9HeF3MNyoJC5k2YqSAzpStDY=',\n      altText: 'fireBlailluminationnket',\n      name: 'illumination',\n      value: 'YES'\n    },\n    {\n      label: 'Ventilation',\n      imageSrc: 'https://media.istockphoto.com/id/943776434/vector/fire-extinguisher-icon-vector.jpg?s=612x612&w=0&k=20&c=KVaDxuV2TV7fdwn09Tg9HeF3MNyoJC5k2YqSAzpStDY=',\n      altText: 'Ventilation',\n      name: 'Ventilation',\n      value: 'YES'\n    }\n  ];\n  tableData2: any[]= [\n    {\n      label: 'Head Protection',\n      imageSrc: 'https://media.istockphoto.com/id/943776434/vector/fire-extinguisher-icon-vector.jpg?s=612x612&w=0&k=20&c=KVaDxuV2TV7fdwn09Tg9HeF3MNyoJC5k2YqSAzpStDY=',\n      altText: 'extinguisher',\n      name: 'check1',\n      value: 'YES'\n    },\n    {\n      label: 'Welding Hood',\n      imageSrc: 'https://media.istockphoto.com/id/943776434/vector/fire-extinguisher-icon-vector.jpg?s=612x612&w=0&k=20&c=KVaDxuV2TV7fdwn09Tg9HeF3MNyoJC5k2YqSAzpStDY=',\n      altText: 'fireBlanket',\n      name: 'check2',\n      value: 'YES'\n    },\n    {\n      label: 'Eye Protection',\n      imageSrc: 'https://media.istockphoto.com/id/943776434/vector/fire-extinguisher-icon-vector.jpg?s=612x612&w=0&k=20&c=KVaDxuV2TV7fdwn09Tg9HeF3MNyoJC5k2YqSAzpStDY=',\n      altText: 'Protection',\n      name: 'Protection',\n      value: 'YES'\n    },\n    {\n      label: 'Hearing Protection',\n      imageSrc: 'https://media.istockphoto.com/id/943776434/vector/fire-extinguisher-icon-vector.jpg?s=612x612&w=0&k=20&c=KVaDxuV2TV7fdwn09Tg9HeF3MNyoJC5k2YqSAzpStDY=',\n      altText: 'Hearing',\n      name: 'Hearing',\n      value: 'YES'\n    }\n  ];\n\n  public hours: any[] = [\n    \"01\",\n    \"02\",\n    \"03\",\n    \"04\",\n    \"05\",\n    \"06\",\n    \"07\",\n    \"08\",\n    \"09\",\n    \"10\",\n    \"11\",\n    \"12\",\n  ];\n\n  public minutes: string[] = [\n    \"00\",\n    \"01\",\n    \"02\",\n    \"03\",\n    \"04\",\n    \"05\",\n    \"06\",\n    \"07\",\n    \"08\",\n    \"09\",\n    \"10\",\n    \"11\",\n    \"12\",\n    \"13\",\n    \"14\",\n    \"15\",\n    \"16\",\n    \"17\",\n    \"18\",\n    \"19\",\n    \"20\",\n    \"21\",\n    \"22\",\n    \"23\",\n    \"24\",\n    \"25\",\n    \"26\",\n    \"27\",\n    \"28\",\n    \"29\",\n    \"30\",\n    \"31\",\n    \"32\",\n    \"33\",\n    \"34\",\n    \"35\",\n    \"36\",\n    \"37\",\n    \"38\",\n    \"39\",\n    \"40\",\n    \"41\",\n    \"42\",\n    \"43\",\n    \"44\",\n    \"45\",\n    \"46\",\n    \"47\",\n    \"48\",\n    \"49\",\n    \"50\",\n    \"51\",\n    \"52\",\n    \"53\",\n    \"54\",\n    \"55\",\n    \"56\",\n    \"57\",\n    \"58\",\n    \"59\",\n  ];\n\n  public selectedHour: string = \"\";\n  public selectedMinute: string = \"\";\n  public selectedMeridiem: string = \"\";\n  public valueName: string = \"\";\n  public valueName1: string = \"\";\n  public bookFlagAccept: string[];\n  public recordId: string;\n  public currentQuestionId: string;\n  public spinnerType: string;\n  public spinnerName: string;\n  public nextValue:string ='';\n\n  start_date?: any;\n\n  //search component\n  public tempoAddress: any[] = [];\n  public selectedValue: string;\n  public selectedPostalcode: string;\n  public selectedProvince: string;\n  public selectedCity: string;\n  public selectedArea: string;\n  public localaddress: any[] = [];\n\n  public allAddress :any [] = [];\n  public PostalCode:string;\n  public places: any[] = [];\n  public province:any[]=[];\n \n  // REQ-01 PROGRESS BAR\n  public progressStyle: string = \"0%\";\n  public answerCount: number = 0;\n  public indexCount: number = 0;\n  public addFlag: boolean = true;\n\n  public myDatePickerOptions: IMyDpOptions = {};\n  individualBookButton: boolean;\n\n  constructor(\n    private sfService: SalesforceService,\n    private dataService: DataService,\n    private route: ActivatedRoute,\n    private sanitizer: DomSanitizer,\n    private spinner: NgxSpinnerService,\n    private _formBuilder: UntypedFormBuilder,\n    //private dbService: NgxIndexedDBService,\n    private deviceService: DeviceDetectorService,\n    el: ElementRef\n  ) {\n    this.spinnerName = \"sp1\";\n    this.spinnerType = \"ball-spin-clockwise\";\n  }\n\n  onDateChanged(event: IMyDateModel) {\n    //console.log('Inside the onDateChanged');\n    //to change the border color\n    if (this.qbItem.Progress_Bar__c) {\n      //console.log('Inside the progressBar cond');\n      this.inpValue =\n        event.date.day + \"/\" + event.date.month + \"/\" + event.date.year;\n      if(this.questionItem.Type__c ==\"Book\"){\n        this.selectDate =  event.date.day + \"/\" + event.date.month + \"/\" + event.date.year;\n      }\n    } else {\n      //console.log('Inside the ELSE of progressBar cond');\n      if(this.questionItem.Type__c ==\"Book\"){\n        this.selectDate =  event.date.day + \"-\" + event.date.month + \"-\" + event.date.year;\n      }\n      this.inpValue =\n        event.date.year + \"-\" + event.date.month + \"-\" + event.date.day;\n    }\n    const htmlElement = window.document.getElementsByClassName(\"mydp\");\n    htmlElement\n      .item(0)\n      .setAttribute(\"style\", \"border-color:#87be1c;width:100%\");\n    this.dateMap.set(this.questionItem.Id, event);\n    if (\n      event.date.day === 0 &&\n      event.date.month === 0 &&\n      event.date.year === 0\n    ) {\n      this.dateMap.delete(this.questionItem.Id);\n      this.answerMap.delete(this.questionItem.Id);\n    }\n    //console.log('this.inpValue = '+this.inpValue);\n    //console.log('this.selectDate = '+this.selectDate);\n  }\n\n  ngOnInit() {\n    this.deviceInfo = this.deviceService.getDeviceInfo();\n    this.route.queryParams.subscribe((params: Params) => {\n      if (params['id']) {\n        this.individualBookButton = true;\n      }else if(params['bookletId']){\n        this.individualBookButton = false;\n      }\n    });\n    console.log('Inside the ngOnInit');\n    // console.log(\"RNXT-Claim\");\n    this.inpValue = \"\";\n    this.selectedMeridiem = \"AM\";\n    this.processQB();\n    //console.log(localStorage.getItem('address'));\n    if(localStorage.getItem(\"address\")){\n      this.localaddress = JSON.parse(localStorage.getItem(\"address\"));\n      //console.log('Length='+this.localaddress.length);\n      this.allAddress=this.localaddress.filter((item, index) => {\n        if (this.localaddress.indexOf(item) == index){\n          return item;\n        }\n      }); \n      this.allAddress.sort(function(a, b){\n        return a.zipCode - b.zipCode\n      });\n    } else if(this.deviceInfo.os === 'iOS'){\n        let openRequest = indexedDB.open(\"addressDB\");\n        openRequest.onsuccess = (event) => {\n          const targetNew = event.target as IDBRequest;\n          let dbNew = targetNew.result;\n          const requestNew = dbNew.transaction('addressTable')\n                .objectStore('addressTable')\n                .get(1);\n          requestNew.onsuccess = ()=> {\n              const tempVar = requestNew.result;\n              this.localaddress = JSON.parse(tempVar.wholeAddressString);\n              this.allAddress=this.localaddress.filter((item, index) => {\n                if (this.localaddress.indexOf(item) == index){\n                  return item;\n                }\n              }); \n              this.allAddress.sort(function(a, b){\n                return a.zipCode - b.zipCode\n              });\n        }\n      };\n    }\n  }\n\n  ngOnChanges() {\n    //console.log('inside Questionnaire ngOnChanges');\n    this.processQB();\n  }\n\n  date_TimeMap() {\n    this.selectedhourMap.set(this.questionItem.Id, this.selectedHour);\n    this.selectedminuteMap.set(this.questionItem.Id, this.selectedMinute);\n  }\n\n  day() {\n    this.myDatePickerOptions = {\n      dateFormat: \"dd.mm.yyyy\",\n      sunHighlight: false,\n      disableDateRanges: [],\n      showClearDateBtn: false,\n      disableSince: {\n        year: 0,\n        month: 0,\n        day: 0,\n      },\n      disableUntil: {\n        year: 0,\n        month: 0,\n        day: 0,\n      },\n      showTodayBtn: false,\n      dayLabels: {\n        su: \"Dom\",\n        mo: \"Lun\",\n        tu: \"Mar\",\n        we: \"Mié\",\n        th: \"Jue\",\n        fr: \"Vie\",\n        sa: \"Sáb\",\n      },\n      monthLabels: {\n        1: \"Ene\",\n        2: \"Feb\",\n        3: \"Mar\",\n        4: \"Abr\",\n        5: \"Mayo\",\n        6: \"Jun\",\n        7: \"Jul\",\n        8: \"Ago\",\n        9: \"Sep\",\n        10: \"Oct\",\n        11: \"Nov\",\n        12: \"Dic\",\n      },\n    };\n  }\n\n  change() {\n    const htmlElement = window.document.getElementsByClassName(\"mydp\");\n    if (this.selDate === null || this.inpValue.length === 0) {\n      htmlElement\n        .item(0)\n        .setAttribute(\"style\", \"width:100%;border: 1px solid red\");\n    } else {\n      htmlElement\n        .item(0)\n        .setAttribute(\"style\", \"border: 1px solid #87be1c ;width:100%\");\n    }\n  }\n\n  processQB() {\n    //console.log('ProcessQB');\n    //this.qbItem\n    //console.log(this.qbId);\n    //console.log('Version in process is 8bf11efa7f91a391d957bf6b5078edc7e656b67c');\n    if (this.qbId) {\n      if (this.qbId.length == 18) {\n        this.readQuestionBook(this.qbId);\n      } else {\n        //console.log('Inside the else part');\n        //console.log('Setting the Question Directly for testing');\n        this.questionItem = DTQUESTION;\n        this.qbItem = TESTQB;\n        this.processQuestion();\n      }\n    }\n  }\n\n  trimLastDummy(input: string) {\n    return (input = input.substring(0, input.length - 6));\n  }\n\n  getProperTime(def: string, input: string) {\n    return input === \"\" ? def : input;\n  }\n\n  //Summary Question Clickable Logic\n  handleEditClick(value: string) {\n    this.backicon = false;\n    if (this.abItem?.Status__c == \"Pending\") {\n      if (value == null) {\n        return;\n      }\n      this.readQuestion(value);\n      //console.log(' in side summaryopen'+ this.summary.length);\n\n      //Assign question stack length from summary part\n      var arrayLength = this.questionStack.length;\n      var lengthValue = this.questionStack.indexOf(value);\n\n      for (let i = arrayLength; i > lengthValue; i--) {\n        this.questionStack.pop();\n      }\n      if (this.qbItem.Progress_Bar__c === true) {\n        var arrayLength1 = this.questionName.length;\n        for (let j = arrayLength1; j > lengthValue; j--) {\n          this.questionName.pop();\n        }\n      }\n      this.summary = [];\n      this.summaryData = [];\n    }\n  }\n\n  handleNextClick() {\n    this.backButtonFlag = false;\n    this.AnswerSave();\n  }\n\n  AnswerSave(){\n    //this.updateProgress();\n    if (this.currentQuestionId === null) {\n      return;\n    }\n    var questionTxt='';\n    this.clearError();\n    this.handleEvent.emit(this.qbItem.Next_Tracking_ID__c);\n    this.recordId = null;\n    var cQuestion: Question = new Question();\n    cQuestion = this.questionItem;\n        // Create an array of objects to store the values\n        for (var i=0; i<this.questionItem.Questions__r.records.length;i++) {\n          if(this.questionItem.Questions__r.records[i].Question_Text__c){\n            var questionText = this.questionItem.Questions__r.records[i].Question_Text__c.replace(/<[^>]+>/g, ''); // Remove HTML tags from the Question_Text__c value\n          }else{\n            questionText = 'undefined';\n          }\n          const input = this.questionItem.Questions__r.records[i].input;\n          const obj = { [questionText]: input }; // Create an object with the questionText as the key and the input as the value\n          this.summaryData.push(obj); // Add the object to the data array\n        }\n         var typ = cQuestion.Type__c;\n    // this.sques += cQuestion.Question__c + '@@##$$';\n    var quesValue = cQuestion.Question_Text__c;\n    var mailformat =\n      \"^[^.][a-zA-Z0-9!#$%&'*+-/=?^_`{|}~]+[^.]@[^-][a-zA-Z0-9.-]+[^-].[a-zA-Z]{2,}$\";\n\n    // Process Inputs\n    if (this.checkboxFlag) {\n      this.inpValue = \"\";\n      // Save all the selected options in the inpValue\n      for (var ov of this.optionValues.filter((item) => item.checked)) {\n        this.inpValue += ov.Value__c + \"@@##$$\";\n        this.recordId = ov.Next_Question__c;\n      }\n      this.inpValue = this.trimLastDummy(this.inpValue);\n    } else if (this.emailFlag) {\n      if (this.inpValue && this.inpValue.match(mailformat)) {\n        this.recordId = this.questionItem.Next_Question__c;\n      } else {\n        this.questionItem.error = new ErrorWrapper();\n        return;\n      }\n    } else if (this.alphanumericFlag) {\n      var isNotValidAccNum = this.isNotValidAccNumber(this.inpValue);\n      if (isNotValidAccNum) {\n        this.notValidAccNum = true;\n        this.recordId = this.questionItem.Next_Question__c;\n        return;\n      }\n      this.notValidAccNum = false;\n    } else if (this.numberFlag) {\n      if (this.inpValue) {\n        this.recordId = this.questionItem.Next_Question__c;\n      } else {\n        this.questionItem.error = new ErrorWrapper();\n        return;\n      }\n    } else if (this.bookFlag) {\n      //console.log(this.questionItem.Type__c)\n      //console.log('Inside the bookFlag cond');\n      //console.log('this.inpValue = '+this.inpValue);\n      //console.log('this.selectDate = '+this.selectDate);\n      //console.log('this.selDate = ');\n      //console.log(this.selDate);\n      this.inpValue = \"\";\n      var hasMissingInput = false;\n      for (var item of this.questionItem.Questions__r.records) {\n        var count = 0;\n      \n        if(item.Type__c == \"Date\" || item.Type__c == \"Time\") {\n          //this one\n          this.change();\n            if(item.Type__c == \"Date\"){\n              //console.log('Inside the date type cond = '+this.selectDate);\n              this.inpValue = this.selectDate;\n              //console.log(this.inpValue)\n              //console.log(this.selectDate)\n          \n            }\n           if(item.Type__c == \"Time\"){\n             //console.log(this.selectedHour+this.selectedMeridiem+this.selectedMinute)\n             \n          if (this.questionItem.X24_Hours__c === false) {\n              this.questionItem.input =\n                (this.selectedMeridiem === \"PM\" && this.selectedHour != \"12\"\n                  ? Number(this.selectedHour) + 12\n                  : this.selectedHour) +\n                \":\" +\n                this.selectedMinute + \" PM\";\n              if (this.selectedMeridiem === \"AM\" && this.selectedHour === \"12\") {\n                this.questionItem.input = \"00\" + \":\" + this.selectedMinute + \" AM\";\n              }\n              if (this.qbItem.Progress_Bar__c) {\n                if(this.selectDate){\n                  this.inpValue = this.selectDate+\" \"+this.questionItem.input;\n                }else{\n                  this.inpValue = \" \"+this.questionItem.input;\n                }\n              } else {\n                if(this.selectDate){\n                  this.inpValue = this.selectDate+\" \"+this.questionItem.input;\n                }else{\n                  this.inpValue = \" \"+this.questionItem.input;\n                }\n                \n              }\n            }\n            if (this.questionItem.X24_Hours__c === true) {\n              this.questionItem.input =\n                this.selectedHour + \":\" + this.selectedMinute;\n              if (this.qbItem.Progress_Bar__c) {\n                this.inpValue = this.questionItem.input;\n              } else {\n                this.inpValue = this.questionItem.input;\n              }\n            }\n          }\n\n          if (this.selDate === null || this.selDate === undefined || !this.inpValue || !this.selectedHour || !this.selectedMinute || !this.selectDate) {\n            //console.log('Inside the null condition of input');\n            this.questionItem.error = new ErrorWrapper();\n            const htmlElement = window.document.getElementsByClassName(\"mydp\");\n            htmlElement\n              .item(0)\n              .setAttribute(\"style\", \"width:100%;border-bottom: 1px solid red !important;\");\n            return;\n          }\n          this.date_TimeMap();\n      }\n\n      if(item.Type__c== \"Text\" && item.Question__c === 'Población'){\n          for(var loc of this.localaddress){\n            if((this.selectedPostalcode == loc.zipCode)&&(this.selectedValue == loc.country)&&(this.selectedCity==loc.town)){\n              item.input= this.selectedCity;\n              break;\n            }\n            else if(count == this.localaddress.length -1){\n            //console.log('error form city')\n            item.error = new ErrorWrapper();\n            hasMissingInput = true;\n            return;\n            }\n            count++;  \n          }\n        //console.log('testin values=='+item.input)\n        } \n        \n        // if(item.Type__c === 'Location' && Array.isArray(item.input) && item.input.every((input) => input !== undefined)){\n        //     const inputValues = \"answerString: \" + item.input ;\n        //     item.input = inputValues;\n        // }\n        if(item.Type__c== \"Text\" && item.Question__c === 'Código postal'){\n          for(var loc of this.localaddress){\n            if(loc.zipCode == this.selectedPostalcode){\n              //console.log('testing zipcode value*****'+ this.selectedPostalcode)\n              item.input=this.selectedPostalcode;\n              break;\n            } else if(count == this.localaddress.length -1){\n            //console.log('error form')\n            item.error = new ErrorWrapper();\n            hasMissingInput = true;\n            return;\n            }\n            count++;  \n          }\n        //console.log('testin values=='+item.input)\n        }\n        \n      \n      if(item.Type__c== \"Text\" && item.Question__c === 'Provincia'){\n\t\t\t  for(var loc of this.localaddress){\n\t\t\t\t  if(loc.province == this.selectedProvince){\n\t\t\t\t\t  //console.log('******testing province value'+ this.selectedProvince)\n\t\t\t\t\t  item.input=this.selectedProvince;\n\t\t\t\t\t  break;\n\t\t\t\t  } else if(count == this.localaddress.length -1){\n\t\t\t\t\t//console.log('error form')\n\t\t\t\t\titem.error = new ErrorWrapper();\n\t\t\t\t\thasMissingInput = true;\n\t\t\t\t\treturn;\n\t\t\t\t  }\n\t\t\t\t  count++;  \n\t\t\t  }\n\t\t\t//console.log('testin values=='+item.input)\n\t\t  }\n\n        if (\n          !item.Is_Optional__c &&\n        //  ((item.Type__c != \"File\" && !item.input && item.Type__c != 'Date' && item.Type__c != 'Time') ||\n         //   (item.Type__c == \"File\" && this.attachments.length == 0))\n         (item.Type__c == \"File\" && this.attachments.length == 0)\n        ) {\n          item.error = new ErrorWrapper();\n          hasMissingInput = true;\n        }\n        if (item.Type__c == \"Radio\") {\n          if (!item.input) {\n            item.error = new ErrorWrapper();\n            hasMissingInput = true;\n          }\n        }\n        if (item.Type__c == \"Dropdown\") {\n          if (!item.input) {\n            item.input = \"\";\n            item.error = new ErrorWrapper();\n            hasMissingInput = true;\n          }\n        }\n        if (item.Type__c == \"Email\") {\n          if (item.input && item.input.match(mailformat)) {\n            this.recordId = cQuestion.Next_Question__c;\n          } else {\n            item.error = new ErrorWrapper();\n            hasMissingInput = true;\n          }\n        }\n        if (item.Type__c == \"File\" && this.attachments.length > 0) {\n          for (var attachmentItem of this.attachments) {\n            this.inpValue +=\n              attachmentItem.attachmentId +\n              \"@#$\" +\n              attachmentItem.attachmentName +\n              \",\";\n            if (item.input == this.inpValue) {\n              this.recordId = cQuestion.Next_Question__c;\n              //console.log('inside' + recordId);\n            }\n          }\n          // this.attachments = [];\n        } //item.input == this.inpValue;\n\n        this.inpValue += (item.input != undefined ? item.input : \"\") + \"@@##$$\";\n        questionTxt += item.Question__c + \"@@##$$\";\n        //console.log('inside book1' + this.inpValue)\n      }\n      if (hasMissingInput) {\n        return;\n      }\n      this.inpValue = this.trimLastDummy(this.inpValue);\n      questionTxt = questionTxt ? this.trimLastDummy(questionTxt) : questionTxt;\n    } \n    else if (this.listFlag) {\n      this.inpValue = '';\n      var hasMissingInput = false;\n      if(this.localSubQMap.has(this.questionItem.Id)){\n        this.subAnsMap = new Map();\n        for (var localQues of this.localSubQMap.get(this.questionItem.Id)) {\n            if(!localQues.input) {\n              localQues.error = new ErrorWrapper();\n              hasMissingInput = true;\n            }\n          if(!this.subAnsMap.has(localQues.Id)){\n            // console.log('inside ans map')\n            this.subAnsMap.set(localQues.Id,localQues.input);\n          } else {\n            // console.log('inside ans map else')\n            this.subAnsMap.set(localQues.Id,this.subAnsMap.get(localQues.Id) + '$$@@##'+localQues.input);\n          }\n        }\n\n        if (hasMissingInput) {\n          //console.log('file two')\n          return;\n        }\n        this.subAnsMap.forEach((value, key) => {\n          // console.log('inside Map' );\n          // console.log(value);\n          this.inpValue += (value != undefined ? value : '') + '@@##$$';\n        });\n        this.inpValue = this.trimLastDummy(this.inpValue);\n      }\n    }\n    else if (this.dropdownFlag) {\n      if (this.inpValue.length <= 1) {\n        this.inpValue = \".\";\n        this.questionItem.error = new ErrorWrapper();\n      }\n    } else if (this.dtFlag && this.dateFlag && this.timeFlag) {\n      //this one\n      this.change();\n      if (this.inpValue) {\n        this.selectedHour = this.getProperTime(\"12\", this.selectedHour);\n        this.selectedMinute = this.getProperTime(\"00\", this.selectedMinute);\n        this.selectedMeridiem = this.getProperTime(\"AM\", this.selectedMeridiem);\n        //console.log(this.inpValue.length);\n\n        if (this.questionItem.X24_Hours__c === false) {\n          this.questionItem.input =\n            (this.selectedMeridiem === \"PM\" && this.selectedHour != \"12\"\n              ? Number(this.selectedHour) + 12\n              : this.selectedHour) +\n            \":\" +\n            this.selectedMinute + \" PM\";\n          if (this.selectedMeridiem === \"AM\" && this.selectedHour === \"12\") {\n            this.questionItem.input = \"00\" + \":\" + this.selectedMinute + \" AM\";\n          }\n          if (this.qbItem.Progress_Bar__c) {\n            this.inpValue = this.inpValue + \" \" + this.questionItem.input;\n          } else {\n            this.inpValue = this.inpValue + \"T\" + this.questionItem.input;\n          }\n        }\n        if (this.questionItem.X24_Hours__c === true) {\n          this.questionItem.input =\n            this.selectedHour + \":\" + this.selectedMinute;\n          if (this.qbItem.Progress_Bar__c) {\n            this.inpValue = this.inpValue + \" \" + this.questionItem.input;\n          } else {\n            this.inpValue = this.inpValue + \"T\" + this.questionItem.input;\n          }\n        }\n        if (this.qbItem.Progress_Bar__c) {\n          //console.log(\"ans => \" + this.inpValue);\n          var date1: any = this.inpValue.split(\" \");\n          date1 = date1[0].split(\"/\");\n          date1 = [date1[2], date1[1], date1[0]].join(\"-\");\n          date1 = new Date(date1);\n          //console.log(date1)\n          var date2: any = this.insuranceStartDate.split(\" \");\n          date2 = new Date(date2[0]);\n          //console.log(date2);\n          if (date1 < date2) {\n            this.questionItem.error = new ErrorWrapper();\n            this.questionItem.error.errorMsg =\n              \"No es posible dar de alta la reclamación debido a que la fecha del incidente es anterior a la fecha de contratación de la póliza\";\n            //console.log('inside')\n            return;\n          }\n        }\n        if (this.selDate === null || !this.inpValue) {\n          this.questionItem.error = new ErrorWrapper();\n          return;\n        }\n        this.date_TimeMap();\n      }\n    } else if (this.timeFlag && this.dtFlag && !this.dateFlag) {\n      this.date_TimeMap();\n      if (this.questionItem.X24_Hours__c === false) {\n        this.inpValue =\n          (this.selectedMeridiem === \"PM\" && this.selectedHour != \"12\"\n            ? Number(this.selectedHour) + 12\n            : this.selectedHour) +\n          \":\" +\n          this.selectedMinute;\n      } else {\n        this.inpValue = this.selectedHour + \":\" + this.selectedMinute;\n      }\n      if (this.inpValue.length < 5) {\n        this.questionItem.error = new ErrorWrapper();\n        return;\n      }\n    } else if (this.dateFlag && this.dtFlag && !this.timeFlag) {\n      this.change();\n      if (this.inpValue.length < 7 || this.selDate === null) {\n        this.questionItem.error = new ErrorWrapper();\n        return;\n      }\n    } else if (this.fileFlag) {\n      //console.log('four')\n      this.inpValue = \"\";\n      if (this.attachments.length > 0) {\n        for (var attachmentItem of this.attachments) {\n          this.inpValue +=\n            attachmentItem.attachmentId +\n            \"@#$\" +\n            attachmentItem.attachmentName +\n            \",\";\n        }\n        //console.log('inside filesss' + this.inpValue);\n        this.inpValue = this.inpValue.substr(0, this.inpValue.length - 1);\n      } else {\n        this.questionItem.error = new ErrorWrapper();\n        return;\n      }\n    }\n\n    // Check for the answer before saving to the DB\n    if (!this.questionItem.Is_Optional__c && !this.inpValue) {\n      // Show error that the question must be answered\n      this.questionItem.error = new ErrorWrapper();\n      return;\n    }\n    // Save the Answer in the DB\n    this.answerWrap = new AnswerWrapper();\n    this.answerWrap.abId = this.abItem.Id;\n    this.answerWrap.quesId = cQuestion.Id;\n    this.answerWrap.quesValue = quesValue;\n    this.answerWrap.qTyp = typ;\n    this.answerWrap.ansValue = this.inpValue;\n    this.answerWrap.groupText = cQuestion.Group__c;\n    this.answerWrap.ansValue = this.inpValue;\n    console.log('this.answerWrap.qTyp',this.answerWrap.qTyp);\n   if(this.answerWrap.qTyp == \"Alphanumeric\"){\n      this.answerWrap.ansValue = 'ES'+ this.inpValue;\n      // console.log('Bank condition');\n      // console.log(this.answerWrap.ansValue);\n    }\n    /*if (cQuestion.Type__c == 'Book'){\n    for (var qb of cQuestion.Questions__r.records){\n      //console.log(qb.Question__c+'****'+\"@@##$$\")\n    } \n  }*/\n    //this.answerWrap.squesValue = cQuestion.Question__c;\n    this.answerWrap.squesValue = questionTxt ? questionTxt : cQuestion.Question__c;\n    this.saveAnswer();\n  }\n\n  next() {\n    var cQuestion: Question = new Question();\n    cQuestion = this.questionItem;\n    var typ = cQuestion.Type__c;\n    // If no error then move to next steps\n    if (this.questionItem.error) {\n      return;\n    }\n\n    this.questionStack.push(cQuestion.Id);\n    //  this.questionName.push(cQuestion.Name);\n\n    // CONDITIONAL vs OPTIONONLY & UNCONDITIONAL\n    if (cQuestion.RecordType.Name == \"CONDITIONAL\") {\n      for (var cOpt of cQuestion.Question_Options__r.records) {\n        // Radio / Data\n        //console.log('Option => ' + cOpt.Value__c + ' matching with ' + ansVal);\n        if (cOpt.Value__c == this.inpValue) {\n          //console.log('Match Found using ' + cOpt.Next_Question__c);\n          this.recordId = cOpt.Next_Question__c;\n          //console.log('conditional record id'+ this.recordId);\n        }\n      }\n      // Could be of type Data and existing value\n      if (this.recordId && typ == \"Data\") {\n        this.recordId = cQuestion.Next_Question__c;\n      }\n    } else if (cQuestion.RecordType.Name == \"OPTIONONLY\") {\n      //  OPTIONONLY logic\n      this.recordId = cQuestion.Next_Question__c;\n    } else if (cQuestion.RecordType.Name == \"UNCONDITIONAL\") {\n      //Unconditional  logic\n      //console.log(\"inside unconditional\");\n      //inside Book Type\n      if (cQuestion.Type__c == \"Book\" && cQuestion.Question_No__c !='6') {\n        //console.log(\"inside book\");\n        for (let opt of cQuestion.Questions__r.records) {\n          //console.log(opt.Type__c);\n          if (opt.Type__c == \"Dropdown\" || opt.Type__c == \"Radio\") {\n            for (var opt1 of opt.Question_Options__r.records) {\n              if (this.valueName == opt1.Value__c) {\n                this.recordId =opt1.Next_Question__c || cQuestion.Next_Question__c;                  \n              } else {\n                //console.log('Else'+this.recordId)\n                this.recordId = cQuestion.Next_Question__c;\n                \n              }\n            }\n          } else {\n            this.recordId = cQuestion.Next_Question__c;\n          }\n        }\n      }\n      else if(cQuestion.Type__c == \"Book\" && cQuestion.Question_No__c =='6' ) {\n        for (let opt of cQuestion.Questions__r.records) {\n          if (opt.Type__c == \"Dropdown\" || opt.Type__c == \"Radio\"){\n          for (var opt1 of opt.Question_Options__r.records) {\n            if (this.valueName == opt1.Value__c) {\n            this.recordId = opt1.Next_Question__c;  \n            }\n          }\n        }\n        }\n      }    \n      \n      else {\n        this.recordId = cQuestion.Next_Question__c;\n      }\n    }\n\n    // CATEGORIZATION\n    //this.stepperCateg();\n\n    // Calling the progres bar update function\n    this.answerCount++;\n    this.updateProgress();\n\n\n    // CATEGORIZATION\n    //this.stepperCateg();\n\n    if (this.recordId) {\n      //console.log('Before Calling readQuestion() using ' + recordId);\n      this.readQuestion(this.recordId);\n      this.pop = true;\n    } else {\n      this.pop = false;\n      //console.log('Summary Page Logic');\n      // Reset the Variables\n      this.inpValue = \"\";\n      this.answerWrap = new AnswerWrapper();\n      this.optionValues = [];\n      this.subQuestions = [];\n\n      this.resetFlag(typ);\n      this.questionItem = null;\n\n      // Show Summary\n      for (var q of this.questionStack) {\n        //console.log('Handling Question => ' + q);\n        var ansWrap = this.answerMap.get(q);\n        if (ansWrap) {\n          //console.log('Handling Answer for ' + ansWrap.quesId + ' of type ' + ansWrap.qTyp);\n          if(ansWrap.qTyp == 'File' || ansWrap.qTyp == 'Book'||ansWrap.qTyp == 'List' || ansWrap.qTyp == 'Checkbox'){\n            var newStr = '';\n            for (var ansStr of ansWrap.ansValue.split('@@##$$')) {\n              for (var ansStr1 of ansStr.split('$$@@##')) {\n              //  if(ansStr1.includes('answerString')){ //remove the answer string  \n               //   const withoutAnswerString = ansStr1.replace(\"answerString: \", \"\");\n                //  ansStr1 = withoutAnswerString;\n              //  }\n                if (ansStr1.length > 0) {\n                  if (newStr.length == 0) {\n                    newStr = ansStr1;\n                  } else {\n                    newStr += '; ' + ansStr1;  //comma(,) changed as semi colon(;) because of address contains comma(,) \n                    if(this.attachmentsMap.has(ansWrap.quesId)){\n                      for(var att of this.attachmentsMap.get(ansWrap.quesId)){\n                        newStr = newStr.replace(att.attachmentId,'');\n                      }\n                    }\n                    newStr = (newStr.replace(',,',', ')).replace(', ,',', ');\n                    newStr = newStr.startsWith(',') ? newStr.substring(1, newStr.length) : (newStr.endsWith(',') ? newStr.substring(0, newStr.length - 1) : newStr);\n                  }\n                }\n              }\n            }ansWrap.ansValue = newStr;\n        }\n          this.summary.push(ansWrap);\n          this.backicon = true;\n        }\n      }\n    }\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  handleBackClick() {\n    this.back = true;\n    if (this.pop === true) {\n      this.questionName.pop();\n    }\n    this.handleEvent.emit(this.qbItem.Back_Tracking_ID__c);\n    var cQuestion: Question = new Question();\n    cQuestion = this.questionItem;\n    if(cQuestion.Question_No__c =='1'){\n      this.handleEvent.emit(this.qbItem.Back__c);\n    }\n    \n\n    this.answerCount--;\n    this.updateProgress();\n    // CATEGORIZATION\n    //this.stepperCateg();\n\n    if (this.summary) {\n      //console.log('summary true');\n      this.summary = [];\n    }\n    if(this.summaryData){\n      this.summaryData =[];\n    }\n\n    // Read the previous question from DB\n    this.readQuestion(this.questionStack.pop());\n    //console.log(this.questionStack);\n  }\n\n  handleBackClickNew() {\n    this.handleEvent.emit(this.qbItem.Edit__c);\n  }\n\n  //updating status once Q&A completed.\n\n  private updateAnswerBook = (uuid: string) => {\n    if(this.serv == \"api\") {\n      this.dataService.getAPIData(\n        this.tkn,\n        [\"AnswerBook\", \"Update\", uuid],\n        this.successupdateAB,\n        this.failureupdateAB\n      );\n    } else {\n      this.sfService.remoteAction(\n        \"NxtController.process\",\n        [\"AnswerBook\", \"Update\", uuid],\n        this.successupdateAB,\n        this.failureupdateAB\n      );\n    }\n  }\n\n  private successupdateAB = (response) => {\n    console.log(response);\n    // //console.log('status success')\n    this.abItem.Status__c = \"Completed\";\n  };\n  private failureupdateAB = (response) => {\n    //console.log('status failed')\n  };\n\n  private readQuestionBook = (uuid: string) => {\n    if(this.serv == \"api\") {\n      this.dataService.getAPIData(\n        this.tkn,\n        [\"QuestionBook\", \"read\", uuid],\n        this.successReadBook,\n        this.failureReadBook\n      );\n    } else {\n      this.sfService.remoteAction(\n        \"NxtController.process\",\n        [\"QuestionBook\", \"read\", uuid],\n        this.successReadBook,\n        this.failureReadBook\n      );\n    }\n  }\n\n  private successReadBook = (response) => {\n    console.log('Inside the successReadBook');\n    console.log(response);\n    if(response != null || response != undefined){\n      this.qbItem = response.questionbook;\n      this.abItem = response.answerbook;\n    }\n   // console.log('readingQuestion using ' + this.qbItem);\n    if (this.abItem?.Status__c == \"Pending\") {\n      if (\n        this.abItem.Answers__r == null ||\n        this.abItem.Answers__r.records.length == 0\n      ) {\n        this.readQuestion(this.qbItem.First_Question__c);\n      } else {\n        // Populate the existing answers\n        var lastQuestionId = \"\";\n\n        for (var ansObject of this.abItem.Answers__r.records) {\n          lastQuestionId = ansObject.Question_Ref__c;\n\n          this.questionStack.push(ansObject.Question_Ref__c);\n\n          this.answerMap.set(ansObject.Question_Ref__c, {\n            quesValue: ansObject.Question_Rich_Text__c,\n            ansValue: ansObject.Answer_Long__c,\n            quesId: ansObject.Question_Ref__c,\n            qTyp: ansObject.Question_Type__c,\n            groupText:ansObject.Question_Group_Text__c,\n          });\n\n          //console.log(this.questionStack)\n          if (ansObject.Question_Type__c == \"Book\") {\n            var av1 = ansObject.Answer_Long__c.split(\"@@##$$\");\n            // //console.log(\"book log\");\n\n            //  //console.log(\"bookid\" + av1[0]);\n            this.attachmentsMap.set(ansObject.Question_Ref__c, [\n              { attachmentName: av1[1], attachmentId: av1[0] },\n            ]);\n            //  //console.log(this.attachmentsMap);\n          } else if (ansObject.Question_Type__c == \"File\") {\n            //  //console.log(\"inside if\");\n            var attList;\n            var att;\n            for (var attVar of ansObject.Answer_Long__c.split(\",\")) {\n              var attIdName = attVar.split(\"@@##$$\");\n              att.attachmentName = attIdName[1];\n              att.attachmentId = attIdName[0];\n              attList.push(att);\n            }\n            this.attachmentsMap.set(ansObject.Question_Ref__c, attList);\n            //  //console.log(this.attachmentsMap);\n          }\n        }\n\n        this.questionStack.pop();\n        //console.log(this.answerMap);\n        // Read the last answered question\n        this.readQuestion(lastQuestionId);\n      }\n    } else if (this.abItem?.Status__c == \"Completed\") {\n      this.handleEvent.emit(\"Summaryupdated\");\n      // Temporary Fix for duplicate answers on the summary.\n      this.summary = [];\n      this.percent = 100;\n      this.progressStyle = \"100%\";\n\n      for (var answer of this.abItem.Answers__r.records) {\n        //console.log(answer.Question_Group_Text__c);\n        //console.log('repeat');\n        //console.log(answer.Question_Rich_Text__c);\n        var answers = {};\n        if (answer.Question_Type__c == \"File\") {\n          var files = \"\";\n          var fIndex = 0;\n          var fileList = answer.Answer_Long__c.split(\",\");\n          for (var fileIdName of fileList) {\n            var fileName = fileIdName.split(\"@#$\");\n            if (fIndex == 0) {\n              files = fileName[1];\n            } else {\n              files = files + \" ,\" + fileName[1];\n            }\n\n            fIndex++;\n          }\n\n          answers = {\n            groupText:answer.Question_Group_Text__c,\n            quesValue: answer.Question_Rich_Text__c,\n            ansValue: files,\n          };\n          this.summary.push(answers);\n        } else if (answer.Question_Type__c == \"Book\") {\n          /*  var quesNo=0;\n         if(answer.Answer_Long__c.includes(\"@@##$$\")){\n            //console.log('line 1223');\n            for (var bqAnswerValue of answer.Answer_Long__c.split(\"@@##$$\")) {\n              var quesValue=answer.Question_Text__c.split(\"@@##$$\");\n              answers = {};\n              answers = {\n               // groupText:answer.Question_Text__c,\n                quesValue:  \"&lt;p&gt;\"+ quesValue[quesNo]+\"&lt;p&gt;\",\n                ansValue: bqAnswerValue,\n              };\n              quesNo++;\n              this.summary.push(answers);\n            }\n           }*/\n          if(answer.Answer_Long__c.includes(\"@@##$$\")){\n            var answervalues = answer.Answer_Long__c.split(\"@@##$$\");\n            //console.log('value')\n            answers = {      \n             //groupText:answer.Question_Group_Text__c,\n             quesValue: answer.Question_Rich_Text__c,\n             ansValue: answervalues,\n           };\n           //console.log(answers)\n           this.summary.push(answers);\n           }\n          else{\n            answers = {      \n              //groupText:answer.Question_Group_Text__c,\n              quesValue: answer.Question_Rich_Text__c,\n              ansValue: answer.Answer_Long__c,\n            };\n            this.summary.push(answers);\n          }\n        } else {\n         // var ans1 = answer.Answer_Long__c.split(\"@@##$$\");\n          answers = {      \n            //groupText:answer.Question_Group_Text__c,\n            quesValue: answer.Question_Rich_Text__c,\n            ansValue: answer.Answer_Long__c,\n          };\n          this.summary.push(answers);\n        }\n      }\n    }\n  };\n\n  private failureReadBook = (response) => {\n    console.log('Inside the failureReadBook');\n    console.log(response);\n  };\n\n  private readAnswerbook = (uuid: string) => {\n    if(this.serv = \"api\") {\n      this.dataService.getAPIData(\n        this.tkn,\n        [\"AnswerBook\", \"read\", uuid],\n        this.successAnswerBookRead,\n        this.failureAnswerBookRead\n      );\n    } else {\n      this.sfService.remoteAction(\n        \"NxtController.process\",\n        [\"AnswerBook\", \"read\", uuid],\n        this.successAnswerBookRead,\n        this.failureAnswerBookRead\n      );\n    }\n  }\n\n\n  private successAnswerBookRead = (response) => {\n    if (this.abItem?.Status__c == \"Completed\") {\n      for (var answer of this.abItem.Answers__r.records) {\n        var av = answer.Answer_Long__c.split(\"@@##$$\");\n        var answers = { quesValue: answer.Question_Rich_Text__c, ansValue: av, groupText:answer.Question_Group_Text__c };\n        //console.log(answers)\n        this.summary.push(answers);\n      }\n      this.handleEvent.emit(\"Summaryupdated\");\n    }\n  };\n\n  private failureAnswerBookRead = (response) => {\n    //console.log('inside failureread');\n    //console.log(response);\n  };\n\n  private readQuestion = (uuid: string) => {\n    if(this.serv == \"api\") {\n      this.dataService.getAPIData(\n        this.tkn,\n        [\"Question\", \"read\", uuid],\n        this.successRead,\n        this.failureRead\n      );\n    } else {\n      this.sfService.remoteAction(\n        \"NxtController.process\",\n        [\"Question\", \"read\", uuid],\n        this.successRead,\n        this.failureRead\n      );\n    }\n  }\n\n  private successRead = (response) => {\n    // console.log('Inside the successRead new');\n    // console.log(response);\n    // console.log(this.questionItem);\n    // Reset the Variables\n\n    if (this.questionItem) {\n      this.inpValue = \"\";\n      this.answerWrap = new AnswerWrapper();\n      this.optionValues = [];\n      this.subQuestions = [];\n      this.resetFlag(this.questionItem.Type__c);\n    }\n    this.questionItem = response.question;\n    // console.log(this.questionItem);\n\n    if(this.questionItem.Type__c === 'Alphanumeric'){\n      this.splCCBackClick = true;\n    }\n\n    this.currentQuestionId = this.questionItem.Id;\n    this.handlePage.emit(this.questionItem.Tracking_ID__c);\n    // Handle the subQuestion options\n    if (response.sqOptions) {\n      //var newRecords = [];\n      for (var q of this.questionItem.Questions__r.records) {\n        //console.log(q.Name);\n        var sq = response.sqOptions[q.Id];\n        if (sq) {\n          //console.log('found options for subquestion ' + q.Name);\n          if (!q.Question_Options__r) {\n            q.Question_Options__r = sq.Question_Options__r;\n          }\n        }\n      }\n    }\n    this.processQuestion();\n    this.innerhtml = this.sanitizer.bypassSecurityTrustHtml(\n      this.questionItem.Additional_Rich__c\n    );\n    this.trackId();\n  };\n\n  trackId() {\n    var qtrackId = this.questionItem.Tracking_ID__c;\n    //console.log('trackId-question'+qtrackId);\n  }\n\n  private failureRead = (response) => {\n    //console.log('inside failureread');\n    //console.log(response);\n  };\n\n  private saveAnswer = () => {\n    // Set the Answer Number based on the Question Stack Length\n    if (this.inpValue != \".\") {\n      this.currentQuestionId = null;\n    }\n    this.answerWrap.ansNumber = this.questionStack.length + 1;\n\n    if(this.serv == \"api\") {\n      this.dataService.getAPIData(\n        this.tkn,\n        [\"Answer\", \"create\", JSON.stringify(this.answerWrap)],\n        this.successSave,\n        this.failureSave\n      );\n    } else {\n      this.sfService.remoteAction(\n        \"NxtController.process\",\n        [\"Answer\", \"create\", JSON.stringify(this.answerWrap)],\n        this.successSave,\n        this.failureSave\n      );\n    }\n  };\n\n  htmlDecode(input) {\n    var doc = new DOMParser().parseFromString(input, \"text/html\");\n    return doc.documentElement.textContent;\n  }\n\n  private successSave = (response) => {\n    if (response.status == \"success\") {\n      //this.abItem = response.answerbook;\n      this.answerMap.set(response.answer.quesId, response.answer);\n    } else {\n      this.questionItem.error = new ErrorWrapper();\n      this.questionItem.error.errorMsg = response.error.errorMsg;\n    }\n    if(!this.backButtonFlag){\n      this.next();\n    }\n  };\n\n  private failureSave = (response) => {\n    //console.log('inside failureSave');\n    //console.log(response);\n  };\n\n  private processQuestion = () => {\n    // console.log('Inside the processQuestion');\n    // console.log('splCCBackClick = '+this.splCCBackClick);\n    // console.log(this.questionStack);\n    //console.log(this.questionItem);\n    this.pop = true;\n\n    // if(!this.back){\n    //   this.questionName.push(this.questionItem.Name)\n    // }\n\n    if (this.qbItem.Progress_Bar__c === true) {\n      if (!this.back) {\n        this.questionName.push(this.questionItem.Name);\n      }\n      this.back = false;\n      if (this.questionName[0] === this.questionName[1]) {\n        this.questionName.pop();\n      }\n\n      this.currentName = this.questionItem.Name;\n      this.pathquestion = this.questionName.indexOf(this.currentName);\n      this.possibilities = this.qbItem.Possibilities__c;\n    }\n\n    this.myDatePickerOptions;\n    this.day();\n    //console.log('processing question ' + this.questionItem.Name + ' existing answers are ' + this.answerMap.size); // => ' + JSON.stringify(this.questionItem));\n\n    // Set the Flags to show right fields\n    this.setFlag(this.questionItem.Type__c);\n    //console.log('After the setFlag method dtFlag = '+this.dtFlag);\n\n    // Check the existing answer from answerMap\n    if (this.answerMap.has(this.questionItem.Id)) {\n      //  //console.log(\"existing answer found for this.questionItem.Name\");\n      var eAnswer = this.answerMap.get(this.questionItem.Id);\n      // Get the existing answer from the Map\n      this.inpValue = eAnswer.ansValue;\n      //console.log('inpValue has been set to ' + this.inpValue);\n      if (this.attachmentsMap.has(this.questionItem.Id)) {\n        this.attachments = this.attachmentsMap.get(this.questionItem.Id);\n      }\n    } else {\n      //console.log('inside removing attachment array');\n      this.attachments = [];\n    }\n    // console.log(this.inpValue);\n    if(this.splCCBackClick && this.inpValue && this.inpValue.includes('ES')){\n      // console.log('Inside the if cond');\n      this.splCCBackClick = false;\n      this.inpValue = this.inpValue.replace('ES','');\n    }\n\n    if (this.checkboxFlag) {\n      // Set the Options for Checkbox\n      this.setOptions(this.questionItem.Question_Options__r.records);\n    } else if (this.bookFlag) {\n      //console.log('Inise the expected bookFlag cond');\n      //console.log('dtFlag = '+this.dtFlag);\n      this.setSubQuestions(this.questionItem.Questions__r.records);\n    } else if (this.listFlag) {\n      // Set the LocalSubQuestions\n      // console.log('inside list flag');\n      // console.log(this.questionItem.Questions__r.records);\n      // console.log(this.abItem.Questions__r.records);\n      if(!this.localSubQMap.has(this.questionItem.Id)){\n        this.setSubQuestions(this.questionItem.Questions__r.records);\n      } \n    } else if (this.dtFlag) {\n      //console.log('Inise the unexpected dtFlag cond');\n      this.selectedHour = \"\";\n      this.selectedMinute = \"\";\n      this.selDate = \"\";\n      // 2021-5-16T00:00\n      if (this.dateMap.has(this.questionItem.Id)) {\n        this.selDate = this.dateMap.get(this.questionItem.Id);\n      }\n      if (this.selectedhourMap.has(this.questionItem.Id)) {\n        this.selectedHour = this.selectedhourMap.get(this.questionItem.Id);\n      }\n      if (this.selectedminuteMap.has(this.questionItem.Id)) {\n        this.selectedMinute = this.selectedminuteMap.get(this.questionItem.Id);\n      }\n      if (this.questionItem.X24_Hours__c === true) {\n        this.hours.push(\n          \"13\",\n          \"14\",\n          \"15\",\n          \"16\",\n          \"17\",\n          \"18\",\n          \"19\",\n          \"20\",\n          \"21\",\n          \"22\",\n          \"23\",\n          \"00\"\n        );\n      }\n      if (this.questionItem.X24_Hours__c === false) {\n        this.hours = this.hours.slice(0, 12);\n      }\n      if (this.dtFlag && this.inpValue) {\n        var dtVal = this.inpValue.split(\"T\"); \n        var dtval0 = this.inpValue.split(\" \");\n        this.inpValue = dtVal[0];\n        this.inpValue = dtval0[0];\n\n        this.questionItem.input = dtVal[1];\n        this.questionItem.input = dtval0[1];\n      }\n      if (\n        this.questionItem.Is_Date_Backward__c ||\n        this.questionItem.Is_Date_Forward__c\n      ) {\n        if (this.questionItem.Is_Date_Backward__c === true) {\n          this.myDatePickerOptions.disableSince = {\n            year: this.today.getFullYear(),\n            month: this.today.getMonth() + 1,\n            day: this.today.getDate() + 1,\n          };\n        }\n        if (this.questionItem.Is_Date_Forward__c === true) {\n          this.myDatePickerOptions.disableUntil = {\n            year: this.today.getFullYear(),\n            month: this.today.getMonth() + 1,\n            day: this.today.getDate(),\n          };\n        }\n      }\n    } else if (this.fileFlag) {\n      this.fileUI();\n      // logic\n      this.allowedFileExtension =\n        this.questionItem.Allowed_File_Extensions__c.split(\";\");\n      //console.log(this.allowedFileExtension);\n    }\n    \n    if (this.qbItem.Progress_Bar__c === true) {\n      this.updateProgress();\n    }\n  };\n\n  setFlag(typ) {\n    //console.log('inside setFlag for ' + typ);\n\n    if (typ) {\n      // Set the Flags\n      if (typ == \"Text\") {\n        this.textFlag = true;\n\n        //this.numberFlag = true;\n      } else if (typ == \"Number\") {\n        this.numberFlag = true;\n      } else if (typ == \"AlphaNumeric\") {\n        this.alphanumericFlag = true;\n        /*if(this.inpValue.length === 0){\n          this.inpValue='ES'\n        }*/\n      } else if (typ == \"Email\") {\n        this.emailFlag = true;\n      } else if (typ == \"File\") {\n        this.fileFlag = true;\n      } else if (typ == \"DateTime\") {\n        this.dtFlag = true;\n        this.timeFlag = true;\n        this.dateFlag = true;\n      } else if (typ == \"TextArea\") {\n        this.taFlag = true;\n      } else if (typ == \"Radio\") {\n        this.radioFlag = true;\n      } else if (typ == \"Dropdown\") {\n        this.dropdownFlag = true;\n      } else if (typ == \"Checkbox\") {\n        this.checkboxFlag = true;\n      } else if (typ == \"Book\") {\n        this.bookFlag = true;\n      }else if (typ == 'List'){\n        this.listFlag = true;\n      } else if (typ == \"Time\") {\n        //console.log('Inside the Time cond');\n        this.dtFlag = true;\n        this.timeFlag = true;\n        //console.log(this.dtFlag);\n      } else if (typ == \"Date\") {\n        //console.log('Inside the Date cond');\n        this.dtFlag = true;\n        this.dateFlag = true;\n        //console.log(this.dtFlag);\n      }\n    }\n  }\n\n  resetFlag(typ) {\n    if (typ) {\n      // Set the Flags\n      if (typ == \"Text\") {\n        this.textFlag = false;\n        //this.numberFlag = false;\n      } else if (typ == \"Number\") {\n        this.numberFlag = false;\n      } else if (typ == \"Alphanumeric\") {\n        this.alphanumericFlag = false;\n      } else if (typ == \"Email\") {\n        this.emailFlag = false;\n      } else if (typ == \"File\") {\n        this.fileFlag = false;\n      } else if (typ == \"DateTime\") {\n        this.dtFlag = false;\n        this.dateFlag = false;\n        this.timeFlag = false;\n      } else if (typ == \"TextArea\") {\n        this.taFlag = false;\n      } else if (typ == \"Radio\") {\n        this.radioFlag = false;\n      } else if (typ == \"Dropdown\") {\n        this.dropdownFlag = false;\n      } else if (typ == \"Checkbox\") {\n        this.checkboxFlag = false;\n      } else if (typ == \"Book\") {\n        this.bookFlag = false;\n      } else if (typ == 'List'){\n        this.listFlag = false;\n      } else if (typ == \"Time\") {\n        this.dtFlag = false;\n        this.timeFlag = false;\n      } else if (typ == \"Date\") {\n        this.dtFlag = false;\n        this.dateFlag = false;\n      }\n    }\n  }\n\n  setOptions(records) {\n    for (var opt of records) {\n      var ov = new OptionValue();\n      ov.Id = opt.Id;\n      ov.Name = opt.Name;\n      ov.Value__c = opt.Value__c;\n      ov.Next_Question__c = opt.Next_Question__c;\n      ov.checked = false;\n\n      if (\n        this.inpValue &&\n        this.inpValue.split(\"@@##$$\").includes(opt.Value__c)\n      ) {\n        ov.checked = true;\n      }\n\n      this.optionValues.push(ov);\n    }\n  }\n  Dropdown(event,ques?:any) {\n    ques.input = event; // here when using the ng-select got event as value\n  }\n\n  setSubQuestions(records) {\n    // console.log('inside setSubQuestions');\n    // console.log(records);\n    var qaMap = new Map();\n    // console.log(this.inpValue);\n    if (this.inpValue) {\n      var aIndex = 0;\n      // search changed as semi colon because of address contains comma \n      if ((this.inpValue.search(\"; \") == -1)) {\n       // const withoutAnswerString = this.inpValue.replace(\"answerString: \", \"\"); //remove the answer string\n       // this.inpValue = withoutAnswerString;\n        this.inpValue = this.inpValue + '@@##$$' ;\n        for (var ansStr of this.inpValue.split(\"@@##$$\")) {\n          aIndex++;\n          qaMap.set(aIndex, ansStr);\n          //console.log('Setting the qaMap for ' + aIndex + ' with ' + ansStr);\n        }\n      } else {\n        for (var ansStr of this.inpValue.split(\"; \")) {\n          aIndex++;\n          qaMap.set(aIndex, ansStr);\n          //console.log('Setting the qaMap ' + aIndex + ' with ' + ansStr);\n        }\n      }\n    }\n    // console.log('after setting values from inpvalue qa map are');\n    // console.log(qaMap);\n\n    for (var ques of records) {\n      if (ques.Type__c == \"File\") {\n        this.valueName1 = ques.Allowed_File_Extensions__c;\n        //console.log(this.valueName1);\n      }\n\n      var ans = '';\n      if (qaMap.has(ques.Question_No__c)) {\n          ques.input = qaMap.get(ques.Question_No__c);\n          // console.log('after fetching map values');\n          // console.log(ques.input);\n          if(ques.input.indexOf('$$@@##') > 0){\n            // console.log('answer supposed to be trimmed');\n            // console.log(ques.input);\n            ans = ques.input.substring(ques.input.indexOf('$$@@##')+6,ques.input.length);\n            // console.log(ans);\n            ques.input = ques.input.substring(0,ques.input.indexOf('$$@@##'));\n            // console.log(ques.input);\n          }\n        }\n\n      if ((ques.Type__c === \"Date\") && (ques.Is_Date_Backward__c || ques.Is_Date_Forward__c)) {\n        //console.log('Inside the date backward/forward cond');\n        if (ques.Is_Date_Backward__c === true) {\n          //console.log('Inside the Is_Date_Backward__c');\n          this.myDatePickerOptions.disableSince = {\n            year: this.today.getFullYear(),\n            month: this.today.getMonth() + 1,\n            day: this.today.getDate() + 1,\n          };\n        }\n        if (ques.Is_Date_Forward__c === true) {\n          //console.log('Inside the Is_Date_Forward__c');\n          this.myDatePickerOptions.disableUntil = {\n            year: this.today.getFullYear(),\n            month: this.today.getMonth() + 1,\n            day: this.today.getDate(),\n          };\n        }\n        //console.log(this.myDatePickerOptions);\n      }\n\n      this.subQuestions.push(ques);\n      for(var i=0; i<this.subQuestions.length;i++){\n        // to show/hide the dependent dropdown only field using the dropDownOnly boolean\n        if(this.subQuestions[i].Size__c == 4){\n          this.subQuestions[i].dropDownOnly = true;\n        }else{\n          this.subQuestions[i].dropDownOnly = false;\n        }\n      }\n      if(ans != ''){\n        for(var an of (ans.split('$$@@##'))){\n          var sQ = new Question();\n          Object.assign(sQ,ques);\n          sQ.input = an;\n          this.subQuestions.push(sQ);\n        }\n      }\n    }\n    if (this.valueName1 != null && this.valueName1.length > 0) {\n      this.bookFlagAccept = this.valueName1.split(\";\");\n      //console.log(this.subQuestions);\n    }\n    this.structLocalSubQuestion(null);\n  }\n\n  optionChange(selValue) {\n    let radioTrackingId: string = \"\";\n    for (var opt of this.questionItem.Question_Options__r.records) {\n      //console.log('optionChange TrackingId'+opt.Tracking_ID__c);\n      if (opt.Value__c == selValue) {\n        //console.log('inside if'+opt.Tracking_ID__c)\n        radioTrackingId = opt.Tracking_ID__c;\n      }\n    }\n\n    this.handleEvent.emit(radioTrackingId);\n    this.clearError();\n    // //console.log('inside optionChange using ' + selValue);\n\n    this.inpValue = selValue;\n  }\n\n  clearError() {\n    if (this.questionItem.error) {\n      this.questionItem.error = null;\n    }\n  }\n\n  clearLocalSubQuesError(quesId) {\n    quesId.error = null;\n  }\n\n  inputValidate(e) {\n    var keyCode = e.keyCode || e.which;\n    // Only ASCII character in that range allowed\n    var ASCIICode = (e.which) ? e.which : e.keyCode;\n    if (ASCIICode > 31 && (ASCIICode < 48 || ASCIICode > 57)){\n      return false;\n    }else{\n      return true;\n    }\n  }\n\n  CCOnChange(inpValue: string) {\n\n      if (inpValue.length == 2) {\n        this.inpValue += \" \";\n      }\n      else if (inpValue.length == 7) {\n        this.inpValue += \" \";\n      }\n      else if (inpValue.length == 12) {\n        this.inpValue += \" \";\n      }\n      else if (inpValue.length == 17) {\n        this.inpValue += \" \";\n      }\n      else if (inpValue.length == 22) {\n        this.inpValue += \" \";\n      }\n\n  }\n\n  isNotValidAccNumber(s: string) {\n    s = s.replace(/\\s+/g, \"\");\n    s = 'ES' + s;\n    var isNotValidStr = false;\n    if (s.length == 24) {\n      for (var i = 0; i < s.length; i++) {\n        if (i <= 1 && /[a-zA-Z]/.test(s.charAt(i))) {\n          //console.log(\"Valid char: \" + s.charAt(i));\n        } else if (i > 1 && /[0-9]/.test(s.charAt(i))) {\n          //console.log(\"Valid numeric: \" + s.charAt(i));\n        } else {\n          isNotValidStr = true;\n          //console.log(\"Not a valid char\");\n        }\n      }\n    } else {\n      isNotValidStr = true;\n      //console.log(\"Not a valid acc number\");\n    }\n    return isNotValidStr;\n  }\n\n  clearSQError(quesId) {\n    var sqList = this.subQuestions.filter((item) => item.Id == quesId);\n    for (var sq of sqList) {\n      sq.error = null;\n    }\n  }\n\n  uploadFile(event,ques?:any) {\n    //console.log('inside upload');\n    this.clearError();\n    this.fileTypeIncorrect = false;\n    var local = this;\n    local.attachment = event.target.files[0];\n    // Validate the file extension\n    //console.log(local.attachment);\n    let fileNameWithType: string =\n      local.attachment && local.attachment.name.toLowerCase();\n    if (\n      !fileNameWithType.endsWith(\".jpg\") &&\n      !fileNameWithType.endsWith(\".png\") &&\n      !fileNameWithType.endsWith(\".pdf\") &&\n      !fileNameWithType.endsWith(\".jpeg\") &&\n      !fileNameWithType.endsWith(\".heic\") &&\n      !fileNameWithType.endsWith(\".heif\") &&\n      !fileNameWithType.endsWith(\".JPG\") &&\n      !fileNameWithType.endsWith(\".PNG\") &&\n      !fileNameWithType.endsWith(\".PDF\") &&\n      !fileNameWithType.endsWith(\".JPEG\") &&\n      !fileNameWithType.endsWith(\".HEIC\") &&\n      !fileNameWithType.endsWith(\".HEIF\")\n    ) {\n      local.fileTypeIncorrect = true;\n    }\n    // Return when the file type is incorrect\n    if (local.fileTypeIncorrect) {\n      return;\n    }\n    let fileContent: any;\n    var reader = new FileReader();\n\n    reader.onload = function () {\n      fileContent = reader.result;\n      local.fileExceededLimit = local.attachment.size > 3242880; //Validating file size\n      // Upload the file to Salesforce when the limit is within range\n      if (!local.fileExceededLimit) {\n        let fileWrapper = new AttachmentWrapper();\n        fileWrapper.parentId = local.abItem.Id;\n        fileWrapper.fileName = local.attachment.name;\n        fileWrapper.fileContent = fileContent;\n        local.createAttachment(fileWrapper);\n        ques.input = fileWrapper.fileName;\n      }\n    };\n    this.spinner.show(this.spinnerName);\n    reader.readAsDataURL(event.target.files[0]);\n  }\n\n  private successAttachmentCreate = (response) => {\n    let createdAttachment: Attachment = new Attachment(\n      response.attachmentId,\n      response.attachmentName,\n      this.attachment.lastModifiedDate\n    );\n    this.attachments.push(createdAttachment);\n    this.attachmentsMap.set(this.questionItem.Id, this.attachments);\n    this.spinner.hide(this.spinnerName);\n  };\n\n  private successAttachmentDelete = (response) => {\n    for (let i = 0; i < this.attachments.length; i++) {\n      if (this.attachments[i].attachmentId === this.attachmentId) {\n        this.attachments.splice(i, 1);\n      }\n    }\n  };\n\n  private failureAttachmentCreate = (response) => {\n    //console.log('inside failureAttachmentCreate');\n  };\n\n  private failureAttachmentDelete = (response) => {\n    //console.log('inside failureAttachmentDelete');\n  };\n\n  handleSubmitClick() {\n    this.handleEvent.emit(this.qbItem.Submit_Tracking_ID__c);\n    this.updateAnswerBook(this.abItem.Id);\n  }\n\n  handleCancelClick() {\n    this.handleEvent.emit(this.qbItem.Cancel_Tracking_ID__c);\n  }\n\n  private createAttachment = (fileWrapper: any) => {\n    if(this.serv == \"api\") {\n      this.dataService.getAPIData(\n        this.tkn,\n        [\"Attachment\", \"create\", JSON.stringify(fileWrapper)],\n        this.successAttachmentCreate,\n        this.failureAttachmentCreate\n      );\n    } else {\n      this.sfService.remoteAction(\n        \"NxtController.process\",\n        [\"Attachment\", \"create\", JSON.stringify(fileWrapper)],\n        this.successAttachmentCreate,\n        this.failureAttachmentCreate\n      );\n    }\n  }\n\n  deleteAttachment(attachmentId: string) {\n    this.attachmentId = attachmentId;\n    this.handleEvent.emit(\"deleteAttachment\");\n    this.deleteSFAttachment(attachmentId);\n  }\n\n  private deleteSFAttachment = (fileId: string) => {\n    if(this.serv == \"api\") {\n      this.dataService.getAPIData(\n        this.tkn,\n        [\"Attachment\", \"delete\", fileId],\n        this.successAttachmentDelete,\n        this.failureAttachmentDelete\n      );\n    } else {\n      this.sfService.remoteAction(\n        \"NxtController.process\",\n        [\"Attachment\", \"delete\", fileId],\n        this.successAttachmentDelete,\n        this.failureAttachmentDelete\n      );\n    }\n  }\n\n  getFileName(fileNamewithIdandType) {\n    //truncate file path\n    var fileNameWithType = fileNamewithIdandType.substr(\n      fileNamewithIdandType.indexOf(\"::::\") + 4\n    );\n    return fileNameWithType; //fileNameWithType.replace(/^(.*(\\/|\\\\))(.+)$/, '$3');\n  }\n  fileUI() {\n    if (this.attachments.length === 0) {\n    }\n  }\n\n  //Update function for categorization\n  // stepperCateg() {\n  //   this.firstFormGroup = this._formBuilder.group({\n  //     firstCtrl: ['', Validators.required]\n  //   });\n  //   this.secondFormGroup = this._formBuilder.group({\n  //     secondCtrl: ['', Validators.required]\n  //   });\n\n  // }\n\n  // Update Function for the Progress Bar\n  updateProgress() {\n    if (this.qbItem.Progress_Bar__c === true) {\n      let j = [];\n      for (let i = 0; i < this.possibilities.total; i++) {\n        var pathposs = Object.values(this.possibilities.paths[i].questions);\n        if (pathposs[this.pathquestion] === this.currentName) {\n          j.push(i);\n          this.check = true;\n        } else {\n          this.check = false;\n        }\n      }\n      if (j.length === 1) {\n        this.count = j[0];\n      }\n      if (j.length > 1) {\n        var width =\n          90 * (this.questionStack.length / this.possibilities.maxQuestions);\n        this.progressStyle = Math.round(width) + \"%\";\n      } else if (j.length === 1) {\n        var width =\n          90 *\n          (this.questionStack.length /\n            this.possibilities.paths[this.count].count);\n        this.progressStyle = Math.round(width) + \"%\";\n      }\n      this.percent = +Math.round(width);\n    }\n  }\n\n  townName(area) {\n    this.selectedValue = area.town;\n    //console.log('this value='+this.selectedValue)\n    this.tempoAddress = [];\n  }\n\n  getTownLocal() {\n    this.tempoAddress = [];\n    if (this.selectedValue.length > 0) {\n      for (var val of this.localaddress) {\n        if (\n          val.town.substring(0, this.selectedValue.length) == this.selectedValue\n        ) {\n          //console.log(val.country)\n          this.tempoAddress.push(val);\n          //console.log('tempoAddress'+this.tempoAddress)\n          if (this.tempoAddress.length == 6) {\n            break;\n          }\n        }\n      }\n    }\n    document.getElementById(\"selectList\").style.display = \"block\";\n    this.setSearchListWidth();\n  }\n\n  clearList() {\n    setTimeout(() => {\n      this.tempoAddress = [];\n    }, 500);\n  }\n\n  setSearchListWidth() {\n    //to resize search list based on the screen size\n    const searchBoxWidth = window.document.getElementById(\"autocomplete-input\").offsetWidth;\n    document.getElementById(\"selectList\").style.width = searchBoxWidth + \"px\";\n  }\n\n    getCode(){\n      this.tempoAddress = [];\n      if (this.selectedPostalcode.length > 0) {\n        for (var val of this.allAddress) {\n          if (val.zipCode.substring(0, this.selectedPostalcode.length) == this.selectedPostalcode) {\n            //console.log(val.country)\n            this.tempoAddress.push(val);\n            //console.log('tempoAddress'+this.tempoAddress)\n            if (this.tempoAddress.length == 6) {\n              break;\n            }\n          }\n        }\n      }\n      document.getElementById(\"selectList\").style.display = \"block\";\n      this.setSearchListWidth();\n    }\n    getPostalcode(value){\n     this.places=[];\n     this.province=[];\n      var province;\n      var town;\n      this.selectedPostalcode = value.zipCode;\n      this.selectedValue = value.country;\n      this.tempoAddress=[];\n\n \n      for(var val of this.localaddress){\n        if(this.selectedPostalcode == val.zipCode ){\n          this.places.push(val);\n          this.province.push(val);\n          this.selectedValue = val.country;\n          province = val.province\n          town = val.town;\n        }\n      }\n      if(this.places.length == 1){\n        \n        this.selectedProvince =province;\n        this.selectedCity = town;\n      }else if(this.places.length >1 || this.places.length ==0){\n        \n          this.selectedCity ='';\n          this.selectedProvince='';\n      }\n    }\n    closeDropdown() {\n      if(this.selectedPostalcode.length == 5){\n        this.getPostalcode({zipCode:this.selectedPostalcode});\n      }\n\n   setTimeout(()=> {\n      document.getElementById('selectList').style.display = \"none\";\n    }, 500);\n   }\n\n\n   //Plus button implementation.\n   structLocalSubQuestion(ques: LocalQuestion){\n    // console.log('inside structLocalSubQuestion');\n      for(var i = 0; i < this.subQuestions.length; i++){\n        var localSubQuestion = new LocalQuestion();\n          localSubQuestion.Id = this.subQuestions[i].Id;\n          localSubQuestion.Name = this.subQuestions[i].Name;\n          localSubQuestion.Question__c = this.subQuestions[i].Question__c;\n          localSubQuestion.Question_Text__c = this.subQuestions[i].Question_Text__c;\n          localSubQuestion.Type__c = this.subQuestions[i].Type__c;\n          localSubQuestion.Title__c = this.subQuestions[i].Title__c;\n          localSubQuestion.SubTitle__c = this.subQuestions[i].SubTitle__c;\n          localSubQuestion.Is_Optional__c = this.subQuestions[i].Is_Optional__c;\n          localSubQuestion.Error_Message__c = this.subQuestions[i].Error_Message__c;\n          localSubQuestion.Next_Question__c = this.subQuestions[i].Next_Question__c;\n          localSubQuestion.Group__c = this.subQuestions[i].Group__c;\n          localSubQuestion.Question_No__c = this.subQuestions[i].Question_No__c;\n          localSubQuestion.Allowed_File_Extensions__c = this.subQuestions[i].Allowed_File_Extensions__c;\n          localSubQuestion.uniqueSubQId = ''+this.subQuestions[i].Id + i; \n          localSubQuestion.input = this.subQuestions[i].input;\n          this.localSubQuestions.push(localSubQuestion);\n      }\n  // console.log('final local sub questions');\n  // console.log(this.localSubQuestions);\n  // console.log(this.questionItem.Id);\n  this.localSubQMap.set(this.questionItem.Id,this.localSubQuestions);\n  this.localSubQuestions = [];\n  // console.log('final key localSubQMap map');\n  // console.log(this.localSubQMap);\n  }\n\n  addInputBox(question: LocalQuestion, index: number){\n    var arra = this.localSubQMap.get(this.questionItem.Id);\n    var qIndex = arra.indexOf(question);\n    var ques: LocalQuestion = new LocalQuestion();\n    Object.assign(ques, question);\n    //console.log((ques.uniqueSubQId).substring(18, (ques.uniqueSubQId).length)+1);\n    if(this.keyIndex == index){\n      ques.uniqueSubQId = ques.Id + (String(index+1));\n      this.keyIndex++;\n    }else{\n      this.keyIndex++;\n      ques.uniqueSubQId = ques.Id + (String(this.keyIndex));\n    }\n    ques.input = '';\n    arra.splice(qIndex+1, 0, ques);\n\n    this.localSubQMap.set(this.questionItem.Id,arra);\n    //console.log(this.localSubQMap);\n  }\n\n  removeAddress(quesUniqueId: string, qName: string) {\n    //console.log(quesUniqueId)\n    var val = this.localSubQMap.get(this.questionItem.Id);\n    var keyindex = 0;\n\n    for(let i=0; i<val.length; i++){\n      if(val[i].Name == qName){\n        keyindex++;\n      }\n    }\n\n    if(this.localSubQMap.has(this.questionItem.Id) && keyindex >1){\n      var reorder = val.filter((item) => item.uniqueSubQId !== quesUniqueId)\n      this.localSubQMap.set(this.questionItem.Id,reorder);\n      keyindex--;\n    }\n  }\n\n  getLocalSubQuestions(id: String){\n    return this.localSubQMap.get(id);\n  }\n\n  //Single Add button functionality for List type\nAdd(question: LocalQuestion){\n    this.addFlag =  false;\n    var arra = this.localSubQMap.get(this.questionItem.Id);\n    var index  = arra.length;\n    var a = arra.slice(-1).pop();\n    this.indexCount  = a.Question_No__c;\n    \n    for (var i = 0; i < this.indexCount ; i++) {\n      var ques: LocalQuestion = new LocalQuestion();\n      Object.assign(ques, question[i]);\n      this.keyIndex++;\n      ques.uniqueSubQId = ques.Id + (String(this.keyIndex));\n      ques.input = '';\n      arra.splice(index+(this.indexCount-1), 0, ques);\n    this.localSubQMap.set(this.questionItem.Id,arra);\n    }  \n    this.addFlag = true;\n  }\n  \n  handleLocationSelected(location: any,ques:any) {\n    ques.input = location;\n  }\n\n  selectedInput(input:any ,ques:any){ \n    ques.input = input;\n  }\n\n  handleTextareaValueChange(value :string){\n    console.log('Selected text-area text:', value);\n  }\n  getData(data:any){\n   console.log('table data',data);\n  }\n\n  dependentChange(value:any){\n  this.nextValue = value;\n  }\n\n  displayDate(dateSelected: any,ques:any){\n    // Parse the date string using moment and assign it to this.selectedDate\n    ques.input = moment(dateSelected.value , 'YYYY-MM-DD HH:mm:ss').format('YYYY-MM-DD HH:mm:ss').toString();\n  }\n\n  getKey(item: any): any {\n    return Object.keys(item)[0];\n  }\n  \n  getValue(item: any): any {\n    return Object.values(item)[0];\n  }\n\n  // In the parent component class\ngetTableData(ques: any): any[] {\n  // Return a new array to ensure each table instance has its own separate array\n  if (ques.Name === 'QN-02251') {\n    ques.tableDataValue = this.tableData1;\n    ques.tableHeader ='Safety Precautions';\n    return [...ques.tableDataValue];\n  } else {\n    ques.tableDataValue = this.tableData2;\n    ques.tableHeader ='Personal Protective Equipments';\n    return [...ques.tableDataValue];\n  }\n}\n  }\n\n","<!-- Spinner -->\n<ngx-spinner [name]=\"spinnerName\" [type]=\"spinnerType\"></ngx-spinner>\n\n<!-- Back Processing -->\n<div *ngIf=\"backicon == false\" >\n  <div class=\"backicon\" [style.visibility]=\"questionStack.length >0 ? 'visible' : 'hidden'\">\n    <button (click)=\"handleBackClick()\" [class]=\" abItem?.Status__c == 'Completed' ? 'summary-volver':'app-back1'\">\n    <img class=\"icon-arrow-back\" src=\"https://rnxt.s3.amazonaws.com/MytIcon/icon-arrow-back.png\" alt=\"Scroll down\"> {{ qbItem?.Back__c }}\n    </button>\n  </div>\n</div>\n\n<!-- Question Hanlding -->\n<div *ngIf=\"questionItem\" [class]=\"qbItem.isShengel__c ? 'questiondiv1' : 'questiondiv1 padd-bottom'\">\n  <!-- Progress Bar & Title -->\n  <div *ngIf=\"questionItem.Title__c && qbItem.Progress_Bar__c\">\n    <h1 class=\"header1\">{{ questionItem?.Title__c }}</h1>\n    <div class=\"header2\">{{ questionItem?.SubTitle__c }}</div>\n  </div>\n\n  <!-- Progress & Grouping -->\n  <div [ngClass]=\"{ questiondiv2: !qbItem?.Progress_Bar__c }\">\n    <!-- Pie Chart Progress -->\n    <div [ngClass]=\"{ bgColor: qbItem?.Progress_Bar__c }\">\n      <div id=\"progress\" *ngIf=\"qbItem?.Progress_Bar__c\">\n        <circle-progress class=\"titlebar\" [percent]=\"this.percent\" [radius]=\"40\" [space]=\"-4\" [outerStrokeWidth]=\"4\"\n        [innerStrokeWidth]=\"4\" [outerStrokeColor]=\"'#e0b1b0'\" [innerStrokeColor]=\"'#e7e8ea'\" [animation]=\"true\" [backgroundPadding]= \"0\"\n        [backgroundColor]= \"'#dd2e13'\" [backgroundGradientStopColor]=\"'#f9bfbd'\" [titleColor]=\"'#f3eded'\" \n        class=\"ng-star-inserted\" [title]=\"this.percent+'%'\" [showSubtitle]=\"false\" [showBackground]=\"true\" [animationDuration]=\"300\"\n        [startFromZero]=\"false\" [responsive]=\"false\" >\n        </circle-progress>\n      </div>\n    </div>\n\n    <!-- Show the Group/Module related to the Progress -->\n    <div *ngIf=\"questionItem.Group__c && qbItem.Progress_Bar__c\"\n        [ngClass]=\"{ questionalign: !qbItem?.Progress_Bar__c }\">\n      <div class=\"largeTitle\">\n        <h3 class=\"myt-font6 myt-text3\">\n          {{ questionItem?.Group__c }}\n        </h3>\n        <div *ngIf=\"questionItem.Sub_Text__c != '¿En qué país ocurrió?'\" class=\"myt-font5 myt-text1\">{{questionItem?.Sub_Text__c}}</div>\n        <div *ngIf=\"questionItem.Sub_Text__c === '¿En qué país ocurrió?'\" class=\"myt-font10 myt-text2\">{{questionItem?.Sub_Text__c}}</div>\n      </div>\n    </div>\n  </div>\n\n  <!-- Question Handling -->\n  <div class=\"questiondiv2\">\n    <!-- Title -->\n    <div *ngIf=\"questionItem.Is_Title__c\">\n      <div *ngIf=\"questionItem.Type__c != 'Book' && questionItem.Question_No__c!='6' && questionItem.Question_No__c!='9'\"> \n        <h3 class=\"questionalign  myt-font3 myt-align myt-text4\" [innerHTML]=\"getText(questionItem?.Question_Text__c)\">\n          {{questionItem?.Question_Text__c}}\n        </h3>\n      </div>\n    </div>\n    <div *ngIf=\"!questionItem.Is_Title__c\" [class]=\"qbItem.isShengel__c ? 'header-style additional' : 'question-f-size additional'\">\n      <div [innerHTML]=\"getText(questionItem?.Question_Text__c)\" >\n        {{ questionItem?.Question_Text__c }}\n      </div>\n    </div>\n\n    <!-- This should be removed with Custom Styling - MR - 11AUG23 -->\n    <div *ngIf=\"questionItem.Type__c == 'Book'\">\n      <div *ngIf=\"questionItem.Question_No__c=='6'\">\n        <h3 class=\"myt-321\" [innerHTML]=\"getText(questionItem?.Question_Text__c)\">\n          {{ questionItem?.Question_Text__c }}\n        </h3>\n      </div>\n    </div>\n    \n    <!-- This should be removed with Custom Styling - MR - 11AUG23 -->\n    <div *ngIf=\"questionItem.Type__c == 'File' \">\n      <div *ngIf=\"questionItem.Question_No__c=='9'\">\n        <h3 class=\"myt-345\" [innerHTML]=\"getText(questionItem?.Question_Text__c)\">\n          {{questionItem?.Question_Text__c}}\n        </h3>\n      </div>\n    </div>\n  </div>\n\n  <!-- Additional Info -->\n  <!-- The below code can be written effectively nested ngIf for Rich Text & Other onw for Progress Bar -->\n  <div *ngIf=\"questionItem.Additional_Rich__c && qbItem.Progress_Bar__c\" >\n    <div\n      class=\"additional \" [innerHTML]=\"innerhtml\">\n    </div>\n  </div>\n  <div *ngIf=\"questionItem.Additional_Rich__c && !qbItem.Progress_Bar__c\">\n    <div class=\"info-alert ques-alert1\">\n      <i class=\"fa fa-info fa-3x iposition icolor\" aria-hidden=\"true\"></i>\n      <div class=\"infodiv\" [innerHTML]=\"innerhtml\"></div>\n    </div>\n  </div>\n\n  <!-- Dropdown-->\n  <div *ngIf=\"dropdownFlag\" >\n    <div class=\"dis-flex\">\n      <select \n        [ngClass]=\"{\n          'dt-line myt-align3 myt-align2 dpDown dropbox down1 myt-dropbox myt-border-r myt-font1': qbItem?.Progress_Bar__c,\n          'custom-select': !qbItem?.Progress_Bar__c\n        }\" class=\"mr-sm-2 dd-height dropbox \"  id=\"dropdown\" [(ngModel)]=\"inpValue\" (change)=\"clearError()\" style.border-color=\"{{\n          this.questionItem?.error ? 'red' : inpValue?.length > 0 ? '#fff' : ''\n        }}\" style.color=\"{{ questionItem?.error ? 'red' : '' }}\" style=\"margin-left: 21.5rem !important;\">\n        <option *ngFor=\"let opt of questionItem.Question_Options__r.records\" class=\"option\" value=\"{{ opt.Value__c }}\">\n          {{ opt.Value__c }}\n        </option>\n        <option value=\".\" disabled hidden>Bitte treffen Sie eine Auswahl</option>\n      </select>\n    </div>\n  </div>\n\n  <!-- Radio -->\n  <div *ngIf=\"radioFlag || dataFlag\" class=\"\">\n    <div *ngIf=\"this.questionItem.error\" class=\"cond-div2\">\n      {{ questionItem?.Error_Message__c }}\n    </div>\n    <div class=\"dis-flex\">\n      <div *ngFor=\"let opt of questionItem.Question_Options__r.records\" class=\"radio radioOption\" >\n        <label class=\"radiocontainer container  myt-font4\">{{ opt.Value__c }}\n          <input type=\"radio\" [id]=\"opt.Id\" [(ngModel)]=\"inpValue\" name=\"inpValue\" value=\"{{ opt.Value__c }}\"\n            (change)=\"optionChange(opt.Value__c)\" />\n          <span class=\"checkmark\"></span>\n        </label>\n      </div>\n    </div>\n  </div>\n\n  <!-- Checkbox -->\n  <div *ngIf=\"checkboxFlag\" class=\"\">\n    <div *ngIf=\"this.questionItem.error\" class=\"cond-div2\">\n      {{ questionItem?.Error_Message__c }}\n    </div>\n    <div class=\"dis-flex\">\n      <div *ngFor=\"let item of optionValues\" class=\"radio col-md-6 optiondiv\">\n        <label class=\" container1 \" >{{ item.Value__c }}\n          <input type=\"checkbox\" [id]=\"item.Id\" [(ngModel)]=\"item.checked\" (click)=\"clearError()\" />\n          <span class='checkmark1'></span>\n        </label>\n      </div>\n    </div>\n  </div>\n\n  <!-- Text -->\n  <div *ngIf=\"textFlag\" class=\"col-md-12 myt-book1\">\n    <div class=\"col-md-12\" class=\"dis-flex myt-align1\" [class]=\"'col-md-' + questionItem?.Size__c + ' paddingnone'\">\n      <input type=\"text\" [(ngModel)]=\"inpValue\" [ngClass]=\"{\n          'boxoutline myt-font1 myt-book1': qbItem?.Progress_Bar__c,\n          textBox1: !qbItem?.Progress_Bar__c\n        }\" id=\"text-input-id\" required=\"\" (focus)=\"clearError()\" style.border-color=\"{{\n          this.questionItem?.error\n            ? 'red'\n            : inpValue?.length > 0\n            ? '#87be1c'\n            : ''\n        }}\" oninput=\"this.value=this.value.replace(/[^a-zA-Z0-9\\s.:;,?]/g,'');\" />\n      <i class=\"fa fa-check check-icon\" aria-hidden=\"true\" *ngIf=\"inpValue?.length > 0\"></i>\n    </div>\n  </div>\n\n  <!-- Text Area -->\n  <div *ngIf=\"taFlag\" class=\"col-md-12\">\n    <div class=\"dis-flex\">\n      <textarea class=\"ta-input\" id=\"ta-input-id\" [(ngModel)]=\"inpValue\" (click)=\"clearError()\" style.border-color=\"{{\n          this.questionItem?.error\n            ? 'red'\n            : inpValue?.length > 0 && taFocusOut\n            ? '#87be1c'\n            : ''\n        }}\" (focusout)=\"taFocusOut = true\"\n        oninput=\"this.value=this.value.replace(/[^a-zA-Z0-9\\s.:;,?]/g,'');\"></textarea>\n      <i class=\"fa fa-check check-icon\" aria-hidden=\"true\" *ngIf=\"inpValue?.length > 0 && taFocusOut\"></i>\n    </div>\n  </div>\n\n  <!-- CC Number Format -->\n  <div *ngIf=\"numberFlag\" class=\"col-md-12\">\n    <div class=\"dis-flex\">\n      <input type=\"Text\" placeholder=\"0000 0000 0000 0000 0000 0000\" [ngClass]=\"{ boxoutline: qbItem?.Progress_Bar__c }\"\n        [(ngModel)]=\"inpValue\" id=\"number-input-id\" (ngModelChange)=\"CCOnChange($event)\" required=\"\" maxlength=\"29\"\n        (focus)=\"clearError()\" oninput=\"this.value=this.value.replace(/[^0-9 ]/g,'');\"\n        style=\"width:-webkit-fill-available;\" style.border-color=\"{{\n          this.questionItem.error\n            ? 'red'\n            : inpValue?.length > 0\n            ? '#87be1c'\n            : ''\n        }}\" />\n      <i class=\"fa fa-check\" aria-hidden=\"true\" style=\"color: #87be1c; margin-left: -2rem; z-index: 1; padding: 5px;\"\n        *ngIf=\"inpValue?.length > 0\"></i>\n    </div>\n  </div>\n  <!-- END-->\n\n  <!-- AlphaNumeric -->\n  <div *ngIf=\"alphanumericFlag\" class=\"col-md-12\"> <!--UI not completed-->\n    <div style=\"position:relative;\">\n      <input type=text placeholder=\"0 of 0\" style=\"padding:5px 5px 5px 150px;\" id=\"youridhere\"/>\n    </div>\n  </div>\n\n  <!-- Email -->\n  <div *ngIf=\"emailFlag\" class=\"col-md-12\">\n    <div class=\"dis-flex\">\n      <input type=\"email\" [ngClass]=\"{ boxoutline: qbItem?.Progress_Bar__c }\" [(ngModel)]=\"inpValue\" id=\"email-input-id\"\n        required=\"\" (focus)=\"clearError()\" style.border-color=\"{{\n          this.questionItem.error\n            ? 'red'\n            : inpValue?.length > 0\n            ? '#87be1c'\n            : ''\n        }}\" />\n      <i class=\"fa fa-check\" aria-hidden=\"true\" style=\"color: #87be1c; margin-left: -2rem; z-index: 1; padding: 5px\"\n        *ngIf=\"inpValue?.length > 0\"></i>\n    </div>\n  </div>\n\n  <!-- DateTime -->\n  <div *ngIf=\"dtFlag\" class=\"col-md-12 paddingZero myt-time1\" >\n    <!-- Error Handling -->\n    <div class=\"col-md-12\" *ngIf=\"questionItem.error\" style=\"font-size: 18px;\n    color: red;\">{{questionItem?.error?.errorMsg}}</div>\n\n    <!-- Date -->\n    <div *ngIf=\"dateFlag\">\n      <div class=\"col-md-12 paddingBottom\">\n        <label class=\"date-time colorf\">{{ questionItem?.Date_Text__c }}</label>\n        <div class=\"dis-flex\">\n          <my-date-picker name=\"mydate\" [options]=\"myDatePickerOptions\" id=\"date\" style=\"font-size: 18px !important;\" (dateChanged)=\"onDateChanged($event)\"\n            [(ngModel)]=\"selDate\" class=\"date-picker\" placeholder=\"Seleccione fecha\" (focus)=\"clearError()\">\n          </my-date-picker>\n        </div>\n      </div>\n    </div>\n\n    <!-- Time -->\n    <div *ngIf=\"timeFlag\">\n      <div class=\"col-md-12 paddingBottom\">\n        <label class=\"date-time colorf\">{{ questionItem?.Time_Text__c }}</label>\n        <div class=\"dis-flex\">\n         <div [ngClass]=\"{'dt-line date-line dt-time': qbItem?.Progress_Bar__c,\n                           dateandTime: !qbItem?.Progress_Bar__c}\" \n              id=\"dateandTime\" [style.border-color]=\"questionItem?.error ? 'red': questionItem?.input?.length > 0 ? '' : ''\"\n              (focus)=\"(clearSQError) \">\n          <select name=\"hours\" class=\"datetime showHour myt-time myt-hour\" [(ngModel)]=\"selectedHour\" id=\"hour\"\n            (focus)=\"clearError()\">\n            <option value=\"\">HH</option>\n            <option [value]=\"hour\" *ngFor=\"let hour of hours\">\n              {{ hour }}\n            </option>\n          </select>\n          <span class=\"colon\"> : </span>\n          <select name=\"minutes\" class=\"datetime showminute myt-time\" [(ngModel)]=\"selectedMinute\" id=\"minute\"\n            (focus)=\"clearError()\">\n            <option value=\"\">MM</option>\n            <option [value]=\"minute\" *ngFor=\"let minute of minutes\">\n              {{ minute }}\n            </option>\n          </select>\n          <div [ngClass]=\"{ colon1: qbItem?.Progress_Bar__c }\" *ngIf=\"questionItem?.X24_Hours__c == false\">\n            <span class=\"colon\"> : </span>\n            <select name=\"AM/PM\" class=\"myt-time\" [(ngModel)]=\"selectedMeridiem\" id=\"meridiem\">\n              <option value=\"AM\">AM</option>\n              <option value=\"PM\">PM</option>\n            </select>\n            <!-- <div [ngClass]=\"{'': qbItem.Progress_Bar__c, 'dateandTime': !qbItem.Progress_Bar__c}\"></div> -->\n          </div>\n        </div>\n      </div>\n      </div>\n      <i class=\"fa check-icon3\" aria-hidden=\"true\" *ngIf=\"questionItem?.input?.length > 0\"></i>\n    </div>\n  </div>\n\n  <!-- Attachment / File -->\n  <div *ngIf=\"fileFlag\">\n    <div *ngIf=\"!qbItem.Progress_Bar__c\">\n      <div class=\"info-alert\" style.border-color=\"{{ this.questionItem?.error ? 'red' : '' }}\">\n        <label class=\"picture-upload\" for=\"file-upload\">\n          <span class=\"picture-upload-child\">\n            <i class=\"fa fa-file-image-o fa-5x icolor\" aria-hidden=\"true\"></i>\n          </span>\n          <span class=\"fa fa-plus fa-2x picture-upload-child pic-upload icolor\">\n            <i class=\"\" aria-hidden=\"true\"></i>\n          </span>\n        </label>\n      </div>\n      <input id=\"file-upload\" type=\"file\" accept=\"{{ allowedFileExtension }}\" (change)=\"uploadFile($event)\" />\n    </div>\n    <ul *ngIf=\"\n        attachments?.length > 0 &&\n        questionItem?.Type__c === 'File' &&\n        !qbItem?.Progress_Bar__c\n      \" class=\"attach-ulist col-md-12\">\n      <li *ngFor=\"let attachment of attachments\" class=\"align-l\">\n        {{ attachment.attachmentName\n        }}<span class=\"attach-list\" (click)=\"deleteAttachment(attachment.attachmentId)\">X</span>\n      </li>\n    </ul>\n\n    <!-- Attachment Progress -->\n    <div *ngIf=\"qbItem.Progress_Bar__c\">\n      <div *ngFor=\"let attachment of attachments\" class=\"file-uploading-box\">\n        <!--<img src=\"https://rnxt.s3.amazonaws.com/MytIcon/icon-doc-img%402x.png\" class=\"icon-edit1\" />-->\n        <span class=\"uploading-file-name \">{{ attachment.attachmentName }}</span>\n        <img src=\"https://rnxt.s3.amazonaws.com/MytIcon/icon-delete%402x.png\" class=\"deleteIcon\"\n          (click)=\"deleteAttachment(attachment.attachmentId)\" />\n      </div>\n      <div class=\"file-upload-box\" style.border-color=\"{{ this.questionItem.error ? 'red' : '' }}\">\n      \n        <!--<img src=\"https://rnxt.s3.amazonaws.com/MytIcon/icon-doc-img%402x.png\" class=\"icon-edit1\" />-->\n        <span class=\"f-Name\" [innerHTML]=\"getText(questionItem?.Question_Text__c)\"> {{ questionItem?.Question_Text__c}}</span>\n        <label class=\"file-label \">\n          <img src=\"https://rnxt.s3.amazonaws.com/MytIcon/file-upload.png\" class=\"file-icon\"/>\n          <input name=\"attachment\" type=\"file\" placeholder=\"Ticket kaufen\" multiple\n            accept=\".pdf, .png, .jpg, .jpeg, .heic, .application/pdf\" (change)=\"uploadFile($event)\"\n            class=\"file-upload-btn\">\n        </label>\n      </div>\n    </div>\n  </div>\n\n  <!-- Book -->\n  <div *ngIf=\"bookFlag\">\n    <div [class]=\"qbItem.isShengel__c ? 'form-group content-box' : 'form-group'\">\n      <div class=\"form-row\">\n        <div class=\"col-md-12\" *ngIf=\"questionItem.error\" style=\"font-size: 18px;\n            color: red;\">{{questionItem?.error?.errorMsg}}</div>\n        <div [class]=\"qbItem.isShengel__c ? '' : 'myt-align3'\" [class]=\"qbItem.isShengel__c ? 'col-lg-' + ques.Size__c + ' paddingnone' : 'col-md-' + ques.Size__c + ' paddingnone'\"\n          *ngFor=\"let ques of subQuestions;let i = index\">\n          <div [ngClass]=\"{ down2: qbItem?.Progress_Bar__c }\">\n            <span [class]=\"qbItem.isShengel__c ? 'dis-flex shengel-myt-font3 myt-font7'  : 'dis-flex myt-font3 myt-font7' \">{{ ques?.Question__c }}</span>\n          </div>\n          <div class=\"col-md-12 paddingZero myt-dateTimeNew\" *ngIf=\"ques.Type__c === 'Time' || ques.Type__c === 'Date'\">\n            <div *ngIf=\"ques.Type__c === 'Date'\">\n              <div class=\"col-md-12 paddingBottom\">\n                <label class=\"date-time colorf\">{{ questionItem?.Date_Text__c }}</label>\n                <div class=\"dis-flex dateandtime\">\n                  <my-date-picker name=\"mydate\" [options]=\"myDatePickerOptions\" id=\"date\" style=\"font-size: 18px !important;\" (dateChanged)=\"onDateChanged($event)\"\n                    [(ngModel)]=\"selDate\" class=\"date-picker\" placeholder=\"Seleccione fecha\"  (focus)=\"clearError()\" >\n                  </my-date-picker>\n                </div>\n              </div>\n            </div>\n            <div *ngIf=\"ques.Type__c === 'Time'\">\n              <div class=\"col-md-12 paddingBottom\">\n                <label class=\"date-time colorf\">{{ questionItem?.Time_Text__c }}</label>\n                <div class=\"dis-flex dateandtime\">\n                <div [ngClass]=\"{'dt-line date-line dt-time': qbItem?.Progress_Bar__c,\n                                  dateandTime: !qbItem?.Progress_Bar__c}\" \n                      id=\"dateandTime\" [style.border-color]=\"questionItem?.error ? 'red': questionItem?.input?.length > 0 ? '' : ''\"\n                      (focus)=\"(clearSQError) \">\n                  <select name=\"hours\" class=\"datetime showHour myt-time myt-hour\" [(ngModel)]=\"selectedHour\" id=\"hour\"\n                    (focus)=\"clearError()\">\n                    <option value=\"\">HH</option>\n                    <option [value]=\"hour\" *ngFor=\"let hour of hours\">\n                      {{ hour }}\n                    </option>\n                  </select>\n                  <span class=\"colon\"> : </span>\n                  <select name=\"minutes\" class=\"datetime showminute myt-time\" [(ngModel)]=\"selectedMinute\" id=\"minute\"\n                    (focus)=\"clearError()\">\n                    <option value=\"\">MM</option>\n                    <option [value]=\"minute\" *ngFor=\"let minute of minutes\">\n                      {{ minute }}\n                    </option>\n                  </select>\n                  <div [ngClass]=\"{ colon1: qbItem?.Progress_Bar__c }\" *ngIf=\"questionItem.X24_Hours__c == false\">\n                    <span class=\"colon\"> : </span>\n                    <select name=\"AM/PM\" class=\"myt-time\" [(ngModel)]=\"selectedMeridiem\" id=\"meridiem\">\n                      <option value=\"AM\">AM</option>\n                      <option value=\"PM\">PM</option>\n                    </select>\n                  </div>\n                </div>\n              </div>\n              </div>\n            </div>\n          </div>\n          <div *ngIf=\"ques.Type__c === 'DateTime'\">\n            <app-custom-date-picker [minDate]=\"ques.minDate\" [date]=\"ques.input\" (dateChange)=\"displayDate($event,ques)\"></app-custom-date-picker>\n          </div>\n          <div *ngIf=\"ques.Type__c === 'Text'\">\n            <app-custom-input\n                  [fromShengel]=\"qbItem.isShengel__c\"\n                  [value]=\"ques.input\"\n                  [ngClassValue]=\"{\n                      'dis-flex dt-line date-line bookText boxoutline myt-font1': qbItem.Progress_Bar__c,\n                      textBox: !qbItem.Progress_Bar__c\n                  }\"\n                  [idValue]=\"ques.Id\"\n                  [focusEvent]=\"clearSQError(ques.Id)\"\n                  [error]=\"ques.error\"\n                  [placeholder]=\"ques.Question__c\"\n                  (inputValue)=\"selectedInput($event,ques)\">\n            </app-custom-input>\n          </div>\n          <div *ngIf=\"ques.Type__c === 'Location'\">\n            <!-- for pick location -->\n            <app-pick-location [address]=\"ques.input\" (locationSelected)=\"handleLocationSelected($event,ques)\"></app-pick-location>\n          </div>\n          <!-- for  text area   -->\n          <div *ngIf=\"ques.Type__c === 'TextArea'\">\n            <app-custom-text-area [value]=\"ques.input\" [rows]=\"3\" [error]=\"ques.error\" [placeholder]=\"ques.Question__c \" (textareaValueChange)=\"handleTextareaValueChange($event)\"></app-custom-text-area>\n          </div>\n          <!-- for to data table we use 'data' type question  -->\n          <div *ngIf=\"ques.Type__c === 'Data'\">\n            <app-custom-table [tableHeader]=\"ques.tableHeader\" [tableData]=\"getTableData(ques)\" [tableIndex]=\"i\" (tableDataChange)=\"getData($event)\"></app-custom-table>\n          </div>\n\n          <div *ngIf=\"ques.Type__c === 'Email'\">\n            <input type=\"email\" [(ngModel)]=\"ques.input\" [id]=\"ques.Id\" required=\"\" (focus)=\"clearSQError(ques.Id)\"\n              style.border-color=\"{{ ques.error ? 'red' : '' }}\" placeholder=\"{{ ques.Question__c }}\" />\n          </div>\n\n          <div *ngIf=\"ques.Type__c === 'File'\">\n            <div *ngIf=\"!qbItem.Progress_Bar__c\">\n              <label class=\"picture-upload custom-file-upload bgcolor-w\" for=\"file-upload\">\n                <span class=\"picture-upload-child\">\n                  <i class=\"fa fa-file-image-o fa-5x icolor\" aria-hidden=\"true\"></i>\n                </span>\n                <span class=\"\n                    fa fa-plus fa-2x\n                    picture-upload-child\n                    pic-upload\n                    icolor\n                  \">\n                  <i class=\"\" aria-hidden=\"true\"></i>\n                </span>\n              </label>\n              <input id=\"file-upload\" type=\"file\" accept=\"{{ bookFlagAccept }}\" (change)=\"uploadFile($event,ques)\" />\n            </div>\n\n            <ul *ngIf=\"\n                attachments?.length > 0 &&\n                ques.Type__c === 'File' &&\n                !qbItem.Progress_Bar__c\n              \" class=\"attach-ulist col-md-12\">\n              <li *ngFor=\"let attachment of attachments\" class=\"align-l\">\n                {{ attachment.attachmentName\n                }}<span class=\"attach-list\" (click)=\"deleteAttachment(attachment.attachmentId)\">X</span>\n              </li>\n            </ul>\n            <div class=\"myt-box\" *ngIf=\"qbItem.Progress_Bar__c\">\n\n              <div *ngFor=\"let attachment of attachments\" class=\"file-uploading-box\">\n                <img src=\"https://rnxt.s3.amazonaws.com/MytIcon/icon-doc-img%402x.png\" class=\"icon-edit1\" />\n                <span class=\"uploading-file-name myt-font1 font-weight: normal;\"> {{ attachment.attachmentName }}</span>\n                <img src=\"https://rnxt.s3.amazonaws.com/MytIcon/icon-delete%402x.png\" class=\"deleteIcon\"\n                  (click)=\"deleteAttachment(attachment.attachmentId)\" />\n              </div>\n              <div class=\"file-upload-box\" style.border-color=\"{{ this.questionItem.error ? 'red' : '' }}\">\n                <img src=\"https://rnxt.s3.amazonaws.com/MytIcon/icon-doc-img%402x.png\" class=\"icon-edit1\" />\n                <span class=\"f-Name\">{{ ques?.Question__c }}</span>\n                <label class=\"file-label \">\n                  <span style=\"color: #c5281c;text-decoration:underline\">\n                    Adjuntar\n                  </span>\n                  <input name=\"attachment\" type=\"file\" placeholder=\"Ticket kaufen\" multiple\n                    accept=\".pdf, .png, .jpg, .jpeg, .heic, .application/pdf\" (change)=\"uploadFile($event,ques)\"\n                    class=\"file-upload-btn\">\n                </label>\n              </div>\n            </div>\n          </div>\n\n          <!-- Dropdown -->\n          <div *ngIf=\"ques.Type__c === 'Dropdown'\" class=\"\">\n            <!-- for common dropdown -->\n            <app-custom-dropdown [fromShengel]=\"qbItem.isShengel__c\"\n                    [options]=\"ques.Question_Options__r.records\"\n                    [apiMeta]=\"ques.Sub_Text__c\"\n                    [id]=\"ques.Name\"\n                    [selectedValue]=\"ques.input\"\n                    [placeholder]=\"'---Select---'\"\n                    [errorMessage]=\"ques.Error_Message__c\"\n                    [error]=\"ques.error\"\n                    (valueChange)=\"Dropdown($event, ques); clearSQError(ques.Id)\">\n            </app-custom-dropdown>\n            <app-dropdown-with-flag *ngIf=\"ques.isDependentPicklist && !ques.dropDownOnly\"  [certified]=\"ques.certifiedFlag\"  [JobPerformerCertificates]=\"ques.certificateList\" (flagDropDownChange)=\"dependentChange($event)\"></app-dropdown-with-flag>\n            <i class=\"fa fa-check \" aria-hidden=\"true\" *ngIf=\"questionItem?.input?.length > 0\"></i>\n          </div>          \n        </div>\n      </div>\n    </div>\n  </div>\n\n  <!--List start-->\n  <div *ngIf=\"listFlag\">\n    <div class=\"form-group\">\n      <div class=\"form-row\">\n        <div class=\"col-md-12\" *ngIf=\"questionItem.error\" style=\"font-size: 18px;\n            color: red;\">{{questionItem?.error?.errorMsg}}</div>\n        <div class=\"myt-align3\" [class]=\"'col-md-' + ques.Size__c + ' paddingnone'\"\n          *ngFor=\"let ques of getLocalSubQuestions(questionItem.Id);let i = index\">\n          <div>\n            <span class=\"dis-flex myt-font3 myt-font7\">{{ ques?.Question__c }}</span>\n          </div>\n          <div *ngIf=\"ques.Type__c === 'Text'\">\n            <input type=\"text\" [(ngModel)]=\"ques.input\" [ngClass]=\"{\n             'dis-flex dt-line date-line bookText boxoutline myt-font1': qbItem.Progress_Bar__c,\n             textBox: !qbItem.Progress_Bar__c\n            }\" id=\"text\" [id]=\"ques.uniqueSubQId\" required=\"\" (focus)=\"clearLocalSubQuesError(ques)\"\n            style.border-color=\"{{ ques.error ? 'red' : '' }}\" placeholder=\"{{ ques.Question__c }}\"\n            oninput=\"this.value=this.value.replace(/[^a-zA-Z0-9\\s.:;,?]/g,'');\" />\n          </div>\n        </div>\n        <div class=\"\" *ngIf=\"addFlag\">\n          <button (click)=\"Add(getLocalSubQuestions(questionItem.Id))\" class=\"btn\"><i class=\"fa fa-plus\" ></i>Add</button>\n         </div>\n      </div>\n    </div>\n  </div>\n  <!--List End-->\n\n  <!-- Actions -->\n  <div *ngIf=\"individualBookButton\" class=\"flexer\">\n    <!-- Backward / Back -->\n    <div class=\"backbutton\" [ngClass]=\"{ 'col-md-6': !qbItem.Progress_Bar__c }\"\n      [style.visibility]=\"questionStack.length > 0 ? 'visible' : 'hidden'\">\n      <div [ngClass]=\"{}\">\n        <button [ngClass]=\"{\n            'left-bt': qbItem.Progress_Bar__c,\n            'nxt-btn btn-primary btn-lg btn-block btn-back-color':\n              !qbItem.Progress_Bar__c\n          }\" (click)=\"handleBackClick()\">\n          {{ qbItem?.Back__c }}\n        </button>\n      </div>\n    </div>\n\n    <!-- Forward / Next -->\n    <div [ngClass]=\"{ 'col-md-6': !qbItem.Progress_Bar__c }\">\n      <div>\n        <button [ngClass]=\"{\n            'rusty': qbItem.Progress_Bar__c,\n            'nxt-btn btn-primary btn-lg btn-block btn-back-color':\n              !qbItem.Progress_Bar__c\n          }\" (click)=\"handleNextClick()\">\n          {{ qbItem.Next__c }}\n        </button>\n      </div>\n    </div>\n  </div>\n</div>\n\n<!-- Summary -->\n<div *ngIf=\"summary && summary.length > 0\" height=\"100% !important\" class=\"col-md-12\" [ngClass]=\"{\n              'col-md-12':!qbItem.Progress_Bar__c\n               }\">\n    <h1 class=\"header1 summarypadd\" >{{ qbItem.SubTitle__c }}</h1>         \n  <div id=\"progress2\" *ngIf=\"!qbItem.Progress_Bar__c && this.abItem.Status__c != 'Completed' \">\n  <div [ngClass]=\"{ 'full-summary': qbItem.Progress_Bar__c }\">\n    <div *ngFor=\"let qa of summary\">\n        <div [ngClass]=\"{ non:  qbItem.Progress_Bar__c }\">\n          <div [ngClass]=\"{ summary:  !qbItem.Progress_Bar__c }\">\n           <div *ngIf=\"!qbItem.Edit__c\"\n              [ngClass]=\"{ 'question': this.abItem.Status__c != 'Completed' }\">\n              <a [ngClass]=\"{ asum: this.abItem.Status__c === 'Completed' }\" (click)=\"handleEditClick(qa.quesId)\"\n                [innerHTML]=\"getText(qa.quesValue)\">{{ qa.quesValue }}</a>\n            </div>\n            <div *ngIf=\"qbItem.Edit__c\"\n              [ngClass]=\"{ 'question': this.abItem.Status__c != 'Completed' }\">\n              <div [ngClass]=\"{ 'question': this.abItem.Status__c === 'Completed' }\"\n                [innerHTML]=\"getText(qa.quesValue)\">\n                {{ qa.quesValue }}\n              </div>\n            </div>\n            <div class=\"answer\" >\n                <div *ngIf=\"qa.qTyp === 'File'\">\n                  <img src=\"https://rnxt.s3.amazonaws.com/MytIcon/icon-doc-img%401.png\" class=\"icon-edit-summary\" />\n                  {{ qa.ansValue }}\n                </div>\n                <div *ngIf=\"qa.qTyp != 'File'\">{{ qa.ansValue }}</div>\n                <div *ngIf=\"qbItem.Edit__c && this.abItem.Status__c != 'Completed'\" style=\"background: #dedddd;\">\n                  <button class=\"edit\" (click)=\"handleEditClick(qa.quesId)\">\n                    <img *ngIf=\"deviceInfo.os === 'iOS'\" src=\"https://rnxt.s3.amazonaws.com/MytIcon/icon-edit%402x.png\" style=\"width:50%!important;\" class=\"icon-editios\"/>\n                    <img *ngIf=\"deviceInfo.os !== 'iOS'\" src=\"https://rnxt.s3.amazonaws.com/MytIcon/icon-edit%402x.png\" class=\"icon-edit\" />\n                  </button>\n                </div>\n          </div>\n        </div>\n        </div>\n    </div>\n    </div>\n  </div>\n\n  <div *ngIf=\"this.abItem.Status__c === 'Completed'\" class=\"col-lg-12\">\n    <div class=\"panel-group panel-group-joined\" id=\"ePTW-details\">\n      <div class=\"panel panel-default\">\n        <div class=\"panel-heading\">\n          <h4 class=\"panel-title\">\n            <a data-toggle=\"collapse\" data-parent=\"#ePTW-details\" href=\"#collapseOne\" class=\"collapsed\">\n              PTW Details\n            </a>\n          </h4>\n        </div>\n        <div id=\"collapseOne\" class=\"panel-collapse collapse\">\n          <div class=\"panel-body\">\n            <div class=\"row\">\n              <ng-container *ngFor=\"let item of summaryData; let i = index\">\n                <ng-container *ngIf=\"i % 2 === 0\">\n                  <div class=\"col-lg-6 m-b-30\">\n                    <label>{{ getKey(item) }}</label>\n                    <p class=\"font-size\">{{ getValue(item) || 'N/A' }}</p>\n                  </div>\n                  <div class=\"col-lg-6\" *ngIf=\"summaryData[i + 1]\">\n                    <label>{{ getKey(summaryData[i + 1]) }}</label>\n                    <p class=\"font-size\">{{ getValue(summaryData[i + 1]) || 'N/A' }}</p>\n                  </div>\n                </ng-container>\n              </ng-container>\n            </div>\n          </div>\n        </div>\n      </div>\n    </div>\n  </div>\n\n  <div id=\"progress2\" *ngIf=\"qbItem.Progress_Bar__c \">\n    <div [ngClass]=\"{'bgColor summary-top' : qbItem.Progress_Bar__c }\" >\n      <div id=\"progress-summary\" *ngIf=\"qbItem.Progress_Bar__c\">\n        <circle-progress class=\"titlebar\" [percent]=\"this.percent\" [radius]=\"40\" [space]=\"-4\" [outerStrokeWidth]=\"4\"\n        [innerStrokeWidth]=\"4\" [outerStrokeColor]=\"'#e0b1b0'\" [innerStrokeColor]=\"'#e7e8ea'\" [animation]=\"true\" [backgroundPadding]= \"0\"\n        [backgroundColor]= \"'#dd2e13'\" [backgroundGradientStopColor]=\"'#f9bfbd'\" [titleColor]=\"'#f3eded'\" \n        class=\"ng-star-inserted\" [title]=\"this.percent+'%'\" [showSubtitle]=\"false\" [showBackground]=\"true\" [animationDuration]=\"300\"\n        [startFromZero]=\"false\" [responsive]=\"false\" >\n      </circle-progress>\n      \n      <div *ngIf=\"qbItem.Summary_Text__c && qbItem.Progress_Bar__c\" \n      [ngClass]=\"{ summaryTitle: qbItem.Progress_Bar__c }\">\n        <h3 class=\"subTitle\" >{{ qbItem.Summary_Text__c }}</h3>\n        <div *ngIf=\"abItem.Status__c != 'Completed'\" class=\"subTitle1\" >{{ qbItem.Summary_Sub_Text__c}}</div>\n      </div>\n    </div>\n    <div *ngIf=\"!qbItem.Progress_Bar__c\">\n      <h3 class=\"summary-h\">\n        {{ qbItem.Summary_Text__c }}\n      </h3>\n    </div>\n  </div>\n  <div [ngClass]=\"{ 'full-summary': qbItem.Progress_Bar__c }\">\n    <div class=\"summary-groupText myt-font2\">\n      <!-- <p>Informe de daño</p> -->\n    </div>\n    <div *ngFor=\"let qa of summary\" >\n        <div [ngClass]=\"{ non:  qbItem.Progress_Bar__c }\">\n          <div [ngClass]=\"{ summary: this.abItem.Status__c != 'Completed' && !qbItem.Progress_Bar__c }\">\n            <div *ngIf=\"!qbItem.Edit__c\"\n              [ngClass]=\"{ 'question sum-ques myt-font3 myt-font8': this.abItem.Status__c != 'Completed' }\">\n              <a [ngClass]=\"{ asum: this.abItem.Status__c === 'Completed' }\" (click)=\"handleEditClick(qa.quesId)\"\n                [innerHTML]=\"getText(qa.quesValue)\">{{ qa.quesValue }}</a>\n            </div>\n            <div *ngIf=\"qbItem.Edit__c\"\n              [ngClass]=\"{ 'sum-ques question myt-font3 myt-font8': this.abItem.Status__c != 'Completed' }\">\n              <div [ngClass]=\"{ 'sum-ques1 question1 summary-completed myt-font3 myt-font8': this.abItem.Status__c === 'Completed' }\"\n                [innerHTML]=\"getText(qa.quesValue)\">\n                {{ qa.quesValue }}\n              </div>\n            </div>\n            <div *ngIf=\"qbItem.Edit__c && this.abItem.Status__c != 'Completed'\" style=\"background: #dedddd;\">\n              <button class=\"edit\" (click)=\"handleEditClick(qa.quesId)\">\n                <img *ngIf=\"deviceInfo.os === 'iOS'\" src=\"https://rnxt.s3.amazonaws.com/MytIcon/icon-edit%402x.png\" style=\"width:50%!important;\" class=\"icon-editios\"/>\n                <img *ngIf=\"deviceInfo.os !== 'iOS'\" src=\"https://rnxt.s3.amazonaws.com/MytIcon/icon-edit%402x.png\" class=\"icon-edit\" />\n              </button>\n            </div>\n           \n            <div class=\"answer \" >\n              <div *ngIf=\"qa.qTyp === 'File'\">\n                <img src=\"https://rnxt.s3.amazonaws.com/MytIcon/icon-doc-img%401.png\" class=\"icon-edit-summary\" />\n                {{ qa.ansValue }}\n              </div>\n              <div *ngIf=\"qa.qTyp != 'File'\">\n                {{ qa.ansValue }}\n              </div>\n            </div>\n          </div>\n        </div>\n      </div>\n    </div>\n  </div>\n\n  <!-- Answer Book -->\n  <div class=\"flexer1\" *ngIf=\"abItem\">\n    <div class=\"\" *ngIf=\"abItem.Status__c == 'Completed'\">\n      <div class=\"col-md-12\">\n        <button [ngClass]=\"{'btn-text': qbItem.Progress_Bar__c,\n                            'nxt-btn btn-primary btn-lg btn-block btn-back-color': !qbItem.Progress_Bar__c}\"\n          (click)=\"handleCancelClick()\">\n          {{ qbItem.Cancel__c }}\n        </button>\n      </div>\n    </div>\n  </div>\n\n  <!-- Group Actions -->\n  <div class=\"align-edit-submit\" *ngIf=\"abItem.Status__c != 'Completed'\">\n    <div class=\"col-md-6\">\n      <button [ngClass]=\"{ 'btn-text2': qbItem.Progress_Bar__c,\n                            'nxt-btn btn-primary btn-lg btn-block btn-back-color': !qbItem.Progress_Bar__c }\" \n        (click)=\"handleSubmitClick()\">\n        {{ qbItem.Submit__c }}\n      </button>\n    </div>\n    <div class=\"col-md-6\">\n      <button [ngClass]=\"{'grey': qbItem.Progress_Bar__c,\n                            'nxt-btn btn-primary btn-lg btn-block btn-back-color': !qbItem.Progress_Bar__c}\" \n              (click)=\"handleBackClickNew()\">\n        {{ qbItem.Edit__c }}\n      </button>\n    </div>\n  </div>\n\n</div>"]}