@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.
- package/README.md +24 -0
- package/esm2022/lib/components/custom-date-picker/custom-date-picker.component.mjs +33 -0
- package/esm2022/lib/components/custom-dropdown/custom-dropdown.component.mjs +73 -0
- package/esm2022/lib/components/custom-input/custom-input.component.mjs +46 -0
- package/esm2022/lib/components/custom-table/custom-table.component.mjs +51 -0
- package/esm2022/lib/components/custom-text-area/custom-text-area.component.mjs +34 -0
- package/esm2022/lib/components/dropdown-with-flag/dropdown-with-flag.component.mjs +34 -0
- package/esm2022/lib/components/pick-location/pick-location.component.mjs +134 -0
- package/esm2022/lib/components/search-box/search-box.component.mjs +84 -0
- package/esm2022/lib/interfaces/apimeta.mjs +2 -0
- package/esm2022/lib/nxt-app.component.mjs +22 -0
- package/esm2022/lib/nxt-app.module.mjs +262 -0
- package/esm2022/lib/nxt-app.service.mjs +14 -0
- package/esm2022/lib/pages/booklet/booklet.component.mjs +79 -0
- package/esm2022/lib/pages/questionnaire/questionnaire.component.mjs +2131 -0
- package/esm2022/lib/sample.mjs +433 -0
- package/esm2022/lib/services/data.service.mjs +40 -0
- package/esm2022/lib/services/salesforce.service.mjs +46 -0
- package/esm2022/lib/wrapper.mjs +165 -0
- package/esm2022/public-api.mjs +10 -0
- package/esm2022/rangertechnologies-ngnxt.mjs +5 -0
- package/fesm2022/rangertechnologies-ngnxt.mjs +3610 -0
- package/fesm2022/rangertechnologies-ngnxt.mjs.map +1 -0
- package/index.d.ts +5 -0
- package/lib/components/custom-date-picker/custom-date-picker.component.d.ts +14 -0
- package/lib/components/custom-dropdown/custom-dropdown.component.d.ts +23 -0
- package/lib/components/custom-input/custom-input.component.d.ts +18 -0
- package/lib/components/custom-table/custom-table.component.d.ts +23 -0
- package/lib/components/custom-text-area/custom-text-area.component.d.ts +14 -0
- package/lib/components/dropdown-with-flag/dropdown-with-flag.component.d.ts +14 -0
- package/lib/components/pick-location/pick-location.component.d.ts +38 -0
- package/lib/components/search-box/search-box.component.d.ts +34 -0
- package/lib/interfaces/apimeta.d.ts +5 -0
- package/lib/nxt-app.component.d.ts +8 -0
- package/lib/nxt-app.module.d.ts +26 -0
- package/lib/nxt-app.service.d.ts +6 -0
- package/lib/pages/booklet/booklet.component.d.ts +29 -0
- package/lib/pages/questionnaire/questionnaire.component.d.ts +207 -0
- package/lib/sample.d.ts +10 -0
- package/lib/services/data.service.d.ts +9 -0
- package/lib/services/salesforce.service.d.ts +11 -0
- package/lib/wrapper.d.ts +164 -0
- package/package.json +43 -0
- package/public-api.d.ts +6 -0
- 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: "<p>"+ quesValue[quesNo]+"<p>",
|
|
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>"]}
|