@rangertechnologies/ngnxt 2.0.30 → 2.0.32
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/components/custom-input/custom-input.component.mjs +3 -3
- package/esm2022/lib/components/file-upload/file-upload.component.mjs +159 -0
- package/esm2022/lib/nxt-app.module.mjs +6 -3
- package/esm2022/lib/pages/booklet/booklet.component.mjs +3 -3
- package/esm2022/lib/pages/questionbook/questionbook.component.mjs +12 -3
- package/esm2022/lib/wrapper.mjs +8 -7
- package/fesm2022/rangertechnologies-ngnxt.mjs +181 -14
- package/fesm2022/rangertechnologies-ngnxt.mjs.map +1 -1
- package/lib/components/file-upload/file-upload.component.d.ts +23 -0
- package/lib/nxt-app.module.d.ts +11 -10
- package/lib/pages/questionbook/questionbook.component.d.ts +3 -0
- package/lib/wrapper.d.ts +7 -6
- package/package.json +1 -1
- package/rangertechnologies-ngnxt-2.0.32.tgz +0 -0
- package/rangertechnologies-ngnxt-2.0.30.tgz +0 -0
|
@@ -28,7 +28,7 @@ export class CustomInputComponent {
|
|
|
28
28
|
this.subscription = this.changeService.changeAnnounced$.subscribe((changeValue) => {
|
|
29
29
|
if (changeValue != undefined) {
|
|
30
30
|
console.log('inside subscription for the change');
|
|
31
|
-
if (changeValue != undefined) {
|
|
31
|
+
if (changeValue != undefined && changeValue.fromQuestionId == dependencyObj.sourceQuestionId) {
|
|
32
32
|
this.value = changeValue.valueObj[dependencyObj.valueField];
|
|
33
33
|
}
|
|
34
34
|
this.changeService.confirmChange(dependencyObj.sourceQuestionId);
|
|
@@ -40,7 +40,7 @@ export class CustomInputComponent {
|
|
|
40
40
|
}
|
|
41
41
|
ngOnDestroy() {
|
|
42
42
|
// prevent memory leak when component destroyed
|
|
43
|
-
this.subscription
|
|
43
|
+
this.subscription?.unsubscribe();
|
|
44
44
|
}
|
|
45
45
|
onInputChange(input) {
|
|
46
46
|
this.inputValue.emit(input.target.value);
|
|
@@ -72,4 +72,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImpo
|
|
|
72
72
|
}], inputValue: [{
|
|
73
73
|
type: Output
|
|
74
74
|
}] } });
|
|
75
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
75
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3VzdG9tLWlucHV0LmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL254dC1hcHAvc3JjL2xpYi9jb21wb25lbnRzL2N1c3RvbS1pbnB1dC9jdXN0b20taW5wdXQuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbnh0LWFwcC9zcmMvbGliL2NvbXBvbmVudHMvY3VzdG9tLWlucHV0L2N1c3RvbS1pbnB1dC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLFlBQVksRUFBRSxLQUFLLEVBQVUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDOzs7OztBQWEvRSxNQUFNLE9BQU8sb0JBQW9CO0lBZVg7SUFkWCxLQUFLLENBQWMsQ0FBQyxjQUFjO0lBQ2xDLFFBQVEsQ0FBVTtJQUNsQixRQUFRLEdBQVksS0FBSyxDQUFDLENBQUMsd0JBQXdCO0lBQ25ELFdBQVcsQ0FBUTtJQUNuQixLQUFLLENBQUs7SUFDVixXQUFXLEdBQVksS0FBSyxDQUFDO0lBRTdCLFlBQVksQ0FBSztJQUNqQixPQUFPLENBQUs7SUFDWixVQUFVLENBQU07SUFDZixVQUFVLEdBQUcsSUFBSSxZQUFZLEVBQU8sQ0FBQztJQUUvQyxZQUFZLENBQWU7SUFFM0IsWUFBb0IsYUFBNEI7UUFBNUIsa0JBQWEsR0FBYixhQUFhLENBQWU7SUFDaEQsQ0FBQztJQUVELFFBQVE7UUFDTiw4Q0FBOEM7UUFDOUMsSUFBRyxJQUFJLENBQUMsUUFBUSxDQUFDLFdBQVcsSUFBSSxTQUFTLEVBQUU7WUFDekMsSUFBSSxDQUFDLFFBQVEsR0FBRyxJQUFJLENBQUM7WUFDckIsSUFBSSxhQUFhLEdBQW1CLElBQUksQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxXQUFXLENBQUMsQ0FBQztZQUUxRSw0QkFBNEI7WUFDNUIsSUFBSSxDQUFDLFlBQVksR0FBRyxJQUFJLENBQUMsYUFBYSxDQUFDLGdCQUFnQixDQUFDLFNBQVMsQ0FDL0QsQ0FBQyxXQUFXLEVBQUUsRUFBRTtnQkFDZCxJQUFHLFdBQVcsSUFBSSxTQUFTLEVBQUU7b0JBQzNCLE9BQU8sQ0FBQyxHQUFHLENBQUMsb0NBQW9DLENBQUMsQ0FBQztvQkFDbEQsSUFBRyxXQUFXLElBQUksU0FBUyxJQUFJLFdBQVcsQ0FBQyxjQUFjLElBQUksYUFBYSxDQUFDLGdCQUFnQixFQUFFO3dCQUMzRixJQUFJLENBQUMsS0FBSyxHQUFHLFdBQVcsQ0FBQyxRQUFRLENBQUMsYUFBYSxDQUFDLFVBQVUsQ0FBQyxDQUFDO3FCQUM3RDtvQkFDRCxJQUFJLENBQUMsYUFBYSxDQUFDLGFBQWEsQ0FBQyxhQUFhLENBQUMsZ0JBQWdCLENBQUMsQ0FBQztpQkFDbEU7WUFDSCxDQUFDLENBQ0YsQ0FBQztTQUNIO0lBQ0gsQ0FBQztJQUVELFVBQVU7SUFDVixDQUFDO0lBRUQsV0FBVztRQUNULCtDQUErQztRQUMvQyxJQUFJLENBQUMsWUFBWSxFQUFFLFdBQVcsRUFBRSxDQUFDO0lBQ25DLENBQUM7SUFFRCxhQUFhLENBQUMsS0FBUztRQUNyQixJQUFJLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsTUFBTSxDQUFDLEtBQUssQ0FBQyxDQUFBO0lBQzFDLENBQUM7d0dBakRVLG9CQUFvQjs0RkFBcEIsb0JBQW9CLDJUQ2JqQyxpcUJBa0JBOzs0RkRMYSxvQkFBb0I7a0JBTmhDLFNBQVM7K0JBQ0Usa0JBQWtCO29HQU1uQixLQUFLO3NCQUFiLEtBQUs7Z0JBQ0csUUFBUTtzQkFBaEIsS0FBSztnQkFDRyxRQUFRO3NCQUFoQixLQUFLO2dCQUNHLFdBQVc7c0JBQW5CLEtBQUs7Z0JBQ0csS0FBSztzQkFBYixLQUFLO2dCQUNHLFdBQVc7c0JBQW5CLEtBQUs7Z0JBRUcsWUFBWTtzQkFBcEIsS0FBSztnQkFDRyxPQUFPO3NCQUFmLEtBQUs7Z0JBQ0csVUFBVTtzQkFBbEIsS0FBSztnQkFDSSxVQUFVO3NCQUFuQixNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBFdmVudEVtaXR0ZXIsIElucHV0LCBPbkluaXQsIE91dHB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBPYnNlcnZhYmxlLCBTdWJzY3JpcHRpb24gfSBmcm9tICdyeGpzJztcclxuaW1wb3J0IHsgQ2hhbmdlU2VydmljZSB9IGZyb20gJy4uLy4uL3NlcnZpY2VzL2NoYW5nZS5zZXJ2aWNlJztcclxuaW1wb3J0IHsgQ2hhbmdlV3JhcHBlciB9IGZyb20gJy4uLy4uL21vZGVsL2NoYW5nZVdyYXBwZXInO1xyXG5pbXBvcnQgeyBRdWVzdGlvbiB9IGZyb20gJy4uLy4uL3dyYXBwZXInO1xyXG5pbXBvcnQgeyBEZXBlbmRlbmN5TWV0YSB9IGZyb20gJy4uLy4uL2ludGVyZmFjZXMvZGVwZW5kZW5jeU1ldGEnO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6ICdhcHAtY3VzdG9tLWlucHV0JyxcclxuICB0ZW1wbGF0ZVVybDogJy4vY3VzdG9tLWlucHV0LmNvbXBvbmVudC5odG1sJyxcclxuICBzdHlsZVVybHM6IFsnLi9jdXN0b20taW5wdXQuY29tcG9uZW50LmNzcyddXHJcbn0pXHJcblxyXG5leHBvcnQgY2xhc3MgQ3VzdG9tSW5wdXRDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xyXG4gIEBJbnB1dCgpIHZhbHVlOiBhbnkgfCBhbnlbXTsgLy8gaW5wdXQgdmFsdWVcclxuICBASW5wdXQoKSBxdWVzdGlvbjogUXVlc3Rpb25cclxuICBASW5wdXQoKSBkaXNhYmxlZDogYm9vbGVhbiA9IGZhbHNlOyAvLyBpbnB1dCBkaXNhYmxlZCBvciBub3RcclxuICBASW5wdXQoKSBwbGFjZWhvbGRlcjpzdHJpbmc7XHJcbiAgQElucHV0KCkgZXJyb3I6YW55O1xyXG4gIEBJbnB1dCgpIGZyb21TaGVuZ2VsOiBib29sZWFuID0gZmFsc2U7XHJcblxyXG4gIEBJbnB1dCgpIG5nQ2xhc3NWYWx1ZTphbnk7XHJcbiAgQElucHV0KCkgaWRWYWx1ZTphbnk7XHJcbiAgQElucHV0KCkgZm9jdXNFdmVudDogYW55O1xyXG4gIEBPdXRwdXQoKSBpbnB1dFZhbHVlID0gbmV3IEV2ZW50RW1pdHRlcjxhbnk+KCk7IFxyXG5cclxuICBzdWJzY3JpcHRpb246IFN1YnNjcmlwdGlvbjtcclxuXHJcbiAgY29uc3RydWN0b3IocHJpdmF0ZSBjaGFuZ2VTZXJ2aWNlOiBDaGFuZ2VTZXJ2aWNlKSB7IFxyXG4gIH1cclxuXHJcbiAgbmdPbkluaXQoKTogdm9pZCB7XHJcbiAgICAvLyBTaW5jZSB0aGUgaWRWYWx1ZSBob2xkcyB0aGUgUGFyZW50IFF1ZXN0aW9uXHJcbiAgICBpZih0aGlzLnF1ZXN0aW9uLlN1Yl9UZXh0X19jICE9IHVuZGVmaW5lZCkge1xyXG4gICAgICB0aGlzLmRpc2FibGVkID0gdHJ1ZTtcclxuICAgICAgbGV0IGRlcGVuZGVuY3lPYmo6IERlcGVuZGVuY3lNZXRhID0gSlNPTi5wYXJzZSh0aGlzLnF1ZXN0aW9uLlN1Yl9UZXh0X19jKTtcclxuXHJcbiAgICAgIC8vIFN1YnNjcmliZSBmb3IgdGhlIGNoYW5nZXNcclxuICAgICAgdGhpcy5zdWJzY3JpcHRpb24gPSB0aGlzLmNoYW5nZVNlcnZpY2UuY2hhbmdlQW5ub3VuY2VkJC5zdWJzY3JpYmUoXHJcbiAgICAgICAgKGNoYW5nZVZhbHVlKSA9PiB7XHJcbiAgICAgICAgICBpZihjaGFuZ2VWYWx1ZSAhPSB1bmRlZmluZWQpIHtcclxuICAgICAgICAgICAgY29uc29sZS5sb2coJ2luc2lkZSBzdWJzY3JpcHRpb24gZm9yIHRoZSBjaGFuZ2UnKTtcclxuICAgICAgICAgICAgaWYoY2hhbmdlVmFsdWUgIT0gdW5kZWZpbmVkICYmIGNoYW5nZVZhbHVlLmZyb21RdWVzdGlvbklkID09IGRlcGVuZGVuY3lPYmouc291cmNlUXVlc3Rpb25JZCkge1xyXG4gICAgICAgICAgICAgIHRoaXMudmFsdWUgPSBjaGFuZ2VWYWx1ZS52YWx1ZU9ialtkZXBlbmRlbmN5T2JqLnZhbHVlRmllbGRdO1xyXG4gICAgICAgICAgICB9XHJcbiAgICAgICAgICAgIHRoaXMuY2hhbmdlU2VydmljZS5jb25maXJtQ2hhbmdlKGRlcGVuZGVuY3lPYmouc291cmNlUXVlc3Rpb25JZCk7XHJcbiAgICAgICAgICB9XHJcbiAgICAgICAgfVxyXG4gICAgICApO1xyXG4gICAgfVxyXG4gIH1cclxuXHJcbiAgbmdPbkNoYW5nZSgpOiB2b2lkIHtcclxuICB9XHJcblxyXG4gIG5nT25EZXN0cm95KCkge1xyXG4gICAgLy8gcHJldmVudCBtZW1vcnkgbGVhayB3aGVuIGNvbXBvbmVudCBkZXN0cm95ZWRcclxuICAgIHRoaXMuc3Vic2NyaXB0aW9uPy51bnN1YnNjcmliZSgpO1xyXG4gIH1cclxuICBcclxuICBvbklucHV0Q2hhbmdlKGlucHV0OmFueSl7XHJcbiAgICB0aGlzLmlucHV0VmFsdWUuZW1pdChpbnB1dC50YXJnZXQudmFsdWUpXHJcbiAgfVxyXG59XHJcbiIsIjxpbnB1dCAqbmdJZj1cIiFmcm9tU2hlbmdlbFwiIHR5cGU9XCJ0ZXh0XCIgXHJcbiAgICAgICBbKG5nTW9kZWwpXT1cInZhbHVlXCJcclxuICAgICAgIFtuZ0NsYXNzXT1cIm5nQ2xhc3NWYWx1ZVwiXHJcbiAgICAgICBbaWRdPVwiaWRWYWx1ZVwiXHJcbiAgICAgICAoZm9jdXMpPVwiZm9jdXNFdmVudFwiXHJcbiAgICAgICBbc3R5bGUuYm9yZGVyLWNvbG9yXT1cImVycm9yID8gJ3JlZCcgOiAnJ1wiXHJcbiAgICAgICBbcGxhY2Vob2xkZXJdPVwicGxhY2Vob2xkZXJcIlxyXG4gICAgICAgKGlucHV0KT1cIm9uSW5wdXRDaGFuZ2UoJGV2ZW50KVwiIC8+XHJcblxyXG48aW5wdXQgKm5nSWY9XCJmcm9tU2hlbmdlbFwiIGNsYXNzPVwiaW5wdXQtc2hlbmdlbFwiXHJcbiAgICAgICBbKG5nTW9kZWwpXT1cInZhbHVlXCJcclxuICAgICAgIHR5cGU9XCJ0ZXh0XCIgXHJcbiAgICAgICBjbGFzcz1cInNoZS1saW5lLWlucHV0IGZvcm0tY29udHJvbFwiIFxyXG4gICAgICAgW3BsYWNlaG9sZGVyXT1cInBsYWNlaG9sZGVyXCJcclxuICAgICAgIFtkaXNhYmxlZF09XCJkaXNhYmxlZFwiXHJcbiAgICAgICAoaW5wdXQpPVwib25JbnB1dENoYW5nZSgkZXZlbnQpXCIgLz5cclxuXHJcbjxzcGFuICpuZ0lmPVwiZXJyb3JcIiBjbGFzcz1cImVycm9yLW1zZ1wiPlJlcXVpcmVkKjwvc3Bhbj5cclxuIl19
|
|
@@ -0,0 +1,159 @@
|
|
|
1
|
+
import { Component, Output, EventEmitter, Input } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
import * as i1 from "@angular/common";
|
|
4
|
+
export class FileUploadComponent {
|
|
5
|
+
selectedFileData = new EventEmitter();
|
|
6
|
+
deletedFileData = new EventEmitter();
|
|
7
|
+
allFiles;
|
|
8
|
+
limitFileUploading;
|
|
9
|
+
isDeleteFileButtonVisible;
|
|
10
|
+
isShowNoFileIcon;
|
|
11
|
+
selectedFileNameArray = [];
|
|
12
|
+
copyOfInputAllFiles;
|
|
13
|
+
copyOfFileUploadingLimit;
|
|
14
|
+
constructor() { }
|
|
15
|
+
ngOnInit() { }
|
|
16
|
+
onFileUpload(event) {
|
|
17
|
+
const fileUploaderElement = document.getElementById('fileUpload');
|
|
18
|
+
fileUploaderElement.click();
|
|
19
|
+
}
|
|
20
|
+
ngOnChanges(simpleChanges) {
|
|
21
|
+
console.log('simple changes', simpleChanges);
|
|
22
|
+
this.copyOfInputAllFiles = simpleChanges.allFiles?.currentValue;
|
|
23
|
+
if (simpleChanges.limitFileUploading) {
|
|
24
|
+
this.copyOfFileUploadingLimit = simpleChanges.limitFileUploading?.currentValue;
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
uploadMultipleFiles(event) {
|
|
28
|
+
console.log('File uploader initiated');
|
|
29
|
+
const inputFiles = this.copyOfInputAllFiles ? this.copyOfInputAllFiles : [];
|
|
30
|
+
const selectedFileData = [];
|
|
31
|
+
const uploadedFiles = event.target.files;
|
|
32
|
+
if (uploadedFiles.length + inputFiles.length <= this.copyOfFileUploadingLimit) {
|
|
33
|
+
for (const eachUploadedFile of uploadedFiles) {
|
|
34
|
+
const reader = new FileReader();
|
|
35
|
+
const file = eachUploadedFile;
|
|
36
|
+
const format = file.name.split('.')[1];
|
|
37
|
+
reader.readAsDataURL(file);
|
|
38
|
+
reader.onload = () => {
|
|
39
|
+
selectedFileData.push({
|
|
40
|
+
doc: reader.result,
|
|
41
|
+
name: file.name,
|
|
42
|
+
type: file.type,
|
|
43
|
+
format,
|
|
44
|
+
id: null,
|
|
45
|
+
});
|
|
46
|
+
inputFiles.push({
|
|
47
|
+
doc: reader.result,
|
|
48
|
+
name: file.name,
|
|
49
|
+
type: file.type,
|
|
50
|
+
format,
|
|
51
|
+
id: null,
|
|
52
|
+
});
|
|
53
|
+
};
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
else {
|
|
57
|
+
console.warn('You can upload max 5 files');
|
|
58
|
+
//this.toastr.warning(TOASTER_MESSAGES.MAX_FIVE_FILES, TOASTER_MESSAGES.WARNING_TITLE);
|
|
59
|
+
}
|
|
60
|
+
event.target.value = '';
|
|
61
|
+
this.copyOfInputAllFiles = inputFiles;
|
|
62
|
+
console.log('uploadedFiles', inputFiles);
|
|
63
|
+
this.selectedFileData.emit(inputFiles);
|
|
64
|
+
}
|
|
65
|
+
deleteFile(currentFileIndex) {
|
|
66
|
+
const deletedFileName = this.selectedFileNameArray.splice(currentFileIndex, 1);
|
|
67
|
+
const deletedFile = this.copyOfInputAllFiles.splice(currentFileIndex, 1);
|
|
68
|
+
console.log('emit', deletedFile[0]);
|
|
69
|
+
this.deletedFileData.emit(deletedFile[0]);
|
|
70
|
+
}
|
|
71
|
+
// viewFile(currentFile) {
|
|
72
|
+
// // Display file here
|
|
73
|
+
// if (currentFile && currentFile.doc) {
|
|
74
|
+
// this.sharedService.viewFile(currentFile.doc.split('/').pop()).subscribe((apiResponse: any) => {
|
|
75
|
+
// if (apiResponse && apiResponse.sas_url) {
|
|
76
|
+
// window.open(apiResponse.sas_url, '_blank');
|
|
77
|
+
// }
|
|
78
|
+
// }, (apiError) => {
|
|
79
|
+
// this.toastr.warning('Error while viewing file', 'Warning');
|
|
80
|
+
// });
|
|
81
|
+
// }
|
|
82
|
+
// }
|
|
83
|
+
getDocIcon(docName) {
|
|
84
|
+
const ext = docName.split('.').pop(-1);
|
|
85
|
+
return this.docIcon(ext);
|
|
86
|
+
}
|
|
87
|
+
docIcon(ext) {
|
|
88
|
+
if (ext === 'pdf') {
|
|
89
|
+
return 'assets/icons/document/img-file-PDF.png';
|
|
90
|
+
}
|
|
91
|
+
else if (ext === 'xlsx') {
|
|
92
|
+
return 'assets/icons/document/img-file-XLSX.png';
|
|
93
|
+
}
|
|
94
|
+
else if (ext === 'docx') {
|
|
95
|
+
return 'assets/icons/document/img-file-DOCX.png';
|
|
96
|
+
}
|
|
97
|
+
else if (ext === 'avi') {
|
|
98
|
+
return 'assets/icons/document/img-file-AVI.png';
|
|
99
|
+
}
|
|
100
|
+
else if (ext === 'doc') {
|
|
101
|
+
return 'assets/icons/document/img-file-DOC.png';
|
|
102
|
+
}
|
|
103
|
+
else if (ext === 'gif') {
|
|
104
|
+
return 'assets/icons/document/img-file-GIF.png';
|
|
105
|
+
}
|
|
106
|
+
else if (ext === 'jpg') {
|
|
107
|
+
return 'assets/icons/document/img-file-JPG.png';
|
|
108
|
+
}
|
|
109
|
+
else if (ext === 'mov') {
|
|
110
|
+
return 'assets/icons/document/img-file-MOV.png';
|
|
111
|
+
}
|
|
112
|
+
else if (ext === 'mp3') {
|
|
113
|
+
return 'assets/icons/document/img-file-MP3.png';
|
|
114
|
+
}
|
|
115
|
+
else if (ext === 'mp4') {
|
|
116
|
+
return 'assets/icons/document/img-file-MP4.png';
|
|
117
|
+
}
|
|
118
|
+
else if (ext === 'mpeg') {
|
|
119
|
+
return 'assets/icons/document/img-file-MPEG.png';
|
|
120
|
+
}
|
|
121
|
+
else if (ext === 'mpg') {
|
|
122
|
+
return 'assets/icons/document/img-file-MPG.png';
|
|
123
|
+
}
|
|
124
|
+
else if (ext === 'png') {
|
|
125
|
+
return 'assets/icons/document/img-file-PNG.png';
|
|
126
|
+
}
|
|
127
|
+
else if (ext === 'ppt') {
|
|
128
|
+
return 'assets/icons/document/img-file-PPT.png';
|
|
129
|
+
}
|
|
130
|
+
else if (ext === 'txt') {
|
|
131
|
+
return 'projects/nxt-app/src/assets/icons/document/img-file-TXT.png';
|
|
132
|
+
}
|
|
133
|
+
else if (ext === 'xls') {
|
|
134
|
+
return 'assets/icons/document/img-file-XLS.png';
|
|
135
|
+
}
|
|
136
|
+
else {
|
|
137
|
+
return 'assets/images/ic_document.svg';
|
|
138
|
+
}
|
|
139
|
+
}
|
|
140
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: FileUploadComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
141
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: FileUploadComponent, selector: "app-file-upload", inputs: { allFiles: "allFiles", limitFileUploading: "limitFileUploading", isDeleteFileButtonVisible: "isDeleteFileButtonVisible", isShowNoFileIcon: "isShowNoFileIcon" }, outputs: { selectedFileData: "selectedFileData", deletedFileData: "deletedFileData" }, usesOnChanges: true, ngImport: i0, template: "<div class=\"row\" style=\"margin: 0;\">\r\n <div class=\"col-md-12\" *ngIf=\"!isDeleteFileButtonVisible\" style=\"text-align: left;\">\r\n <label class=\"she-label\">Attachment</label>\r\n </div>\r\n <div class=\"col-lg-3 document-cnt m-t-10 m-b-10 hover-pointer\"\r\n *ngFor=\"let eachFile of copyOfInputAllFiles; let currentFileIndex = index\">\r\n <div class=\"row\"> <!-- (click)=\"viewFile(eachFile)\" -->\r\n <div class=\"col-lg-3 document_image\">\r\n <img [src]=\"getDocIcon(eachFile?.name)\" style=\"margin-right: 10px;height: 40px;\">\r\n </div>\r\n <div class=\"col-lg-9 document_name\">\r\n {{eachFile?.name}}\r\n </div>\r\n <div class=\"document_delete\" (click)=\"deleteFile(currentFileIndex);$event.stopPropagation()\" *ngIf=\"isDeleteFileButtonVisible\">\r\n <img src=\"assets/images/bin.svg\">\r\n </div>\r\n </div>\r\n </div>\r\n <div class=\"col-md-12 m-b-30 text-center\" *ngIf=\"copyOfInputAllFiles?.length === 0 && isShowNoFileIcon\">\r\n <img src=\"../../../assets/images/ic_no_attachments.svg\" style=\"height: 140px;\">\r\n </div>\r\n</div>\r\n\r\n<div class=\"col-lg-6\" style=\"padding:0;margin-top: 10px;\">\r\n <label class=\"custom-file\" *ngIf=\"isDeleteFileButtonVisible\">\r\n <button class=\"she-btn-primary-bordered\" style=\"width:275px;\" (click)=\"onFileUpload($event)\"\r\n [ngClass]=\"{ 'btn-disabled': copyOfInputAllFiles?.length >= copyOfFileUploadingLimit }\" [disabled]=\"copyOfInputAllFiles?.length >= copyOfFileUploadingLimit\"\r\n >Choose\r\n files</button>\r\n\r\n <input id='fileUpload' type=\"file\" id=\"fileUpload\" name=\"fileUpload\" multiple=\"multiple\" accept=\"*\" style=\"display:none;\"\r\n (change) = uploadMultipleFiles($event)\r\n />\r\n </label>\r\n <!-- <span class=\"error-msg\" *ngIf=\"(formControl?.documents?.touched || formControl?.documents?.dirty) &&\r\n formControl?.documents?.errors?.required\">\r\n {{LM_POLICY_VALIDATION_MESSAGE.REQUIRED}}\r\n </span> -->\r\n</div>\r\n", styles: [".nav.nav-tabs+.tab-content{background:transparent}.row_cnt_folder{background:#fff;padding:50px 30px}.row-recent-file{border-top:1px solid #EBEBEB;padding:20px 0;cursor:pointer}p{margin-bottom:0}.floating_button{position:fixed;right:20px;bottom:20px;z-index:10;cursor:pointer}.floating_button img{height:60px}.form-cnt{background:#ffffff;padding:40px;border:1px solid #e8e8e8;border-bottom-left-radius:5px;border-bottom-right-radius:5px}.section-header{padding:15px;background:#F8F8F8;color:#898989;border:1px solid #e8e8e8;border-top-left-radius:5px;border-top-right-radius:5px}.document-cnt{border:1px solid #48B7FF;border-radius:5px;margin-right:30px;margin-top:10px}.document_image{background:#48B7FF66;padding:10px}.document_name{padding:15px 5px;overflow:hidden}.document_delete{position:absolute;background:#C20808;display:block;height:30px;width:30px;border-radius:50px;bottom:32px;right:-15px;cursor:pointer}.document_delete img{position:relative;left:8px;top:3px}.btn-disabled{background:#e1e1e1;color:#fff;border:none;border-radius:5px;height:50px}.form-control[disabled]{border-radius:5px}.custom-file{color:#9a9a9a;font-size:14px;font-weight:400;display:inline-block;width:auto;margin-bottom:5px}.she-btn-primary-bordered{background:#ffffff;color:#48b7ff;border:1px solid #48B7FF;border-radius:5px;height:50px;outline:none!important}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] });
|
|
142
|
+
}
|
|
143
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: FileUploadComponent, decorators: [{
|
|
144
|
+
type: Component,
|
|
145
|
+
args: [{ selector: 'app-file-upload', template: "<div class=\"row\" style=\"margin: 0;\">\r\n <div class=\"col-md-12\" *ngIf=\"!isDeleteFileButtonVisible\" style=\"text-align: left;\">\r\n <label class=\"she-label\">Attachment</label>\r\n </div>\r\n <div class=\"col-lg-3 document-cnt m-t-10 m-b-10 hover-pointer\"\r\n *ngFor=\"let eachFile of copyOfInputAllFiles; let currentFileIndex = index\">\r\n <div class=\"row\"> <!-- (click)=\"viewFile(eachFile)\" -->\r\n <div class=\"col-lg-3 document_image\">\r\n <img [src]=\"getDocIcon(eachFile?.name)\" style=\"margin-right: 10px;height: 40px;\">\r\n </div>\r\n <div class=\"col-lg-9 document_name\">\r\n {{eachFile?.name}}\r\n </div>\r\n <div class=\"document_delete\" (click)=\"deleteFile(currentFileIndex);$event.stopPropagation()\" *ngIf=\"isDeleteFileButtonVisible\">\r\n <img src=\"assets/images/bin.svg\">\r\n </div>\r\n </div>\r\n </div>\r\n <div class=\"col-md-12 m-b-30 text-center\" *ngIf=\"copyOfInputAllFiles?.length === 0 && isShowNoFileIcon\">\r\n <img src=\"../../../assets/images/ic_no_attachments.svg\" style=\"height: 140px;\">\r\n </div>\r\n</div>\r\n\r\n<div class=\"col-lg-6\" style=\"padding:0;margin-top: 10px;\">\r\n <label class=\"custom-file\" *ngIf=\"isDeleteFileButtonVisible\">\r\n <button class=\"she-btn-primary-bordered\" style=\"width:275px;\" (click)=\"onFileUpload($event)\"\r\n [ngClass]=\"{ 'btn-disabled': copyOfInputAllFiles?.length >= copyOfFileUploadingLimit }\" [disabled]=\"copyOfInputAllFiles?.length >= copyOfFileUploadingLimit\"\r\n >Choose\r\n files</button>\r\n\r\n <input id='fileUpload' type=\"file\" id=\"fileUpload\" name=\"fileUpload\" multiple=\"multiple\" accept=\"*\" style=\"display:none;\"\r\n (change) = uploadMultipleFiles($event)\r\n />\r\n </label>\r\n <!-- <span class=\"error-msg\" *ngIf=\"(formControl?.documents?.touched || formControl?.documents?.dirty) &&\r\n formControl?.documents?.errors?.required\">\r\n {{LM_POLICY_VALIDATION_MESSAGE.REQUIRED}}\r\n </span> -->\r\n</div>\r\n", styles: [".nav.nav-tabs+.tab-content{background:transparent}.row_cnt_folder{background:#fff;padding:50px 30px}.row-recent-file{border-top:1px solid #EBEBEB;padding:20px 0;cursor:pointer}p{margin-bottom:0}.floating_button{position:fixed;right:20px;bottom:20px;z-index:10;cursor:pointer}.floating_button img{height:60px}.form-cnt{background:#ffffff;padding:40px;border:1px solid #e8e8e8;border-bottom-left-radius:5px;border-bottom-right-radius:5px}.section-header{padding:15px;background:#F8F8F8;color:#898989;border:1px solid #e8e8e8;border-top-left-radius:5px;border-top-right-radius:5px}.document-cnt{border:1px solid #48B7FF;border-radius:5px;margin-right:30px;margin-top:10px}.document_image{background:#48B7FF66;padding:10px}.document_name{padding:15px 5px;overflow:hidden}.document_delete{position:absolute;background:#C20808;display:block;height:30px;width:30px;border-radius:50px;bottom:32px;right:-15px;cursor:pointer}.document_delete img{position:relative;left:8px;top:3px}.btn-disabled{background:#e1e1e1;color:#fff;border:none;border-radius:5px;height:50px}.form-control[disabled]{border-radius:5px}.custom-file{color:#9a9a9a;font-size:14px;font-weight:400;display:inline-block;width:auto;margin-bottom:5px}.she-btn-primary-bordered{background:#ffffff;color:#48b7ff;border:1px solid #48B7FF;border-radius:5px;height:50px;outline:none!important}\n"] }]
|
|
146
|
+
}], ctorParameters: function () { return []; }, propDecorators: { selectedFileData: [{
|
|
147
|
+
type: Output
|
|
148
|
+
}], deletedFileData: [{
|
|
149
|
+
type: Output
|
|
150
|
+
}], allFiles: [{
|
|
151
|
+
type: Input
|
|
152
|
+
}], limitFileUploading: [{
|
|
153
|
+
type: Input
|
|
154
|
+
}], isDeleteFileButtonVisible: [{
|
|
155
|
+
type: Input
|
|
156
|
+
}], isShowNoFileIcon: [{
|
|
157
|
+
type: Input
|
|
158
|
+
}] } });
|
|
159
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"file-upload.component.js","sourceRoot":"","sources":["../../../../../../projects/nxt-app/src/lib/components/file-upload/file-upload.component.ts","../../../../../../projects/nxt-app/src/lib/components/file-upload/file-upload.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit,Output,EventEmitter, Input ,ElementRef, OnChanges,SimpleChanges} from '@angular/core';\r\n@Component({\r\n  selector: 'app-file-upload',\r\n  templateUrl: './file-upload.component.html',\r\n  styleUrls: ['./file-upload.component.css']\r\n})\r\nexport class FileUploadComponent implements OnInit,OnChanges {\r\n  @Output() selectedFileData = new EventEmitter<any[]>();\r\n  @Output() deletedFileData = new EventEmitter<any>();\r\n  @Input() allFiles;\r\n  @Input() limitFileUploading;\r\n  @Input() isDeleteFileButtonVisible;\r\n  @Input() isShowNoFileIcon;\r\n\r\n  public selectedFileNameArray: string[] = [];\r\n  public copyOfInputAllFiles;\r\n  public copyOfFileUploadingLimit;\r\n  constructor(\r\n  ) { }\r\n\r\n  ngOnInit() { }\r\n\r\n  onFileUpload(event: any) {\r\n    const fileUploaderElement: HTMLElement = document.getElementById(\r\n      'fileUpload'\r\n    ) as HTMLElement;\r\n    fileUploaderElement.click();\r\n  }\r\n\r\n  ngOnChanges(simpleChanges: SimpleChanges) {\r\n    console.log('simple changes', simpleChanges);\r\n    this.copyOfInputAllFiles = simpleChanges.allFiles?.currentValue;\r\n    if (simpleChanges.limitFileUploading) {\r\n      this.copyOfFileUploadingLimit = simpleChanges.limitFileUploading?.currentValue;\r\n    }\r\n\r\n  }\r\n\r\n  uploadMultipleFiles(event: any) {\r\n    console.log('File uploader initiated');\r\n    const inputFiles: any[] = this.copyOfInputAllFiles ? this.copyOfInputAllFiles : [];\r\n    const selectedFileData = [];\r\n    const uploadedFiles = event.target.files;\r\n    if (uploadedFiles.length + inputFiles.length <= this.copyOfFileUploadingLimit) {\r\n      for (const eachUploadedFile of uploadedFiles) {\r\n        const reader = new FileReader();\r\n        const file: File = eachUploadedFile;\r\n        const format = file.name.split('.')[1];\r\n        reader.readAsDataURL(file);\r\n        reader.onload = () => {\r\n          selectedFileData.push({\r\n            doc: reader.result,\r\n            name: file.name,\r\n            type: file.type,\r\n            format,\r\n            id: null,\r\n          });\r\n          inputFiles.push({\r\n            doc: reader.result,\r\n            name: file.name,\r\n            type: file.type,\r\n            format,\r\n            id: null,\r\n          });\r\n        };\r\n      }\r\n    } else {\r\n      console.warn('You can upload max 5 files');\r\n      //this.toastr.warning(TOASTER_MESSAGES.MAX_FIVE_FILES, TOASTER_MESSAGES.WARNING_TITLE);\r\n    }\r\n    event.target.value = '';\r\n    this.copyOfInputAllFiles = inputFiles;\r\n    console.log('uploadedFiles',inputFiles);\r\n    this.selectedFileData.emit(inputFiles);\r\n  }\r\n\r\n\r\n  deleteFile(currentFileIndex) {\r\n        const deletedFileName = this.selectedFileNameArray.splice(currentFileIndex, 1);\r\n        const deletedFile = this.copyOfInputAllFiles.splice(currentFileIndex, 1);\r\n        console.log('emit', deletedFile[0]);\r\n        this.deletedFileData.emit(deletedFile[0]);\r\n  }\r\n\r\n  // viewFile(currentFile) {\r\n  //   // Display file here\r\n  //   if (currentFile && currentFile.doc) {\r\n  //     this.sharedService.viewFile(currentFile.doc.split('/').pop()).subscribe((apiResponse: any) => {\r\n  //       if (apiResponse && apiResponse.sas_url) {\r\n  //         window.open(apiResponse.sas_url, '_blank');\r\n  //       }\r\n  //     }, (apiError) => {\r\n  //       this.toastr.warning('Error while viewing file', 'Warning');\r\n  //     });\r\n  //   }\r\n  // }\r\n\r\n  getDocIcon(docName) {\r\n    const ext = docName.split('.').pop(-1);\r\n    return this.docIcon(ext);\r\n  }\r\n\r\n docIcon(ext) {\r\n    if (ext === 'pdf') {\r\n      return 'assets/icons/document/img-file-PDF.png';\r\n    } else if (ext === 'xlsx') {\r\n      return 'assets/icons/document/img-file-XLSX.png';\r\n    } else if (ext === 'docx') {\r\n      return 'assets/icons/document/img-file-DOCX.png';\r\n    } else if (ext === 'avi') {\r\n      return 'assets/icons/document/img-file-AVI.png';\r\n    } else if (ext === 'doc') {\r\n      return 'assets/icons/document/img-file-DOC.png';\r\n    } else if (ext === 'gif') {\r\n      return 'assets/icons/document/img-file-GIF.png';\r\n    } else if (ext === 'jpg') {\r\n      return 'assets/icons/document/img-file-JPG.png';\r\n    } else if (ext === 'mov') {\r\n      return 'assets/icons/document/img-file-MOV.png';\r\n    } else if (ext === 'mp3') {\r\n      return 'assets/icons/document/img-file-MP3.png';\r\n    } else if (ext === 'mp4') {\r\n      return 'assets/icons/document/img-file-MP4.png';\r\n    } else if (ext === 'mpeg') {\r\n      return 'assets/icons/document/img-file-MPEG.png';\r\n    } else if (ext === 'mpg') {\r\n      return 'assets/icons/document/img-file-MPG.png';\r\n    } else if (ext === 'png') {\r\n      return 'assets/icons/document/img-file-PNG.png';\r\n    } else if (ext === 'ppt') {\r\n      return 'assets/icons/document/img-file-PPT.png';\r\n    } else if (ext === 'txt') {\r\n      return 'projects/nxt-app/src/assets/icons/document/img-file-TXT.png';\r\n    } else if (ext === 'xls') {\r\n      return 'assets/icons/document/img-file-XLS.png';\r\n    } else {\r\n      return 'assets/images/ic_document.svg';\r\n    }\r\n  }\r\n}\r\n","<div class=\"row\" style=\"margin: 0;\">\r\n  <div class=\"col-md-12\" *ngIf=\"!isDeleteFileButtonVisible\" style=\"text-align: left;\">\r\n    <label class=\"she-label\">Attachment</label>\r\n  </div>\r\n  <div class=\"col-lg-3 document-cnt m-t-10 m-b-10 hover-pointer\"\r\n    *ngFor=\"let eachFile of copyOfInputAllFiles; let currentFileIndex = index\">\r\n     <div class=\"row\"> <!-- (click)=\"viewFile(eachFile)\"  -->\r\n      <div class=\"col-lg-3 document_image\">\r\n        <img [src]=\"getDocIcon(eachFile?.name)\" style=\"margin-right: 10px;height: 40px;\">\r\n    </div>\r\n      <div class=\"col-lg-9 document_name\">\r\n        {{eachFile?.name}}\r\n      </div>\r\n      <div class=\"document_delete\" (click)=\"deleteFile(currentFileIndex);$event.stopPropagation()\" *ngIf=\"isDeleteFileButtonVisible\">\r\n        <img src=\"assets/images/bin.svg\">\r\n      </div>\r\n    </div>\r\n  </div>\r\n  <div class=\"col-md-12 m-b-30 text-center\" *ngIf=\"copyOfInputAllFiles?.length === 0 && isShowNoFileIcon\">\r\n    <img src=\"../../../assets/images/ic_no_attachments.svg\" style=\"height: 140px;\">\r\n  </div>\r\n</div>\r\n\r\n<div class=\"col-lg-6\" style=\"padding:0;margin-top: 10px;\">\r\n  <label class=\"custom-file\" *ngIf=\"isDeleteFileButtonVisible\">\r\n    <button class=\"she-btn-primary-bordered\" style=\"width:275px;\" (click)=\"onFileUpload($event)\"\r\n    [ngClass]=\"{ 'btn-disabled': copyOfInputAllFiles?.length >= copyOfFileUploadingLimit }\" [disabled]=\"copyOfInputAllFiles?.length >= copyOfFileUploadingLimit\"\r\n    >Choose\r\n      files</button>\r\n\r\n    <input id='fileUpload' type=\"file\" id=\"fileUpload\" name=\"fileUpload\" multiple=\"multiple\" accept=\"*\" style=\"display:none;\"\r\n    (change) = uploadMultipleFiles($event)\r\n    />\r\n  </label>\r\n  <!-- <span class=\"error-msg\" *ngIf=\"(formControl?.documents?.touched ||        formControl?.documents?.dirty) &&\r\n  formControl?.documents?.errors?.required\">\r\n    {{LM_POLICY_VALIDATION_MESSAGE.REQUIRED}}\r\n  </span> -->\r\n</div>\r\n"]}
|
|
@@ -21,6 +21,7 @@ import { BookletComponent } from './pages/booklet/booklet.component';
|
|
|
21
21
|
import { GoogleMapsModule } from '@angular/google-maps';
|
|
22
22
|
import { SearchBoxComponent } from './components/search-box/search-box.component';
|
|
23
23
|
import { QuestionbookComponent } from './pages/questionbook/questionbook.component';
|
|
24
|
+
import { FileUploadComponent } from './components/file-upload/file-upload.component';
|
|
24
25
|
import * as i0 from "@angular/core";
|
|
25
26
|
import * as i1 from "ng-circle-progress";
|
|
26
27
|
// export const MY_CUSTOM_FORMATS = {
|
|
@@ -40,7 +41,8 @@ export class NxtAppModule {
|
|
|
40
41
|
CustomDropdownComponent,
|
|
41
42
|
BookletComponent,
|
|
42
43
|
SearchBoxComponent,
|
|
43
|
-
QuestionbookComponent
|
|
44
|
+
QuestionbookComponent,
|
|
45
|
+
FileUploadComponent], imports: [CommonModule, FormsModule,
|
|
44
46
|
MyDatePickerModule,
|
|
45
47
|
OwlDateTimeModule,
|
|
46
48
|
OwlNativeDateTimeModule,
|
|
@@ -158,7 +160,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImpo
|
|
|
158
160
|
CustomDropdownComponent,
|
|
159
161
|
BookletComponent,
|
|
160
162
|
SearchBoxComponent,
|
|
161
|
-
QuestionbookComponent
|
|
163
|
+
QuestionbookComponent,
|
|
164
|
+
FileUploadComponent
|
|
162
165
|
],
|
|
163
166
|
imports: [
|
|
164
167
|
CommonModule, FormsModule,
|
|
@@ -262,4 +265,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImpo
|
|
|
262
265
|
// ]
|
|
263
266
|
}]
|
|
264
267
|
}] });
|
|
265
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"nxt-app.module.js","sourceRoot":"","sources":["../../../../projects/nxt-app/src/lib/nxt-app.module.ts"],"names":[],"mappings":"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","sourcesContent":["import { NgModule, CUSTOM_ELEMENTS_SCHEMA } from '@angular/core';\r\nimport { NxtAppComponent } from './nxt-app.component';\r\nimport { QuestionnaireComponent } from './pages/questionnaire/questionnaire.component';\r\nimport { CommonModule } from \"@angular/common\";\r\nimport { FormsModule,ReactiveFormsModule } from '@angular/forms';\r\nimport { MyDatePickerModule } from 'mydatepicker';\r\nimport { NgCircleProgressModule } from 'ng-circle-progress';\r\nimport { NgxSpinnerModule } from \"ngx-spinner\";\r\n//import { AgmCoreModule } from '@agm/core';\r\nimport { GOOGLE_MAP_API_KEY } from '../lib/sample';\r\nimport { PickLocationComponent } from './components/pick-location/pick-location.component';\r\nimport { NgSelectModule } from '@ng-select/ng-select';\r\nimport { CustomInputComponent } from './components/custom-input/custom-input.component';\r\nimport { CustomTextAreaComponent } from './components/custom-text-area/custom-text-area.component';\r\nimport { CustomTableComponent } from './components/custom-table/custom-table.component';\r\nimport { DropdownWithFlagComponent } from './components/dropdown-with-flag/dropdown-with-flag.component';\r\nimport { OwlDateTimeModule,OwlNativeDateTimeModule } from 'ng-pick-datetime';\r\n\r\n//import { OWL_MOMENT_DATE_TIME_ADAPTER_OPTIONS } from 'ng-pick-datetime/date-time/adapter/moment-adapter/moment-date-time-adapter.class';\r\nimport { CustomDatePickerComponent } from './components/custom-date-picker/custom-date-picker.component';\r\nimport { CustomDropdownComponent } from './components/custom-dropdown/custom-dropdown.component';\r\nimport { HttpClientModule } from '@angular/common/http';\r\nimport { BookletComponent } from './pages/booklet/booklet.component';\r\nimport { GoogleMapsModule } from '@angular/google-maps';\r\nimport { SearchBoxComponent } from './components/search-box/search-box.component';\r\nimport { QuestionbookComponent } from './pages/questionbook/questionbook.component';\r\n\r\n// export const MY_CUSTOM_FORMATS = {\r\n//   fullPickerInput: 'DD/MM/YYYY HH:mm:ss',\r\n//   useUtc: true,\r\n// };\r\n\r\n@NgModule({\r\n  declarations: [NxtAppComponent, \r\n    QuestionnaireComponent,\r\n    PickLocationComponent,\r\n    CustomInputComponent,\r\n    CustomTextAreaComponent,\r\n    CustomTableComponent,\r\n    CustomDatePickerComponent,\r\n    DropdownWithFlagComponent,\r\n    CustomDropdownComponent,\r\n    BookletComponent,\r\n    SearchBoxComponent,\r\n    QuestionbookComponent\r\n  ],\r\n  imports: [\r\n    CommonModule, FormsModule,\r\n    MyDatePickerModule,\r\n    OwlDateTimeModule,\r\n    OwlNativeDateTimeModule,\r\n    HttpClientModule,\r\n    NgSelectModule,\r\n    GoogleMapsModule,\r\n    //AgmCoreModule.forRoot({\r\n    //  apiKey: GOOGLE_MAP_API_KEY,\r\n    //  libraries: ['geometry', 'places', 'visualization', 'drawing']\r\n  //  }),\r\n    ReactiveFormsModule, NgxSpinnerModule,\r\n    /*NgCircleProgressModule.forRoot({\r\n      \"backgroundPadding\": -10,\r\n      \"radius\": 60,\r\n      \"space\": -6,\r\n      \"innerStrokeColor\": \"#919191\",\r\n      \"outerStrokeColor\": \"#db9594\",\r\n      \"outerStrokeGradientStopColor\": \"#e0b1b0\",\r\n      \"innerStrokeWidth\": 2,\r\n      \"backgroundGradient\": true,\r\n      \"backgroundColor\": \"#dd2e13\",\r\n      \"backgroundGradientStopColor\": \"#dd2e13\",\r\n      \"backgroundStroke\": \"#d3cfcf\",\r\n      \"title\": [\r\n                \r\n                \"%\"\r\n      ],\r\n      // titleFontSize: 12,\r\n      // \"subtitleFontSize\": 20,\r\n      \"animateTitle\": false,\r\n      \"animationDuration\": 1000,\r\n      \"showUnits\": false,\r\n      \"clockwise\":true\r\n\r\n      //\"backgroundStrokeWidth\": \"0\",\r\n\"backgroundGradient\": true,\r\n      //\"backgroundColor\": \"#dd2e13\",\r\n      \"backgroundGradientStopColor\": \"#dd2e13\",\r\n      \"backgroundStroke\": \"#000000\",\r\n      \"backgroundPadding\": -10,\r\n      \"radius\": 60,\r\n      \"unitsFontWeight\": \"600\",\r\n      \"unitsColor\": \"#f2f2f2\",\r\n      \"outerStrokeGradient\": true,\r\n      \"outerStrokeColor\": \"#e0b1b0\",\r\n      \"outerStrokeGradientStopColor\": \"#e0b1b0\",\r\n      \"outerStrokeLinecap\": \"inherit\",\r\n      \"innerStrokeColor\": \"#f6dfdf\",\r\n      \"title\": [\r\n                \r\n        \"%\"\r\n],\r\n      \"titleColor\": \"#e7d9d9\",\r\n      \"titleFontSize\": \"31\",\r\n      \"titleFontWeight\": \"100\",\r\n      \"subtitleColor\": \"#f7f7f7\",\r\n      \"subtitleFontSize\": \"36\",\r\n      \"subtitleFontWeight\": \"900\",\r\n      \"animateTitle\": false,\r\n      \"animationDuration\": 1000,\r\n      \"showTitle\": true,\r\n      \"showUnits\": true,\r\n      \"clockwise\": false,\r\n      \"startFromZero\": true,\r\n      \"showZeroOuterStroke\": false,\r\n      \"lazy\": true})*/\r\n\r\n      NgCircleProgressModule.forRoot({\r\n        \"backgroundGradient\": true,\r\n        \"backgroundColor\": \"#e29d98\",\r\n        \"backgroundGradientStopColor\": \"#c5281c\",\r\n        \"backgroundStroke\": \"#ece4e4\",\r\n        \"backgroundStrokeWidth\": 0,\r\n        \"backgroundPadding\": -10,\r\n        \"radius\": 60,\r\n        \"space\": 4,\r\n        \"maxPercent\": 100,\r\n        \"unitsFontSize\": \"35\",\r\n        \"unitsColor\": \"#f0ebeb\",\r\n        \"outerStrokeGradient\": true,\r\n        \"outerStrokeWidth\": 10,\r\n        \"outerStrokeColor\": \"#f7c0bf\",\r\n        \"outerStrokeGradientStopColor\": \"#f9c9c8\",\r\n        \"innerStrokeWidth\": 0,\r\n        \"titleColor\": \"#f3eded\",\r\n        \"titleFontSize\": \"40\",\r\n        \"subtitleColor\": \"#444444\",\r\n        \"showSubtitle\": false})\r\n  ],\r\n  schemas: [CUSTOM_ELEMENTS_SCHEMA],\r\n  exports: [NxtAppComponent, \r\n    QuestionnaireComponent,\r\n    BookletComponent\r\n  ]\r\n  // providers: [\r\n  //   { provide: OWL_MOMENT_DATE_TIME_ADAPTER_OPTIONS, useValue: { useUtc: false } },\r\n  //   { provide: OWL_DATE_TIME_FORMATS, useValue: MY_CUSTOM_FORMATS },\r\n  // ]\r\n})\r\nexport class NxtAppModule { }\r\n"]}
|
|
268
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"nxt-app.module.js","sourceRoot":"","sources":["../../../../projects/nxt-app/src/lib/nxt-app.module.ts"],"names":[],"mappings":"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","sourcesContent":["import { NgModule, CUSTOM_ELEMENTS_SCHEMA } from '@angular/core';\r\nimport { NxtAppComponent } from './nxt-app.component';\r\nimport { QuestionnaireComponent } from './pages/questionnaire/questionnaire.component';\r\nimport { CommonModule } from \"@angular/common\";\r\nimport { FormsModule,ReactiveFormsModule } from '@angular/forms';\r\nimport { MyDatePickerModule } from 'mydatepicker';\r\nimport { NgCircleProgressModule } from 'ng-circle-progress';\r\nimport { NgxSpinnerModule } from \"ngx-spinner\";\r\n//import { AgmCoreModule } from '@agm/core';\r\nimport { GOOGLE_MAP_API_KEY } from '../lib/sample';\r\nimport { PickLocationComponent } from './components/pick-location/pick-location.component';\r\nimport { NgSelectModule } from '@ng-select/ng-select';\r\nimport { CustomInputComponent } from './components/custom-input/custom-input.component';\r\nimport { CustomTextAreaComponent } from './components/custom-text-area/custom-text-area.component';\r\nimport { CustomTableComponent } from './components/custom-table/custom-table.component';\r\nimport { DropdownWithFlagComponent } from './components/dropdown-with-flag/dropdown-with-flag.component';\r\nimport { OwlDateTimeModule,OwlNativeDateTimeModule } from 'ng-pick-datetime';\r\n\r\n//import { OWL_MOMENT_DATE_TIME_ADAPTER_OPTIONS } from 'ng-pick-datetime/date-time/adapter/moment-adapter/moment-date-time-adapter.class';\r\nimport { CustomDatePickerComponent } from './components/custom-date-picker/custom-date-picker.component';\r\nimport { CustomDropdownComponent } from './components/custom-dropdown/custom-dropdown.component';\r\nimport { HttpClientModule } from '@angular/common/http';\r\nimport { BookletComponent } from './pages/booklet/booklet.component';\r\nimport { GoogleMapsModule } from '@angular/google-maps';\r\nimport { SearchBoxComponent } from './components/search-box/search-box.component';\r\nimport { QuestionbookComponent } from './pages/questionbook/questionbook.component';\r\nimport { FileUploadComponent } from './components/file-upload/file-upload.component';\r\n\r\n// export const MY_CUSTOM_FORMATS = {\r\n//   fullPickerInput: 'DD/MM/YYYY HH:mm:ss',\r\n//   useUtc: true,\r\n// };\r\n\r\n@NgModule({\r\n  declarations: [NxtAppComponent, \r\n    QuestionnaireComponent,\r\n    PickLocationComponent,\r\n    CustomInputComponent,\r\n    CustomTextAreaComponent,\r\n    CustomTableComponent,\r\n    CustomDatePickerComponent,\r\n    DropdownWithFlagComponent,\r\n    CustomDropdownComponent,\r\n    BookletComponent,\r\n    SearchBoxComponent,\r\n    QuestionbookComponent,\r\n    FileUploadComponent\r\n  ],\r\n  imports: [\r\n    CommonModule, FormsModule,\r\n    MyDatePickerModule,\r\n    OwlDateTimeModule,\r\n    OwlNativeDateTimeModule,\r\n    HttpClientModule,\r\n    NgSelectModule,\r\n    GoogleMapsModule,\r\n    //AgmCoreModule.forRoot({\r\n    //  apiKey: GOOGLE_MAP_API_KEY,\r\n    //  libraries: ['geometry', 'places', 'visualization', 'drawing']\r\n  //  }),\r\n    ReactiveFormsModule, NgxSpinnerModule,\r\n    /*NgCircleProgressModule.forRoot({\r\n      \"backgroundPadding\": -10,\r\n      \"radius\": 60,\r\n      \"space\": -6,\r\n      \"innerStrokeColor\": \"#919191\",\r\n      \"outerStrokeColor\": \"#db9594\",\r\n      \"outerStrokeGradientStopColor\": \"#e0b1b0\",\r\n      \"innerStrokeWidth\": 2,\r\n      \"backgroundGradient\": true,\r\n      \"backgroundColor\": \"#dd2e13\",\r\n      \"backgroundGradientStopColor\": \"#dd2e13\",\r\n      \"backgroundStroke\": \"#d3cfcf\",\r\n      \"title\": [\r\n                \r\n                \"%\"\r\n      ],\r\n      // titleFontSize: 12,\r\n      // \"subtitleFontSize\": 20,\r\n      \"animateTitle\": false,\r\n      \"animationDuration\": 1000,\r\n      \"showUnits\": false,\r\n      \"clockwise\":true\r\n\r\n      //\"backgroundStrokeWidth\": \"0\",\r\n\"backgroundGradient\": true,\r\n      //\"backgroundColor\": \"#dd2e13\",\r\n      \"backgroundGradientStopColor\": \"#dd2e13\",\r\n      \"backgroundStroke\": \"#000000\",\r\n      \"backgroundPadding\": -10,\r\n      \"radius\": 60,\r\n      \"unitsFontWeight\": \"600\",\r\n      \"unitsColor\": \"#f2f2f2\",\r\n      \"outerStrokeGradient\": true,\r\n      \"outerStrokeColor\": \"#e0b1b0\",\r\n      \"outerStrokeGradientStopColor\": \"#e0b1b0\",\r\n      \"outerStrokeLinecap\": \"inherit\",\r\n      \"innerStrokeColor\": \"#f6dfdf\",\r\n      \"title\": [\r\n                \r\n        \"%\"\r\n],\r\n      \"titleColor\": \"#e7d9d9\",\r\n      \"titleFontSize\": \"31\",\r\n      \"titleFontWeight\": \"100\",\r\n      \"subtitleColor\": \"#f7f7f7\",\r\n      \"subtitleFontSize\": \"36\",\r\n      \"subtitleFontWeight\": \"900\",\r\n      \"animateTitle\": false,\r\n      \"animationDuration\": 1000,\r\n      \"showTitle\": true,\r\n      \"showUnits\": true,\r\n      \"clockwise\": false,\r\n      \"startFromZero\": true,\r\n      \"showZeroOuterStroke\": false,\r\n      \"lazy\": true})*/\r\n\r\n      NgCircleProgressModule.forRoot({\r\n        \"backgroundGradient\": true,\r\n        \"backgroundColor\": \"#e29d98\",\r\n        \"backgroundGradientStopColor\": \"#c5281c\",\r\n        \"backgroundStroke\": \"#ece4e4\",\r\n        \"backgroundStrokeWidth\": 0,\r\n        \"backgroundPadding\": -10,\r\n        \"radius\": 60,\r\n        \"space\": 4,\r\n        \"maxPercent\": 100,\r\n        \"unitsFontSize\": \"35\",\r\n        \"unitsColor\": \"#f0ebeb\",\r\n        \"outerStrokeGradient\": true,\r\n        \"outerStrokeWidth\": 10,\r\n        \"outerStrokeColor\": \"#f7c0bf\",\r\n        \"outerStrokeGradientStopColor\": \"#f9c9c8\",\r\n        \"innerStrokeWidth\": 0,\r\n        \"titleColor\": \"#f3eded\",\r\n        \"titleFontSize\": \"40\",\r\n        \"subtitleColor\": \"#444444\",\r\n        \"showSubtitle\": false})\r\n  ],\r\n  schemas: [CUSTOM_ELEMENTS_SCHEMA],\r\n  exports: [NxtAppComponent, \r\n    QuestionnaireComponent,\r\n    BookletComponent\r\n  ]\r\n  // providers: [\r\n  //   { provide: OWL_MOMENT_DATE_TIME_ADAPTER_OPTIONS, useValue: { useUtc: false } },\r\n  //   { provide: OWL_DATE_TIME_FORMATS, useValue: MY_CUSTOM_FORMATS },\r\n  // ]\r\n})\r\nexport class NxtAppModule { }\r\n"]}
|
|
@@ -104,11 +104,11 @@ export class BookletComponent {
|
|
|
104
104
|
return this.sanitizer.bypassSecurityTrustHtml(doc.documentElement.textContent);
|
|
105
105
|
}
|
|
106
106
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: BookletComponent, deps: [{ token: i1.SalesforceService }, { token: i2.DataService }, { token: i3.ActivatedRoute }, { token: i4.DomSanitizer }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
107
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: BookletComponent, selector: "lib-booklet", inputs: { bookletId: "bookletId", serv: "serv", tkn: "tkn" }, outputs: { handleBookletActionEvent: "handleBookletActionEvent", handlePage: "handlePage" }, usesOnChanges: true, ngImport: i0, template: "<ngx-spinner [name]=\"spinnerName\" [type]=\"spinnerType\"></ngx-spinner>\r\n<!-- Booklet Handling-->\r\n<div *ngFor=\"let qb of booklet\">\r\n <!-- MR Commented below code to ensure single JSON for UNCONDITIONAL Booklets -->\r\n <!-- <lib-questionnaire [serv]=\"serv\" [qbId]=\"qb.Id\" [tkn]=\"tkn\"></lib-questionnaire> -->\r\n\r\n <div *ngFor=\"let ques of qb.Questions__r.records\" [class]=\"qb.isShengel__c ? 'questiondiv1' : 'questiondiv1 padd-bottom'\">\r\n <div class=\"questiondiv2\">\r\n <div *ngIf=\"!ques.Is_Title__c\" [class]=\"qb.isShengel__c ? 'header-style
|
|
107
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: BookletComponent, selector: "lib-booklet", inputs: { bookletId: "bookletId", serv: "serv", tkn: "tkn" }, outputs: { handleBookletActionEvent: "handleBookletActionEvent", handlePage: "handlePage" }, usesOnChanges: true, ngImport: i0, template: "<ngx-spinner [name]=\"spinnerName\" [type]=\"spinnerType\"></ngx-spinner>\r\n<!-- Booklet Handling-->\r\n<div *ngFor=\"let qb of booklet\">\r\n <!-- MR Commented below code to ensure single JSON for UNCONDITIONAL Booklets -->\r\n <!-- <lib-questionnaire [serv]=\"serv\" [qbId]=\"qb.Id\" [tkn]=\"tkn\"></lib-questionnaire> -->\r\n\r\n <div *ngFor=\"let ques of qb.Questions__r.records\" [class]=\"qb.isShengel__c ? 'questiondiv1' : 'questiondiv1 padd-bottom'\">\r\n <div class=\"questiondiv2\">\r\n <div *ngIf=\"!ques.Is_Title__c\" [class]=\"qb.isShengel__c ? 'header-style' : 'question-f-size additional'\">\r\n <div [innerHTML]=\"getText(ques?.Question_Text__c)\" >\r\n {{ ques?.Question_Text__c }}\r\n </div>\r\n </div>\r\n <lib-questionbook [qbItem]=\"qb\" [questionItem]=\"ques\" [questions]=\"readQuestions(qb.Id)\"></lib-questionbook>\r\n </div>\r\n </div>\r\n</div>\r\n\r\n<!-- Group Actions -->\r\n<div class=\"align-submit-row\" *ngIf=\"abItem.Status__c != 'Completed'\">\r\n <div *ngFor=\"let action of actions\">\r\n <button (click)=\"handleBookletActionClick(action)\">\r\n {{ action.name }}\r\n </button>\r\n </div>\r\n</div>\r\n", styles: [".align-submit-row{display:flex}.align-submit-row button{margin-left:25px;background:#48B7FF;color:#fff;border:none;border-radius:5px;height:50px;width:150px}.header-style{padding:15px;background:#F8F8F8;color:#898989;border:1px solid #e8e8e8;border-top-left-radius:5px;border-top-right-radius:5px;margin-left:0;justify-content:left;font-size:15px}\n"], dependencies: [{ kind: "directive", type: i5.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i6.NgxSpinnerComponent, selector: "ngx-spinner", inputs: ["disableAnimation", "bdColor", "zIndex", "color", "type", "size", "fullScreen", "name", "template", "showSpinner"] }, { kind: "component", type: i7.QuestionbookComponent, selector: "lib-questionbook", inputs: ["qbItem", "questionItem", "questions"] }] });
|
|
108
108
|
}
|
|
109
109
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: BookletComponent, decorators: [{
|
|
110
110
|
type: Component,
|
|
111
|
-
args: [{ selector: 'lib-booklet', template: "<ngx-spinner [name]=\"spinnerName\" [type]=\"spinnerType\"></ngx-spinner>\r\n<!-- Booklet Handling-->\r\n<div *ngFor=\"let qb of booklet\">\r\n <!-- MR Commented below code to ensure single JSON for UNCONDITIONAL Booklets -->\r\n <!-- <lib-questionnaire [serv]=\"serv\" [qbId]=\"qb.Id\" [tkn]=\"tkn\"></lib-questionnaire> -->\r\n\r\n <div *ngFor=\"let ques of qb.Questions__r.records\" [class]=\"qb.isShengel__c ? 'questiondiv1' : 'questiondiv1 padd-bottom'\">\r\n <div class=\"questiondiv2\">\r\n <div *ngIf=\"!ques.Is_Title__c\" [class]=\"qb.isShengel__c ? 'header-style
|
|
111
|
+
args: [{ selector: 'lib-booklet', template: "<ngx-spinner [name]=\"spinnerName\" [type]=\"spinnerType\"></ngx-spinner>\r\n<!-- Booklet Handling-->\r\n<div *ngFor=\"let qb of booklet\">\r\n <!-- MR Commented below code to ensure single JSON for UNCONDITIONAL Booklets -->\r\n <!-- <lib-questionnaire [serv]=\"serv\" [qbId]=\"qb.Id\" [tkn]=\"tkn\"></lib-questionnaire> -->\r\n\r\n <div *ngFor=\"let ques of qb.Questions__r.records\" [class]=\"qb.isShengel__c ? 'questiondiv1' : 'questiondiv1 padd-bottom'\">\r\n <div class=\"questiondiv2\">\r\n <div *ngIf=\"!ques.Is_Title__c\" [class]=\"qb.isShengel__c ? 'header-style' : 'question-f-size additional'\">\r\n <div [innerHTML]=\"getText(ques?.Question_Text__c)\" >\r\n {{ ques?.Question_Text__c }}\r\n </div>\r\n </div>\r\n <lib-questionbook [qbItem]=\"qb\" [questionItem]=\"ques\" [questions]=\"readQuestions(qb.Id)\"></lib-questionbook>\r\n </div>\r\n </div>\r\n</div>\r\n\r\n<!-- Group Actions -->\r\n<div class=\"align-submit-row\" *ngIf=\"abItem.Status__c != 'Completed'\">\r\n <div *ngFor=\"let action of actions\">\r\n <button (click)=\"handleBookletActionClick(action)\">\r\n {{ action.name }}\r\n </button>\r\n </div>\r\n</div>\r\n", styles: [".align-submit-row{display:flex}.align-submit-row button{margin-left:25px;background:#48B7FF;color:#fff;border:none;border-radius:5px;height:50px;width:150px}.header-style{padding:15px;background:#F8F8F8;color:#898989;border:1px solid #e8e8e8;border-top-left-radius:5px;border-top-right-radius:5px;margin-left:0;justify-content:left;font-size:15px}\n"] }]
|
|
112
112
|
}], ctorParameters: function () { return [{ type: i1.SalesforceService }, { type: i2.DataService }, { type: i3.ActivatedRoute }, { type: i4.DomSanitizer }, { type: i0.ElementRef }]; }, propDecorators: { bookletId: [{
|
|
113
113
|
type: Input
|
|
114
114
|
}], serv: [{
|
|
@@ -120,4 +120,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImpo
|
|
|
120
120
|
}], handlePage: [{
|
|
121
121
|
type: Output
|
|
122
122
|
}] } });
|
|
123
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"booklet.component.js","sourceRoot":"","sources":["../../../../../../projects/nxt-app/src/lib/pages/booklet/booklet.component.ts","../../../../../../projects/nxt-app/src/lib/pages/booklet/booklet.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  OnInit,\r\n  OnChanges,\r\n  Inject,\r\n  Input,\r\n  Output,\r\n  EventEmitter,\r\n  ViewEncapsulation,\r\n  ElementRef,\r\n} from \"@angular/core\";\r\nimport { SalesforceService } from \"../../services/salesforce.service\";\r\nimport { DataService } from '../../services/data.service';\r\nimport { ActivatedRoute, Params } from \"@angular/router\";\r\nimport { DomSanitizer, SafeHtml } from \"@angular/platform-browser\";\r\nimport { ActionMeta } from '../../interfaces/actionMeta';\r\nimport { Question } from \"../../wrapper\";\r\n\r\n@Component({\r\n  selector: 'lib-booklet',\r\n  templateUrl: './booklet.component.html',\r\n  styleUrls: ['./booklet.component.css']\r\n})\r\nexport class BookletComponent implements OnInit {\r\n  @Input() bookletId: string;\r\n  @Input() serv: string;\r\n  @Input() tkn: string;\r\n  @Output() handleBookletActionEvent = new EventEmitter();\r\n  @Output() handlePage: EventEmitter<any> = new EventEmitter();\r\n\r\n  public booklet: any[] = [];\r\n  public abItem: any = {};\r\n  public actions: ActionMeta[] = [];\r\n  public bookQuestionsMap: any = new Map();\r\n  private sqOptions: any = new Map();\r\n  public spinnerName: string;\r\n  public spinnerType:string;\r\n\r\n  constructor(\r\n    private sfService: SalesforceService,\r\n    private dataService: DataService,\r\n    private route: ActivatedRoute,\r\n    private sanitizer: DomSanitizer,\r\n    el: ElementRef\r\n  ) { \r\n    this.spinnerName = \"sp1\";\r\n    this.spinnerType = \"ball-spin-clockwise\";\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    this.processBooklet();\r\n  }\r\n\r\n  ngOnChanges() {\r\n    console.log('inside Questionnaire ngOnChanges');\r\n    console.log(this.booklet);\r\n    if(this.booklet == undefined || this.booklet.length == 0) {\r\n      this.processBooklet();\r\n    }\r\n  }\r\n\r\n  processBooklet() {\r\n    if (this.bookletId) {\r\n      if (this.bookletId.length == 18) {\r\n        this.readBooklet(this.bookletId);\r\n      }\r\n    }\r\n  }\r\n\r\n  private readBooklet = (uuid: string) => {\r\n    if(this.serv == \"api\") {\r\n      this.dataService.getAPIData(\r\n        this.tkn,\r\n        [\"Booklet\", \"read\", uuid],\r\n        this.successReadBooklet,\r\n        this.failureReadBooklet\r\n      );\r\n    } else {\r\n      this.sfService.remoteAction(\r\n        \"NxtController.process\",\r\n        [\"Booklet\", \"read\", uuid],\r\n        this.successReadBooklet,\r\n        this.failureReadBooklet\r\n      );\r\n    }\r\n  }\r\n\r\n  private successReadBooklet = (response) => {\r\n    console.log('Inside the successReadBooklet');\r\n    // console.log(response);\r\n    if(response != null || response != undefined) {\r\n      this.booklet = response.records;\r\n      this.abItem = response.answerbook;\r\n      // Process the Sub Question Options\r\n      for (var sq in response.sqOptions) {\r\n        this.sqOptions.set(sq, response.sqOptions[sq]);\r\n      }\r\n      // Process the Questions\r\n      for (var value in response.bookQuestionsMap) {\r\n        this.bookQuestionsMap.set(value, response.bookQuestionsMap[value]);\r\n      }\r\n\r\n      if(response.questionbook?.Actions__c != undefined) {\r\n        this.actions = JSON.parse(response.questionbook.Actions__c);\r\n      }\r\n    }\r\n  }\r\n\r\n  private failureReadBooklet = (response) => {\r\n\r\n  }\r\n\r\n  handleBookletActionClick(action:ActionMeta) {\r\n    console.log(action);\r\n    this.handleBookletActionEvent.emit(action.eventtoemit);\r\n  }\r\n\r\n  readQuestions(qbId: string) {\r\n    console.log('inside BookletComponent.readQuestions ' + qbId);\r\n    // console.log(this.bookQuestionsMap.size);\r\n    let questions = [];\r\n    for(var sq in this.bookQuestionsMap?.get(qbId).Questions__r.records) {\r\n      let q: Question = this.bookQuestionsMap?.get(qbId).Questions__r.records[sq];\r\n      if(q.Type__c == 'Dropdown') {\r\n        questions.push(this.sqOptions.get(q.Id));\r\n      } else {\r\n        questions.push(q);\r\n      }\r\n    }\r\n    // console.log(questions);\r\n    return questions;\r\n  }\r\n\r\n  getText(value) {\r\n    var doc = new DOMParser().parseFromString(value, \"text/html\");\r\n    //console.log( doc.documentElement.textContent);\r\n    return this.sanitizer.bypassSecurityTrustHtml(\r\n      doc.documentElement.textContent\r\n    );\r\n  }\r\n}\r\n","<ngx-spinner [name]=\"spinnerName\" [type]=\"spinnerType\"></ngx-spinner>\r\n<!-- Booklet Handling-->\r\n<div *ngFor=\"let qb of booklet\">\r\n    <!-- MR Commented below code to ensure single JSON for UNCONDITIONAL Booklets -->\r\n    <!-- <lib-questionnaire [serv]=\"serv\" [qbId]=\"qb.Id\" [tkn]=\"tkn\"></lib-questionnaire> -->\r\n\r\n    <div *ngFor=\"let ques of qb.Questions__r.records\" [class]=\"qb.isShengel__c ? 'questiondiv1' : 'questiondiv1 padd-bottom'\">\r\n        <div class=\"questiondiv2\">\r\n            <div *ngIf=\"!ques.Is_Title__c\" [class]=\"qb.isShengel__c ? 'header-style additional' : 'question-f-size additional'\">\r\n                <div [innerHTML]=\"getText(ques?.Question_Text__c)\" >\r\n                    {{ ques?.Question_Text__c }}\r\n                </div>\r\n            </div>\r\n            <lib-questionbook [qbItem]=\"qb\" [questionItem]=\"ques\" [questions]=\"readQuestions(qb.Id)\"></lib-questionbook>\r\n        </div>\r\n    </div>\r\n</div>\r\n\r\n<!-- Group Actions -->\r\n<div class=\"align-submit-row\" *ngIf=\"abItem.Status__c != 'Completed'\">\r\n    <div *ngFor=\"let action of actions\">\r\n        <button (click)=\"handleBookletActionClick(action)\">\r\n            {{ action.name }}\r\n        </button>\r\n    </div>\r\n</div>\r\n"]}
|
|
123
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"booklet.component.js","sourceRoot":"","sources":["../../../../../../projects/nxt-app/src/lib/pages/booklet/booklet.component.ts","../../../../../../projects/nxt-app/src/lib/pages/booklet/booklet.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  OnInit,\r\n  OnChanges,\r\n  Inject,\r\n  Input,\r\n  Output,\r\n  EventEmitter,\r\n  ViewEncapsulation,\r\n  ElementRef,\r\n} from \"@angular/core\";\r\nimport { SalesforceService } from \"../../services/salesforce.service\";\r\nimport { DataService } from '../../services/data.service';\r\nimport { ActivatedRoute, Params } from \"@angular/router\";\r\nimport { DomSanitizer, SafeHtml } from \"@angular/platform-browser\";\r\nimport { ActionMeta } from '../../interfaces/actionMeta';\r\nimport { Question } from \"../../wrapper\";\r\n\r\n@Component({\r\n  selector: 'lib-booklet',\r\n  templateUrl: './booklet.component.html',\r\n  styleUrls: ['./booklet.component.css']\r\n})\r\nexport class BookletComponent implements OnInit {\r\n  @Input() bookletId: string;\r\n  @Input() serv: string;\r\n  @Input() tkn: string;\r\n  @Output() handleBookletActionEvent = new EventEmitter();\r\n  @Output() handlePage: EventEmitter<any> = new EventEmitter();\r\n\r\n  public booklet: any[] = [];\r\n  public abItem: any = {};\r\n  public actions: ActionMeta[] = [];\r\n  public bookQuestionsMap: any = new Map();\r\n  private sqOptions: any = new Map();\r\n  public spinnerName: string;\r\n  public spinnerType:string;\r\n\r\n  constructor(\r\n    private sfService: SalesforceService,\r\n    private dataService: DataService,\r\n    private route: ActivatedRoute,\r\n    private sanitizer: DomSanitizer,\r\n    el: ElementRef\r\n  ) { \r\n    this.spinnerName = \"sp1\";\r\n    this.spinnerType = \"ball-spin-clockwise\";\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    this.processBooklet();\r\n  }\r\n\r\n  ngOnChanges() {\r\n    console.log('inside Questionnaire ngOnChanges');\r\n    console.log(this.booklet);\r\n    if(this.booklet == undefined || this.booklet.length == 0) {\r\n      this.processBooklet();\r\n    }\r\n  }\r\n\r\n  processBooklet() {\r\n    if (this.bookletId) {\r\n      if (this.bookletId.length == 18) {\r\n        this.readBooklet(this.bookletId);\r\n      }\r\n    }\r\n  }\r\n\r\n  private readBooklet = (uuid: string) => {\r\n    if(this.serv == \"api\") {\r\n      this.dataService.getAPIData(\r\n        this.tkn,\r\n        [\"Booklet\", \"read\", uuid],\r\n        this.successReadBooklet,\r\n        this.failureReadBooklet\r\n      );\r\n    } else {\r\n      this.sfService.remoteAction(\r\n        \"NxtController.process\",\r\n        [\"Booklet\", \"read\", uuid],\r\n        this.successReadBooklet,\r\n        this.failureReadBooklet\r\n      );\r\n    }\r\n  }\r\n\r\n  private successReadBooklet = (response) => {\r\n    console.log('Inside the successReadBooklet');\r\n    // console.log(response);\r\n    if(response != null || response != undefined) {\r\n      this.booklet = response.records;\r\n      this.abItem = response.answerbook;\r\n      // Process the Sub Question Options\r\n      for (var sq in response.sqOptions) {\r\n        this.sqOptions.set(sq, response.sqOptions[sq]);\r\n      }\r\n      // Process the Questions\r\n      for (var value in response.bookQuestionsMap) {\r\n        this.bookQuestionsMap.set(value, response.bookQuestionsMap[value]);\r\n      }\r\n\r\n      if(response.questionbook?.Actions__c != undefined) {\r\n        this.actions = JSON.parse(response.questionbook.Actions__c);\r\n      }\r\n    }\r\n  }\r\n\r\n  private failureReadBooklet = (response) => {\r\n\r\n  }\r\n\r\n  handleBookletActionClick(action:ActionMeta) {\r\n    console.log(action);\r\n    this.handleBookletActionEvent.emit(action.eventtoemit);\r\n  }\r\n\r\n  readQuestions(qbId: string) {\r\n    console.log('inside BookletComponent.readQuestions ' + qbId);\r\n    // console.log(this.bookQuestionsMap.size);\r\n    let questions = [];\r\n    for(var sq in this.bookQuestionsMap?.get(qbId).Questions__r.records) {\r\n      let q: Question = this.bookQuestionsMap?.get(qbId).Questions__r.records[sq];\r\n      if(q.Type__c == 'Dropdown') {\r\n        questions.push(this.sqOptions.get(q.Id));\r\n      } else {\r\n        questions.push(q);\r\n      }\r\n    }\r\n    // console.log(questions);\r\n    return questions;\r\n  }\r\n\r\n  getText(value) {\r\n    var doc = new DOMParser().parseFromString(value, \"text/html\");\r\n    //console.log( doc.documentElement.textContent);\r\n    return this.sanitizer.bypassSecurityTrustHtml(\r\n      doc.documentElement.textContent\r\n    );\r\n  }\r\n}\r\n","<ngx-spinner [name]=\"spinnerName\" [type]=\"spinnerType\"></ngx-spinner>\r\n<!-- Booklet Handling-->\r\n<div *ngFor=\"let qb of booklet\">\r\n    <!-- MR Commented below code to ensure single JSON for UNCONDITIONAL Booklets -->\r\n    <!-- <lib-questionnaire [serv]=\"serv\" [qbId]=\"qb.Id\" [tkn]=\"tkn\"></lib-questionnaire> -->\r\n\r\n    <div *ngFor=\"let ques of qb.Questions__r.records\" [class]=\"qb.isShengel__c ? 'questiondiv1' : 'questiondiv1 padd-bottom'\">\r\n        <div class=\"questiondiv2\">\r\n            <div *ngIf=\"!ques.Is_Title__c\" [class]=\"qb.isShengel__c ? 'header-style' : 'question-f-size additional'\">\r\n                <div [innerHTML]=\"getText(ques?.Question_Text__c)\" >\r\n                    {{ ques?.Question_Text__c }}\r\n                </div>\r\n            </div>\r\n            <lib-questionbook [qbItem]=\"qb\" [questionItem]=\"ques\" [questions]=\"readQuestions(qb.Id)\"></lib-questionbook>\r\n        </div>\r\n    </div>\r\n</div>\r\n\r\n<!-- Group Actions -->\r\n<div class=\"align-submit-row\" *ngIf=\"abItem.Status__c != 'Completed'\">\r\n    <div *ngFor=\"let action of actions\">\r\n        <button (click)=\"handleBookletActionClick(action)\">\r\n            {{ action.name }}\r\n        </button>\r\n    </div>\r\n</div>\r\n"]}
|
|
@@ -11,6 +11,7 @@ import * as i8 from "../../components/custom-text-area/custom-text-area.componen
|
|
|
11
11
|
import * as i9 from "../../components/custom-table/custom-table.component";
|
|
12
12
|
import * as i10 from "../../components/custom-date-picker/custom-date-picker.component";
|
|
13
13
|
import * as i11 from "../../components/custom-dropdown/custom-dropdown.component";
|
|
14
|
+
import * as i12 from "../../components/file-upload/file-upload.component";
|
|
14
15
|
export class QuestionbookComponent {
|
|
15
16
|
sfService;
|
|
16
17
|
dataService;
|
|
@@ -19,6 +20,7 @@ export class QuestionbookComponent {
|
|
|
19
20
|
questionItem;
|
|
20
21
|
questions;
|
|
21
22
|
subQuestions;
|
|
23
|
+
selectedFileData = [];
|
|
22
24
|
constructor(sfService, dataService, changeService) {
|
|
23
25
|
this.sfService = sfService;
|
|
24
26
|
this.dataService = dataService;
|
|
@@ -49,12 +51,19 @@ export class QuestionbookComponent {
|
|
|
49
51
|
this.changeService.announceChange(event);
|
|
50
52
|
//ques.input = event; // here when using the ng-select got event as value
|
|
51
53
|
}
|
|
54
|
+
assignSelectedFileData(fileData) {
|
|
55
|
+
console.log('fileDATA', fileData);
|
|
56
|
+
this.selectedFileData = fileData;
|
|
57
|
+
}
|
|
58
|
+
deleteFile(fileData) {
|
|
59
|
+
console.log('fileDATA', fileData);
|
|
60
|
+
}
|
|
52
61
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: QuestionbookComponent, deps: [{ token: i1.SalesforceService }, { token: i2.DataService }, { token: i3.ChangeService }], target: i0.ɵɵFactoryTarget.Component });
|
|
53
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: QuestionbookComponent, selector: "lib-questionbook", inputs: { qbItem: "qbItem", questionItem: "questionItem", questions: "questions" }, ngImport: i0, template: "<div [class]=\"qbItem.isShengel__c ? 'form-group content-box' : 'form-group'\">\r\n <div class=\"form-row\">\r\n <div [class]=\"qbItem.isShengel__c ? '' : 'myt-align3'\"\r\n [class]=\"qbItem.isShengel__c ? 'col-lg-' + ques.Size__c + ' paddingnone' : 'col-md-' + ques.Size__c + ' paddingnone'\"\r\n *ngFor=\"let ques of questions;let i = index\" [id]=\"ques.Id\">\r\n <!-- Sub Question Label -->\r\n <div [ngClass]=\"{ down2: qbItem?.Progress_Bar__c }\">\r\n <span [class]=\"qbItem.isShengel__c ? 'dis-flex shengel-myt-font3 myt-font7' : 'dis-flex myt-font3 myt-font7' \">{{ ques?.Question__c }}</span>\r\n </div>\r\n\r\n <!-- DateTime -->\r\n <div *ngIf=\"ques.Type__c === 'DateTime'\">\r\n <app-custom-date-picker [minDate]=\"ques.minDate\" [date]=\"ques.input\" (dateChange)=\"childEventCapture($event, ques)\">\r\n </app-custom-date-picker>\r\n </div>\r\n\r\n <!-- Text -->\r\n <div *ngIf=\"ques.Type__c === 'Text'\">\r\n <app-custom-input [fromShengel]=\"qbItem.isShengel__c\" [value]=\"ques.input\" [ngClassValue]=\"{\r\n 'dis-flex dt-line date-line bookText boxoutline myt-font1': qbItem.Progress_Bar__c,\r\n textBox: !qbItem.Progress_Bar__c\r\n }\" [question]=\"ques\" [idValue]=\"ques.Tracking_ID__c\" [focusEvent]=\"clearSQError(ques.Id)\"\r\n [error]=\"ques.error\" [placeholder]=\"ques.Question__c\" (inputValue)=\"childEventCapture($event, ques)\">\r\n </app-custom-input>\r\n </div>\r\n \r\n <!-- for pick location -->\r\n <div *ngIf=\"ques.Type__c === 'Location'\">\r\n <app-pick-location [address]=\"ques.input\" (locationSelected)=\"childEventCapture($event, ques)\">\r\n </app-pick-location>\r\n </div>\r\n\r\n <!-- for text area -->\r\n <div *ngIf=\"ques.Type__c === 'TextArea'\">\r\n <app-custom-text-area [value]=\"ques.input\" [rows]=\"3\" [error]=\"ques.error\" [placeholder]=\"ques.Question__c \"\r\n (textareaValueChange)=\"childEventCapture($event)\"></app-custom-text-area>\r\n </div>\r\n\r\n <!-- Email -->\r\n <div *ngIf=\"ques.Type__c === 'Email'\">\r\n <input type=\"email\" [(ngModel)]=\"ques.input\" [id]=\"ques.Id\" required=\"\" (focus)=\"clearSQError(ques.Id)\"\r\n style.border-color=\"{{ ques.error ? 'red' : '' }}\" placeholder=\"{{ ques.Question__c }}\" />\r\n </div>\r\n\r\n <!-- Table -->\r\n <div *ngIf=\"ques.Type__c === 'Table'\" class=\"\">\r\n <app-custom-table [question]=\"ques\" (valueChange)=\"childEventCapture($event, ques); clearSQError(ques.Id)\">\r\n </app-custom-table>\r\n </div>\r\n\r\n <!-- Dropdown -->\r\n <div *ngIf=\"ques.Type__c === 'Dropdown'\" class=\"\">\r\n <app-custom-dropdown [fromShengel]=\"qbItem.isShengel__c\" [options]=\"ques.Question_Options__r.records\"\r\n [apiMeta]=\"ques.Sub_Text__c\" [id]=\"ques.
|
|
62
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: QuestionbookComponent, selector: "lib-questionbook", inputs: { qbItem: "qbItem", questionItem: "questionItem", questions: "questions" }, ngImport: i0, template: "<div [class]=\"qbItem.isShengel__c ? 'form-group content-box' : 'form-group'\">\r\n <div class=\"form-row\">\r\n <div [class]=\"qbItem.isShengel__c ? '' : 'myt-align3'\"\r\n [class]=\"qbItem.isShengel__c ? 'col-lg-' + ques.Size__c + ' paddingnone' : 'col-md-' + ques.Size__c + ' paddingnone'\"\r\n *ngFor=\"let ques of questions;let i = index\" [id]=\"ques.Id\">\r\n <!-- Sub Question Label -->\r\n <div [ngClass]=\"{ down2: qbItem?.Progress_Bar__c }\">\r\n <span [class]=\"qbItem.isShengel__c ? 'dis-flex shengel-myt-font3 myt-font7' : 'dis-flex myt-font3 myt-font7' \">{{ ques?.Question__c }}</span>\r\n </div>\r\n\r\n <!-- DateTime -->\r\n <div *ngIf=\"ques.Type__c === 'DateTime'\">\r\n <app-custom-date-picker [minDate]=\"ques.minDate\" [date]=\"ques.input\" (dateChange)=\"childEventCapture($event, ques)\">\r\n </app-custom-date-picker>\r\n </div>\r\n\r\n <!-- Text -->\r\n <div *ngIf=\"ques.Type__c === 'Text'\">\r\n <app-custom-input [fromShengel]=\"qbItem.isShengel__c\" [value]=\"ques.input\" [ngClassValue]=\"{\r\n 'dis-flex dt-line date-line bookText boxoutline myt-font1': qbItem.Progress_Bar__c,\r\n textBox: !qbItem.Progress_Bar__c\r\n }\" [question]=\"ques\" [idValue]=\"ques.Tracking_ID__c\" [focusEvent]=\"clearSQError(ques.Id)\"\r\n [error]=\"ques.error\" [placeholder]=\"ques.Question__c\" (inputValue)=\"childEventCapture($event, ques)\">\r\n </app-custom-input>\r\n </div>\r\n \r\n <!-- for pick location -->\r\n <div *ngIf=\"ques.Type__c === 'Location'\">\r\n <app-pick-location [address]=\"ques.input\" (locationSelected)=\"childEventCapture($event, ques)\">\r\n </app-pick-location>\r\n </div>\r\n\r\n <!-- for text area -->\r\n <div *ngIf=\"ques.Type__c === 'TextArea'\">\r\n <app-custom-text-area [value]=\"ques.input\" [rows]=\"3\" [error]=\"ques.error\" [placeholder]=\"ques.Question__c \"\r\n (textareaValueChange)=\"childEventCapture($event)\"></app-custom-text-area>\r\n </div>\r\n\r\n <!-- Email -->\r\n <div *ngIf=\"ques.Type__c === 'Email'\">\r\n <input type=\"email\" [(ngModel)]=\"ques.input\" [id]=\"ques.Id\" required=\"\" (focus)=\"clearSQError(ques.Id)\"\r\n style.border-color=\"{{ ques.error ? 'red' : '' }}\" placeholder=\"{{ ques.Question__c }}\" />\r\n </div>\r\n\r\n <!-- Table -->\r\n <div *ngIf=\"ques.Type__c === 'Table'\" class=\"\">\r\n <app-custom-table [question]=\"ques\" (valueChange)=\"childEventCapture($event, ques); clearSQError(ques.Id)\">\r\n </app-custom-table>\r\n </div>\r\n\r\n <!-- Dropdown -->\r\n <div *ngIf=\"ques.Type__c === 'Dropdown'\" class=\"\">\r\n <app-custom-dropdown [fromShengel]=\"qbItem.isShengel__c\" [options]=\"ques.Question_Options__r.records\"\r\n [apiMeta]=\"ques.Sub_Text__c\" [id]=\"ques.Id\" [selectedValue]=\"ques.input\" [placeholder]=\"'---Select---'\"\r\n [errorMessage]=\"ques.Error_Message__c\" [error]=\"ques.error\"\r\n (valueChange)=\"childEventCapture($event, ques); clearSQError(ques.Id)\">\r\n </app-custom-dropdown>\r\n <i class=\"fa fa-check \" aria-hidden=\"true\" *ngIf=\"ques?.input?.length > 0\"></i>\r\n </div>\r\n\r\n <!-- file Upload -->\r\n <div *ngIf=\"ques.Type__c === 'File'\" class=\"\">\r\n <app-file-upload [limitFileUploading]=\"5\" [allFiles]=\"selectedFileData\"\r\n (selectedFileData)=\"assignSelectedFileData($event)\" (deletedFileData)=\"deleteFile($event)\"\r\n [isDeleteFileButtonVisible]=\"true\"></app-file-upload>\r\n </div>\r\n </div>\r\n </div>\r\n</div>", styles: [".form-group.content-box{background:#ffffff;padding:40px;border:1px solid #e8e8e8;border-bottom-left-radius:5px;border-bottom-right-radius:5px}.form-row{display:flex;flex-wrap:wrap;margin-right:-5px;margin-left:-5px}.col-lg-6{width:100%}.shengel-myt-font3{padding:5px 15px 5px 2px;color:#9a9a9a;font-size:14px;font-weight:400}.myt-font7{display:flex;justify-content:flex-start}@media (min-width: 1200px){.col-lg-6{width:50%!important}}\n"], dependencies: [{ kind: "directive", type: i4.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i5.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: i5.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i5.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i5.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i6.PickLocationComponent, selector: "app-pick-location", inputs: ["address"], outputs: ["locationSelected"] }, { kind: "component", type: i7.CustomInputComponent, selector: "app-custom-input", inputs: ["value", "question", "disabled", "placeholder", "error", "fromShengel", "ngClassValue", "idValue", "focusEvent"], outputs: ["inputValue"] }, { kind: "component", type: i8.CustomTextAreaComponent, selector: "app-custom-text-area", inputs: ["value", "placeholder", "rows", "error"], outputs: ["textareaValueChange"] }, { kind: "component", type: i9.CustomTableComponent, selector: "app-custom-table", inputs: ["question"], outputs: ["valueChange"] }, { kind: "component", type: i10.CustomDatePickerComponent, selector: "app-custom-date-picker", inputs: ["date", "minDate", "maxDate"], outputs: ["dateChange"] }, { kind: "component", type: i11.CustomDropdownComponent, selector: "app-custom-dropdown", inputs: ["options", "placeholder", "apiMeta", "selectedValue", "progressBar", "id", "errorMessage", "error", "fromShengel"], outputs: ["valueChange"] }, { kind: "component", type: i12.FileUploadComponent, selector: "app-file-upload", inputs: ["allFiles", "limitFileUploading", "isDeleteFileButtonVisible", "isShowNoFileIcon"], outputs: ["selectedFileData", "deletedFileData"] }] });
|
|
54
63
|
}
|
|
55
64
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: QuestionbookComponent, decorators: [{
|
|
56
65
|
type: Component,
|
|
57
|
-
args: [{ selector: 'lib-questionbook', template: "<div [class]=\"qbItem.isShengel__c ? 'form-group content-box' : 'form-group'\">\r\n <div class=\"form-row\">\r\n <div [class]=\"qbItem.isShengel__c ? '' : 'myt-align3'\"\r\n [class]=\"qbItem.isShengel__c ? 'col-lg-' + ques.Size__c + ' paddingnone' : 'col-md-' + ques.Size__c + ' paddingnone'\"\r\n *ngFor=\"let ques of questions;let i = index\" [id]=\"ques.Id\">\r\n <!-- Sub Question Label -->\r\n <div [ngClass]=\"{ down2: qbItem?.Progress_Bar__c }\">\r\n <span [class]=\"qbItem.isShengel__c ? 'dis-flex shengel-myt-font3 myt-font7' : 'dis-flex myt-font3 myt-font7' \">{{ ques?.Question__c }}</span>\r\n </div>\r\n\r\n <!-- DateTime -->\r\n <div *ngIf=\"ques.Type__c === 'DateTime'\">\r\n <app-custom-date-picker [minDate]=\"ques.minDate\" [date]=\"ques.input\" (dateChange)=\"childEventCapture($event, ques)\">\r\n </app-custom-date-picker>\r\n </div>\r\n\r\n <!-- Text -->\r\n <div *ngIf=\"ques.Type__c === 'Text'\">\r\n <app-custom-input [fromShengel]=\"qbItem.isShengel__c\" [value]=\"ques.input\" [ngClassValue]=\"{\r\n 'dis-flex dt-line date-line bookText boxoutline myt-font1': qbItem.Progress_Bar__c,\r\n textBox: !qbItem.Progress_Bar__c\r\n }\" [question]=\"ques\" [idValue]=\"ques.Tracking_ID__c\" [focusEvent]=\"clearSQError(ques.Id)\"\r\n [error]=\"ques.error\" [placeholder]=\"ques.Question__c\" (inputValue)=\"childEventCapture($event, ques)\">\r\n </app-custom-input>\r\n </div>\r\n \r\n <!-- for pick location -->\r\n <div *ngIf=\"ques.Type__c === 'Location'\">\r\n <app-pick-location [address]=\"ques.input\" (locationSelected)=\"childEventCapture($event, ques)\">\r\n </app-pick-location>\r\n </div>\r\n\r\n <!-- for text area -->\r\n <div *ngIf=\"ques.Type__c === 'TextArea'\">\r\n <app-custom-text-area [value]=\"ques.input\" [rows]=\"3\" [error]=\"ques.error\" [placeholder]=\"ques.Question__c \"\r\n (textareaValueChange)=\"childEventCapture($event)\"></app-custom-text-area>\r\n </div>\r\n\r\n <!-- Email -->\r\n <div *ngIf=\"ques.Type__c === 'Email'\">\r\n <input type=\"email\" [(ngModel)]=\"ques.input\" [id]=\"ques.Id\" required=\"\" (focus)=\"clearSQError(ques.Id)\"\r\n style.border-color=\"{{ ques.error ? 'red' : '' }}\" placeholder=\"{{ ques.Question__c }}\" />\r\n </div>\r\n\r\n <!-- Table -->\r\n <div *ngIf=\"ques.Type__c === 'Table'\" class=\"\">\r\n <app-custom-table [question]=\"ques\" (valueChange)=\"childEventCapture($event, ques); clearSQError(ques.Id)\">\r\n </app-custom-table>\r\n </div>\r\n\r\n <!-- Dropdown -->\r\n <div *ngIf=\"ques.Type__c === 'Dropdown'\" class=\"\">\r\n <app-custom-dropdown [fromShengel]=\"qbItem.isShengel__c\" [options]=\"ques.Question_Options__r.records\"\r\n [apiMeta]=\"ques.Sub_Text__c\" [id]=\"ques.
|
|
66
|
+
args: [{ selector: 'lib-questionbook', template: "<div [class]=\"qbItem.isShengel__c ? 'form-group content-box' : 'form-group'\">\r\n <div class=\"form-row\">\r\n <div [class]=\"qbItem.isShengel__c ? '' : 'myt-align3'\"\r\n [class]=\"qbItem.isShengel__c ? 'col-lg-' + ques.Size__c + ' paddingnone' : 'col-md-' + ques.Size__c + ' paddingnone'\"\r\n *ngFor=\"let ques of questions;let i = index\" [id]=\"ques.Id\">\r\n <!-- Sub Question Label -->\r\n <div [ngClass]=\"{ down2: qbItem?.Progress_Bar__c }\">\r\n <span [class]=\"qbItem.isShengel__c ? 'dis-flex shengel-myt-font3 myt-font7' : 'dis-flex myt-font3 myt-font7' \">{{ ques?.Question__c }}</span>\r\n </div>\r\n\r\n <!-- DateTime -->\r\n <div *ngIf=\"ques.Type__c === 'DateTime'\">\r\n <app-custom-date-picker [minDate]=\"ques.minDate\" [date]=\"ques.input\" (dateChange)=\"childEventCapture($event, ques)\">\r\n </app-custom-date-picker>\r\n </div>\r\n\r\n <!-- Text -->\r\n <div *ngIf=\"ques.Type__c === 'Text'\">\r\n <app-custom-input [fromShengel]=\"qbItem.isShengel__c\" [value]=\"ques.input\" [ngClassValue]=\"{\r\n 'dis-flex dt-line date-line bookText boxoutline myt-font1': qbItem.Progress_Bar__c,\r\n textBox: !qbItem.Progress_Bar__c\r\n }\" [question]=\"ques\" [idValue]=\"ques.Tracking_ID__c\" [focusEvent]=\"clearSQError(ques.Id)\"\r\n [error]=\"ques.error\" [placeholder]=\"ques.Question__c\" (inputValue)=\"childEventCapture($event, ques)\">\r\n </app-custom-input>\r\n </div>\r\n \r\n <!-- for pick location -->\r\n <div *ngIf=\"ques.Type__c === 'Location'\">\r\n <app-pick-location [address]=\"ques.input\" (locationSelected)=\"childEventCapture($event, ques)\">\r\n </app-pick-location>\r\n </div>\r\n\r\n <!-- for text area -->\r\n <div *ngIf=\"ques.Type__c === 'TextArea'\">\r\n <app-custom-text-area [value]=\"ques.input\" [rows]=\"3\" [error]=\"ques.error\" [placeholder]=\"ques.Question__c \"\r\n (textareaValueChange)=\"childEventCapture($event)\"></app-custom-text-area>\r\n </div>\r\n\r\n <!-- Email -->\r\n <div *ngIf=\"ques.Type__c === 'Email'\">\r\n <input type=\"email\" [(ngModel)]=\"ques.input\" [id]=\"ques.Id\" required=\"\" (focus)=\"clearSQError(ques.Id)\"\r\n style.border-color=\"{{ ques.error ? 'red' : '' }}\" placeholder=\"{{ ques.Question__c }}\" />\r\n </div>\r\n\r\n <!-- Table -->\r\n <div *ngIf=\"ques.Type__c === 'Table'\" class=\"\">\r\n <app-custom-table [question]=\"ques\" (valueChange)=\"childEventCapture($event, ques); clearSQError(ques.Id)\">\r\n </app-custom-table>\r\n </div>\r\n\r\n <!-- Dropdown -->\r\n <div *ngIf=\"ques.Type__c === 'Dropdown'\" class=\"\">\r\n <app-custom-dropdown [fromShengel]=\"qbItem.isShengel__c\" [options]=\"ques.Question_Options__r.records\"\r\n [apiMeta]=\"ques.Sub_Text__c\" [id]=\"ques.Id\" [selectedValue]=\"ques.input\" [placeholder]=\"'---Select---'\"\r\n [errorMessage]=\"ques.Error_Message__c\" [error]=\"ques.error\"\r\n (valueChange)=\"childEventCapture($event, ques); clearSQError(ques.Id)\">\r\n </app-custom-dropdown>\r\n <i class=\"fa fa-check \" aria-hidden=\"true\" *ngIf=\"ques?.input?.length > 0\"></i>\r\n </div>\r\n\r\n <!-- file Upload -->\r\n <div *ngIf=\"ques.Type__c === 'File'\" class=\"\">\r\n <app-file-upload [limitFileUploading]=\"5\" [allFiles]=\"selectedFileData\"\r\n (selectedFileData)=\"assignSelectedFileData($event)\" (deletedFileData)=\"deleteFile($event)\"\r\n [isDeleteFileButtonVisible]=\"true\"></app-file-upload>\r\n </div>\r\n </div>\r\n </div>\r\n</div>", styles: [".form-group.content-box{background:#ffffff;padding:40px;border:1px solid #e8e8e8;border-bottom-left-radius:5px;border-bottom-right-radius:5px}.form-row{display:flex;flex-wrap:wrap;margin-right:-5px;margin-left:-5px}.col-lg-6{width:100%}.shengel-myt-font3{padding:5px 15px 5px 2px;color:#9a9a9a;font-size:14px;font-weight:400}.myt-font7{display:flex;justify-content:flex-start}@media (min-width: 1200px){.col-lg-6{width:50%!important}}\n"] }]
|
|
58
67
|
}], ctorParameters: function () { return [{ type: i1.SalesforceService }, { type: i2.DataService }, { type: i3.ChangeService }]; }, propDecorators: { qbItem: [{
|
|
59
68
|
type: Input
|
|
60
69
|
}], questionItem: [{
|
|
@@ -62,4 +71,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImpo
|
|
|
62
71
|
}], questions: [{
|
|
63
72
|
type: Input
|
|
64
73
|
}] } });
|
|
65
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"questionbook.component.js","sourceRoot":"","sources":["../../../../../../projects/nxt-app/src/lib/pages/questionbook/questionbook.component.ts","../../../../../../projects/nxt-app/src/lib/pages/questionbook/questionbook.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAU,KAAK,GAAyB,MAAM,eAAe,CAAC;;;;;;;;;;;;;AAWhF,MAAM,OAAO,qBAAqB;IAOZ;IACV;IACA;IARD,MAAM,CAAe;IACrB,YAAY,CAAW;IACvB,SAAS,CAAa;IAE/B,YAAY,CAAa;IAEzB,YAAoB,SAA4B,EACtC,WAAwB,EACxB,aAA4B;QAFlB,cAAS,GAAT,SAAS,CAAmB;QACtC,gBAAW,GAAX,WAAW,CAAa;QACxB,kBAAa,GAAb,aAAa,CAAe;IAEtC,CAAC;IAED,QAAQ;QACN,OAAO,CAAC,GAAG,CAAC,qCAAqC,CAAC,CAAC;QACnD,4BAA4B;QAC5B,+BAA+B;QAC/B,IAAI,CAAC,YAAY,GAAG,EAAE,CAAC;QACvB,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;IACvC,CAAC;IAED,YAAY,CAAC,MAAM;QACjB,4DAA4D;QAC5D,IAAI,MAAM,GAAG,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,EAAE,IAAI,MAAM,CAAC,CAAC;QACnE,KAAK,IAAI,EAAE,IAAI,MAAM,EAAE;YACrB,EAAE,CAAC,KAAK,GAAG,IAAI,CAAC;SACjB;IACH,CAAC;IAED,eAAe,CAAC,OAAO;QACrB,OAAO,CAAC,GAAG,CAAC,8CAA8C,CAAC,CAAC;QAC5D,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;IAClC,CAAC;IAED,kCAAkC;IAClC,iBAAiB,CAAC,KAAK,EAAE,IAAS;QAChC,OAAO,CAAC,GAAG,CAAC,gDAAgD,CAAC,CAAC;QAC9D,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;QACnB,IAAI,CAAC,aAAa,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC;QACzC,yEAAyE;IAC3E,CAAC;wGAxCU,qBAAqB;4FAArB,qBAAqB,4ICXlC,urHA6DM;;4FDlDO,qBAAqB;kBALjC,SAAS;+BACE,kBAAkB;8JAKnB,MAAM;sBAAd,KAAK;gBACG,YAAY;sBAApB,KAAK;gBACG,SAAS;sBAAjB,KAAK","sourcesContent":["import { Component, OnInit, Input, Output, EventEmitter, } from '@angular/core';\r\nimport { Question, QuestionBook } from '../../wrapper';\r\nimport { SalesforceService } from \"../../services/salesforce.service\";\r\nimport { DataService } from '../../services/data.service';\r\nimport { ChangeService } from '../../services/change.service';\r\n\r\n@Component({\r\n  selector: 'lib-questionbook',\r\n  templateUrl: './questionbook.component.html',\r\n  styleUrls: ['./questionbook.component.css']\r\n})\r\nexport class QuestionbookComponent implements OnInit {\r\n  @Input() qbItem: QuestionBook;\r\n  @Input() questionItem: Question;\r\n  @Input() questions: Question[];\r\n  \r\n  subQuestions: Question[];\r\n\r\n  constructor(private sfService: SalesforceService,\r\n    private dataService: DataService,\r\n    private changeService: ChangeService, ) { \r\n      \r\n  }\r\n\r\n  ngOnInit(): void {\r\n    console.log('inside QuestionBookComponent OnInit');\r\n    // console.log(this.qbItem);\r\n    // console.log(this.questions);\r\n    this.subQuestions = [];\r\n    this.setSubQuestions(this.questions);\r\n  }\r\n\r\n  clearSQError(quesId) {\r\n    // console.log('inside QuestionBookComponent clearSQError');\r\n    var sqList = this.subQuestions.filter((item) => item.Id == quesId);\r\n    for (var sq of sqList) {\r\n      sq.error = null;\r\n    }\r\n  }\r\n\r\n  setSubQuestions(records) {\r\n    console.log('inside QuestionbookComponent setSubQuestions');\r\n    this.subQuestions.push(records);\r\n  }\r\n\r\n  // Capture and Process Child Event\r\n  childEventCapture(event, ques?:any) {\r\n    console.log('inside QuestionbookComponent childEventCapture');\r\n    console.log(event);\r\n    this.changeService.announceChange(event);\r\n    //ques.input = event; // here when using the ng-select got event as value\r\n  }\r\n}\r\n","<div [class]=\"qbItem.isShengel__c ? 'form-group content-box' : 'form-group'\">\r\n    <div class=\"form-row\">\r\n        <div [class]=\"qbItem.isShengel__c ? '' : 'myt-align3'\"\r\n            [class]=\"qbItem.isShengel__c ? 'col-lg-' + ques.Size__c + ' paddingnone' : 'col-md-' + ques.Size__c + ' paddingnone'\"\r\n            *ngFor=\"let ques of questions;let i = index\" [id]=\"ques.Id\">\r\n            <!-- Sub Question Label -->\r\n            <div [ngClass]=\"{ down2: qbItem?.Progress_Bar__c }\">\r\n                <span [class]=\"qbItem.isShengel__c ? 'dis-flex shengel-myt-font3 myt-font7'  : 'dis-flex myt-font3 myt-font7' \">{{ ques?.Question__c }}</span>\r\n            </div>\r\n\r\n            <!-- DateTime -->\r\n            <div *ngIf=\"ques.Type__c === 'DateTime'\">\r\n                <app-custom-date-picker [minDate]=\"ques.minDate\" [date]=\"ques.input\" (dateChange)=\"childEventCapture($event, ques)\">\r\n                </app-custom-date-picker>\r\n            </div>\r\n\r\n            <!-- Text -->\r\n            <div *ngIf=\"ques.Type__c === 'Text'\">\r\n                <app-custom-input [fromShengel]=\"qbItem.isShengel__c\" [value]=\"ques.input\" [ngClassValue]=\"{\r\n                        'dis-flex dt-line date-line bookText boxoutline myt-font1': qbItem.Progress_Bar__c,\r\n                        textBox: !qbItem.Progress_Bar__c\r\n                    }\" [question]=\"ques\" [idValue]=\"ques.Tracking_ID__c\" [focusEvent]=\"clearSQError(ques.Id)\"\r\n                    [error]=\"ques.error\" [placeholder]=\"ques.Question__c\" (inputValue)=\"childEventCapture($event, ques)\">\r\n                </app-custom-input>\r\n            </div>\r\n            \r\n            <!-- for pick location -->\r\n            <div *ngIf=\"ques.Type__c === 'Location'\">\r\n                <app-pick-location [address]=\"ques.input\" (locationSelected)=\"childEventCapture($event, ques)\">\r\n                </app-pick-location>\r\n            </div>\r\n\r\n            <!-- for  text area   -->\r\n            <div *ngIf=\"ques.Type__c === 'TextArea'\">\r\n                <app-custom-text-area [value]=\"ques.input\" [rows]=\"3\" [error]=\"ques.error\" [placeholder]=\"ques.Question__c \"\r\n                    (textareaValueChange)=\"childEventCapture($event)\"></app-custom-text-area>\r\n            </div>\r\n\r\n            <!-- Email -->\r\n            <div *ngIf=\"ques.Type__c === 'Email'\">\r\n                <input type=\"email\" [(ngModel)]=\"ques.input\" [id]=\"ques.Id\" required=\"\" (focus)=\"clearSQError(ques.Id)\"\r\n                    style.border-color=\"{{ ques.error ? 'red' : '' }}\" placeholder=\"{{ ques.Question__c }}\" />\r\n            </div>\r\n\r\n            <!-- Table -->\r\n            <div *ngIf=\"ques.Type__c === 'Table'\" class=\"\">\r\n                <app-custom-table [question]=\"ques\" (valueChange)=\"childEventCapture($event, ques); clearSQError(ques.Id)\">\r\n                </app-custom-table>\r\n            </div>\r\n\r\n            <!-- Dropdown -->\r\n            <div *ngIf=\"ques.Type__c === 'Dropdown'\" class=\"\">\r\n                <app-custom-dropdown [fromShengel]=\"qbItem.isShengel__c\" [options]=\"ques.Question_Options__r.records\"\r\n                    [apiMeta]=\"ques.Sub_Text__c\" [id]=\"ques.Name\" [selectedValue]=\"ques.input\" [placeholder]=\"'---Select---'\"\r\n                    [errorMessage]=\"ques.Error_Message__c\" [error]=\"ques.error\"\r\n                    (valueChange)=\"childEventCapture($event, ques); clearSQError(ques.Id)\">\r\n                </app-custom-dropdown>\r\n                <i class=\"fa fa-check \" aria-hidden=\"true\" *ngIf=\"ques?.input?.length > 0\"></i>\r\n            </div>\r\n        </div>\r\n    </div>\r\n</div>"]}
|
|
74
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"questionbook.component.js","sourceRoot":"","sources":["../../../../../../projects/nxt-app/src/lib/pages/questionbook/questionbook.component.ts","../../../../../../projects/nxt-app/src/lib/pages/questionbook/questionbook.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAU,KAAK,GAAyB,MAAM,eAAe,CAAC;;;;;;;;;;;;;;AAWhF,MAAM,OAAO,qBAAqB;IAQZ;IACV;IACA;IATD,MAAM,CAAe;IACrB,YAAY,CAAW;IACvB,SAAS,CAAa;IAE/B,YAAY,CAAa;IACzB,gBAAgB,GAAU,EAAE,CAAC;IAE7B,YAAoB,SAA4B,EACtC,WAAwB,EACxB,aAA4B;QAFlB,cAAS,GAAT,SAAS,CAAmB;QACtC,gBAAW,GAAX,WAAW,CAAa;QACxB,kBAAa,GAAb,aAAa,CAAe;IAEtC,CAAC;IAED,QAAQ;QACN,OAAO,CAAC,GAAG,CAAC,qCAAqC,CAAC,CAAC;QACnD,4BAA4B;QAC5B,+BAA+B;QAC/B,IAAI,CAAC,YAAY,GAAG,EAAE,CAAC;QACvB,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;IACvC,CAAC;IAED,YAAY,CAAC,MAAM;QACjB,4DAA4D;QAC5D,IAAI,MAAM,GAAG,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,EAAE,IAAI,MAAM,CAAC,CAAC;QACnE,KAAK,IAAI,EAAE,IAAI,MAAM,EAAE;YACrB,EAAE,CAAC,KAAK,GAAG,IAAI,CAAC;SACjB;IACH,CAAC;IAED,eAAe,CAAC,OAAO;QACrB,OAAO,CAAC,GAAG,CAAC,8CAA8C,CAAC,CAAC;QAC5D,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;IAClC,CAAC;IAED,kCAAkC;IAClC,iBAAiB,CAAC,KAAK,EAAE,IAAS;QAChC,OAAO,CAAC,GAAG,CAAC,gDAAgD,CAAC,CAAC;QAC9D,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;QACnB,IAAI,CAAC,aAAa,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC;QACzC,yEAAyE;IAC3E,CAAC;IACD,sBAAsB,CAAC,QAAY;QACjC,OAAO,CAAC,GAAG,CAAC,UAAU,EAAC,QAAQ,CAAC,CAAC;QACjC,IAAI,CAAC,gBAAgB,GAAG,QAAQ,CAAC;IACnC,CAAC;IACD,UAAU,CAAC,QAAY;QACrB,OAAO,CAAC,GAAG,CAAC,UAAU,EAAC,QAAQ,CAAC,CAAA;IAClC,CAAC;wGAhDU,qBAAqB;4FAArB,qBAAqB,4ICXlC,ilIAoEM;;4FDzDO,qBAAqB;kBALjC,SAAS;+BACE,kBAAkB;8JAKnB,MAAM;sBAAd,KAAK;gBACG,YAAY;sBAApB,KAAK;gBACG,SAAS;sBAAjB,KAAK","sourcesContent":["import { Component, OnInit, Input, Output, EventEmitter, } from '@angular/core';\r\nimport { Question, QuestionBook } from '../../wrapper';\r\nimport { SalesforceService } from \"../../services/salesforce.service\";\r\nimport { DataService } from '../../services/data.service';\r\nimport { ChangeService } from '../../services/change.service';\r\n\r\n@Component({\r\n  selector: 'lib-questionbook',\r\n  templateUrl: './questionbook.component.html',\r\n  styleUrls: ['./questionbook.component.css']\r\n})\r\nexport class QuestionbookComponent implements OnInit {\r\n  @Input() qbItem: QuestionBook;\r\n  @Input() questionItem: Question;\r\n  @Input() questions: Question[];\r\n  \r\n  subQuestions: Question[];\r\n  selectedFileData: any[] = [];\r\n\r\n  constructor(private sfService: SalesforceService,\r\n    private dataService: DataService,\r\n    private changeService: ChangeService, ) { \r\n      \r\n  }\r\n\r\n  ngOnInit(): void {\r\n    console.log('inside QuestionBookComponent OnInit');\r\n    // console.log(this.qbItem);\r\n    // console.log(this.questions);\r\n    this.subQuestions = [];\r\n    this.setSubQuestions(this.questions);\r\n  }\r\n\r\n  clearSQError(quesId) {\r\n    // console.log('inside QuestionBookComponent clearSQError');\r\n    var sqList = this.subQuestions.filter((item) => item.Id == quesId);\r\n    for (var sq of sqList) {\r\n      sq.error = null;\r\n    }\r\n  }\r\n\r\n  setSubQuestions(records) {\r\n    console.log('inside QuestionbookComponent setSubQuestions');\r\n    this.subQuestions.push(records);\r\n  }\r\n\r\n  // Capture and Process Child Event\r\n  childEventCapture(event, ques?:any) {\r\n    console.log('inside QuestionbookComponent childEventCapture');\r\n    console.log(event);\r\n    this.changeService.announceChange(event);\r\n    //ques.input = event; // here when using the ng-select got event as value\r\n  }\r\n  assignSelectedFileData(fileData:any){\r\n    console.log('fileDATA',fileData);\r\n    this.selectedFileData = fileData;\r\n  }\r\n  deleteFile(fileData:any){\r\n    console.log('fileDATA',fileData)\r\n  }\r\n}\r\n","<div [class]=\"qbItem.isShengel__c ? 'form-group content-box' : 'form-group'\">\r\n    <div class=\"form-row\">\r\n        <div [class]=\"qbItem.isShengel__c ? '' : 'myt-align3'\"\r\n            [class]=\"qbItem.isShengel__c ? 'col-lg-' + ques.Size__c + ' paddingnone' : 'col-md-' + ques.Size__c + ' paddingnone'\"\r\n            *ngFor=\"let ques of questions;let i = index\" [id]=\"ques.Id\">\r\n            <!-- Sub Question Label -->\r\n            <div [ngClass]=\"{ down2: qbItem?.Progress_Bar__c }\">\r\n                <span [class]=\"qbItem.isShengel__c ? 'dis-flex shengel-myt-font3 myt-font7'  : 'dis-flex myt-font3 myt-font7' \">{{ ques?.Question__c }}</span>\r\n            </div>\r\n\r\n            <!-- DateTime -->\r\n            <div *ngIf=\"ques.Type__c === 'DateTime'\">\r\n                <app-custom-date-picker [minDate]=\"ques.minDate\" [date]=\"ques.input\" (dateChange)=\"childEventCapture($event, ques)\">\r\n                </app-custom-date-picker>\r\n            </div>\r\n\r\n            <!-- Text -->\r\n            <div *ngIf=\"ques.Type__c === 'Text'\">\r\n                <app-custom-input [fromShengel]=\"qbItem.isShengel__c\" [value]=\"ques.input\" [ngClassValue]=\"{\r\n                        'dis-flex dt-line date-line bookText boxoutline myt-font1': qbItem.Progress_Bar__c,\r\n                        textBox: !qbItem.Progress_Bar__c\r\n                    }\" [question]=\"ques\" [idValue]=\"ques.Tracking_ID__c\" [focusEvent]=\"clearSQError(ques.Id)\"\r\n                    [error]=\"ques.error\" [placeholder]=\"ques.Question__c\" (inputValue)=\"childEventCapture($event, ques)\">\r\n                </app-custom-input>\r\n            </div>\r\n            \r\n            <!-- for pick location -->\r\n            <div *ngIf=\"ques.Type__c === 'Location'\">\r\n                <app-pick-location [address]=\"ques.input\" (locationSelected)=\"childEventCapture($event, ques)\">\r\n                </app-pick-location>\r\n            </div>\r\n\r\n            <!-- for  text area   -->\r\n            <div *ngIf=\"ques.Type__c === 'TextArea'\">\r\n                <app-custom-text-area [value]=\"ques.input\" [rows]=\"3\" [error]=\"ques.error\" [placeholder]=\"ques.Question__c \"\r\n                    (textareaValueChange)=\"childEventCapture($event)\"></app-custom-text-area>\r\n            </div>\r\n\r\n            <!-- Email -->\r\n            <div *ngIf=\"ques.Type__c === 'Email'\">\r\n                <input type=\"email\" [(ngModel)]=\"ques.input\" [id]=\"ques.Id\" required=\"\" (focus)=\"clearSQError(ques.Id)\"\r\n                    style.border-color=\"{{ ques.error ? 'red' : '' }}\" placeholder=\"{{ ques.Question__c }}\" />\r\n            </div>\r\n\r\n            <!-- Table -->\r\n            <div *ngIf=\"ques.Type__c === 'Table'\" class=\"\">\r\n                <app-custom-table [question]=\"ques\" (valueChange)=\"childEventCapture($event, ques); clearSQError(ques.Id)\">\r\n                </app-custom-table>\r\n            </div>\r\n\r\n            <!-- Dropdown -->\r\n            <div *ngIf=\"ques.Type__c === 'Dropdown'\" class=\"\">\r\n                <app-custom-dropdown [fromShengel]=\"qbItem.isShengel__c\" [options]=\"ques.Question_Options__r.records\"\r\n                    [apiMeta]=\"ques.Sub_Text__c\" [id]=\"ques.Id\" [selectedValue]=\"ques.input\" [placeholder]=\"'---Select---'\"\r\n                    [errorMessage]=\"ques.Error_Message__c\" [error]=\"ques.error\"\r\n                    (valueChange)=\"childEventCapture($event, ques); clearSQError(ques.Id)\">\r\n                </app-custom-dropdown>\r\n                <i class=\"fa fa-check \" aria-hidden=\"true\" *ngIf=\"ques?.input?.length > 0\"></i>\r\n            </div>\r\n\r\n            <!-- file Upload -->\r\n            <div *ngIf=\"ques.Type__c === 'File'\" class=\"\">\r\n                <app-file-upload [limitFileUploading]=\"5\" [allFiles]=\"selectedFileData\"\r\n                (selectedFileData)=\"assignSelectedFileData($event)\" (deletedFileData)=\"deleteFile($event)\"\r\n                [isDeleteFileButtonVisible]=\"true\"></app-file-upload>\r\n            </div>\r\n        </div>\r\n    </div>\r\n</div>"]}
|