@rangertechnologies/ngnxt 2.0.42 → 2.0.43
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-date/custom-date.component.mjs +27 -0
- package/esm2022/lib/components/custom-dropdown/custom-dropdown.component.mjs +6 -3
- package/esm2022/lib/components/custom-label/custom-label.component.mjs +18 -0
- package/esm2022/lib/components/custom-table/custom-table.component.mjs +8 -4
- package/esm2022/lib/components/custom-time/custom-time.component.mjs +27 -0
- package/esm2022/lib/components/dependent-table/dependent-table.component.mjs +42 -0
- package/esm2022/lib/components/file-upload/file-upload.component.mjs +6 -3
- package/esm2022/lib/components/search-box/search-box.component.mjs +2 -2
- package/esm2022/lib/components/table-appendix/table-appendix.component.mjs +117 -0
- package/esm2022/lib/model/tableWrapper.mjs +5 -1
- package/esm2022/lib/nxt-app.module.mjs +18 -3
- package/esm2022/lib/pages/booklet/booklet.component.mjs +20 -8
- package/esm2022/lib/pages/questionbook/questionbook.component.mjs +26 -5
- package/esm2022/lib/pages/questionnaire/questionnaire.component.mjs +1 -1
- package/esm2022/lib/services/change.service.mjs +7 -1
- package/esm2022/lib/services/storage.service.mjs +2 -1
- package/fesm2022/rangertechnologies-ngnxt.mjs +298 -32
- package/fesm2022/rangertechnologies-ngnxt.mjs.map +1 -1
- package/lib/components/custom-date/custom-date.component.d.ts +12 -0
- package/lib/components/custom-dropdown/custom-dropdown.component.d.ts +2 -1
- package/lib/components/custom-label/custom-label.component.d.ts +9 -0
- package/lib/components/custom-table/custom-table.component.d.ts +2 -1
- package/lib/components/custom-time/custom-time.component.d.ts +12 -0
- package/lib/components/dependent-table/dependent-table.component.d.ts +15 -0
- package/lib/components/file-upload/file-upload.component.d.ts +2 -1
- package/lib/components/table-appendix/table-appendix.component.d.ts +28 -0
- package/lib/model/tableWrapper.d.ts +3 -0
- package/lib/nxt-app.module.d.ts +15 -10
- package/lib/pages/booklet/booklet.component.d.ts +5 -1
- package/lib/pages/questionbook/questionbook.component.d.ts +5 -2
- package/lib/services/change.service.d.ts +3 -0
- package/lib/services/storage.service.d.ts +1 -0
- package/package.json +1 -1
- package/rangertechnologies-ngnxt-2.0.43.tgz +0 -0
- package/rangertechnologies-ngnxt-2.0.42.tgz +0 -0
|
@@ -0,0 +1,117 @@
|
|
|
1
|
+
import { Component, EventEmitter, Input, Output } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
import * as i1 from "@angular/common";
|
|
4
|
+
import * as i2 from "@angular/forms";
|
|
5
|
+
import * as i3 from "../custom-dropdown/custom-dropdown.component";
|
|
6
|
+
import * as i4 from "../file-upload/file-upload.component";
|
|
7
|
+
export class TableAppendixComponent {
|
|
8
|
+
question;
|
|
9
|
+
valueChange = new EventEmitter();
|
|
10
|
+
tableInfo;
|
|
11
|
+
tableHeader;
|
|
12
|
+
tableData;
|
|
13
|
+
addRowColSpan;
|
|
14
|
+
tableAppendix;
|
|
15
|
+
dropDownApi;
|
|
16
|
+
dropDownData;
|
|
17
|
+
constructor() { }
|
|
18
|
+
ngOnInit() {
|
|
19
|
+
if (this.question.Sub_Text__c != undefined) {
|
|
20
|
+
this.tableInfo = JSON.parse(this.question.Sub_Text__c);
|
|
21
|
+
this.tableHeader = this.tableInfo.header;
|
|
22
|
+
this.tableData = this.tableInfo.data;
|
|
23
|
+
this.tableAppendix = this.tableInfo.tableAppendix;
|
|
24
|
+
this.dropDownApi = JSON.stringify(this.tableInfo['dropdownApi']);
|
|
25
|
+
this.dropDownData = this.tableInfo['dropdownData'];
|
|
26
|
+
const combinedData = {
|
|
27
|
+
tableData: this.tableData,
|
|
28
|
+
tableAppendix: null
|
|
29
|
+
};
|
|
30
|
+
if (this.tableAppendix) {
|
|
31
|
+
combinedData.tableAppendix = this.tableAppendix;
|
|
32
|
+
}
|
|
33
|
+
this.valueChange.emit(combinedData);
|
|
34
|
+
if (this.tableData?.addRow) {
|
|
35
|
+
this.addRowColSpan = this.tableHeader.length - 2;
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
addRow() {
|
|
40
|
+
let newItem = JSON.parse(JSON.stringify(this.tableInfo.newRowDefault));
|
|
41
|
+
const updatedTableData = [...this.tableData, newItem];
|
|
42
|
+
this.tableData = updatedTableData;
|
|
43
|
+
this.emitTableDataValue(updatedTableData, this.tableAppendix);
|
|
44
|
+
}
|
|
45
|
+
updateLabel(rowIndex, label, value) {
|
|
46
|
+
this.tableData[rowIndex][label] = value;
|
|
47
|
+
this.tableData[rowIndex].name = value.replace(/\s+/g, '').toLowerCase();
|
|
48
|
+
this.emitTableDataValue(this.tableData, this.tableAppendix);
|
|
49
|
+
}
|
|
50
|
+
updateNumber(item, label, value) {
|
|
51
|
+
item.value[label] = value;
|
|
52
|
+
this.emitTableDataValue(this.tableData, this.tableAppendix);
|
|
53
|
+
}
|
|
54
|
+
updateToggle(item, header, value) {
|
|
55
|
+
let label = header['fieldName'];
|
|
56
|
+
let toggleValue = header['toggleValue'];
|
|
57
|
+
if (label == 'test1') {
|
|
58
|
+
item.value[label][1] = value ? toggleValue[0] : toggleValue[1];
|
|
59
|
+
}
|
|
60
|
+
else {
|
|
61
|
+
item.value[label] = value ? toggleValue[0] : toggleValue[1];
|
|
62
|
+
}
|
|
63
|
+
this.emitTableDataValue(this.tableData, this.tableAppendix);
|
|
64
|
+
}
|
|
65
|
+
updateDropDown(item, label, value) {
|
|
66
|
+
item.value[label] = value.valueObj['Value__c'];
|
|
67
|
+
this.emitTableDataValue(this.tableData, this.tableAppendix);
|
|
68
|
+
}
|
|
69
|
+
updateCheckText(item, label, value) {
|
|
70
|
+
item.value[label][0] = value;
|
|
71
|
+
this.emitTableDataValue(this.tableData, this.tableAppendix);
|
|
72
|
+
}
|
|
73
|
+
updateTableAppendix(item, label, value) {
|
|
74
|
+
let toggleValue = item.value[0].toggleValue;
|
|
75
|
+
if (item.key == 'dropDownData') {
|
|
76
|
+
item.value[0].value[label] = value.valueObj['empIdName'];
|
|
77
|
+
}
|
|
78
|
+
else if (item.key == 'toggleData') {
|
|
79
|
+
item.value[0].value[label] = value ? toggleValue[0] : toggleValue[1];
|
|
80
|
+
}
|
|
81
|
+
else {
|
|
82
|
+
item.value[0].value[label] = value;
|
|
83
|
+
}
|
|
84
|
+
this.emitTableDataValue(this.tableData, this.tableAppendix);
|
|
85
|
+
}
|
|
86
|
+
emitTableDataValue(updatedTableData, tableAppendix) {
|
|
87
|
+
const combinedData = {
|
|
88
|
+
tableData: updatedTableData,
|
|
89
|
+
tableAppendix: null
|
|
90
|
+
};
|
|
91
|
+
if (tableAppendix) {
|
|
92
|
+
combinedData.tableAppendix = this.tableAppendix;
|
|
93
|
+
}
|
|
94
|
+
this.valueChange.emit(combinedData);
|
|
95
|
+
}
|
|
96
|
+
//This function finds the index of the current test in the list of test keys and returns the key of the previous test.
|
|
97
|
+
// If the current test is the first one, it returns null, as there is no previous test
|
|
98
|
+
getPreviousTestKey(item, currentTest) {
|
|
99
|
+
const testKeys = Object.keys(item.value);
|
|
100
|
+
const currentIndex = testKeys.indexOf(currentTest);
|
|
101
|
+
if (currentIndex > 0) {
|
|
102
|
+
return testKeys[currentIndex - 1];
|
|
103
|
+
}
|
|
104
|
+
return null;
|
|
105
|
+
}
|
|
106
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: TableAppendixComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
107
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: TableAppendixComponent, selector: "app-table-appendix", inputs: { question: "question" }, outputs: { valueChange: "valueChange" }, ngImport: i0, template: "<table class=\"table table-striped table-bordered\">\n <thead class=\"none-border\" *ngIf=\"tableInfo.tableType === 'lockout' && tableInfo.tableHeader\">\n <th></th>\n <th>{{ tableInfo.tableHeader }}</th>\n <th></th>\n </thead>\n <thead>\n <th *ngFor=\"let header of tableHeader; let hi = index\" [class]=\"'col-md-' + header.size\">\n {{ header.label }}\n </th>\n </thead>\n <tbody id=\"safetyMeasuresTableBody\">\n <tr *ngFor=\"let item of tableData; let i = index\">\n <td *ngFor=\"let header of tableHeader; let j = index\">\n <div *ngIf=\"header.type === 'text'\">\n <input type=\"text\" [(ngModel)]=\"item[header.fieldName]\" [placeholder]=\"header.placeholder\" (ngModelChange)=\"tableInfo.tableType != 'lockout' ? updateLabel(i, header.fieldName, item[header.fieldName]) : updateNumber(item, header.fieldName, item[header.fieldName])\" class=\"she-line-input table-input\">\n </div>\n <div *ngIf=\"header.type.includes('number')\">\n <input type=\"number\" [(ngModel)]=\"item.value[header.fieldName]\" [disabled]=\"item.value[getPreviousTestKey(item, header.fieldName)] === null && tableInfo.tableType != 'lockout'\" (ngModelChange)=\"updateNumber(item, header.fieldName, item.value[header.fieldName])\" placeholder=\"Enter Value\" class=\"she-line-input table-input\">\n </div>\n <div *ngIf=\"header.type === 'dropdown'\">\n <app-custom-dropdown [fromShengel]=\"true\" [options]=\"dropDownData\" \n [selectedValue]=\"item.value[header.fieldName]\" [placeholder]=\"header.placeholder\"\n (valueChange)=\"updateDropDown(item,header.fieldName,$event)\">\n </app-custom-dropdown>\n </div>\n <div *ngIf=\"header.type === 'textcheckbox'\">\n <div style=\"display: flex; justify-content: center;align-items: center;\">\n <input type=\"text\" [(ngModel)]=\"item.value[header.fieldName][0]\" (ngModelChange)=\"updateCheckText(item, header.fieldName, item.value[header.fieldName][0])\" style=\"width: 85px; height: 27px; text-align: center; padding: 5px; border-bottom: none; border-top: 1px solid transparent; border-right: 1px solid transparent; border-left: 1px solid transparent; background: transparent;outline: none;\">\n <label class=\"switch2\">\n <input class=\"switch-input2\" (change)=\"updateToggle(item,header,$event.target.checked)\" \n type=\"checkbox\"\n [checked]=\"item.value[header.fieldName][1] == header.toggleValue[0]\"/>\n <span class=\"switch-label2\" data-on=\"Psi\" data-off=\"Bar\"></span> \n <span class=\"switch-handle2\"></span> \n </label> \n </div>\n </div>\n <div *ngIf=\"header.type === 'labelcheckbox'\">\n <div style=\"display: flex; justify-content: center;align-items: center;\">\n <span style=\"text-align:left;\">Calibrated</span>\n <label class=\"switch2\">\n <input class=\"switch-input2\" (change)=\"updateToggle(item,header,$event.target.checked)\" \n type=\"checkbox\"\n [checked]=\"item.value[header.fieldName] == header.toggleValue[0]\"/>\n <span class=\"switch-label3\" data-on=\"Yes\" data-off=\"No\"></span> \n <span class=\"switch-handle2\"></span> \n </label> \n </div>\n </div>\n </td>\n </tr>\n <tr *ngIf=\"tableInfo.addRow && tableInfo.tableType === 'lockout'\">\n <td colspan=\"1\">\n <b style=\"text-align: center; cursor: pointer;\" id=\"addSafety\" (click)=\"addRow()\">Add More +</b>\n </td>\n </tr>\n <tr *ngIf=\"tableInfo.addRow && tableInfo.tableType != 'lockout'\">\n <td colspan=\"3\">\n <b>Add More</b>\n </td>\n <td colspan=\"2\" style=\"text-align: center; cursor: pointer;\" id=\"addSafety\" (click)=\"addRow()\">\n +\n </td>\n </tr>\n <tr *ngFor=\"let item of tableAppendix | keyvalue; let k = index\">\n <td *ngFor=\"let header of tableHeader; let l = index\">\n <div *ngIf=\"header.type === 'text'\" >\n <input type=\"text\" [(ngModel)]=\"item.value[0][header.fieldName]\" (ngModelChange)=\"updateLabel(k, header.fieldName, item[header.fieldName])\" class=\"she-line-input table-input\">\n </div>\n <div *ngIf=\"header.type.includes('dropdown') && item.key == 'dropDownData'\" >\n <app-custom-dropdown [fromShengel]=\"true\" [apiMeta]=\"dropDownApi\" \n [selectedValue]=\"item.value[0].value[header.fieldName]\" [placeholder]=\"'---Select---'\"\n (valueChange)=\"updateTableAppendix(item,header.fieldName,$event)\">\n </app-custom-dropdown>\n </div>\n <div *ngIf=\"header.type.includes('datetime') && item.key == 'dateData'\">\n <input [(ngModel)]=\"item.value[0].value[header.fieldName]\" type=\"datetime-local\"\n (ngModelChange)=\"updateTableAppendix(item,header.fieldName,$event)\"\n placeholder=\"DD/MM/YYYY HH:MM\">\n </div>\n <div *ngIf=\"header.type.includes('checkbox') && item.key == 'toggleData'\">\n <label class=\"switch2\">\n <input class=\"switch-input2\" (change)=\"updateTableAppendix(item,header.fieldName,$event.target.checked)\" \n type=\"checkbox\"\n [checked]=\"item.value[0].value[header.fieldName] == item.value[0].toggleValue[0]\"/>\n <span class=\"switch-label3\" data-on=\"Safe\" data-off=\"Unsafe\"></span> \n <span class=\"switch-handle2\"></span> \n </label> \n </div>\n <div *ngIf=\"header.type.includes('file') && item.key == 'fileData'\">\n <app-file-upload [limitFileUploading]=\"2\" [allFiles]=\"item.value[0].value[header.fieldName]\" [tableFile]=\"true\"\n (selectedFileData)=\"updateTableAppendix(item ,header.fieldName, $event)\"\n [isDeleteFileButtonVisible]=\"true\"></app-file-upload>\n </div>\n </td>\n </tr>\n </tbody>\n </table>", styles: [".table{width:100%;max-width:100%;margin-bottom:20px;border-collapse:collapse;border-spacing:0}.table-bordered{border:1px solid #ddd}thead{background-color:#03a9f4}thead th{color:#fff;font-size:14px}.table-bordered>tbody>tr>td,.table-bordered>tbody>tr>th,.table-bordered>tfoot>tr>td,.table-bordered>tfoot>tr>th,.table-bordered>thead>tr>td,.table-bordered>thead>tr>th{border:1px solid #ddd}th{text-align:left}thead .permission{text-align:center}.table>tbody>tr>td,.table>tbody>tr>th,.table>tfoot>tr>td,.table>tfoot>tr>th,.table>thead>tr>td,.table>thead>tr>th{padding:8px;line-height:1.42857143;vertical-align:top;border-top:1px solid #ddd}tbody{color:#797979}.table-striped>tbody>tr:nth-of-type(odd){background-color:#f9f9f9}tbody td{font-size:13px}.permission_yes,.permission_no,.permission_na{text-align:center}.none-border th{border:none}.switch2{position:relative;width:73px;height:23.5px;margin-left:5px;margin-top:3px;background:linear-gradient(to bottom,#eeeeee,#FFFFFF 25px);background-image:-webkit-linear-gradient(top,#eeeeee,#FFFFFF 25px);border-radius:5px;box-shadow:inset 0 -1px #fff,inset 0 1px 1px #0000000d;cursor:pointer}.switch-input2{position:absolute;top:0;left:0;opacity:0}.switch-label2{position:relative;display:block;height:inherit;font-size:12px;background:rgba(175,172,172,.5);color:#000;border-radius:inherit;box-shadow:inset 0 1px 2px #0000001f,inset 0 0 2px #00000026}.switch-label3{position:relative;display:block;height:inherit;font-size:12px;background:red;color:#fff;border-radius:inherit;box-shadow:inset 0 1px 2px #0000001f,inset 0 0 2px #00000026}.switch-label2:before,.switch-label2:after{position:absolute;top:50%;margin-top:-.5em;line-height:1;transition:inherit}.switch-label3:before,.switch-label2:after{position:absolute;top:50%;margin-top:-.5em;line-height:1;transition:inherit}.switch-label2:before{content:attr(data-off);right:11px;text-shadow:0 1px rgba(255,255,255,.5)}.switch-label3:before{content:attr(data-off);right:11px;text-shadow:0 1px rgba(255,255,255,.5)}.switch-label2:after{content:attr(data-on);left:11px;color:#fff;text-shadow:0 1px rgba(0,0,0,.2);opacity:0}.switch-label3:after{content:attr(data-on);left:11px;margin-left:10px;vertical-align:sub;color:#fff;text-shadow:0 1px rgba(0,0,0,.2);opacity:0}.switch-input2:checked~.switch-label2{background:#03a9f4;border-color:#03a9f4;box-shadow:inset 0 1px 2px #00000026,inset 0 0 3px #0003}.switch-input2:checked~.switch-label3{background:rgb(2,173,2);border-color:#02ad02;box-shadow:inset 0 1px 2px #00000026,inset 0 0 3px #0003}.switch-input2:checked~.switch-label2:before{opacity:0}.switch-input2:checked~.switch-label3:before{opacity:0}.switch-input2:checked~.switch-label2:after{opacity:1;margin-right:15px}.switch-input2:checked~.switch-label3:after{opacity:1;margin-right:15px}.switch-handle2{position:absolute;top:2px;left:2px;width:18px;height:18px;background:linear-gradient(to bottom,#FFFFFF 40%,#f0f0f0);background-image:-webkit-linear-gradient(top,#FFFFFF 40%,#f0f0f0);border-radius:20%;box-shadow:1px 1px 5px #0003}.switch-handle2:before{content:\"\";position:absolute;top:50%;left:50%;margin:-6px 0 0 -6px;width:12px;height:12px;background:linear-gradient(to bottom,#eeeeee,#FFFFFF);background-image:-webkit-linear-gradient(top,#eeeeee,#FFFFFF);border-radius:6px;box-shadow:inset 0 1px #00000005}.switch-input2:checked~.switch-handle2{left:51px;box-shadow:-1px 1px 5px #0003}.switch-label2,.switch-handle2,.switch-label3{transition:All .3s ease;-webkit-transition:All .3s ease;-moz-transition:All .3s ease;-o-transition:All .3s ease}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.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: i2.NumberValueAccessor, selector: "input[type=number][formControlName],input[type=number][formControl],input[type=number][ngModel]" }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i3.CustomDropdownComponent, selector: "app-custom-dropdown", inputs: ["options", "placeholder", "apiMeta", "selectedValue", "progressBar", "id", "errorMessage", "error", "fromShengel", "referenceField"], outputs: ["valueChange"] }, { kind: "component", type: i4.FileUploadComponent, selector: "app-file-upload", inputs: ["allFiles", "limitFileUploading", "isDeleteFileButtonVisible", "isShowNoFileIcon", "tableFile"], outputs: ["selectedFileData", "deletedFileData"] }, { kind: "pipe", type: i1.KeyValuePipe, name: "keyvalue" }] });
|
|
108
|
+
}
|
|
109
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: TableAppendixComponent, decorators: [{
|
|
110
|
+
type: Component,
|
|
111
|
+
args: [{ selector: 'app-table-appendix', template: "<table class=\"table table-striped table-bordered\">\n <thead class=\"none-border\" *ngIf=\"tableInfo.tableType === 'lockout' && tableInfo.tableHeader\">\n <th></th>\n <th>{{ tableInfo.tableHeader }}</th>\n <th></th>\n </thead>\n <thead>\n <th *ngFor=\"let header of tableHeader; let hi = index\" [class]=\"'col-md-' + header.size\">\n {{ header.label }}\n </th>\n </thead>\n <tbody id=\"safetyMeasuresTableBody\">\n <tr *ngFor=\"let item of tableData; let i = index\">\n <td *ngFor=\"let header of tableHeader; let j = index\">\n <div *ngIf=\"header.type === 'text'\">\n <input type=\"text\" [(ngModel)]=\"item[header.fieldName]\" [placeholder]=\"header.placeholder\" (ngModelChange)=\"tableInfo.tableType != 'lockout' ? updateLabel(i, header.fieldName, item[header.fieldName]) : updateNumber(item, header.fieldName, item[header.fieldName])\" class=\"she-line-input table-input\">\n </div>\n <div *ngIf=\"header.type.includes('number')\">\n <input type=\"number\" [(ngModel)]=\"item.value[header.fieldName]\" [disabled]=\"item.value[getPreviousTestKey(item, header.fieldName)] === null && tableInfo.tableType != 'lockout'\" (ngModelChange)=\"updateNumber(item, header.fieldName, item.value[header.fieldName])\" placeholder=\"Enter Value\" class=\"she-line-input table-input\">\n </div>\n <div *ngIf=\"header.type === 'dropdown'\">\n <app-custom-dropdown [fromShengel]=\"true\" [options]=\"dropDownData\" \n [selectedValue]=\"item.value[header.fieldName]\" [placeholder]=\"header.placeholder\"\n (valueChange)=\"updateDropDown(item,header.fieldName,$event)\">\n </app-custom-dropdown>\n </div>\n <div *ngIf=\"header.type === 'textcheckbox'\">\n <div style=\"display: flex; justify-content: center;align-items: center;\">\n <input type=\"text\" [(ngModel)]=\"item.value[header.fieldName][0]\" (ngModelChange)=\"updateCheckText(item, header.fieldName, item.value[header.fieldName][0])\" style=\"width: 85px; height: 27px; text-align: center; padding: 5px; border-bottom: none; border-top: 1px solid transparent; border-right: 1px solid transparent; border-left: 1px solid transparent; background: transparent;outline: none;\">\n <label class=\"switch2\">\n <input class=\"switch-input2\" (change)=\"updateToggle(item,header,$event.target.checked)\" \n type=\"checkbox\"\n [checked]=\"item.value[header.fieldName][1] == header.toggleValue[0]\"/>\n <span class=\"switch-label2\" data-on=\"Psi\" data-off=\"Bar\"></span> \n <span class=\"switch-handle2\"></span> \n </label> \n </div>\n </div>\n <div *ngIf=\"header.type === 'labelcheckbox'\">\n <div style=\"display: flex; justify-content: center;align-items: center;\">\n <span style=\"text-align:left;\">Calibrated</span>\n <label class=\"switch2\">\n <input class=\"switch-input2\" (change)=\"updateToggle(item,header,$event.target.checked)\" \n type=\"checkbox\"\n [checked]=\"item.value[header.fieldName] == header.toggleValue[0]\"/>\n <span class=\"switch-label3\" data-on=\"Yes\" data-off=\"No\"></span> \n <span class=\"switch-handle2\"></span> \n </label> \n </div>\n </div>\n </td>\n </tr>\n <tr *ngIf=\"tableInfo.addRow && tableInfo.tableType === 'lockout'\">\n <td colspan=\"1\">\n <b style=\"text-align: center; cursor: pointer;\" id=\"addSafety\" (click)=\"addRow()\">Add More +</b>\n </td>\n </tr>\n <tr *ngIf=\"tableInfo.addRow && tableInfo.tableType != 'lockout'\">\n <td colspan=\"3\">\n <b>Add More</b>\n </td>\n <td colspan=\"2\" style=\"text-align: center; cursor: pointer;\" id=\"addSafety\" (click)=\"addRow()\">\n +\n </td>\n </tr>\n <tr *ngFor=\"let item of tableAppendix | keyvalue; let k = index\">\n <td *ngFor=\"let header of tableHeader; let l = index\">\n <div *ngIf=\"header.type === 'text'\" >\n <input type=\"text\" [(ngModel)]=\"item.value[0][header.fieldName]\" (ngModelChange)=\"updateLabel(k, header.fieldName, item[header.fieldName])\" class=\"she-line-input table-input\">\n </div>\n <div *ngIf=\"header.type.includes('dropdown') && item.key == 'dropDownData'\" >\n <app-custom-dropdown [fromShengel]=\"true\" [apiMeta]=\"dropDownApi\" \n [selectedValue]=\"item.value[0].value[header.fieldName]\" [placeholder]=\"'---Select---'\"\n (valueChange)=\"updateTableAppendix(item,header.fieldName,$event)\">\n </app-custom-dropdown>\n </div>\n <div *ngIf=\"header.type.includes('datetime') && item.key == 'dateData'\">\n <input [(ngModel)]=\"item.value[0].value[header.fieldName]\" type=\"datetime-local\"\n (ngModelChange)=\"updateTableAppendix(item,header.fieldName,$event)\"\n placeholder=\"DD/MM/YYYY HH:MM\">\n </div>\n <div *ngIf=\"header.type.includes('checkbox') && item.key == 'toggleData'\">\n <label class=\"switch2\">\n <input class=\"switch-input2\" (change)=\"updateTableAppendix(item,header.fieldName,$event.target.checked)\" \n type=\"checkbox\"\n [checked]=\"item.value[0].value[header.fieldName] == item.value[0].toggleValue[0]\"/>\n <span class=\"switch-label3\" data-on=\"Safe\" data-off=\"Unsafe\"></span> \n <span class=\"switch-handle2\"></span> \n </label> \n </div>\n <div *ngIf=\"header.type.includes('file') && item.key == 'fileData'\">\n <app-file-upload [limitFileUploading]=\"2\" [allFiles]=\"item.value[0].value[header.fieldName]\" [tableFile]=\"true\"\n (selectedFileData)=\"updateTableAppendix(item ,header.fieldName, $event)\"\n [isDeleteFileButtonVisible]=\"true\"></app-file-upload>\n </div>\n </td>\n </tr>\n </tbody>\n </table>", styles: [".table{width:100%;max-width:100%;margin-bottom:20px;border-collapse:collapse;border-spacing:0}.table-bordered{border:1px solid #ddd}thead{background-color:#03a9f4}thead th{color:#fff;font-size:14px}.table-bordered>tbody>tr>td,.table-bordered>tbody>tr>th,.table-bordered>tfoot>tr>td,.table-bordered>tfoot>tr>th,.table-bordered>thead>tr>td,.table-bordered>thead>tr>th{border:1px solid #ddd}th{text-align:left}thead .permission{text-align:center}.table>tbody>tr>td,.table>tbody>tr>th,.table>tfoot>tr>td,.table>tfoot>tr>th,.table>thead>tr>td,.table>thead>tr>th{padding:8px;line-height:1.42857143;vertical-align:top;border-top:1px solid #ddd}tbody{color:#797979}.table-striped>tbody>tr:nth-of-type(odd){background-color:#f9f9f9}tbody td{font-size:13px}.permission_yes,.permission_no,.permission_na{text-align:center}.none-border th{border:none}.switch2{position:relative;width:73px;height:23.5px;margin-left:5px;margin-top:3px;background:linear-gradient(to bottom,#eeeeee,#FFFFFF 25px);background-image:-webkit-linear-gradient(top,#eeeeee,#FFFFFF 25px);border-radius:5px;box-shadow:inset 0 -1px #fff,inset 0 1px 1px #0000000d;cursor:pointer}.switch-input2{position:absolute;top:0;left:0;opacity:0}.switch-label2{position:relative;display:block;height:inherit;font-size:12px;background:rgba(175,172,172,.5);color:#000;border-radius:inherit;box-shadow:inset 0 1px 2px #0000001f,inset 0 0 2px #00000026}.switch-label3{position:relative;display:block;height:inherit;font-size:12px;background:red;color:#fff;border-radius:inherit;box-shadow:inset 0 1px 2px #0000001f,inset 0 0 2px #00000026}.switch-label2:before,.switch-label2:after{position:absolute;top:50%;margin-top:-.5em;line-height:1;transition:inherit}.switch-label3:before,.switch-label2:after{position:absolute;top:50%;margin-top:-.5em;line-height:1;transition:inherit}.switch-label2:before{content:attr(data-off);right:11px;text-shadow:0 1px rgba(255,255,255,.5)}.switch-label3:before{content:attr(data-off);right:11px;text-shadow:0 1px rgba(255,255,255,.5)}.switch-label2:after{content:attr(data-on);left:11px;color:#fff;text-shadow:0 1px rgba(0,0,0,.2);opacity:0}.switch-label3:after{content:attr(data-on);left:11px;margin-left:10px;vertical-align:sub;color:#fff;text-shadow:0 1px rgba(0,0,0,.2);opacity:0}.switch-input2:checked~.switch-label2{background:#03a9f4;border-color:#03a9f4;box-shadow:inset 0 1px 2px #00000026,inset 0 0 3px #0003}.switch-input2:checked~.switch-label3{background:rgb(2,173,2);border-color:#02ad02;box-shadow:inset 0 1px 2px #00000026,inset 0 0 3px #0003}.switch-input2:checked~.switch-label2:before{opacity:0}.switch-input2:checked~.switch-label3:before{opacity:0}.switch-input2:checked~.switch-label2:after{opacity:1;margin-right:15px}.switch-input2:checked~.switch-label3:after{opacity:1;margin-right:15px}.switch-handle2{position:absolute;top:2px;left:2px;width:18px;height:18px;background:linear-gradient(to bottom,#FFFFFF 40%,#f0f0f0);background-image:-webkit-linear-gradient(top,#FFFFFF 40%,#f0f0f0);border-radius:20%;box-shadow:1px 1px 5px #0003}.switch-handle2:before{content:\"\";position:absolute;top:50%;left:50%;margin:-6px 0 0 -6px;width:12px;height:12px;background:linear-gradient(to bottom,#eeeeee,#FFFFFF);background-image:-webkit-linear-gradient(top,#eeeeee,#FFFFFF);border-radius:6px;box-shadow:inset 0 1px #00000005}.switch-input2:checked~.switch-handle2{left:51px;box-shadow:-1px 1px 5px #0003}.switch-label2,.switch-handle2,.switch-label3{transition:All .3s ease;-webkit-transition:All .3s ease;-moz-transition:All .3s ease;-o-transition:All .3s ease}\n"] }]
|
|
112
|
+
}], ctorParameters: function () { return []; }, propDecorators: { question: [{
|
|
113
|
+
type: Input
|
|
114
|
+
}], valueChange: [{
|
|
115
|
+
type: Output
|
|
116
|
+
}] } });
|
|
117
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-appendix.component.js","sourceRoot":"","sources":["../../../../../../projects/nxt-app/src/lib/components/table-appendix/table-appendix.component.ts","../../../../../../projects/nxt-app/src/lib/components/table-appendix/table-appendix.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,KAAK,EAAU,MAAM,EAAE,MAAM,eAAe,CAAC;;;;;;AAS/E,MAAM,OAAO,sBAAsB;IACxB,QAAQ,CAAU;IACjB,WAAW,GAAsB,IAAI,YAAY,EAAO,CAAC;IAEnE,SAAS,CAAe;IACxB,WAAW,CAAM;IACjB,SAAS,CAAM;IACf,aAAa,CAAS;IACtB,aAAa,CAAK;IAClB,WAAW,CAAM;IACjB,YAAY,CAAK;IAEjB,gBAAgB,CAAC;IAEjB,QAAQ;QACN,IAAG,IAAI,CAAC,QAAQ,CAAC,WAAW,IAAI,SAAS,EAAE;YACzC,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,CAAC;YAEvD,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC;YACzC,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC;YACrC,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC;YAClD,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,CAAC,CAAC;YACjE,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,SAAS,CAAC,cAAc,CAAC,CAAC;YACnD,MAAM,YAAY,GAAG;gBACnB,SAAS,EAAE,IAAI,CAAC,SAAS;gBACzB,aAAa,EAAE,IAAI;aACpB,CAAC;YACF,IAAI,IAAI,CAAC,aAAa,EAAE;gBACtB,YAAY,CAAC,aAAa,GAAG,IAAI,CAAC,aAAa,CAAC;aACjD;YACD,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;YAEpC,IAAG,IAAI,CAAC,SAAS,EAAE,MAAM,EAAE;gBACzB,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,WAAW,CAAC,MAAM,GAAG,CAAC,CAAC;aAClD;SACF;IACH,CAAC;IAED,MAAM;QACJ,IAAI,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,CAAC,CAAC;QACvE,MAAM,gBAAgB,GAAG,CAAC,GAAG,IAAI,CAAC,SAAS,EAAE,OAAO,CAAC,CAAC;QACtD,IAAI,CAAC,SAAS,GAAG,gBAAgB,CAAC;QAClC,IAAI,CAAC,kBAAkB,CAAC,gBAAgB,EAAC,IAAI,CAAC,aAAa,CAAC,CAAC;IAC/D,CAAC;IAED,WAAW,CAAC,QAAgB,EAAE,KAAa,EAAE,KAAa;QACxD,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC,KAAK,CAAC,GAAG,KAAK,CAAC;QACxC,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC,IAAI,GAAG,KAAK,CAAC,OAAO,CAAC,MAAM,EAAE,EAAE,CAAC,CAAC,WAAW,EAAE,CAAC;QACxE,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,SAAS,EAAC,IAAI,CAAC,aAAa,CAAC,CAAC;IAC7D,CAAC;IAED,YAAY,CAAC,IAAS,EAAE,KAAa,EAAE,KAAa;QAClD,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,GAAG,KAAK,CAAC;QAC1B,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,SAAS,EAAC,IAAI,CAAC,aAAa,CAAC,CAAC;IAC7D,CAAC;IAED,YAAY,CAAC,IAAS,EAAE,MAAc,EAAE,KAAU;QAChD,IAAI,KAAK,GAAG,MAAM,CAAC,WAAW,CAAC,CAAC;QAChC,IAAI,WAAW,GAAG,MAAM,CAAC,aAAa,CAAC,CAAC;QACxC,IAAG,KAAK,IAAI,OAAO,EAAC;YAClB,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC;SAChE;aAAI;YACH,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC;SAC7D;QACD,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,SAAS,EAAC,IAAI,CAAC,aAAa,CAAC,CAAC;IAC7D,CAAC;IACD,cAAc,CAAC,IAAS,EAAE,KAAa,EAAE,KAAU;QACjD,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,GAAG,KAAK,CAAC,QAAQ,CAAC,UAAU,CAAC,CAAC;QAC/C,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,SAAS,EAAC,IAAI,CAAC,aAAa,CAAC,CAAC;IAC7D,CAAC;IAED,eAAe,CAAC,IAAS,EAAE,KAAa,EAAE,KAAU;QAClD,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC;QAC7B,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,SAAS,EAAC,IAAI,CAAC,aAAa,CAAC,CAAC;IAC7D,CAAC;IAED,mBAAmB,CAAC,IAAS,EAAE,KAAa,EAAE,KAAU;QACtD,IAAI,WAAW,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,WAAW,CAAC;QAC5C,IAAG,IAAI,CAAC,GAAG,IAAI,cAAc,EAAC;YAC5B,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC,GAAG,KAAK,CAAC,QAAQ,CAAC,WAAW,CAAC,CAAC;SAC1D;aAAK,IAAG,IAAI,CAAC,GAAG,IAAI,YAAY,EAAC;YAChC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC;SACtE;aAAI;YACH,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC,GAAG,KAAK,CAAC;SACpC;QACD,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,SAAS,EAAC,IAAI,CAAC,aAAa,CAAC,CAAC;IAC7D,CAAC;IAED,kBAAkB,CAAC,gBAAuB,EAAC,aAAiB;QAC1D,MAAM,YAAY,GAAG;YACnB,SAAS,EAAE,gBAAgB;YAC3B,aAAa,EAAE,IAAI;SACpB,CAAC;QACF,IAAG,aAAa,EAAC;YACf,YAAY,CAAC,aAAa,GAAG,IAAI,CAAC,aAAa,CAAC;SACjD;QACD,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;IACtC,CAAC;IAED,uHAAuH;IACvH,sFAAsF;IACtF,kBAAkB,CAAC,IAAS,EAAE,WAAmB;QAC/C,MAAM,QAAQ,GAAG,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QACzC,MAAM,YAAY,GAAG,QAAQ,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC;QAEnD,IAAI,YAAY,GAAG,CAAC,EAAE;YACpB,OAAO,QAAQ,CAAC,YAAY,GAAG,CAAC,CAAC,CAAC;SACnC;QAED,OAAO,IAAI,CAAC;IACd,CAAC;wGA9GU,sBAAsB;4FAAtB,sBAAsB,qICTnC,2nMAkGU;;4FDzFG,sBAAsB;kBALlC,SAAS;+BACE,oBAAoB;0EAKrB,QAAQ;sBAAhB,KAAK;gBACI,WAAW;sBAApB,MAAM","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\nimport { TableWrapper } from '../../model/tableWrapper';\nimport { Question } from '../../wrapper';\n\n@Component({\n  selector: 'app-table-appendix',\n  templateUrl: './table-appendix.component.html',\n  styleUrls: ['./table-appendix.component.css']\n})\nexport class TableAppendixComponent implements OnInit {\n  @Input() question: Question\n  @Output() valueChange: EventEmitter<any> = new EventEmitter<any>();\n\n  tableInfo: TableWrapper;\n  tableHeader: any;\n  tableData: any;\n  addRowColSpan: number;\n  tableAppendix:any;\n  dropDownApi :any;\n  dropDownData:any;\n\n  constructor() { }\n\n  ngOnInit(): void {\n    if(this.question.Sub_Text__c != undefined) {\n      this.tableInfo = JSON.parse(this.question.Sub_Text__c);\n\n      this.tableHeader = this.tableInfo.header;\n      this.tableData = this.tableInfo.data;\n      this.tableAppendix = this.tableInfo.tableAppendix;\n      this.dropDownApi = JSON.stringify(this.tableInfo['dropdownApi']);\n      this.dropDownData = this.tableInfo['dropdownData'];\n      const combinedData = {\n        tableData: this.tableData,\n        tableAppendix: null\n      };\n      if (this.tableAppendix) {\n        combinedData.tableAppendix = this.tableAppendix;\n      }\n      this.valueChange.emit(combinedData);\n\n      if(this.tableData?.addRow) {\n        this.addRowColSpan = this.tableHeader.length - 2;\n      }\n    }\n  }\n\n  addRow(): void {\n    let newItem = JSON.parse(JSON.stringify(this.tableInfo.newRowDefault));\n    const updatedTableData = [...this.tableData, newItem];\n    this.tableData = updatedTableData;\n    this.emitTableDataValue(updatedTableData,this.tableAppendix);\n  }\n\n  updateLabel(rowIndex: number, label: string, value: string): void {\n    this.tableData[rowIndex][label] = value;\n    this.tableData[rowIndex].name = value.replace(/\\s+/g, '').toLowerCase();\n    this.emitTableDataValue(this.tableData,this.tableAppendix);\n  }\n  \n  updateNumber(item: any, label: string, value: string){\n    item.value[label] = value;\n    this.emitTableDataValue(this.tableData,this.tableAppendix);\n  }\n\n  updateToggle(item: any, header: string, value: any){\n    let label = header['fieldName'];\n    let toggleValue = header['toggleValue'];\n    if(label == 'test1'){\n      item.value[label][1] = value ? toggleValue[0] : toggleValue[1];\n    }else{\n      item.value[label] = value ? toggleValue[0] : toggleValue[1];\n    }\n    this.emitTableDataValue(this.tableData,this.tableAppendix);\n  }\n  updateDropDown(item: any, label: string, value: any){\n    item.value[label] = value.valueObj['Value__c'];\n    this.emitTableDataValue(this.tableData,this.tableAppendix);\n  }\n\n  updateCheckText(item: any, label: string, value: any){\n    item.value[label][0] = value;\n    this.emitTableDataValue(this.tableData,this.tableAppendix);\n  }\n\n  updateTableAppendix(item: any, label: string, value: any){\n    let toggleValue = item.value[0].toggleValue;\n    if(item.key == 'dropDownData'){\n      item.value[0].value[label] = value.valueObj['empIdName'];\n    }else if(item.key == 'toggleData'){\n      item.value[0].value[label] = value ? toggleValue[0] : toggleValue[1];\n    }else{\n      item.value[0].value[label] = value;\n    }\n    this.emitTableDataValue(this.tableData,this.tableAppendix);\n  }\n\n  emitTableDataValue(updatedTableData: any[],tableAppendix:any): void {\n    const combinedData = {\n      tableData: updatedTableData,\n      tableAppendix: null\n    };\n    if(tableAppendix){\n      combinedData.tableAppendix = this.tableAppendix;\n    }\n    this.valueChange.emit(combinedData);\n  }\n\n  //This function finds the index of the current test in the list of test keys and returns the key of the previous test. \n  // If the current test is the first one, it returns null, as there is no previous test\n  getPreviousTestKey(item: any, currentTest: string): string {\n    const testKeys = Object.keys(item.value);\n    const currentIndex = testKeys.indexOf(currentTest);\n  \n    if (currentIndex > 0) {\n      return testKeys[currentIndex - 1];\n    }\n\n    return null;\n  }\n\n}\n","<table class=\"table table-striped table-bordered\">\n    <thead class=\"none-border\" *ngIf=\"tableInfo.tableType === 'lockout' && tableInfo.tableHeader\">\n      <th></th>\n      <th>{{ tableInfo.tableHeader }}</th>\n      <th></th>\n    </thead>\n    <thead>\n      <th *ngFor=\"let header of tableHeader; let hi = index\" [class]=\"'col-md-' + header.size\">\n        {{ header.label }}\n      </th>\n    </thead>\n    <tbody id=\"safetyMeasuresTableBody\">\n      <tr *ngFor=\"let item of tableData; let i = index\">\n        <td *ngFor=\"let header of tableHeader; let j = index\">\n          <div *ngIf=\"header.type === 'text'\">\n            <input type=\"text\" [(ngModel)]=\"item[header.fieldName]\" [placeholder]=\"header.placeholder\" (ngModelChange)=\"tableInfo.tableType != 'lockout' ? updateLabel(i, header.fieldName, item[header.fieldName]) : updateNumber(item, header.fieldName, item[header.fieldName])\" class=\"she-line-input table-input\">\n          </div>\n          <div *ngIf=\"header.type.includes('number')\">\n            <input type=\"number\" [(ngModel)]=\"item.value[header.fieldName]\" [disabled]=\"item.value[getPreviousTestKey(item, header.fieldName)] === null && tableInfo.tableType != 'lockout'\" (ngModelChange)=\"updateNumber(item, header.fieldName, item.value[header.fieldName])\" placeholder=\"Enter Value\" class=\"she-line-input table-input\">\n          </div>\n          <div *ngIf=\"header.type === 'dropdown'\">\n            <app-custom-dropdown [fromShengel]=\"true\" [options]=\"dropDownData\" \n            [selectedValue]=\"item.value[header.fieldName]\" [placeholder]=\"header.placeholder\"\n            (valueChange)=\"updateDropDown(item,header.fieldName,$event)\">\n            </app-custom-dropdown>\n          </div>\n          <div *ngIf=\"header.type === 'textcheckbox'\">\n            <div style=\"display: flex; justify-content: center;align-items: center;\">\n              <input type=\"text\" [(ngModel)]=\"item.value[header.fieldName][0]\" (ngModelChange)=\"updateCheckText(item, header.fieldName, item.value[header.fieldName][0])\"  style=\"width: 85px; height: 27px; text-align: center; padding: 5px; border-bottom: none; border-top: 1px solid transparent; border-right: 1px solid transparent; border-left: 1px solid transparent; background: transparent;outline: none;\">\n              <label class=\"switch2\">\n                <input  class=\"switch-input2\" (change)=\"updateToggle(item,header,$event.target.checked)\" \n                type=\"checkbox\"\n                [checked]=\"item.value[header.fieldName][1] == header.toggleValue[0]\"/>\n                <span class=\"switch-label2\" data-on=\"Psi\" data-off=\"Bar\"></span> \n                <span class=\"switch-handle2\"></span> \n              </label> \n            </div>\n          </div>\n          <div *ngIf=\"header.type === 'labelcheckbox'\">\n            <div style=\"display: flex; justify-content: center;align-items: center;\">\n              <span style=\"text-align:left;\">Calibrated</span>\n              <label class=\"switch2\">\n                <input  class=\"switch-input2\" (change)=\"updateToggle(item,header,$event.target.checked)\" \n                type=\"checkbox\"\n                [checked]=\"item.value[header.fieldName] == header.toggleValue[0]\"/>\n                <span class=\"switch-label3\" data-on=\"Yes\" data-off=\"No\"></span> \n                <span class=\"switch-handle2\"></span> \n              </label> \n            </div>\n          </div>\n        </td>\n      </tr>\n      <tr *ngIf=\"tableInfo.addRow && tableInfo.tableType === 'lockout'\">\n        <td colspan=\"1\">\n          <b style=\"text-align: center; cursor: pointer;\" id=\"addSafety\"  (click)=\"addRow()\">Add More +</b>\n        </td>\n      </tr>\n      <tr *ngIf=\"tableInfo.addRow && tableInfo.tableType != 'lockout'\">\n        <td colspan=\"3\">\n          <b>Add More</b>\n        </td>\n        <td colspan=\"2\" style=\"text-align: center; cursor: pointer;\" id=\"addSafety\"  (click)=\"addRow()\">\n          +\n        </td>\n      </tr>\n      <tr  *ngFor=\"let item of tableAppendix | keyvalue; let k = index\">\n        <td *ngFor=\"let header of tableHeader; let l = index\">\n          <div *ngIf=\"header.type === 'text'\" >\n            <input type=\"text\" [(ngModel)]=\"item.value[0][header.fieldName]\" (ngModelChange)=\"updateLabel(k, header.fieldName, item[header.fieldName])\" class=\"she-line-input table-input\">\n          </div>\n          <div *ngIf=\"header.type.includes('dropdown') && item.key == 'dropDownData'\" >\n            <app-custom-dropdown [fromShengel]=\"true\" [apiMeta]=\"dropDownApi\" \n            [selectedValue]=\"item.value[0].value[header.fieldName]\" [placeholder]=\"'---Select---'\"\n            (valueChange)=\"updateTableAppendix(item,header.fieldName,$event)\">\n            </app-custom-dropdown>\n          </div>\n          <div *ngIf=\"header.type.includes('datetime') && item.key == 'dateData'\">\n            <input [(ngModel)]=\"item.value[0].value[header.fieldName]\" type=\"datetime-local\"\n            (ngModelChange)=\"updateTableAppendix(item,header.fieldName,$event)\"\n            placeholder=\"DD/MM/YYYY HH:MM\">\n          </div>\n          <div *ngIf=\"header.type.includes('checkbox') && item.key == 'toggleData'\">\n            <label class=\"switch2\">\n              <input  class=\"switch-input2\" (change)=\"updateTableAppendix(item,header.fieldName,$event.target.checked)\" \n              type=\"checkbox\"\n              [checked]=\"item.value[0].value[header.fieldName] == item.value[0].toggleValue[0]\"/>\n              <span class=\"switch-label3\" data-on=\"Safe\" data-off=\"Unsafe\"></span> \n              <span class=\"switch-handle2\"></span> \n            </label> \n          </div>\n          <div *ngIf=\"header.type.includes('file') && item.key == 'fileData'\">\n            <app-file-upload [limitFileUploading]=\"2\" [allFiles]=\"item.value[0].value[header.fieldName]\" [tableFile]=\"true\"\n            (selectedFileData)=\"updateTableAppendix(item ,header.fieldName, $event)\"\n            [isDeleteFileButtonVisible]=\"true\"></app-file-upload>\n          </div>\n        </td>\n      </tr>\n    </tbody>\n  </table>"]}
|
|
@@ -8,9 +8,13 @@ export class TableHeader {
|
|
|
8
8
|
export class TableWrapper {
|
|
9
9
|
header;
|
|
10
10
|
data;
|
|
11
|
+
tableAppendix;
|
|
12
|
+
// dropDownData:any[];
|
|
11
13
|
keyValueField;
|
|
12
14
|
rowFunction;
|
|
13
15
|
addRow;
|
|
14
16
|
newRowDefault;
|
|
17
|
+
tableType;
|
|
18
|
+
tableHeader;
|
|
15
19
|
}
|
|
16
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
20
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGVXcmFwcGVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbnh0LWFwcC9zcmMvbGliL21vZGVsL3RhYmxlV3JhcHBlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxNQUFNLE9BQU8sV0FBVztJQUNwQixLQUFLLENBQVM7SUFDZCxTQUFTLENBQVM7SUFDbEIsT0FBTyxDQUFTO0lBQ2hCLElBQUksQ0FBUztJQUNiLFVBQVUsQ0FBVTtDQUN2QjtBQUVELE1BQU0sT0FBTyxZQUFZO0lBQ3JCLE1BQU0sQ0FBZ0I7SUFDdEIsSUFBSSxDQUFTO0lBQ2IsYUFBYSxDQUFPO0lBQ3BCLHNCQUFzQjtJQUN0QixhQUFhLENBQVM7SUFDdEIsV0FBVyxDQUFNO0lBQ2pCLE1BQU0sQ0FBVTtJQUNoQixhQUFhLENBQU07SUFDbkIsU0FBUyxDQUFRO0lBQ2pCLFdBQVcsQ0FBUTtDQUN0QiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBjbGFzcyBUYWJsZUhlYWRlciB7XG4gICAgbGFiZWw6IHN0cmluZztcbiAgICBmaWVsZE5hbWU6IHN0cmluZztcbiAgICBmaWVsZElkOiBzdHJpbmc7XG4gICAgdHlwZTogc3RyaW5nO1xuICAgIGlzUmVhZE9ubHk6IGJvb2xlYW47XG59XG5cbmV4cG9ydCBjbGFzcyBUYWJsZVdyYXBwZXIge1xuICAgIGhlYWRlcjogVGFibGVIZWFkZXJbXTtcbiAgICBkYXRhOiBhbnkgW107XG4gICAgdGFibGVBcHBlbmRpeDphbnlbXTtcbiAgICAvLyBkcm9wRG93bkRhdGE6YW55W107XG4gICAga2V5VmFsdWVGaWVsZDogc3RyaW5nO1xuICAgIHJvd0Z1bmN0aW9uOiBhbnk7XG4gICAgYWRkUm93OiBib29sZWFuO1xuICAgIG5ld1Jvd0RlZmF1bHQ6IGFueTtcbiAgICB0YWJsZVR5cGU6c3RyaW5nO1xuICAgIHRhYmxlSGVhZGVyOnN0cmluZztcbn1cbiJdfQ==
|
|
@@ -24,6 +24,11 @@ import { QuestionbookComponent } from './pages/questionbook/questionbook.compone
|
|
|
24
24
|
import { FileUploadComponent } from './components/file-upload/file-upload.component';
|
|
25
25
|
import { SummaryPageComponent } from './pages/summary-page/summary-page.component';
|
|
26
26
|
import { FileViewComponent } from './components/file-view/file-view.component';
|
|
27
|
+
import { DependentTableComponent } from './components/dependent-table/dependent-table.component';
|
|
28
|
+
import { CustomLabelComponent } from './components/custom-label/custom-label.component';
|
|
29
|
+
import { TableAppendixComponent } from './components/table-appendix/table-appendix.component';
|
|
30
|
+
import { CustomDateComponent } from './components/custom-date/custom-date.component';
|
|
31
|
+
import { CustomTimeComponent } from './components/custom-time/custom-time.component';
|
|
27
32
|
import * as i0 from "@angular/core";
|
|
28
33
|
import * as i1 from "ng-circle-progress";
|
|
29
34
|
// export const MY_CUSTOM_FORMATS = {
|
|
@@ -46,7 +51,12 @@ export class NxtAppModule {
|
|
|
46
51
|
QuestionbookComponent,
|
|
47
52
|
FileUploadComponent,
|
|
48
53
|
SummaryPageComponent,
|
|
49
|
-
FileViewComponent
|
|
54
|
+
FileViewComponent,
|
|
55
|
+
DependentTableComponent,
|
|
56
|
+
CustomLabelComponent,
|
|
57
|
+
TableAppendixComponent,
|
|
58
|
+
CustomDateComponent,
|
|
59
|
+
CustomTimeComponent], imports: [CommonModule, FormsModule,
|
|
50
60
|
MyDatePickerModule,
|
|
51
61
|
OwlDateTimeModule,
|
|
52
62
|
OwlNativeDateTimeModule,
|
|
@@ -168,7 +178,12 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImpo
|
|
|
168
178
|
QuestionbookComponent,
|
|
169
179
|
FileUploadComponent,
|
|
170
180
|
SummaryPageComponent,
|
|
171
|
-
FileViewComponent
|
|
181
|
+
FileViewComponent,
|
|
182
|
+
DependentTableComponent,
|
|
183
|
+
CustomLabelComponent,
|
|
184
|
+
TableAppendixComponent,
|
|
185
|
+
CustomDateComponent,
|
|
186
|
+
CustomTimeComponent
|
|
172
187
|
],
|
|
173
188
|
imports: [
|
|
174
189
|
CommonModule, FormsModule,
|
|
@@ -273,4 +288,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImpo
|
|
|
273
288
|
// ]
|
|
274
289
|
}]
|
|
275
290
|
}] });
|
|
276
|
-
//# 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":"AAAA,OAAO,EAAE,QAAQ,EAAE,sBAAsB,EAAE,MAAM,eAAe,CAAC;AACjE,OAAO,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAC;AACtD,OAAO,EAAE,sBAAsB,EAAE,MAAM,+CAA+C,CAAC;AACvF,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,WAAW,EAAC,mBAAmB,EAAE,MAAM,gBAAgB,CAAC;AACjE,OAAO,EAAE,kBAAkB,EAAE,MAAM,cAAc,CAAC;AAClD,OAAO,EAAE,sBAAsB,EAAE,MAAM,oBAAoB,CAAC;AAC5D,OAAO,EAAE,gBAAgB,EAAE,MAAM,aAAa,CAAC;AAG/C,OAAO,EAAE,qBAAqB,EAAE,MAAM,oDAAoD,CAAC;AAC3F,OAAO,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAC;AACtD,OAAO,EAAE,oBAAoB,EAAE,MAAM,kDAAkD,CAAC;AACxF,OAAO,EAAE,uBAAuB,EAAE,MAAM,0DAA0D,CAAC;AACnG,OAAO,EAAE,oBAAoB,EAAE,MAAM,kDAAkD,CAAC;AACxF,OAAO,EAAE,yBAAyB,EAAE,MAAM,8DAA8D,CAAC;AACzG,OAAO,EAAE,iBAAiB,EAAC,uBAAuB,EAAE,MAAM,kBAAkB,CAAC;AAE7E,0IAA0I;AAC1I,OAAO,EAAE,yBAAyB,EAAE,MAAM,8DAA8D,CAAC;AACzG,OAAO,EAAE,uBAAuB,EAAE,MAAM,wDAAwD,CAAC;AACjG,OAAO,EAAE,gBAAgB,EAAE,MAAM,sBAAsB,CAAC;AACxD,OAAO,EAAE,gBAAgB,EAAE,MAAM,mCAAmC,CAAC;AACrE,OAAO,EAAE,gBAAgB,EAAE,MAAM,sBAAsB,CAAC;AACxD,OAAO,EAAE,kBAAkB,EAAE,MAAM,8CAA8C,CAAC;AAClF,OAAO,EAAE,qBAAqB,EAAE,MAAM,6CAA6C,CAAC;AACpF,OAAO,EAAE,mBAAmB,EAAE,MAAM,gDAAgD,CAAC;AACrF,OAAO,EAAE,oBAAoB,EAAE,MAAM,6CAA6C,CAAC;AACnF,OAAO,EAAE,iBAAiB,EAAE,MAAM,4CAA4C,CAAC;;;AAG/E,qCAAqC;AACrC,4CAA4C;AAC5C,kBAAkB;AAClB,KAAK;AAyHL,MAAM,OAAO,YAAY;wGAAZ,YAAY;yGAAZ,YAAY,iBAtHR,eAAe;YAC5B,sBAAsB;YACtB,qBAAqB;YACrB,oBAAoB;YACpB,uBAAuB;YACvB,oBAAoB;YACpB,yBAAyB;YACzB,yBAAyB;YACzB,uBAAuB;YACvB,gBAAgB;YAChB,kBAAkB;YAClB,qBAAqB;YACrB,mBAAmB;YACnB,oBAAoB;YACpB,iBAAiB,aAGjB,YAAY,EAAE,WAAW;YACzB,kBAAkB;YAClB,iBAAiB;YACjB,uBAAuB;YACvB,gBAAgB;YAChB,cAAc;YACd,gBAAgB;YAChB,yBAAyB;YACzB,+BAA+B;YAC/B,iEAAiE;YACnE,OAAO;YACL,mBAAmB,EAAE,gBAAgB,wCAgF7B,eAAe;YACvB,sBAAsB;YACtB,gBAAgB;YAChB,oBAAoB;yGAOX,YAAY,YArGrB,YAAY,EAAE,WAAW;YACzB,kBAAkB;YAClB,iBAAiB;YACjB,uBAAuB;YACvB,gBAAgB;YAChB,cAAc;YACd,gBAAgB;YAChB,yBAAyB;YACzB,+BAA+B;YAC/B,iEAAiE;YACnE,OAAO;YACL,mBAAmB,EAAE,gBAAgB;YACrC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;8BAsDkB;YAEhB,sBAAsB,CAAC,OAAO,CAAC;gBAC7B,oBAAoB,EAAE,IAAI;gBAC1B,iBAAiB,EAAE,SAAS;gBAC5B,6BAA6B,EAAE,SAAS;gBACxC,kBAAkB,EAAE,SAAS;gBAC7B,uBAAuB,EAAE,CAAC;gBAC1B,mBAAmB,EAAE,CAAC,EAAE;gBACxB,QAAQ,EAAE,EAAE;gBACZ,OAAO,EAAE,CAAC;gBACV,YAAY,EAAE,GAAG;gBACjB,eAAe,EAAE,IAAI;gBACrB,YAAY,EAAE,SAAS;gBACvB,qBAAqB,EAAE,IAAI;gBAC3B,kBAAkB,EAAE,EAAE;gBACtB,kBAAkB,EAAE,SAAS;gBAC7B,8BAA8B,EAAE,SAAS;gBACzC,kBAAkB,EAAE,CAAC;gBACrB,YAAY,EAAE,SAAS;gBACvB,eAAe,EAAE,IAAI;gBACrB,eAAe,EAAE,SAAS;gBAC1B,cAAc,EAAE,KAAK;aAAC,CAAC;;4FAalB,YAAY;kBAvHxB,QAAQ;mBAAC;oBACR,YAAY,EAAE,CAAC,eAAe;wBAC5B,sBAAsB;wBACtB,qBAAqB;wBACrB,oBAAoB;wBACpB,uBAAuB;wBACvB,oBAAoB;wBACpB,yBAAyB;wBACzB,yBAAyB;wBACzB,uBAAuB;wBACvB,gBAAgB;wBAChB,kBAAkB;wBAClB,qBAAqB;wBACrB,mBAAmB;wBACnB,oBAAoB;wBACpB,iBAAiB;qBAClB;oBACD,OAAO,EAAE;wBACP,YAAY,EAAE,WAAW;wBACzB,kBAAkB;wBAClB,iBAAiB;wBACjB,uBAAuB;wBACvB,gBAAgB;wBAChB,cAAc;wBACd,gBAAgB;wBAChB,yBAAyB;wBACzB,+BAA+B;wBAC/B,iEAAiE;wBACnE,OAAO;wBACL,mBAAmB,EAAE,gBAAgB;wBACrC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;0CAsDkB;wBAEhB,sBAAsB,CAAC,OAAO,CAAC;4BAC7B,oBAAoB,EAAE,IAAI;4BAC1B,iBAAiB,EAAE,SAAS;4BAC5B,6BAA6B,EAAE,SAAS;4BACxC,kBAAkB,EAAE,SAAS;4BAC7B,uBAAuB,EAAE,CAAC;4BAC1B,mBAAmB,EAAE,CAAC,EAAE;4BACxB,QAAQ,EAAE,EAAE;4BACZ,OAAO,EAAE,CAAC;4BACV,YAAY,EAAE,GAAG;4BACjB,eAAe,EAAE,IAAI;4BACrB,YAAY,EAAE,SAAS;4BACvB,qBAAqB,EAAE,IAAI;4BAC3B,kBAAkB,EAAE,EAAE;4BACtB,kBAAkB,EAAE,SAAS;4BAC7B,8BAA8B,EAAE,SAAS;4BACzC,kBAAkB,EAAE,CAAC;4BACrB,YAAY,EAAE,SAAS;4BACvB,eAAe,EAAE,IAAI;4BACrB,eAAe,EAAE,SAAS;4BAC1B,cAAc,EAAE,KAAK;yBAAC,CAAC;qBAC5B;oBACD,OAAO,EAAE,CAAC,sBAAsB,CAAC;oBACjC,OAAO,EAAE,CAAC,eAAe;wBACvB,sBAAsB;wBACtB,gBAAgB;wBAChB,oBAAoB;qBACrB;oBACD,eAAe;oBACf,oFAAoF;oBACpF,qEAAqE;oBACrE,IAAI;iBACL","sourcesContent":["import { NgModule, CUSTOM_ELEMENTS_SCHEMA } from '@angular/core';\nimport { NxtAppComponent } from './nxt-app.component';\nimport { QuestionnaireComponent } from './pages/questionnaire/questionnaire.component';\nimport { CommonModule } from \"@angular/common\";\nimport { FormsModule,ReactiveFormsModule } from '@angular/forms';\nimport { MyDatePickerModule } from 'mydatepicker';\nimport { NgCircleProgressModule } from 'ng-circle-progress';\nimport { NgxSpinnerModule } from \"ngx-spinner\";\n//import { AgmCoreModule } from '@agm/core';\nimport { GOOGLE_MAP_API_KEY } from '../lib/sample';\nimport { PickLocationComponent } from './components/pick-location/pick-location.component';\nimport { NgSelectModule } from '@ng-select/ng-select';\nimport { CustomInputComponent } from './components/custom-input/custom-input.component';\nimport { CustomTextAreaComponent } from './components/custom-text-area/custom-text-area.component';\nimport { CustomTableComponent } from './components/custom-table/custom-table.component';\nimport { DropdownWithFlagComponent } from './components/dropdown-with-flag/dropdown-with-flag.component';\nimport { OwlDateTimeModule,OwlNativeDateTimeModule } from 'ng-pick-datetime';\n\n//import { OWL_MOMENT_DATE_TIME_ADAPTER_OPTIONS } from 'ng-pick-datetime/date-time/adapter/moment-adapter/moment-date-time-adapter.class';\nimport { CustomDatePickerComponent } from './components/custom-date-picker/custom-date-picker.component';\nimport { CustomDropdownComponent } from './components/custom-dropdown/custom-dropdown.component';\nimport { HttpClientModule } from '@angular/common/http';\nimport { BookletComponent } from './pages/booklet/booklet.component';\nimport { GoogleMapsModule } from '@angular/google-maps';\nimport { SearchBoxComponent } from './components/search-box/search-box.component';\nimport { QuestionbookComponent } from './pages/questionbook/questionbook.component';\nimport { FileUploadComponent } from './components/file-upload/file-upload.component';\nimport { SummaryPageComponent } from './pages/summary-page/summary-page.component';\nimport { FileViewComponent } from './components/file-view/file-view.component';\n\n\n// export const MY_CUSTOM_FORMATS = {\n//   fullPickerInput: 'DD/MM/YYYY HH:mm:ss',\n//   useUtc: true,\n// };\n\n@NgModule({\n  declarations: [NxtAppComponent, \n    QuestionnaireComponent,\n    PickLocationComponent,\n    CustomInputComponent,\n    CustomTextAreaComponent,\n    CustomTableComponent,\n    CustomDatePickerComponent,\n    DropdownWithFlagComponent,\n    CustomDropdownComponent,\n    BookletComponent,\n    SearchBoxComponent,\n    QuestionbookComponent,\n    FileUploadComponent,\n    SummaryPageComponent,\n    FileViewComponent\n  ],\n  imports: [\n    CommonModule, FormsModule,\n    MyDatePickerModule,\n    OwlDateTimeModule,\n    OwlNativeDateTimeModule,\n    HttpClientModule,\n    NgSelectModule,\n    GoogleMapsModule,\n    //AgmCoreModule.forRoot({\n    //  apiKey: GOOGLE_MAP_API_KEY,\n    //  libraries: ['geometry', 'places', 'visualization', 'drawing']\n  //  }),\n    ReactiveFormsModule, NgxSpinnerModule,\n    /*NgCircleProgressModule.forRoot({\n      \"backgroundPadding\": -10,\n      \"radius\": 60,\n      \"space\": -6,\n      \"innerStrokeColor\": \"#919191\",\n      \"outerStrokeColor\": \"#db9594\",\n      \"outerStrokeGradientStopColor\": \"#e0b1b0\",\n      \"innerStrokeWidth\": 2,\n      \"backgroundGradient\": true,\n      \"backgroundColor\": \"#dd2e13\",\n      \"backgroundGradientStopColor\": \"#dd2e13\",\n      \"backgroundStroke\": \"#d3cfcf\",\n      \"title\": [\n                \n                \"%\"\n      ],\n      // titleFontSize: 12,\n      // \"subtitleFontSize\": 20,\n      \"animateTitle\": false,\n      \"animationDuration\": 1000,\n      \"showUnits\": false,\n      \"clockwise\":true\n\n      //\"backgroundStrokeWidth\": \"0\",\n\"backgroundGradient\": true,\n      //\"backgroundColor\": \"#dd2e13\",\n      \"backgroundGradientStopColor\": \"#dd2e13\",\n      \"backgroundStroke\": \"#000000\",\n      \"backgroundPadding\": -10,\n      \"radius\": 60,\n      \"unitsFontWeight\": \"600\",\n      \"unitsColor\": \"#f2f2f2\",\n      \"outerStrokeGradient\": true,\n      \"outerStrokeColor\": \"#e0b1b0\",\n      \"outerStrokeGradientStopColor\": \"#e0b1b0\",\n      \"outerStrokeLinecap\": \"inherit\",\n      \"innerStrokeColor\": \"#f6dfdf\",\n      \"title\": [\n                \n        \"%\"\n],\n      \"titleColor\": \"#e7d9d9\",\n      \"titleFontSize\": \"31\",\n      \"titleFontWeight\": \"100\",\n      \"subtitleColor\": \"#f7f7f7\",\n      \"subtitleFontSize\": \"36\",\n      \"subtitleFontWeight\": \"900\",\n      \"animateTitle\": false,\n      \"animationDuration\": 1000,\n      \"showTitle\": true,\n      \"showUnits\": true,\n      \"clockwise\": false,\n      \"startFromZero\": true,\n      \"showZeroOuterStroke\": false,\n      \"lazy\": true})*/\n\n      NgCircleProgressModule.forRoot({\n        \"backgroundGradient\": true,\n        \"backgroundColor\": \"#e29d98\",\n        \"backgroundGradientStopColor\": \"#c5281c\",\n        \"backgroundStroke\": \"#ece4e4\",\n        \"backgroundStrokeWidth\": 0,\n        \"backgroundPadding\": -10,\n        \"radius\": 60,\n        \"space\": 4,\n        \"maxPercent\": 100,\n        \"unitsFontSize\": \"35\",\n        \"unitsColor\": \"#f0ebeb\",\n        \"outerStrokeGradient\": true,\n        \"outerStrokeWidth\": 10,\n        \"outerStrokeColor\": \"#f7c0bf\",\n        \"outerStrokeGradientStopColor\": \"#f9c9c8\",\n        \"innerStrokeWidth\": 0,\n        \"titleColor\": \"#f3eded\",\n        \"titleFontSize\": \"40\",\n        \"subtitleColor\": \"#444444\",\n        \"showSubtitle\": false})\n  ],\n  schemas: [CUSTOM_ELEMENTS_SCHEMA],\n  exports: [NxtAppComponent, \n    QuestionnaireComponent,\n    BookletComponent,\n    SummaryPageComponent\n  ]\n  // providers: [\n  //   { provide: OWL_MOMENT_DATE_TIME_ADAPTER_OPTIONS, useValue: { useUtc: false } },\n  //   { provide: OWL_DATE_TIME_FORMATS, useValue: MY_CUSTOM_FORMATS },\n  // ]\n})\nexport class NxtAppModule { }\n"]}
|
|
291
|
+
//# 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';\nimport { NxtAppComponent } from './nxt-app.component';\nimport { QuestionnaireComponent } from './pages/questionnaire/questionnaire.component';\nimport { CommonModule } from \"@angular/common\";\nimport { FormsModule,ReactiveFormsModule } from '@angular/forms';\nimport { MyDatePickerModule } from 'mydatepicker';\nimport { NgCircleProgressModule } from 'ng-circle-progress';\nimport { NgxSpinnerModule } from \"ngx-spinner\";\n//import { AgmCoreModule } from '@agm/core';\nimport { GOOGLE_MAP_API_KEY } from '../lib/sample';\nimport { PickLocationComponent } from './components/pick-location/pick-location.component';\nimport { NgSelectModule } from '@ng-select/ng-select';\nimport { CustomInputComponent } from './components/custom-input/custom-input.component';\nimport { CustomTextAreaComponent } from './components/custom-text-area/custom-text-area.component';\nimport { CustomTableComponent } from './components/custom-table/custom-table.component';\nimport { DropdownWithFlagComponent } from './components/dropdown-with-flag/dropdown-with-flag.component';\nimport { OwlDateTimeModule,OwlNativeDateTimeModule } from 'ng-pick-datetime';\n\n//import { OWL_MOMENT_DATE_TIME_ADAPTER_OPTIONS } from 'ng-pick-datetime/date-time/adapter/moment-adapter/moment-date-time-adapter.class';\nimport { CustomDatePickerComponent } from './components/custom-date-picker/custom-date-picker.component';\nimport { CustomDropdownComponent } from './components/custom-dropdown/custom-dropdown.component';\nimport { HttpClientModule } from '@angular/common/http';\nimport { BookletComponent } from './pages/booklet/booklet.component';\nimport { GoogleMapsModule } from '@angular/google-maps';\nimport { SearchBoxComponent } from './components/search-box/search-box.component';\nimport { QuestionbookComponent } from './pages/questionbook/questionbook.component';\nimport { FileUploadComponent } from './components/file-upload/file-upload.component';\nimport { SummaryPageComponent } from './pages/summary-page/summary-page.component';\nimport { FileViewComponent } from './components/file-view/file-view.component';\nimport { DependentTableComponent } from './components/dependent-table/dependent-table.component';\nimport { CustomLabelComponent } from './components/custom-label/custom-label.component';\nimport { TableAppendixComponent } from './components/table-appendix/table-appendix.component';\nimport { CustomDateComponent } from './components/custom-date/custom-date.component';\nimport { CustomTimeComponent } from './components/custom-time/custom-time.component';\n\n// export const MY_CUSTOM_FORMATS = {\n//   fullPickerInput: 'DD/MM/YYYY HH:mm:ss',\n//   useUtc: true,\n// };\n\n@NgModule({\n  declarations: [NxtAppComponent, \n    QuestionnaireComponent,\n    PickLocationComponent,\n    CustomInputComponent,\n    CustomTextAreaComponent,\n    CustomTableComponent,\n    CustomDatePickerComponent,\n    DropdownWithFlagComponent,\n    CustomDropdownComponent,\n    BookletComponent,\n    SearchBoxComponent,\n    QuestionbookComponent,\n    FileUploadComponent,\n    SummaryPageComponent,\n    FileViewComponent,\n    DependentTableComponent,\n    CustomLabelComponent,\n    TableAppendixComponent,\n    CustomDateComponent,\n    CustomTimeComponent\n  ],\n  imports: [\n    CommonModule, FormsModule,\n    MyDatePickerModule,\n    OwlDateTimeModule,\n    OwlNativeDateTimeModule,\n    HttpClientModule,\n    NgSelectModule,\n    GoogleMapsModule,\n    //AgmCoreModule.forRoot({\n    //  apiKey: GOOGLE_MAP_API_KEY,\n    //  libraries: ['geometry', 'places', 'visualization', 'drawing']\n  //  }),\n    ReactiveFormsModule, NgxSpinnerModule,\n    /*NgCircleProgressModule.forRoot({\n      \"backgroundPadding\": -10,\n      \"radius\": 60,\n      \"space\": -6,\n      \"innerStrokeColor\": \"#919191\",\n      \"outerStrokeColor\": \"#db9594\",\n      \"outerStrokeGradientStopColor\": \"#e0b1b0\",\n      \"innerStrokeWidth\": 2,\n      \"backgroundGradient\": true,\n      \"backgroundColor\": \"#dd2e13\",\n      \"backgroundGradientStopColor\": \"#dd2e13\",\n      \"backgroundStroke\": \"#d3cfcf\",\n      \"title\": [\n                \n                \"%\"\n      ],\n      // titleFontSize: 12,\n      // \"subtitleFontSize\": 20,\n      \"animateTitle\": false,\n      \"animationDuration\": 1000,\n      \"showUnits\": false,\n      \"clockwise\":true\n\n      //\"backgroundStrokeWidth\": \"0\",\n\"backgroundGradient\": true,\n      //\"backgroundColor\": \"#dd2e13\",\n      \"backgroundGradientStopColor\": \"#dd2e13\",\n      \"backgroundStroke\": \"#000000\",\n      \"backgroundPadding\": -10,\n      \"radius\": 60,\n      \"unitsFontWeight\": \"600\",\n      \"unitsColor\": \"#f2f2f2\",\n      \"outerStrokeGradient\": true,\n      \"outerStrokeColor\": \"#e0b1b0\",\n      \"outerStrokeGradientStopColor\": \"#e0b1b0\",\n      \"outerStrokeLinecap\": \"inherit\",\n      \"innerStrokeColor\": \"#f6dfdf\",\n      \"title\": [\n                \n        \"%\"\n],\n      \"titleColor\": \"#e7d9d9\",\n      \"titleFontSize\": \"31\",\n      \"titleFontWeight\": \"100\",\n      \"subtitleColor\": \"#f7f7f7\",\n      \"subtitleFontSize\": \"36\",\n      \"subtitleFontWeight\": \"900\",\n      \"animateTitle\": false,\n      \"animationDuration\": 1000,\n      \"showTitle\": true,\n      \"showUnits\": true,\n      \"clockwise\": false,\n      \"startFromZero\": true,\n      \"showZeroOuterStroke\": false,\n      \"lazy\": true})*/\n\n      NgCircleProgressModule.forRoot({\n        \"backgroundGradient\": true,\n        \"backgroundColor\": \"#e29d98\",\n        \"backgroundGradientStopColor\": \"#c5281c\",\n        \"backgroundStroke\": \"#ece4e4\",\n        \"backgroundStrokeWidth\": 0,\n        \"backgroundPadding\": -10,\n        \"radius\": 60,\n        \"space\": 4,\n        \"maxPercent\": 100,\n        \"unitsFontSize\": \"35\",\n        \"unitsColor\": \"#f0ebeb\",\n        \"outerStrokeGradient\": true,\n        \"outerStrokeWidth\": 10,\n        \"outerStrokeColor\": \"#f7c0bf\",\n        \"outerStrokeGradientStopColor\": \"#f9c9c8\",\n        \"innerStrokeWidth\": 0,\n        \"titleColor\": \"#f3eded\",\n        \"titleFontSize\": \"40\",\n        \"subtitleColor\": \"#444444\",\n        \"showSubtitle\": false})\n  ],\n  schemas: [CUSTOM_ELEMENTS_SCHEMA],\n  exports: [NxtAppComponent, \n    QuestionnaireComponent,\n    BookletComponent,\n    SummaryPageComponent\n  ]\n  // providers: [\n  //   { provide: OWL_MOMENT_DATE_TIME_ADAPTER_OPTIONS, useValue: { useUtc: false } },\n  //   { provide: OWL_DATE_TIME_FORMATS, useValue: MY_CUSTOM_FORMATS },\n  // ]\n})\nexport class NxtAppModule { }\n"]}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { Component, Input, Output, EventEmitter
|
|
1
|
+
import { Component, Input, Output, EventEmitter } from "@angular/core";
|
|
2
2
|
import * as i0 from "@angular/core";
|
|
3
3
|
import * as i1 from "../../services/salesforce.service";
|
|
4
4
|
import * as i2 from "../../services/data.service";
|
|
@@ -20,8 +20,11 @@ export class BookletComponent {
|
|
|
20
20
|
serv;
|
|
21
21
|
tkn;
|
|
22
22
|
bookletJSON;
|
|
23
|
+
dropdownDependentData;
|
|
24
|
+
labelValue;
|
|
23
25
|
handleBookletActionEvent = new EventEmitter();
|
|
24
26
|
handlePage = new EventEmitter();
|
|
27
|
+
hadleDropDownDependent = new EventEmitter();
|
|
25
28
|
nxtBooklet;
|
|
26
29
|
booklet = [];
|
|
27
30
|
abItem = {};
|
|
@@ -40,16 +43,16 @@ export class BookletComponent {
|
|
|
40
43
|
this.changeService = changeService;
|
|
41
44
|
this.spinnerName = "sp1";
|
|
42
45
|
this.spinnerType = "ball-spin-clockwise";
|
|
46
|
+
console.log('dropdownDependentData', this.dropdownDependentData);
|
|
43
47
|
}
|
|
44
48
|
ngOnInit() {
|
|
45
49
|
this.processBooklet();
|
|
46
50
|
}
|
|
47
51
|
ngOnChanges() {
|
|
48
|
-
// console.log('inside Questionnaire ngOnChanges');
|
|
49
52
|
console.log(this.booklet);
|
|
50
|
-
if
|
|
51
|
-
|
|
52
|
-
}
|
|
53
|
+
//if(this.booklet == undefined || this.booklet.length == 0) {
|
|
54
|
+
this.processBooklet();
|
|
55
|
+
// }
|
|
53
56
|
}
|
|
54
57
|
processBooklet() {
|
|
55
58
|
if (this.bookletId) {
|
|
@@ -149,12 +152,15 @@ export class BookletComponent {
|
|
|
149
152
|
//console.log( doc.documentElement.textContent);
|
|
150
153
|
return this.sanitizer.bypassSecurityTrustHtml(doc.documentElement.textContent);
|
|
151
154
|
}
|
|
155
|
+
getDropDown(event) {
|
|
156
|
+
this.hadleDropDownDependent.emit(event);
|
|
157
|
+
}
|
|
152
158
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: BookletComponent, deps: [{ token: i1.SalesforceService }, { token: i2.DataService }, { token: i3.StorageService }, { token: i4.ActivatedRoute }, { token: i5.DomSanitizer }, { token: i6.ChangeService }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
153
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: BookletComponent, selector: "lib-booklet", inputs: { bookletId: "bookletId", serv: "serv", tkn: "tkn", bookletJSON: "bookletJSON" }, outputs: { handleBookletActionEvent: "handleBookletActionEvent", handlePage: "handlePage" }, usesOnChanges: true, ngImport: i0, template: "<ngx-spinner [name]=\"spinnerName\" [type]=\"spinnerType\"></ngx-spinner>\n<!-- Booklet Handling-->\n<div *ngFor=\"let qb of booklet\">\n <!-- MR Commented below code to ensure single JSON for UNCONDITIONAL Booklets -->\n <!-- <lib-questionnaire [serv]=\"serv\" [qbId]=\"qb.Id\" [tkn]=\"tkn\"></lib-questionnaire> -->\n <div *ngFor=\"let ques of qb.Questions__r.records\" [class]=\"qb.isShengel__c ? 'questiondiv1' : 'questiondiv1 padd-bottom'\">\n <div class=\"questiondiv2\">\n <div *ngIf=\"!ques.Is_Title__c\" [class]=\"qb.isShengel__c ? 'header-style' : 'question-f-size additional'\">\n <div [innerHTML]=\"getText(ques?.Question_Text__c)\" >\n {{ ques?.Question_Text__c }}\n </div>\n </div>\n <lib-questionbook [qbItem]=\"qb\" [questionItem]=\"ques\" [questions]=\"readQuestions(qb.Id)\"></lib-questionbook>\n </div>\n </div>\n</div>\n\n<!-- Group Actions -->\n<div class=\"align-submit-row\" *ngIf=\"abItem.Status__c != 'Completed'\">\n <div *ngFor=\"let action of actions; let i = index\">\n <button (click)=\"handleBookletActionClick(action)\" [ngClass]=\"{'first-button': i === 0, 'second-button': i === 1}\">\n {{ action.name }}\n </button>\n </div>\n</div>\n", styles: [".align-submit-row{display:flex}.align-submit-row button{margin-left:25px;background:#48B7FF;color:#fff;border:none;border-radius:5px;height:50px;width:150px}.header-style{padding:15px;background:#F8F8F8;color:#898989;border:1px solid #e8e8e8;border-top-left-radius:5px;border-top-right-radius:5px;margin-left:0;justify-content:left;font-size:15px}\n"], dependencies: [{ kind: "directive", type: i7.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i7.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i7.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i8.NgxSpinnerComponent, selector: "ngx-spinner", inputs: ["disableAnimation", "bdColor", "zIndex", "color", "type", "size", "fullScreen", "name", "template", "showSpinner"] }, { kind: "component", type: i9.QuestionbookComponent, selector: "lib-questionbook", inputs: ["qbItem", "questionItem", "questions", "errorFieldId"] }] });
|
|
159
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: BookletComponent, selector: "lib-booklet", inputs: { bookletId: "bookletId", serv: "serv", tkn: "tkn", bookletJSON: "bookletJSON", dropdownDependentData: "dropdownDependentData", labelValue: "labelValue" }, outputs: { handleBookletActionEvent: "handleBookletActionEvent", handlePage: "handlePage", hadleDropDownDependent: "hadleDropDownDependent" }, usesOnChanges: true, ngImport: i0, template: "<ngx-spinner [name]=\"spinnerName\" [type]=\"spinnerType\"></ngx-spinner>\n<!-- Booklet Handling-->\n<div *ngFor=\"let qb of booklet\">\n <!-- MR Commented below code to ensure single JSON for UNCONDITIONAL Booklets -->\n <!-- <lib-questionnaire [serv]=\"serv\" [qbId]=\"qb.Id\" [tkn]=\"tkn\"></lib-questionnaire> -->\n <div *ngFor=\"let ques of qb.Questions__r.records\" [class]=\"qb.isShengel__c ? 'questiondiv1' : 'questiondiv1 padd-bottom'\">\n <div class=\"questiondiv2\">\n <div *ngIf=\"!ques.Is_Title__c\" [class]=\"qb.isShengel__c ? 'header-style' : 'question-f-size additional'\">\n <div [innerHTML]=\"getText(ques?.Question_Text__c)\" >\n {{ ques?.Question_Text__c }}\n </div>\n </div>\n <lib-questionbook [qbItem]=\"qb\" [labelValue]=\"labelValue\" [questionItem]=\"ques\" [questions]=\"readQuestions(qb.Id)\" (handleDropDown)=\"getDropDown($event)\"></lib-questionbook>\n </div>\n </div>\n</div>\n\n<!-- Group Actions -->\n<div class=\"align-submit-row\" *ngIf=\"abItem.Status__c != 'Completed'\">\n <div *ngFor=\"let action of actions; let i = index\">\n <button (click)=\"handleBookletActionClick(action)\" [ngClass]=\"{'first-button': i === 0, 'second-button': i === 1}\">\n {{ action.name }}\n </button>\n </div>\n</div>\n", styles: [".align-submit-row{display:flex}.align-submit-row button{margin-left:25px;background:#48B7FF;color:#fff;border:none;border-radius:5px;height:50px;width:150px}.header-style{padding:15px;background:#F8F8F8;color:#898989;border:1px solid #e8e8e8;border-top-left-radius:5px;border-top-right-radius:5px;margin-left:0;justify-content:left;font-size:15px}\n"], dependencies: [{ kind: "directive", type: i7.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i7.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i7.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i8.NgxSpinnerComponent, selector: "ngx-spinner", inputs: ["disableAnimation", "bdColor", "zIndex", "color", "type", "size", "fullScreen", "name", "template", "showSpinner"] }, { kind: "component", type: i9.QuestionbookComponent, selector: "lib-questionbook", inputs: ["qbItem", "questionItem", "questions", "errorFieldId", "labelValue", "dropDownData"], outputs: ["handleDropDown"] }] });
|
|
154
160
|
}
|
|
155
161
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: BookletComponent, decorators: [{
|
|
156
162
|
type: Component,
|
|
157
|
-
args: [{ selector: 'lib-booklet', template: "<ngx-spinner [name]=\"spinnerName\" [type]=\"spinnerType\"></ngx-spinner>\n<!-- Booklet Handling-->\n<div *ngFor=\"let qb of booklet\">\n <!-- MR Commented below code to ensure single JSON for UNCONDITIONAL Booklets -->\n <!-- <lib-questionnaire [serv]=\"serv\" [qbId]=\"qb.Id\" [tkn]=\"tkn\"></lib-questionnaire> -->\n <div *ngFor=\"let ques of qb.Questions__r.records\" [class]=\"qb.isShengel__c ? 'questiondiv1' : 'questiondiv1 padd-bottom'\">\n <div class=\"questiondiv2\">\n <div *ngIf=\"!ques.Is_Title__c\" [class]=\"qb.isShengel__c ? 'header-style' : 'question-f-size additional'\">\n <div [innerHTML]=\"getText(ques?.Question_Text__c)\" >\n {{ ques?.Question_Text__c }}\n </div>\n </div>\n <lib-questionbook [qbItem]=\"qb\" [questionItem]=\"ques\" [questions]=\"readQuestions(qb.Id)\"></lib-questionbook>\n </div>\n </div>\n</div>\n\n<!-- Group Actions -->\n<div class=\"align-submit-row\" *ngIf=\"abItem.Status__c != 'Completed'\">\n <div *ngFor=\"let action of actions; let i = index\">\n <button (click)=\"handleBookletActionClick(action)\" [ngClass]=\"{'first-button': i === 0, 'second-button': i === 1}\">\n {{ action.name }}\n </button>\n </div>\n</div>\n", styles: [".align-submit-row{display:flex}.align-submit-row button{margin-left:25px;background:#48B7FF;color:#fff;border:none;border-radius:5px;height:50px;width:150px}.header-style{padding:15px;background:#F8F8F8;color:#898989;border:1px solid #e8e8e8;border-top-left-radius:5px;border-top-right-radius:5px;margin-left:0;justify-content:left;font-size:15px}\n"] }]
|
|
163
|
+
args: [{ selector: 'lib-booklet', template: "<ngx-spinner [name]=\"spinnerName\" [type]=\"spinnerType\"></ngx-spinner>\n<!-- Booklet Handling-->\n<div *ngFor=\"let qb of booklet\">\n <!-- MR Commented below code to ensure single JSON for UNCONDITIONAL Booklets -->\n <!-- <lib-questionnaire [serv]=\"serv\" [qbId]=\"qb.Id\" [tkn]=\"tkn\"></lib-questionnaire> -->\n <div *ngFor=\"let ques of qb.Questions__r.records\" [class]=\"qb.isShengel__c ? 'questiondiv1' : 'questiondiv1 padd-bottom'\">\n <div class=\"questiondiv2\">\n <div *ngIf=\"!ques.Is_Title__c\" [class]=\"qb.isShengel__c ? 'header-style' : 'question-f-size additional'\">\n <div [innerHTML]=\"getText(ques?.Question_Text__c)\" >\n {{ ques?.Question_Text__c }}\n </div>\n </div>\n <lib-questionbook [qbItem]=\"qb\" [labelValue]=\"labelValue\" [questionItem]=\"ques\" [questions]=\"readQuestions(qb.Id)\" (handleDropDown)=\"getDropDown($event)\"></lib-questionbook>\n </div>\n </div>\n</div>\n\n<!-- Group Actions -->\n<div class=\"align-submit-row\" *ngIf=\"abItem.Status__c != 'Completed'\">\n <div *ngFor=\"let action of actions; let i = index\">\n <button (click)=\"handleBookletActionClick(action)\" [ngClass]=\"{'first-button': i === 0, 'second-button': i === 1}\">\n {{ action.name }}\n </button>\n </div>\n</div>\n", styles: [".align-submit-row{display:flex}.align-submit-row button{margin-left:25px;background:#48B7FF;color:#fff;border:none;border-radius:5px;height:50px;width:150px}.header-style{padding:15px;background:#F8F8F8;color:#898989;border:1px solid #e8e8e8;border-top-left-radius:5px;border-top-right-radius:5px;margin-left:0;justify-content:left;font-size:15px}\n"] }]
|
|
158
164
|
}], ctorParameters: function () { return [{ type: i1.SalesforceService }, { type: i2.DataService }, { type: i3.StorageService }, { type: i4.ActivatedRoute }, { type: i5.DomSanitizer }, { type: i6.ChangeService }, { type: i0.ElementRef }]; }, propDecorators: { bookletId: [{
|
|
159
165
|
type: Input
|
|
160
166
|
}], serv: [{
|
|
@@ -163,9 +169,15 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImpo
|
|
|
163
169
|
type: Input
|
|
164
170
|
}], bookletJSON: [{
|
|
165
171
|
type: Input
|
|
172
|
+
}], dropdownDependentData: [{
|
|
173
|
+
type: Input
|
|
174
|
+
}], labelValue: [{
|
|
175
|
+
type: Input
|
|
166
176
|
}], handleBookletActionEvent: [{
|
|
167
177
|
type: Output
|
|
168
178
|
}], handlePage: [{
|
|
169
179
|
type: Output
|
|
180
|
+
}], hadleDropDownDependent: [{
|
|
181
|
+
type: Output
|
|
170
182
|
}] } });
|
|
171
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"booklet.component.js","sourceRoot":"","sources":["../../../../../../projects/nxt-app/src/lib/pages/booklet/booklet.component.ts","../../../../../../projects/nxt-app/src/lib/pages/booklet/booklet.component.html"],"names":[],"mappings":"AAAA,OAAO,EACL,SAAS,EAIT,KAAK,EACL,MAAM,EACN,YAAY,GAGb,MAAM,eAAe,CAAC;;;;;;;;;;;AAgBvB,MAAM,OAAO,gBAAgB;IAqBjB;IACA;IACA;IACA;IACA;IACA;IAzBD,SAAS,CAAS;IAClB,IAAI,CAAS;IACb,GAAG,CAAS;IACZ,WAAW,CAAM;IAEhB,wBAAwB,GAAsB,IAAI,YAAY,EAAE,CAAC;IACjE,UAAU,GAAsB,IAAI,YAAY,EAAE,CAAC;IAEtD,UAAU,CAAiB;IAE3B,OAAO,GAAU,EAAE,CAAC;IACpB,MAAM,GAAQ,EAAE,CAAC;IACjB,OAAO,GAAiB,EAAE,CAAC;IAC3B,gBAAgB,GAAQ,IAAI,GAAG,EAAE,CAAC;IACjC,SAAS,GAAQ,IAAI,GAAG,EAAE,CAAC;IAC5B,YAAY,GAAY,KAAK,CAAC;IAC9B,WAAW,CAAS;IACpB,WAAW,CAAS;IAE3B,YACU,SAA4B,EAC5B,WAAwB,EACxB,cAA8B,EAC9B,KAAqB,EACrB,SAAuB,EACvB,aAA4B,EACpC,EAAc;QANN,cAAS,GAAT,SAAS,CAAmB;QAC5B,gBAAW,GAAX,WAAW,CAAa;QACxB,mBAAc,GAAd,cAAc,CAAgB;QAC9B,UAAK,GAAL,KAAK,CAAgB;QACrB,cAAS,GAAT,SAAS,CAAc;QACvB,kBAAa,GAAb,aAAa,CAAe;QAGpC,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC;QACzB,IAAI,CAAC,WAAW,GAAG,qBAAqB,CAAC;IAC3C,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,cAAc,EAAE,CAAC;IACxB,CAAC;IAED,WAAW;QACT,mDAAmD;QACnD,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QAC1B,IAAG,IAAI,CAAC,OAAO,IAAI,SAAS,IAAI,IAAI,CAAC,OAAO,CAAC,MAAM,IAAI,CAAC,EAAE;YACxD,IAAI,CAAC,cAAc,EAAE,CAAC;SACvB;IACH,CAAC;IAED,cAAc;QACZ,IAAI,IAAI,CAAC,SAAS,EAAE;YAClB,IAAI,IAAI,CAAC,SAAS,CAAC,MAAM,IAAI,EAAE,EAAE;gBAC/B,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;aAClC;SACF;aAAM,IAAG,IAAI,CAAC,WAAW,EAAE;YAC1B,8FAA8F;YAC9F,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;YAEzB,IAAG,IAAI,CAAC,WAAW,IAAI,IAAI,IAAI,IAAI,CAAC,WAAW,IAAI,SAAS,EAAE;gBAC1D,0CAA0C;gBAC1C,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;aAC9C;YAED,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC;YACxC,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,WAAW,CAAC,UAAU,CAAC;YAE1C,2FAA2F;YAC3F,KAAK,IAAI,EAAE,IAAI,IAAI,CAAC,WAAW,CAAC,SAAS,EAAE;gBACzC,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,EAAE,EAAE,IAAI,CAAC,WAAW,CAAC,SAAS,CAAC,EAAE,CAAC,CAAC,CAAC;aACxD;YAED,wBAAwB;YACxB,KAAK,IAAI,KAAK,IAAI,IAAI,CAAC,WAAW,CAAC,gBAAgB,EAAE;gBACnD,IAAI,CAAC,gBAAgB,CAAC,GAAG,CAAC,KAAK,EAAE,IAAI,CAAC,WAAW,CAAC,gBAAgB,CAAC,KAAK,CAAC,CAAC,CAAC;aAC5E;YAED,IAAG,IAAI,CAAC,WAAW,CAAC,YAAY,EAAE,UAAU,IAAI,SAAS,EAAE;gBACzD,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,WAAW,CAAC,YAAY,CAAC,UAAU,CAAC,CAAC;aACrE;SACF;IACH,CAAC;IAEO,WAAW,GAAG,CAAC,IAAY,EAAE,EAAE;QACrC,IAAG,IAAI,CAAC,IAAI,IAAI,KAAK,EAAE;YACrB,IAAI,CAAC,WAAW,CAAC,UAAU,CACzB,IAAI,CAAC,GAAG,EACR,CAAC,SAAS,EAAE,MAAM,EAAE,IAAI,CAAC,EACzB,IAAI,CAAC,kBAAkB,EACvB,IAAI,CAAC,kBAAkB,CACxB,CAAC;SACH;aAAM;YACL,IAAI,CAAC,SAAS,CAAC,YAAY,CACzB,uBAAuB,EACvB,CAAC,SAAS,EAAE,MAAM,EAAE,IAAI,CAAC,EACzB,IAAI,CAAC,kBAAkB,EACvB,IAAI,CAAC,kBAAkB,CACxB,CAAC;SACH;IACH,CAAC,CAAA;IAEO,kBAAkB,GAAG,CAAC,QAAQ,EAAE,EAAE;QACxC,OAAO,CAAC,GAAG,CAAC,+BAA+B,CAAC,CAAC;QAC7C,yBAAyB;QACzB,IAAG,QAAQ,IAAI,IAAI,IAAI,QAAQ,IAAI,SAAS,EAAE;YAC5C,0CAA0C;YAC1C,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;YAEnC,8FAA8F;YAC9F,4BAA4B;YAE5B,IAAI,CAAC,OAAO,GAAG,QAAQ,CAAC,OAAO,CAAC;YAChC,IAAI,CAAC,MAAM,GAAG,QAAQ,CAAC,UAAU,CAAC;YAElC,2FAA2F;YAC3F,KAAK,IAAI,EAAE,IAAI,QAAQ,CAAC,SAAS,EAAE;gBACjC,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,EAAE,EAAE,QAAQ,CAAC,SAAS,CAAC,EAAE,CAAC,CAAC,CAAC;aAChD;YAED,wBAAwB;YACxB,KAAK,IAAI,KAAK,IAAI,QAAQ,CAAC,gBAAgB,EAAE;gBAC3C,IAAI,CAAC,gBAAgB,CAAC,GAAG,CAAC,KAAK,EAAE,QAAQ,CAAC,gBAAgB,CAAC,KAAK,CAAC,CAAC,CAAC;aACpE;YAED,IAAG,QAAQ,CAAC,YAAY,EAAE,UAAU,IAAI,SAAS,EAAE;gBACjD,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,YAAY,CAAC,UAAU,CAAC,CAAC;aAC7D;SACF;IACH,CAAC,CAAA;IAEO,kBAAkB,GAAG,CAAC,QAAQ,EAAE,EAAE;IAE1C,CAAC,CAAA;IAED,wBAAwB,CAAC,MAAiB;QACxC,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;QACpB,IAAI,YAAY,GAAG,EAAE,CAAC;QACtB,YAAY,CAAC,QAAQ,CAAC,GAAG,MAAM,CAAC,WAAW,CAAC;QAC5C,YAAY,CAAC,MAAM,CAAC,GAAG,IAAI,CAAC,cAAc,CAAC,GAAG,EAAE,CAAC;QACjD,IAAI,CAAC,wBAAwB,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;QAEjD,iEAAiE;QACjE,KAAI,IAAI,GAAG,IAAI,YAAY,CAAC,MAAM,CAAC,CAAC,gBAAgB,EAAC;YACnD,MAAM,WAAW,GAAI,YAAY,CAAC,MAAM,CAAC,CAAC,gBAAgB,CAAC,GAAG,CAAC,CAAC;YAChE,WAAW,CAAC,YAAY,CAAC,OAAO,CAAC,OAAO,CAAC,OAAO,CAAC,EAAE;gBACjD,IAAG,OAAO,CAAC,gBAAgB,IAAI,YAAY,CAAC,QAAQ,CAAC,IAAI,QAAQ,IAAI,CAAC,OAAO,CAAC,KAAK,EAAC;oBAClF,IAAI,CAAC,aAAa,CAAC,YAAY,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;iBAC7C;YACF,CAAC,CAAC,CAAC;SACL;IAEH,CAAC;IAED,aAAa,CAAC,IAAY;QACxB,gEAAgE;QAChE,2CAA2C;QAC3C,IAAI,SAAS,GAAG,EAAE,CAAC;QACnB,KAAI,IAAI,EAAE,IAAI,IAAI,CAAC,gBAAgB,EAAE,GAAG,CAAC,IAAI,CAAC,CAAC,YAAY,CAAC,OAAO,EAAE;YACnE,IAAI,CAAC,GAAa,IAAI,CAAC,gBAAgB,EAAE,GAAG,CAAC,IAAI,CAAC,CAAC,YAAY,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;YAC5E,IAAG,CAAC,CAAC,OAAO,IAAI,UAAU,EAAE;gBAC1B,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;aAC1C;iBAAM;gBACL,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;aACnB;SACF;QACD,0BAA0B;QAC1B,OAAO,SAAS,CAAC;IACnB,CAAC;IAED,OAAO,CAAC,KAAK;QACX,IAAI,GAAG,GAAG,IAAI,SAAS,EAAE,CAAC,eAAe,CAAC,KAAK,EAAE,WAAW,CAAC,CAAC;QAC9D,gDAAgD;QAChD,OAAO,IAAI,CAAC,SAAS,CAAC,uBAAuB,CAC3C,GAAG,CAAC,eAAe,CAAC,WAAW,CAChC,CAAC;IACJ,CAAC;wGA1KU,gBAAgB;4FAAhB,gBAAgB,+PC1B7B,8xCAyBA;;4FDCa,gBAAgB;kBAL5B,SAAS;+BACE,aAAa;4QAKd,SAAS;sBAAjB,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBACG,GAAG;sBAAX,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBAEI,wBAAwB;sBAAjC,MAAM;gBACG,UAAU;sBAAnB,MAAM","sourcesContent":["import {\n  Component,\n  OnInit,\n  OnChanges,\n  Inject,\n  Input,\n  Output,\n  EventEmitter,\n  ViewEncapsulation,\n  ElementRef,\n} from \"@angular/core\";\nimport { SalesforceService } from \"../../services/salesforce.service\";\nimport { DataService } from '../../services/data.service';\nimport { ActivatedRoute, Params } from \"@angular/router\";\nimport { DomSanitizer, SafeHtml } from \"@angular/platform-browser\";\nimport { ActionMeta } from '../../interfaces/actionMeta';\nimport { Question } from \"../../wrapper\";\nimport { BookletWrapper } from \"../../model/bookletWrapper\";\nimport { StorageService } from '../../services/storage.service';\nimport { ChangeService } from \"../../services/change.service\";\n\n@Component({\n  selector: 'lib-booklet',\n  templateUrl: './booklet.component.html',\n  styleUrls: ['./booklet.component.css']\n})\nexport class BookletComponent implements OnInit {\n  @Input() bookletId: string;\n  @Input() serv: string;\n  @Input() tkn: string;\n  @Input() bookletJSON: any;\n  \n  @Output() handleBookletActionEvent: EventEmitter<any> = new EventEmitter();\n  @Output() handlePage: EventEmitter<any> = new EventEmitter();\n\n  public nxtBooklet: BookletWrapper;\n\n  public booklet: any[] = [];\n  public abItem: any = {};\n  public actions: ActionMeta[] = [];\n  public bookQuestionsMap: any = new Map();\n  private sqOptions: any = new Map();\n  public isAnswerFlag: boolean = false;\n  public spinnerName: string;\n  public spinnerType: string;\n\n  constructor(\n    private sfService: SalesforceService,\n    private dataService: DataService,\n    private storageService: StorageService,\n    private route: ActivatedRoute,\n    private sanitizer: DomSanitizer,\n    private changeService: ChangeService, \n    el: ElementRef\n  ) { \n    this.spinnerName = \"sp1\";\n    this.spinnerType = \"ball-spin-clockwise\";\n  }\n\n  ngOnInit(): void {\n    this.processBooklet();\n  }\n\n  ngOnChanges() {\n    // console.log('inside Questionnaire ngOnChanges');\n    console.log(this.booklet);\n    if(this.booklet == undefined || this.booklet.length == 0) {\n      this.processBooklet();\n    }\n  }\n\n  processBooklet() {\n    if (this.bookletId) {\n      if (this.bookletId.length == 18) {\n        this.readBooklet(this.bookletId);\n      }\n    } else if(this.bookletJSON) {\n      // Try to pass a value from Backend to differentiate the QuestionBook Read and AnswerBook Read\n      this.isAnswerFlag = true;\n\n      if(this.bookletJSON != null || this.bookletJSON != undefined) {\n          // Storing the API response for future use\n          this.storageService.save(this.bookletJSON);\n      }\n      \n      this.booklet = this.bookletJSON.records;\n      this.abItem = this.bookletJSON.answerbook;\n\n      // Process the Sub Question Options - This should be merged with bookQuestionsMap in future\n      for (var sq in this.bookletJSON.sqOptions) {\n        this.sqOptions.set(sq, this.bookletJSON.sqOptions[sq]);\n      }\n\n      // Process the Questions\n      for (var value in this.bookletJSON.bookQuestionsMap) {\n        this.bookQuestionsMap.set(value, this.bookletJSON.bookQuestionsMap[value]);\n      }\n\n      if(this.bookletJSON.questionbook?.Actions__c != undefined) {\n        this.actions = JSON.parse(this.bookletJSON.questionbook.Actions__c);\n      }\n    }\n  }\n\n  private readBooklet = (uuid: string) => {\n    if(this.serv == \"api\") {\n      this.dataService.getAPIData(\n        this.tkn,\n        [\"Booklet\", \"read\", uuid],\n        this.successReadBooklet,\n        this.failureReadBooklet\n      );\n    } else {\n      this.sfService.remoteAction(\n        \"NxtController.process\",\n        [\"Booklet\", \"read\", uuid],\n        this.successReadBooklet,\n        this.failureReadBooklet\n      );\n    }\n  }\n\n  private successReadBooklet = (response) => {\n    console.log('Inside the successReadBooklet');\n    // console.log(response);\n    if(response != null || response != undefined) {\n      // Storing the API response for future use\n      this.storageService.save(response);\n\n      // Try to pass a value from Backend to differentiate the QuestionBook Read and AnswerBook Read\n      // this.isAnswerFlag = true;\n      \n      this.booklet = response.records;\n      this.abItem = response.answerbook;\n\n      // Process the Sub Question Options - This should be merged with bookQuestionsMap in future\n      for (var sq in response.sqOptions) {\n        this.sqOptions.set(sq, response.sqOptions[sq]);\n      }\n\n      // Process the Questions\n      for (var value in response.bookQuestionsMap) {\n        this.bookQuestionsMap.set(value, response.bookQuestionsMap[value]);\n      }\n\n      if(response.questionbook?.Actions__c != undefined) {\n        this.actions = JSON.parse(response.questionbook.Actions__c);\n      }\n    }\n  }\n\n  private failureReadBooklet = (response) => {\n\n  }\n\n  handleBookletActionClick(action:ActionMeta) {\n    console.log(action);\n    let dataToParent = {};\n    dataToParent['action'] = action.eventtoemit;\n    dataToParent['data'] = this.storageService.get();\n    this.handleBookletActionEvent.emit(dataToParent);\n\n    // when clicking the submit button validating the required fields\n    for(let key in dataToParent['data'].bookQuestionsMap){\n      const currentBook  = dataToParent['data'].bookQuestionsMap[key];\n      currentBook.Questions__r.records.forEach(element => {\n        if(element.Error_Message__c && dataToParent['action'] == 'submit' && !element.input){\n          this.changeService.submitChange(element.Id);\n        }\n       });\n    }\n\n  }\n\n  readQuestions(qbId: string) {\n    // console.log('inside BookletComponent.readQuestions ' + qbId);\n    // console.log(this.bookQuestionsMap.size);\n    let questions = [];\n    for(var sq in this.bookQuestionsMap?.get(qbId).Questions__r.records) {\n      let q: Question = this.bookQuestionsMap?.get(qbId).Questions__r.records[sq];\n      if(q.Type__c == 'Dropdown') {\n        questions.push(this.sqOptions.get(q.Id));\n      } else {\n        questions.push(q);\n      }\n    }\n    // console.log(questions);\n    return questions;\n  }\n\n  getText(value) {\n    var doc = new DOMParser().parseFromString(value, \"text/html\");\n    //console.log( doc.documentElement.textContent);\n    return this.sanitizer.bypassSecurityTrustHtml(\n      doc.documentElement.textContent\n    );\n  }\n}\n","<ngx-spinner [name]=\"spinnerName\" [type]=\"spinnerType\"></ngx-spinner>\n<!-- Booklet Handling-->\n<div *ngFor=\"let qb of booklet\">\n    <!-- MR Commented below code to ensure single JSON for UNCONDITIONAL Booklets -->\n    <!-- <lib-questionnaire [serv]=\"serv\" [qbId]=\"qb.Id\" [tkn]=\"tkn\"></lib-questionnaire> -->\n    <div *ngFor=\"let ques of qb.Questions__r.records\" [class]=\"qb.isShengel__c ? 'questiondiv1' : 'questiondiv1 padd-bottom'\">\n        <div class=\"questiondiv2\">\n            <div *ngIf=\"!ques.Is_Title__c\" [class]=\"qb.isShengel__c ? 'header-style' : 'question-f-size additional'\">\n                <div [innerHTML]=\"getText(ques?.Question_Text__c)\" >\n                    {{ ques?.Question_Text__c }}\n                </div>\n            </div>\n            <lib-questionbook [qbItem]=\"qb\" [questionItem]=\"ques\" [questions]=\"readQuestions(qb.Id)\"></lib-questionbook>\n        </div>\n    </div>\n</div>\n\n<!-- Group Actions -->\n<div class=\"align-submit-row\" *ngIf=\"abItem.Status__c != 'Completed'\">\n    <div *ngFor=\"let action of actions; let i = index\">\n        <button (click)=\"handleBookletActionClick(action)\" [ngClass]=\"{'first-button': i === 0, 'second-button': i === 1}\">\n            {{ action.name }}\n        </button>\n    </div>\n</div>\n"]}
|
|
183
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"booklet.component.js","sourceRoot":"","sources":["../../../../../../projects/nxt-app/src/lib/pages/booklet/booklet.component.ts","../../../../../../projects/nxt-app/src/lib/pages/booklet/booklet.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  OnInit,\n  OnChanges,\n  Inject,\n  Input,\n  Output,\n  EventEmitter,\n  ViewEncapsulation,\n  ElementRef\n} from \"@angular/core\";\nimport { SalesforceService } from \"../../services/salesforce.service\";\nimport { DataService } from '../../services/data.service';\nimport { ActivatedRoute, Params } from \"@angular/router\";\nimport { DomSanitizer, SafeHtml } from \"@angular/platform-browser\";\nimport { ActionMeta } from '../../interfaces/actionMeta';\nimport { Question } from \"../../wrapper\";\nimport { BookletWrapper } from \"../../model/bookletWrapper\";\nimport { StorageService } from '../../services/storage.service';\nimport { ChangeService } from \"../../services/change.service\";\n\n@Component({\n  selector: 'lib-booklet',\n  templateUrl: './booklet.component.html',\n  styleUrls: ['./booklet.component.css']\n})\nexport class BookletComponent implements OnInit {\n  @Input() bookletId: string;\n  @Input() serv: string;\n  @Input() tkn: string;\n  @Input() bookletJSON: any;\n  @Input() dropdownDependentData:any;\n  @Input() labelValue:string;\n  \n  @Output() handleBookletActionEvent: EventEmitter<any> = new EventEmitter();\n  @Output() handlePage: EventEmitter<any> = new EventEmitter();\n  @Output() hadleDropDownDependent:EventEmitter<any> = new EventEmitter();\n\n  public nxtBooklet: BookletWrapper;\n\n  public booklet: any[] = [];\n  public abItem: any = {};\n  public actions: ActionMeta[] = [];\n  public bookQuestionsMap: any = new Map();\n  private sqOptions: any = new Map();\n  public isAnswerFlag: boolean = false;\n  public spinnerName: string;\n  public spinnerType: string;\n\n  constructor(\n    private sfService: SalesforceService,\n    private dataService: DataService,\n    private storageService: StorageService,\n    private route: ActivatedRoute,\n    private sanitizer: DomSanitizer,\n    private changeService: ChangeService, \n    el: ElementRef\n  ) { \n    this.spinnerName = \"sp1\";\n    this.spinnerType = \"ball-spin-clockwise\";\n    console.log('dropdownDependentData',this.dropdownDependentData);\n  }\n\n  ngOnInit(): void {\n    this.processBooklet();\n  }\n\n  ngOnChanges() {\n    console.log(this.booklet);\n   //if(this.booklet == undefined || this.booklet.length == 0) {\n      this.processBooklet();\n   // }\n  }\n\n  processBooklet() {\n    if (this.bookletId) {\n      if (this.bookletId.length == 18) {\n        this.readBooklet(this.bookletId);\n      }\n    } else if(this.bookletJSON) {\n      // Try to pass a value from Backend to differentiate the QuestionBook Read and AnswerBook Read\n      this.isAnswerFlag = true;\n\n      if(this.bookletJSON != null || this.bookletJSON != undefined) {\n          // Storing the API response for future use\n          this.storageService.save(this.bookletJSON);\n      }\n      \n      this.booklet = this.bookletJSON.records;\n      this.abItem = this.bookletJSON.answerbook;\n\n      // Process the Sub Question Options - This should be merged with bookQuestionsMap in future\n      for (var sq in this.bookletJSON.sqOptions) {\n        this.sqOptions.set(sq, this.bookletJSON.sqOptions[sq]);\n      }\n\n      // Process the Questions\n      for (var value in this.bookletJSON.bookQuestionsMap) {\n        this.bookQuestionsMap.set(value, this.bookletJSON.bookQuestionsMap[value]);\n      }\n\n      if(this.bookletJSON.questionbook?.Actions__c != undefined) {\n        this.actions = JSON.parse(this.bookletJSON.questionbook.Actions__c);\n      }\n    }\n  }\n\n  private readBooklet = (uuid: string) => {\n    if(this.serv == \"api\") {\n      this.dataService.getAPIData(\n        this.tkn,\n        [\"Booklet\", \"read\", uuid],\n        this.successReadBooklet,\n        this.failureReadBooklet\n      );\n    } else {\n      this.sfService.remoteAction(\n        \"NxtController.process\",\n        [\"Booklet\", \"read\", uuid],\n        this.successReadBooklet,\n        this.failureReadBooklet\n      );\n    }\n  }\n\n  private successReadBooklet = (response) => {\n    console.log('Inside the successReadBooklet');\n    // console.log(response);\n    if(response != null || response != undefined) {\n      // Storing the API response for future use\n      this.storageService.save(response);\n\n      // Try to pass a value from Backend to differentiate the QuestionBook Read and AnswerBook Read\n      // this.isAnswerFlag = true;\n      \n      this.booklet = response.records;\n      this.abItem = response.answerbook;\n\n      // Process the Sub Question Options - This should be merged with bookQuestionsMap in future\n      for (var sq in response.sqOptions) {\n        this.sqOptions.set(sq, response.sqOptions[sq]);\n      }\n\n      // Process the Questions\n      for (var value in response.bookQuestionsMap) {\n        this.bookQuestionsMap.set(value, response.bookQuestionsMap[value]);\n      }\n\n      if(response.questionbook?.Actions__c != undefined) {\n        this.actions = JSON.parse(response.questionbook.Actions__c);\n      }\n    }\n  }\n\n  private failureReadBooklet = (response) => {\n\n  }\n\n  handleBookletActionClick(action:ActionMeta) {\n    console.log(action);\n    let dataToParent = {};\n    dataToParent['action'] = action.eventtoemit;\n    dataToParent['data'] = this.storageService.get();\n    this.handleBookletActionEvent.emit(dataToParent);\n\n    // when clicking the submit button validating the required fields\n    for(let key in dataToParent['data'].bookQuestionsMap){\n      const currentBook  = dataToParent['data'].bookQuestionsMap[key];\n      currentBook.Questions__r.records.forEach(element => {\n        if(element.Error_Message__c && dataToParent['action'] == 'submit' && !element.input){\n          this.changeService.submitChange(element.Id);\n        }\n       });\n    }\n\n  }\n\n  readQuestions(qbId: string) {\n    // console.log('inside BookletComponent.readQuestions ' + qbId);\n    // console.log(this.bookQuestionsMap.size);\n    let questions = [];\n    for(var sq in this.bookQuestionsMap?.get(qbId).Questions__r.records) {\n      let q: Question = this.bookQuestionsMap?.get(qbId).Questions__r.records[sq];\n      if(q.Type__c == 'Dropdown') {\n        questions.push(this.sqOptions.get(q.Id));\n      } else {\n        questions.push(q);\n      }\n    }\n    // console.log(questions);\n    return questions;\n  }\n\n  getText(value) {\n    var doc = new DOMParser().parseFromString(value, \"text/html\");\n    //console.log( doc.documentElement.textContent);\n    return this.sanitizer.bypassSecurityTrustHtml(\n      doc.documentElement.textContent\n    );\n  }\n  getDropDown(event:any){\n    this.hadleDropDownDependent.emit(event);\n  }\n}\n","<ngx-spinner [name]=\"spinnerName\" [type]=\"spinnerType\"></ngx-spinner>\n<!-- Booklet Handling-->\n<div *ngFor=\"let qb of booklet\">\n    <!-- MR Commented below code to ensure single JSON for UNCONDITIONAL Booklets -->\n    <!-- <lib-questionnaire [serv]=\"serv\" [qbId]=\"qb.Id\" [tkn]=\"tkn\"></lib-questionnaire> -->\n    <div *ngFor=\"let ques of qb.Questions__r.records\" [class]=\"qb.isShengel__c ? 'questiondiv1' : 'questiondiv1 padd-bottom'\">\n        <div class=\"questiondiv2\">\n            <div *ngIf=\"!ques.Is_Title__c\" [class]=\"qb.isShengel__c ? 'header-style' : 'question-f-size additional'\">\n                <div [innerHTML]=\"getText(ques?.Question_Text__c)\" >\n                    {{ ques?.Question_Text__c }}\n                </div>\n            </div>\n            <lib-questionbook [qbItem]=\"qb\" [labelValue]=\"labelValue\" [questionItem]=\"ques\" [questions]=\"readQuestions(qb.Id)\"  (handleDropDown)=\"getDropDown($event)\"></lib-questionbook>\n        </div>\n    </div>\n</div>\n\n<!-- Group Actions -->\n<div class=\"align-submit-row\" *ngIf=\"abItem.Status__c != 'Completed'\">\n    <div *ngFor=\"let action of actions; let i = index\">\n        <button (click)=\"handleBookletActionClick(action)\" [ngClass]=\"{'first-button': i === 0, 'second-button': i === 1}\">\n            {{ action.name }}\n        </button>\n    </div>\n</div>\n"]}
|