@rangertechnologies/ngnxt 2.1.76 → 2.1.78
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +29 -29
- package/esm2022/lib/ar.i18n.mjs +29 -29
- package/esm2022/lib/components/custom-button/custom-button.component.mjs +39 -39
- package/esm2022/lib/components/custom-calendar/custom-calendar.component.mjs +366 -366
- package/esm2022/lib/components/custom-date/custom-date.component.mjs +47 -47
- package/esm2022/lib/components/custom-date-picker/custom-date-picker.component.mjs +48 -48
- package/esm2022/lib/components/custom-dropdown/custom-dropdown.component.mjs +219 -212
- package/esm2022/lib/components/custom-image/custom-image.component.mjs +34 -34
- package/esm2022/lib/components/custom-input/custom-input.component.mjs +93 -93
- package/esm2022/lib/components/custom-label/custom-label.component.mjs +21 -21
- package/esm2022/lib/components/custom-model/custom-model.component.mjs +48 -48
- package/esm2022/lib/components/custom-radio/custom-radio.component.mjs +115 -115
- package/esm2022/lib/components/custom-table/custom-table.component.mjs +169 -169
- package/esm2022/lib/components/custom-text-area/custom-text-area.component.mjs +65 -65
- package/esm2022/lib/components/custom-time/custom-time.component.mjs +61 -61
- package/esm2022/lib/components/dependent-table/dependent-table.component.mjs +42 -42
- package/esm2022/lib/components/dropdown-with-flag/dropdown-with-flag.component.mjs +39 -39
- package/esm2022/lib/components/file-upload/file-upload.component.mjs +233 -233
- package/esm2022/lib/components/file-view/file-view.component.mjs +46 -46
- package/esm2022/lib/components/loader/loader.component.mjs +23 -23
- package/esm2022/lib/components/pick-location/pick-location.component.mjs +188 -188
- package/esm2022/lib/components/search-box/search-box.component.mjs +130 -130
- package/esm2022/lib/components/table-appendix/table-appendix.component.mjs +123 -123
- package/esm2022/lib/directives/componenthost/componenthost.directive.mjs +19 -19
- package/esm2022/lib/en.i18n.mjs +29 -29
- package/esm2022/lib/i18n-config.service.mjs +4 -4
- package/esm2022/lib/i18n.component.mjs +47 -47
- package/esm2022/lib/i18n.module.mjs +38 -38
- package/esm2022/lib/i18n.pipe.mjs +25 -25
- package/esm2022/lib/i18n.service.mjs +56 -56
- package/esm2022/lib/interfaces/actionMeta.mjs +2 -2
- package/esm2022/lib/interfaces/apimeta.mjs +2 -2
- package/esm2022/lib/interfaces/dependencyMeta.mjs +2 -2
- package/esm2022/lib/model/bookletWrapper.mjs +9 -9
- package/esm2022/lib/model/changeWrapper.mjs +11 -11
- package/esm2022/lib/model/errorWrapper.mjs +6 -6
- package/esm2022/lib/model/tableWrapper.mjs +20 -20
- package/esm2022/lib/nxt-app.component.mjs +22 -22
- package/esm2022/lib/nxt-app.module.mjs +352 -352
- package/esm2022/lib/nxt-app.service.mjs +14 -14
- package/esm2022/lib/pages/booklet/booklet.component.mjs +541 -541
- package/esm2022/lib/pages/questionbook/questionbook.component.mjs +407 -407
- package/esm2022/lib/pages/questionnaire/questionnaire.component.mjs +2373 -2373
- package/esm2022/lib/pages/summary-page/summary-page.component.mjs +76 -76
- package/esm2022/lib/pipe/get-value.pipe.mjs +50 -50
- package/esm2022/lib/sample.mjs +3430 -3430
- package/esm2022/lib/services/change.service.mjs +53 -53
- package/esm2022/lib/services/data.service.mjs +80 -80
- package/esm2022/lib/services/salesforce.service.mjs +46 -46
- package/esm2022/lib/services/shared.service.mjs +100 -100
- package/esm2022/lib/services/storage.service.mjs +44 -44
- package/esm2022/lib/tam.i18n.mjs +29 -29
- package/esm2022/lib/wrapper.mjs +175 -175
- package/esm2022/public-api.mjs +15 -15
- package/esm2022/rangertechnologies-ngnxt.mjs +4 -4
- package/fesm2022/rangertechnologies-ngnxt.mjs +9812 -9805
- package/fesm2022/rangertechnologies-ngnxt.mjs.map +1 -1
- package/index.d.ts +5 -5
- package/lib/ar.i18n.d.ts +24 -24
- package/lib/components/custom-button/custom-button.component.d.ts +16 -16
- package/lib/components/custom-calendar/custom-calendar.component.d.ts +65 -65
- package/lib/components/custom-date/custom-date.component.d.ts +18 -18
- package/lib/components/custom-date-picker/custom-date-picker.component.d.ts +19 -19
- package/lib/components/custom-dropdown/custom-dropdown.component.d.ts +39 -39
- package/lib/components/custom-image/custom-image.component.d.ts +13 -13
- package/lib/components/custom-input/custom-input.component.d.ts +31 -31
- package/lib/components/custom-label/custom-label.component.d.ts +10 -10
- package/lib/components/custom-model/custom-model.component.d.ts +19 -19
- package/lib/components/custom-radio/custom-radio.component.d.ts +33 -33
- package/lib/components/custom-table/custom-table.component.d.ts +43 -43
- package/lib/components/custom-text-area/custom-text-area.component.d.ts +22 -22
- package/lib/components/custom-time/custom-time.component.d.ts +18 -18
- package/lib/components/dependent-table/dependent-table.component.d.ts +15 -15
- package/lib/components/dropdown-with-flag/dropdown-with-flag.component.d.ts +16 -16
- package/lib/components/file-upload/file-upload.component.d.ts +42 -42
- package/lib/components/file-view/file-view.component.d.ts +16 -16
- package/lib/components/loader/loader.component.d.ts +11 -11
- package/lib/components/pick-location/pick-location.component.d.ts +42 -42
- package/lib/components/search-box/search-box.component.d.ts +40 -40
- package/lib/components/table-appendix/table-appendix.component.d.ts +30 -30
- package/lib/directives/componenthost/componenthost.directive.d.ts +8 -8
- package/lib/en.i18n.d.ts +24 -24
- package/lib/i18n-config.service.d.ts +2 -2
- package/lib/i18n.component.d.ts +11 -11
- package/lib/i18n.module.d.ts +9 -9
- package/lib/i18n.pipe.d.ts +10 -10
- package/lib/i18n.service.d.ts +14 -14
- package/lib/interfaces/actionMeta.d.ts +5 -5
- package/lib/interfaces/apimeta.d.ts +14 -13
- package/lib/interfaces/dependencyMeta.d.ts +8 -8
- package/lib/model/bookletWrapper.d.ts +5 -5
- package/lib/model/changeWrapper.d.ts +10 -10
- package/lib/model/errorWrapper.d.ts +5 -5
- package/lib/model/tableWrapper.d.ts +18 -18
- package/lib/nxt-app.component.d.ts +8 -8
- package/lib/nxt-app.module.d.ts +46 -46
- package/lib/nxt-app.service.d.ts +6 -6
- package/lib/pages/booklet/booklet.component.d.ts +68 -68
- package/lib/pages/questionbook/questionbook.component.d.ts +66 -66
- package/lib/pages/questionnaire/questionnaire.component.d.ts +218 -218
- package/lib/pages/summary-page/summary-page.component.d.ts +20 -20
- package/lib/pipe/get-value.pipe.d.ts +7 -7
- package/lib/sample.d.ts +10 -10
- package/lib/services/change.service.d.ts +22 -22
- package/lib/services/data.service.d.ts +13 -13
- package/lib/services/salesforce.service.d.ts +11 -11
- package/lib/services/shared.service.d.ts +15 -15
- package/lib/services/storage.service.d.ts +13 -13
- package/lib/tam.i18n.d.ts +24 -24
- package/lib/wrapper.d.ts +203 -203
- package/package.json +1 -1
- package/public-api.d.ts +10 -10
- package/rangertechnologies-ngnxt-2.1.78.tgz +0 -0
- package/rangertechnologies-ngnxt-2.1.76.tgz +0 -0
|
@@ -1,169 +1,169 @@
|
|
|
1
|
-
import { Component, EventEmitter, Input, Output } from '@angular/core';
|
|
2
|
-
import * as i0 from "@angular/core";
|
|
3
|
-
import * as i1 from "../../services/change.service";
|
|
4
|
-
import * as i2 from "../../i18n.service";
|
|
5
|
-
import * as i3 from "../../services/salesforce.service";
|
|
6
|
-
import * as i4 from "../../services/data.service";
|
|
7
|
-
import * as i5 from "@angular/common";
|
|
8
|
-
import * as i6 from "@angular/forms";
|
|
9
|
-
import * as i7 from "../../pipe/get-value.pipe";
|
|
10
|
-
export class CustomTableComponent {
|
|
11
|
-
changeService;
|
|
12
|
-
i18nService;
|
|
13
|
-
sfService;
|
|
14
|
-
dataService;
|
|
15
|
-
question;
|
|
16
|
-
valueChange = new EventEmitter();
|
|
17
|
-
tableInfo;
|
|
18
|
-
tableHeader = [];
|
|
19
|
-
tableData = [];
|
|
20
|
-
addRowColSpan;
|
|
21
|
-
tableSize; // HA 28DEC23 table size declaration
|
|
22
|
-
objName;
|
|
23
|
-
filterLogic;
|
|
24
|
-
fieldMeta;
|
|
25
|
-
firStr;
|
|
26
|
-
searchBox = false;
|
|
27
|
-
apiMeta;
|
|
28
|
-
options;
|
|
29
|
-
isDisabled = true;
|
|
30
|
-
subscription;
|
|
31
|
-
labelField;
|
|
32
|
-
constructor(changeService, i18nService, sfService, dataService) {
|
|
33
|
-
this.changeService = changeService;
|
|
34
|
-
this.i18nService = i18nService;
|
|
35
|
-
this.sfService = sfService;
|
|
36
|
-
this.dataService = dataService;
|
|
37
|
-
}
|
|
38
|
-
// RS 09DEC24 Changed keys
|
|
39
|
-
ngOnInit() {
|
|
40
|
-
this.tableHeader = JSON.parse(this.question['fieldsMeta']);
|
|
41
|
-
this.tableSize = 10 / this.tableHeader.length;
|
|
42
|
-
// 12JUN24 - default table value
|
|
43
|
-
if (this.question?.input) {
|
|
44
|
-
this.tableData = this.question?.input;
|
|
45
|
-
}
|
|
46
|
-
if (this.apiMeta !== undefined) {
|
|
47
|
-
this.options = [];
|
|
48
|
-
let apiObj = JSON.parse(this.apiMeta);
|
|
49
|
-
this.labelField = apiObj.field;
|
|
50
|
-
if (apiObj.endpoint) {
|
|
51
|
-
this.dataService.apiResponse(apiObj.endpoint)?.subscribe((apiResponse) => {
|
|
52
|
-
let responses;
|
|
53
|
-
if (apiObj.variable) {
|
|
54
|
-
// VD 22May24 - handling multiple child objects
|
|
55
|
-
responses = this.dataService.getValue(apiResponse, apiObj.variable);
|
|
56
|
-
let results = [];
|
|
57
|
-
// HA 19JAN24 To avoid undefined error in console
|
|
58
|
-
for (let i = 0; i < responses?.length; i++) {
|
|
59
|
-
var resp = responses[i];
|
|
60
|
-
results.push(resp);
|
|
61
|
-
}
|
|
62
|
-
this.options = results;
|
|
63
|
-
}
|
|
64
|
-
else { // VD 19JAN24 - if response has value(which is array) only
|
|
65
|
-
responses = apiResponse;
|
|
66
|
-
this.options = responses;
|
|
67
|
-
}
|
|
68
|
-
this.options = this.options.map((obj) => ({ ...obj, edit: false }));
|
|
69
|
-
// Reference https://www.npmjs.com/package/@ng-select/ng-select
|
|
70
|
-
this.tableData = this.options;
|
|
71
|
-
console.log('tableData', this.tableData);
|
|
72
|
-
});
|
|
73
|
-
}
|
|
74
|
-
// VD NOV23 - handle the dependent update for dropdown
|
|
75
|
-
let sourceId = apiObj.sourceQuestionId;
|
|
76
|
-
let field = apiObj.field; // VD 13MAY24 - dynamic field changes
|
|
77
|
-
if (sourceId) {
|
|
78
|
-
// // VD 10May24 Subscribe for the changes
|
|
79
|
-
this.subscription = this.changeService.changeAnnounced$.subscribe((changeValue) => {
|
|
80
|
-
if (changeValue != undefined) {
|
|
81
|
-
if (changeValue.valueObj != undefined && changeValue.fromQuestionId == apiObj.sourceQuestionId) {
|
|
82
|
-
console.log('changes happen');
|
|
83
|
-
this.options = this.options.map((obj) => ({ ...obj, edit: false }));
|
|
84
|
-
let item = changeValue.valueObj;
|
|
85
|
-
let validItem = true;
|
|
86
|
-
// VD 13MAY24 - bind dynamic field
|
|
87
|
-
if (this.tableData.length > 0) {
|
|
88
|
-
this.tableData.forEach(element => {
|
|
89
|
-
// VD 26Jun24 - to handle multiple objects
|
|
90
|
-
const objElementValue = this.dataService.getValue(element, field);
|
|
91
|
-
const objItemValue = this.dataService.getValue(item, field);
|
|
92
|
-
if (objElementValue == objItemValue) {
|
|
93
|
-
validItem = false;
|
|
94
|
-
}
|
|
95
|
-
});
|
|
96
|
-
}
|
|
97
|
-
if (validItem) {
|
|
98
|
-
if (this.tableData.length > 0) {
|
|
99
|
-
this.tableData = [...this.tableData, item];
|
|
100
|
-
this.emitTableDataValue(this.tableData);
|
|
101
|
-
}
|
|
102
|
-
else {
|
|
103
|
-
this.tableData.push(item);
|
|
104
|
-
this.emitTableDataValue(this.tableData);
|
|
105
|
-
}
|
|
106
|
-
}
|
|
107
|
-
}
|
|
108
|
-
this.changeService.confirmChange(apiObj.sourceQuestionId);
|
|
109
|
-
}
|
|
110
|
-
});
|
|
111
|
-
}
|
|
112
|
-
}
|
|
113
|
-
console.log('tableData', this.tableData);
|
|
114
|
-
console.log('tableHeader', this.tableHeader);
|
|
115
|
-
console.log('tableInfo', this.tableInfo);
|
|
116
|
-
}
|
|
117
|
-
addRow() {
|
|
118
|
-
let newItem = {};
|
|
119
|
-
this.tableHeader.forEach(item => {
|
|
120
|
-
if (item.apiName) {
|
|
121
|
-
newItem[item.apiName] = "";
|
|
122
|
-
}
|
|
123
|
-
});
|
|
124
|
-
const updatedTableData = [...this.tableData, newItem];
|
|
125
|
-
this.tableData = updatedTableData;
|
|
126
|
-
this.emitTableDataValue(updatedTableData);
|
|
127
|
-
}
|
|
128
|
-
updateRadio(item, value) {
|
|
129
|
-
item.value = value;
|
|
130
|
-
this.emitTableDataValue(this.tableData);
|
|
131
|
-
}
|
|
132
|
-
// VD 23Aug24 handle Type
|
|
133
|
-
updateLabel(rowIndex, label, value) {
|
|
134
|
-
this.tableData[rowIndex][label] = value;
|
|
135
|
-
this.emitTableDataValue(this.tableData);
|
|
136
|
-
}
|
|
137
|
-
deleteRow(rowIndex) {
|
|
138
|
-
this.tableData.splice(rowIndex, 1);
|
|
139
|
-
}
|
|
140
|
-
editRow(rowIndex) {
|
|
141
|
-
var a = 0;
|
|
142
|
-
this.tableData.forEach(element => {
|
|
143
|
-
if (a === rowIndex) {
|
|
144
|
-
element.edit = true;
|
|
145
|
-
}
|
|
146
|
-
a++;
|
|
147
|
-
});
|
|
148
|
-
}
|
|
149
|
-
updateNumber(item, label, value) {
|
|
150
|
-
item.value[label] = value;
|
|
151
|
-
this.emitTableDataValue(this.tableData);
|
|
152
|
-
}
|
|
153
|
-
emitTableDataValue(updatedTableData) {
|
|
154
|
-
this.valueChange.emit(updatedTableData);
|
|
155
|
-
}
|
|
156
|
-
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: CustomTableComponent, deps: [{ token: i1.ChangeService }, { token: i2.I18nService }, { token: i3.SalesforceService }, { token: i4.DataService }], target: i0.ɵɵFactoryTarget.Component });
|
|
157
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: CustomTableComponent, selector: "app-custom-table", inputs: { question: "question", apiMeta: "apiMeta" }, outputs: { valueChange: "valueChange" }, ngImport: i0, template: "<table class=\"table table-striped table-bordered\">\n <thead>\n <!-- HA 28DEC23 changed table header values and changed table size logic to evenly visible -->\n <!-- <th><input type=\"checkbox\" (change)=\"selectAll($event.target.checked)\"></th> -->\n <th *ngFor=\"let header of tableHeader; let hi = index\" [class]=\"'col-md-' + tableSize\">\n {{ header.label }}\n </th>\n <th class=\"col-md-2\" colspan=\"2\">Actions</th>\n </thead>\n <tbody *ngIf=\"tableData\">\n <tr *ngFor=\"let item of tableData; let i = index\">\n <!-- <td><input type=\"checkbox\" [(ngModel)]=\"item.selected\" (change)=\"selectItem(item)\"></td> -->\n <td *ngFor=\"let header of tableHeader; let j = index\">\n <div *ngIf=\"header.fldType === 'imagetext'\" [class]=\"'col-md-' + header.size\" style=\"display: flex;\">\n <img style=\"width: 35px; height: 32px; margin-right: 5px;\" [src]=\"item.imageSrc\" [alt]=\"item.altText\">\n <input type=\"text\" [(ngModel)]=\"item[header.fieldName]\" (ngModelChange)=\"updateLabel(i, header.fieldName, item[header.fieldName])\" class=\"she-line-input table-input\">\n </div>\n <div *ngIf=\"header.fldType === 'image'\" [class]=\"'col-md-' + header.size\">\n <img style=\"width: 35px; height: 32px; margin-right: 5px;\" [src]=\"item[header.fieldName]\" [alt]=\"item.altText\">\n </div>\n <!--VD 23Aug24 handle readOnly -->\n <div *ngIf=\"header.fldType === 'Text' || header.fldType === 'Text'\">\n <!-- VD 26Jun24 - pipe change to handle multiple objects-->\n <input type=\"text\" [readonly]=\"header.readOnly\" [disabled]=\"!item.edit\" [ngClass]=\"{'editInput': item.edit && !header.readOnly}\" [ngModel]=\"'' | getValue: item : header.apiName\" (ngModelChange)=\"updateLabel(i, header.apiName,$event)\" class=\"she-line-input table-input\">\n </div>\n <!--VD 23Aug24 handle Number Type -->\n <div *ngIf=\"header.fldType === 'Number' || header.fldType === 'Number'\">\n <!-- VD 26Jun24 - pipe change to handle multiple objects-->\n <input type=\"Number\" [readonly]=\"header.readOnly\" [disabled]=\"!item.edit\" [ngClass]=\"{'editInput': item.edit && !header.readOnly}\" [ngModel]=\"'' | getValue: item : header.apiName\" (ngModelChange)=\"updateLabel(i, header.apiName,$event)\" class=\"she-line-input table-input\">\n </div>\n <div *ngIf=\"header.fldType === 'radio'\" [class]=\"'col-md-' + header.size\">\n <input type=\"radio\" [name]=\"item.name\" [checked]=\"item.value == header.fieldName\" (click)=\"updateRadio(item, header.fieldName)\">\n </div>\n </td>\n <td class=\"action\">\n <a style=\"display: flex; justify-content: space-evenly;\" (click)=\"editRow(i)\"><img src=\"https://rnxt.s3.amazonaws.com/MytIcon/icon-edit%402x.png\" class=\"icon-edit1\" /><span>Edit</span></a>\n </td>\n <td class=\"action\">\n <a style=\"display: flex; justify-content: space-evenly;\" (click)=\"deleteRow(i)\"><img src=\"https://rnxt.s3.amazonaws.com/MytIcon/icon-delete%402x.png\" class=\"deleteIcon\"/><span>Delete</span></a>\n </td>\n </tr>\n </tbody>\n</table>\n<div (click)=\"addRow()\" class=\"addRowClass\"><div class=\"circle-button\">+</div></div>", 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;text-align:center}.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}.addRowClass{float:right;margin-right:15%}.editInput{border-bottom:1px solid red!important}.action,.addRowClass{cursor:pointer}.action :hover{color:red}.circle-button{width:50px;height:50px;border-radius:50%;background-color:#03a9f4;color:#fff;font-size:25px;display:flex;justify-content:center;align-items:center;cursor:pointer;box-shadow:0 2px 4px #0003}.circle-button:hover{background-color:#03a9f4}\n"], dependencies: [{ kind: "directive", type: i5.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i5.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i6.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i6.NumberValueAccessor, selector: "input[type=number][formControlName],input[type=number][formControl],input[type=number][ngModel]" }, { kind: "directive", type: i6.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i6.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "pipe", type: i7.GetValuePipe, name: "getValue" }] });
|
|
158
|
-
}
|
|
159
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: CustomTableComponent, decorators: [{
|
|
160
|
-
type: Component,
|
|
161
|
-
args: [{ selector: 'app-custom-table', template: "<table class=\"table table-striped table-bordered\">\n <thead>\n <!-- HA 28DEC23 changed table header values and changed table size logic to evenly visible -->\n <!-- <th><input type=\"checkbox\" (change)=\"selectAll($event.target.checked)\"></th> -->\n <th *ngFor=\"let header of tableHeader; let hi = index\" [class]=\"'col-md-' + tableSize\">\n {{ header.label }}\n </th>\n <th class=\"col-md-2\" colspan=\"2\">Actions</th>\n </thead>\n <tbody *ngIf=\"tableData\">\n <tr *ngFor=\"let item of tableData; let i = index\">\n <!-- <td><input type=\"checkbox\" [(ngModel)]=\"item.selected\" (change)=\"selectItem(item)\"></td> -->\n <td *ngFor=\"let header of tableHeader; let j = index\">\n <div *ngIf=\"header.fldType === 'imagetext'\" [class]=\"'col-md-' + header.size\" style=\"display: flex;\">\n <img style=\"width: 35px; height: 32px; margin-right: 5px;\" [src]=\"item.imageSrc\" [alt]=\"item.altText\">\n <input type=\"text\" [(ngModel)]=\"item[header.fieldName]\" (ngModelChange)=\"updateLabel(i, header.fieldName, item[header.fieldName])\" class=\"she-line-input table-input\">\n </div>\n <div *ngIf=\"header.fldType === 'image'\" [class]=\"'col-md-' + header.size\">\n <img style=\"width: 35px; height: 32px; margin-right: 5px;\" [src]=\"item[header.fieldName]\" [alt]=\"item.altText\">\n </div>\n <!--VD 23Aug24 handle readOnly -->\n <div *ngIf=\"header.fldType === 'Text' || header.fldType === 'Text'\">\n <!-- VD 26Jun24 - pipe change to handle multiple objects-->\n <input type=\"text\" [readonly]=\"header.readOnly\" [disabled]=\"!item.edit\" [ngClass]=\"{'editInput': item.edit && !header.readOnly}\" [ngModel]=\"'' | getValue: item : header.apiName\" (ngModelChange)=\"updateLabel(i, header.apiName,$event)\" class=\"she-line-input table-input\">\n </div>\n <!--VD 23Aug24 handle Number Type -->\n <div *ngIf=\"header.fldType === 'Number' || header.fldType === 'Number'\">\n <!-- VD 26Jun24 - pipe change to handle multiple objects-->\n <input type=\"Number\" [readonly]=\"header.readOnly\" [disabled]=\"!item.edit\" [ngClass]=\"{'editInput': item.edit && !header.readOnly}\" [ngModel]=\"'' | getValue: item : header.apiName\" (ngModelChange)=\"updateLabel(i, header.apiName,$event)\" class=\"she-line-input table-input\">\n </div>\n <div *ngIf=\"header.fldType === 'radio'\" [class]=\"'col-md-' + header.size\">\n <input type=\"radio\" [name]=\"item.name\" [checked]=\"item.value == header.fieldName\" (click)=\"updateRadio(item, header.fieldName)\">\n </div>\n </td>\n <td class=\"action\">\n <a style=\"display: flex; justify-content: space-evenly;\" (click)=\"editRow(i)\"><img src=\"https://rnxt.s3.amazonaws.com/MytIcon/icon-edit%402x.png\" class=\"icon-edit1\" /><span>Edit</span></a>\n </td>\n <td class=\"action\">\n <a style=\"display: flex; justify-content: space-evenly;\" (click)=\"deleteRow(i)\"><img src=\"https://rnxt.s3.amazonaws.com/MytIcon/icon-delete%402x.png\" class=\"deleteIcon\"/><span>Delete</span></a>\n </td>\n </tr>\n </tbody>\n</table>\n<div (click)=\"addRow()\" class=\"addRowClass\"><div class=\"circle-button\">+</div></div>", 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;text-align:center}.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}.addRowClass{float:right;margin-right:15%}.editInput{border-bottom:1px solid red!important}.action,.addRowClass{cursor:pointer}.action :hover{color:red}.circle-button{width:50px;height:50px;border-radius:50%;background-color:#03a9f4;color:#fff;font-size:25px;display:flex;justify-content:center;align-items:center;cursor:pointer;box-shadow:0 2px 4px #0003}.circle-button:hover{background-color:#03a9f4}\n"] }]
|
|
162
|
-
}], ctorParameters: function () { return [{ type: i1.ChangeService }, { type: i2.I18nService }, { type: i3.SalesforceService }, { type: i4.DataService }]; }, propDecorators: { question: [{
|
|
163
|
-
type: Input
|
|
164
|
-
}], valueChange: [{
|
|
165
|
-
type: Output
|
|
166
|
-
}], apiMeta: [{
|
|
167
|
-
type: Input
|
|
168
|
-
}] } });
|
|
169
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"custom-table.component.js","sourceRoot":"","sources":["../../../../../../projects/nxt-app/src/lib/components/custom-table/custom-table.component.ts","../../../../../../projects/nxt-app/src/lib/components/custom-table/custom-table.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\n// HA 19DEC23 imported translation service\nimport { I18nService } from '../../i18n.service';\nimport { TableWrapper } from '../../model/tableWrapper';\nimport { SalesforceService } from '../../services/salesforce.service';\nimport { Question } from '../../wrapper';\nimport { DataService } from '../../services/data.service';\nimport { APIMeta } from '../../interfaces/apimeta';\nimport { Observable, Subscription } from 'rxjs';\nimport { ChangeService } from '../../services/change.service';\n\ndeclare var $: any;\n\n@Component({\n  selector: 'app-custom-table',\n  templateUrl: './custom-table.component.html',\n  styleUrls: ['./custom-table.component.css']\n})\n\nexport class CustomTableComponent implements OnInit {\n  @Input() question: Question\n  @Output() valueChange: EventEmitter<any> = new EventEmitter<any>();\n\n  tableInfo: TableWrapper;\n  tableHeader = [];\n  tableData = [];\n  addRowColSpan: number;\n  tableSize: number; // HA 28DEC23 table size declaration\n  objName: any;\n  filterLogic: any;\n  fieldMeta: string;\n  firStr: string;\n  searchBox: boolean = false;\n  @Input() apiMeta: string;\n  public options: string[];\n  isDisabled: boolean = true;\n  subscription: Subscription;\n\n  public labelField: string;\n\n  constructor(private changeService: ChangeService,public i18nService: I18nService, private sfService: SalesforceService, private dataService: DataService) { }\n  // RS 09DEC24 Changed keys\n  ngOnInit(): void {\n    this.tableHeader = JSON.parse(this.question['fieldsMeta']);\n    this.tableSize = 10/this.tableHeader.length;\n// 12JUN24 - default table value\n    if(this.question?.input){\n        this.tableData = this.question?.input;\n    }\n    if(this.apiMeta !== undefined) {\n      this.options = [];\n      let apiObj: APIMeta = JSON.parse(this.apiMeta);\n      this.labelField = apiObj.field;\n      if(apiObj.endpoint){\n        this.dataService.apiResponse(apiObj.endpoint)?.subscribe((apiResponse) => {\n          let responses;\n          if(apiObj.variable){\n             // VD 22May24 - handling multiple child objects\n            responses =  this.dataService.getValue(apiResponse,apiObj.variable);\n            let results = [];\n            // HA 19JAN24 To avoid undefined error in console\n            for (let i = 0; i < responses?.length; i++) {\n              var resp = responses[i];\n              results.push(resp);\n            }\n            this.options = results;\n          }else{  // VD 19JAN24 - if response has value(which is array) only\n            responses = apiResponse;\n            this.options = responses;\n          }\n          this.options = this.options.map((obj: any) => ({ ...obj, edit: false }));\n          // Reference https://www.npmjs.com/package/@ng-select/ng-select\n         this.tableData = this.options;\n        console.log('tableData', this.tableData);\n          \n        });\n      }\n     \n      // VD NOV23 - handle the dependent update for dropdown\n      let sourceId = apiObj.sourceQuestionId;\n      let field = apiObj.field;        // VD 13MAY24 - dynamic field changes\n      if(sourceId){\n        // // VD 10May24 Subscribe for the changes\n        this.subscription = this.changeService.changeAnnounced$.subscribe(\n          (changeValue) => {\n            if(changeValue != undefined) {\n              if(changeValue.valueObj != undefined && changeValue.fromQuestionId == apiObj.sourceQuestionId) {\n                console.log('changes happen');\n                this.options = this.options.map((obj: any) => ({ ...obj, edit: false }));\n                let item = changeValue.valueObj;\n                let validItem = true;\n                 // VD 13MAY24 - bind dynamic field\n                if(this.tableData.length > 0){\n                  this.tableData.forEach(element => {\n                   // VD 26Jun24 - to handle multiple objects\n                    const objElementValue = this.dataService.getValue(element,field);\n                    const objItemValue = this.dataService.getValue(item,field)\n                    if(objElementValue == objItemValue){\n                       validItem = false;\n                    }\n                  });\n                }\n                if(validItem){\n                  if(this.tableData.length > 0){\n                    this.tableData = [...this.tableData,item];\n                    this.emitTableDataValue(this.tableData);\n                  }else {\n                    this.tableData.push(item);\n                    this.emitTableDataValue(this.tableData);\n                  }\n                }\n              }\n              this.changeService.confirmChange(apiObj.sourceQuestionId);\n            }\n          }\n        );\n      }\n    }\n    console.log('tableData', this.tableData);\n    console.log('tableHeader', this.tableHeader);\n    console.log('tableInfo', this.tableInfo);\n  }\n\n\n  addRow(): void {\n    let newItem = {};\n      this.tableHeader.forEach(item => {\n        if(item.apiName){\n          newItem[item.apiName]= \"\";\n        }\n      });\n    const updatedTableData = [...this.tableData, newItem];\n    this.tableData = updatedTableData;\n    this.emitTableDataValue(updatedTableData);\n  }\n\n  updateRadio(item: any, value: string): void {\n    item.value = value;\n    this.emitTableDataValue(this.tableData);\n  }\n  // VD 23Aug24 handle  Type\n  updateLabel(rowIndex: number, label: string, value: any): void {\n    this.tableData[rowIndex][label] = value;\n    this.emitTableDataValue(this.tableData);\n  }\n  deleteRow(rowIndex: number){\n    this.tableData.splice(rowIndex, 1);\n  }\n  editRow(rowIndex: number){\n    var a = 0;\n    this.tableData.forEach(element => {\n      if(a === rowIndex){\n        element.edit = true;\n      }\n      a++;\n    });\n  }\n\n  updateNumber(item: any, label: string, value: string){\n    item.value[label] = value;\n    this.emitTableDataValue(this.tableData);\n  }\n\n\n  emitTableDataValue(updatedTableData: any[]): void {\n    this.valueChange.emit(updatedTableData);\n  }\n}","<table class=\"table table-striped table-bordered\">\n  <thead>\n    <!-- HA 28DEC23 changed table header values and changed table size logic to evenly visible -->\n    <!-- <th><input type=\"checkbox\" (change)=\"selectAll($event.target.checked)\"></th> -->\n    <th *ngFor=\"let header of tableHeader; let hi = index\" [class]=\"'col-md-' + tableSize\">\n      {{ header.label }}\n    </th>\n    <th class=\"col-md-2\" colspan=\"2\">Actions</th>\n  </thead>\n  <tbody *ngIf=\"tableData\">\n    <tr *ngFor=\"let item of tableData; let i = index\">\n      <!-- <td><input type=\"checkbox\" [(ngModel)]=\"item.selected\" (change)=\"selectItem(item)\"></td> -->\n      <td *ngFor=\"let header of tableHeader; let j = index\">\n        <div *ngIf=\"header.fldType === 'imagetext'\" [class]=\"'col-md-' + header.size\" style=\"display: flex;\">\n          <img style=\"width: 35px; height: 32px; margin-right: 5px;\" [src]=\"item.imageSrc\" [alt]=\"item.altText\">\n          <input type=\"text\" [(ngModel)]=\"item[header.fieldName]\" (ngModelChange)=\"updateLabel(i, header.fieldName, item[header.fieldName])\" class=\"she-line-input table-input\">\n        </div>\n        <div *ngIf=\"header.fldType === 'image'\" [class]=\"'col-md-' + header.size\">\n          <img style=\"width: 35px; height: 32px; margin-right: 5px;\" [src]=\"item[header.fieldName]\" [alt]=\"item.altText\">\n        </div>\n        <!--VD 23Aug24 handle readOnly  -->\n        <div *ngIf=\"header.fldType === 'Text' || header.fldType === 'Text'\">\n          <!-- VD 26Jun24 - pipe change to handle multiple objects-->\n          <input type=\"text\" [readonly]=\"header.readOnly\" [disabled]=\"!item.edit\" [ngClass]=\"{'editInput': item.edit && !header.readOnly}\" [ngModel]=\"'' | getValue: item : header.apiName\" (ngModelChange)=\"updateLabel(i, header.apiName,$event)\" class=\"she-line-input table-input\">\n        </div>\n        <!--VD 23Aug24 handle Number Type -->\n        <div *ngIf=\"header.fldType === 'Number' || header.fldType === 'Number'\">\n          <!-- VD 26Jun24 - pipe change to handle multiple objects-->\n          <input type=\"Number\" [readonly]=\"header.readOnly\" [disabled]=\"!item.edit\" [ngClass]=\"{'editInput': item.edit && !header.readOnly}\" [ngModel]=\"'' | getValue: item : header.apiName\" (ngModelChange)=\"updateLabel(i, header.apiName,$event)\" class=\"she-line-input table-input\">\n        </div>\n        <div *ngIf=\"header.fldType === 'radio'\" [class]=\"'col-md-' + header.size\">\n          <input type=\"radio\" [name]=\"item.name\" [checked]=\"item.value == header.fieldName\"  (click)=\"updateRadio(item, header.fieldName)\">\n        </div>\n      </td>\n      <td class=\"action\">\n        <a style=\"display: flex; justify-content: space-evenly;\" (click)=\"editRow(i)\"><img src=\"https://rnxt.s3.amazonaws.com/MytIcon/icon-edit%402x.png\" class=\"icon-edit1\" /><span>Edit</span></a>\n      </td>\n      <td class=\"action\">\n        <a style=\"display: flex; justify-content: space-evenly;\" (click)=\"deleteRow(i)\"><img src=\"https://rnxt.s3.amazonaws.com/MytIcon/icon-delete%402x.png\" class=\"deleteIcon\"/><span>Delete</span></a>\n      </td>\n    </tr>\n  </tbody>\n</table>\n<div (click)=\"addRow()\" class=\"addRowClass\"><div class=\"circle-button\">+</div></div>"]}
|
|
1
|
+
import { Component, EventEmitter, Input, Output } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
import * as i1 from "../../services/change.service";
|
|
4
|
+
import * as i2 from "../../i18n.service";
|
|
5
|
+
import * as i3 from "../../services/salesforce.service";
|
|
6
|
+
import * as i4 from "../../services/data.service";
|
|
7
|
+
import * as i5 from "@angular/common";
|
|
8
|
+
import * as i6 from "@angular/forms";
|
|
9
|
+
import * as i7 from "../../pipe/get-value.pipe";
|
|
10
|
+
export class CustomTableComponent {
|
|
11
|
+
changeService;
|
|
12
|
+
i18nService;
|
|
13
|
+
sfService;
|
|
14
|
+
dataService;
|
|
15
|
+
question;
|
|
16
|
+
valueChange = new EventEmitter();
|
|
17
|
+
tableInfo;
|
|
18
|
+
tableHeader = [];
|
|
19
|
+
tableData = [];
|
|
20
|
+
addRowColSpan;
|
|
21
|
+
tableSize; // HA 28DEC23 table size declaration
|
|
22
|
+
objName;
|
|
23
|
+
filterLogic;
|
|
24
|
+
fieldMeta;
|
|
25
|
+
firStr;
|
|
26
|
+
searchBox = false;
|
|
27
|
+
apiMeta;
|
|
28
|
+
options;
|
|
29
|
+
isDisabled = true;
|
|
30
|
+
subscription;
|
|
31
|
+
labelField;
|
|
32
|
+
constructor(changeService, i18nService, sfService, dataService) {
|
|
33
|
+
this.changeService = changeService;
|
|
34
|
+
this.i18nService = i18nService;
|
|
35
|
+
this.sfService = sfService;
|
|
36
|
+
this.dataService = dataService;
|
|
37
|
+
}
|
|
38
|
+
// RS 09DEC24 Changed keys
|
|
39
|
+
ngOnInit() {
|
|
40
|
+
this.tableHeader = JSON.parse(this.question['fieldsMeta']);
|
|
41
|
+
this.tableSize = 10 / this.tableHeader.length;
|
|
42
|
+
// 12JUN24 - default table value
|
|
43
|
+
if (this.question?.input) {
|
|
44
|
+
this.tableData = this.question?.input;
|
|
45
|
+
}
|
|
46
|
+
if (this.apiMeta !== undefined) {
|
|
47
|
+
this.options = [];
|
|
48
|
+
let apiObj = JSON.parse(this.apiMeta);
|
|
49
|
+
this.labelField = apiObj.field;
|
|
50
|
+
if (apiObj.endpoint) {
|
|
51
|
+
this.dataService.apiResponse(apiObj.endpoint)?.subscribe((apiResponse) => {
|
|
52
|
+
let responses;
|
|
53
|
+
if (apiObj.variable) {
|
|
54
|
+
// VD 22May24 - handling multiple child objects
|
|
55
|
+
responses = this.dataService.getValue(apiResponse, apiObj.variable);
|
|
56
|
+
let results = [];
|
|
57
|
+
// HA 19JAN24 To avoid undefined error in console
|
|
58
|
+
for (let i = 0; i < responses?.length; i++) {
|
|
59
|
+
var resp = responses[i];
|
|
60
|
+
results.push(resp);
|
|
61
|
+
}
|
|
62
|
+
this.options = results;
|
|
63
|
+
}
|
|
64
|
+
else { // VD 19JAN24 - if response has value(which is array) only
|
|
65
|
+
responses = apiResponse;
|
|
66
|
+
this.options = responses;
|
|
67
|
+
}
|
|
68
|
+
this.options = this.options.map((obj) => ({ ...obj, edit: false }));
|
|
69
|
+
// Reference https://www.npmjs.com/package/@ng-select/ng-select
|
|
70
|
+
this.tableData = this.options;
|
|
71
|
+
console.log('tableData', this.tableData);
|
|
72
|
+
});
|
|
73
|
+
}
|
|
74
|
+
// VD NOV23 - handle the dependent update for dropdown
|
|
75
|
+
let sourceId = apiObj.sourceQuestionId;
|
|
76
|
+
let field = apiObj.field; // VD 13MAY24 - dynamic field changes
|
|
77
|
+
if (sourceId) {
|
|
78
|
+
// // VD 10May24 Subscribe for the changes
|
|
79
|
+
this.subscription = this.changeService.changeAnnounced$.subscribe((changeValue) => {
|
|
80
|
+
if (changeValue != undefined) {
|
|
81
|
+
if (changeValue.valueObj != undefined && changeValue.fromQuestionId == apiObj.sourceQuestionId) {
|
|
82
|
+
console.log('changes happen');
|
|
83
|
+
this.options = this.options.map((obj) => ({ ...obj, edit: false }));
|
|
84
|
+
let item = changeValue.valueObj;
|
|
85
|
+
let validItem = true;
|
|
86
|
+
// VD 13MAY24 - bind dynamic field
|
|
87
|
+
if (this.tableData.length > 0) {
|
|
88
|
+
this.tableData.forEach(element => {
|
|
89
|
+
// VD 26Jun24 - to handle multiple objects
|
|
90
|
+
const objElementValue = this.dataService.getValue(element, field);
|
|
91
|
+
const objItemValue = this.dataService.getValue(item, field);
|
|
92
|
+
if (objElementValue == objItemValue) {
|
|
93
|
+
validItem = false;
|
|
94
|
+
}
|
|
95
|
+
});
|
|
96
|
+
}
|
|
97
|
+
if (validItem) {
|
|
98
|
+
if (this.tableData.length > 0) {
|
|
99
|
+
this.tableData = [...this.tableData, item];
|
|
100
|
+
this.emitTableDataValue(this.tableData);
|
|
101
|
+
}
|
|
102
|
+
else {
|
|
103
|
+
this.tableData.push(item);
|
|
104
|
+
this.emitTableDataValue(this.tableData);
|
|
105
|
+
}
|
|
106
|
+
}
|
|
107
|
+
}
|
|
108
|
+
this.changeService.confirmChange(apiObj.sourceQuestionId);
|
|
109
|
+
}
|
|
110
|
+
});
|
|
111
|
+
}
|
|
112
|
+
}
|
|
113
|
+
console.log('tableData', this.tableData);
|
|
114
|
+
console.log('tableHeader', this.tableHeader);
|
|
115
|
+
console.log('tableInfo', this.tableInfo);
|
|
116
|
+
}
|
|
117
|
+
addRow() {
|
|
118
|
+
let newItem = {};
|
|
119
|
+
this.tableHeader.forEach(item => {
|
|
120
|
+
if (item.apiName) {
|
|
121
|
+
newItem[item.apiName] = "";
|
|
122
|
+
}
|
|
123
|
+
});
|
|
124
|
+
const updatedTableData = [...this.tableData, newItem];
|
|
125
|
+
this.tableData = updatedTableData;
|
|
126
|
+
this.emitTableDataValue(updatedTableData);
|
|
127
|
+
}
|
|
128
|
+
updateRadio(item, value) {
|
|
129
|
+
item.value = value;
|
|
130
|
+
this.emitTableDataValue(this.tableData);
|
|
131
|
+
}
|
|
132
|
+
// VD 23Aug24 handle Type
|
|
133
|
+
updateLabel(rowIndex, label, value) {
|
|
134
|
+
this.tableData[rowIndex][label] = value;
|
|
135
|
+
this.emitTableDataValue(this.tableData);
|
|
136
|
+
}
|
|
137
|
+
deleteRow(rowIndex) {
|
|
138
|
+
this.tableData.splice(rowIndex, 1);
|
|
139
|
+
}
|
|
140
|
+
editRow(rowIndex) {
|
|
141
|
+
var a = 0;
|
|
142
|
+
this.tableData.forEach(element => {
|
|
143
|
+
if (a === rowIndex) {
|
|
144
|
+
element.edit = true;
|
|
145
|
+
}
|
|
146
|
+
a++;
|
|
147
|
+
});
|
|
148
|
+
}
|
|
149
|
+
updateNumber(item, label, value) {
|
|
150
|
+
item.value[label] = value;
|
|
151
|
+
this.emitTableDataValue(this.tableData);
|
|
152
|
+
}
|
|
153
|
+
emitTableDataValue(updatedTableData) {
|
|
154
|
+
this.valueChange.emit(updatedTableData);
|
|
155
|
+
}
|
|
156
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: CustomTableComponent, deps: [{ token: i1.ChangeService }, { token: i2.I18nService }, { token: i3.SalesforceService }, { token: i4.DataService }], target: i0.ɵɵFactoryTarget.Component });
|
|
157
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: CustomTableComponent, selector: "app-custom-table", inputs: { question: "question", apiMeta: "apiMeta" }, outputs: { valueChange: "valueChange" }, ngImport: i0, template: "<table class=\"table table-striped table-bordered\">\r\n <thead>\r\n <!-- HA 28DEC23 changed table header values and changed table size logic to evenly visible -->\r\n <!-- <th><input type=\"checkbox\" (change)=\"selectAll($event.target.checked)\"></th> -->\r\n <th *ngFor=\"let header of tableHeader; let hi = index\" [class]=\"'col-md-' + tableSize\">\r\n {{ header.label }}\r\n </th>\r\n <th class=\"col-md-2\" colspan=\"2\">Actions</th>\r\n </thead>\r\n <tbody *ngIf=\"tableData\">\r\n <tr *ngFor=\"let item of tableData; let i = index\">\r\n <!-- <td><input type=\"checkbox\" [(ngModel)]=\"item.selected\" (change)=\"selectItem(item)\"></td> -->\r\n <td *ngFor=\"let header of tableHeader; let j = index\">\r\n <div *ngIf=\"header.fldType === 'imagetext'\" [class]=\"'col-md-' + header.size\" style=\"display: flex;\">\r\n <img style=\"width: 35px; height: 32px; margin-right: 5px;\" [src]=\"item.imageSrc\" [alt]=\"item.altText\">\r\n <input type=\"text\" [(ngModel)]=\"item[header.fieldName]\" (ngModelChange)=\"updateLabel(i, header.fieldName, item[header.fieldName])\" class=\"she-line-input table-input\">\r\n </div>\r\n <div *ngIf=\"header.fldType === 'image'\" [class]=\"'col-md-' + header.size\">\r\n <img style=\"width: 35px; height: 32px; margin-right: 5px;\" [src]=\"item[header.fieldName]\" [alt]=\"item.altText\">\r\n </div>\r\n <!--VD 23Aug24 handle readOnly -->\r\n <div *ngIf=\"header.fldType === 'Text' || header.fldType === 'Text'\">\r\n <!-- VD 26Jun24 - pipe change to handle multiple objects-->\r\n <input type=\"text\" [readonly]=\"header.readOnly\" [disabled]=\"!item.edit\" [ngClass]=\"{'editInput': item.edit && !header.readOnly}\" [ngModel]=\"'' | getValue: item : header.apiName\" (ngModelChange)=\"updateLabel(i, header.apiName,$event)\" class=\"she-line-input table-input\">\r\n </div>\r\n <!--VD 23Aug24 handle Number Type -->\r\n <div *ngIf=\"header.fldType === 'Number' || header.fldType === 'Number'\">\r\n <!-- VD 26Jun24 - pipe change to handle multiple objects-->\r\n <input type=\"Number\" [readonly]=\"header.readOnly\" [disabled]=\"!item.edit\" [ngClass]=\"{'editInput': item.edit && !header.readOnly}\" [ngModel]=\"'' | getValue: item : header.apiName\" (ngModelChange)=\"updateLabel(i, header.apiName,$event)\" class=\"she-line-input table-input\">\r\n </div>\r\n <div *ngIf=\"header.fldType === 'radio'\" [class]=\"'col-md-' + header.size\">\r\n <input type=\"radio\" [name]=\"item.name\" [checked]=\"item.value == header.fieldName\" (click)=\"updateRadio(item, header.fieldName)\">\r\n </div>\r\n </td>\r\n <td class=\"action\">\r\n <a style=\"display: flex; justify-content: space-evenly;\" (click)=\"editRow(i)\"><img src=\"https://rnxt.s3.amazonaws.com/MytIcon/icon-edit%402x.png\" class=\"icon-edit1\" /><span>Edit</span></a>\r\n </td>\r\n <td class=\"action\">\r\n <a style=\"display: flex; justify-content: space-evenly;\" (click)=\"deleteRow(i)\"><img src=\"https://rnxt.s3.amazonaws.com/MytIcon/icon-delete%402x.png\" class=\"deleteIcon\"/><span>Delete</span></a>\r\n </td>\r\n </tr>\r\n </tbody>\r\n</table>\r\n<div (click)=\"addRow()\" class=\"addRowClass\"><div class=\"circle-button\">+</div></div>", 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;text-align:center}.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}.addRowClass{float:right;margin-right:15%}.editInput{border-bottom:1px solid red!important}.action,.addRowClass{cursor:pointer}.action :hover{color:red}.circle-button{width:50px;height:50px;border-radius:50%;background-color:#03a9f4;color:#fff;font-size:25px;display:flex;justify-content:center;align-items:center;cursor:pointer;box-shadow:0 2px 4px #0003}.circle-button:hover{background-color:#03a9f4}\n"], dependencies: [{ kind: "directive", type: i5.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i5.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i6.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i6.NumberValueAccessor, selector: "input[type=number][formControlName],input[type=number][formControl],input[type=number][ngModel]" }, { kind: "directive", type: i6.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i6.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "pipe", type: i7.GetValuePipe, name: "getValue" }] });
|
|
158
|
+
}
|
|
159
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: CustomTableComponent, decorators: [{
|
|
160
|
+
type: Component,
|
|
161
|
+
args: [{ selector: 'app-custom-table', template: "<table class=\"table table-striped table-bordered\">\r\n <thead>\r\n <!-- HA 28DEC23 changed table header values and changed table size logic to evenly visible -->\r\n <!-- <th><input type=\"checkbox\" (change)=\"selectAll($event.target.checked)\"></th> -->\r\n <th *ngFor=\"let header of tableHeader; let hi = index\" [class]=\"'col-md-' + tableSize\">\r\n {{ header.label }}\r\n </th>\r\n <th class=\"col-md-2\" colspan=\"2\">Actions</th>\r\n </thead>\r\n <tbody *ngIf=\"tableData\">\r\n <tr *ngFor=\"let item of tableData; let i = index\">\r\n <!-- <td><input type=\"checkbox\" [(ngModel)]=\"item.selected\" (change)=\"selectItem(item)\"></td> -->\r\n <td *ngFor=\"let header of tableHeader; let j = index\">\r\n <div *ngIf=\"header.fldType === 'imagetext'\" [class]=\"'col-md-' + header.size\" style=\"display: flex;\">\r\n <img style=\"width: 35px; height: 32px; margin-right: 5px;\" [src]=\"item.imageSrc\" [alt]=\"item.altText\">\r\n <input type=\"text\" [(ngModel)]=\"item[header.fieldName]\" (ngModelChange)=\"updateLabel(i, header.fieldName, item[header.fieldName])\" class=\"she-line-input table-input\">\r\n </div>\r\n <div *ngIf=\"header.fldType === 'image'\" [class]=\"'col-md-' + header.size\">\r\n <img style=\"width: 35px; height: 32px; margin-right: 5px;\" [src]=\"item[header.fieldName]\" [alt]=\"item.altText\">\r\n </div>\r\n <!--VD 23Aug24 handle readOnly -->\r\n <div *ngIf=\"header.fldType === 'Text' || header.fldType === 'Text'\">\r\n <!-- VD 26Jun24 - pipe change to handle multiple objects-->\r\n <input type=\"text\" [readonly]=\"header.readOnly\" [disabled]=\"!item.edit\" [ngClass]=\"{'editInput': item.edit && !header.readOnly}\" [ngModel]=\"'' | getValue: item : header.apiName\" (ngModelChange)=\"updateLabel(i, header.apiName,$event)\" class=\"she-line-input table-input\">\r\n </div>\r\n <!--VD 23Aug24 handle Number Type -->\r\n <div *ngIf=\"header.fldType === 'Number' || header.fldType === 'Number'\">\r\n <!-- VD 26Jun24 - pipe change to handle multiple objects-->\r\n <input type=\"Number\" [readonly]=\"header.readOnly\" [disabled]=\"!item.edit\" [ngClass]=\"{'editInput': item.edit && !header.readOnly}\" [ngModel]=\"'' | getValue: item : header.apiName\" (ngModelChange)=\"updateLabel(i, header.apiName,$event)\" class=\"she-line-input table-input\">\r\n </div>\r\n <div *ngIf=\"header.fldType === 'radio'\" [class]=\"'col-md-' + header.size\">\r\n <input type=\"radio\" [name]=\"item.name\" [checked]=\"item.value == header.fieldName\" (click)=\"updateRadio(item, header.fieldName)\">\r\n </div>\r\n </td>\r\n <td class=\"action\">\r\n <a style=\"display: flex; justify-content: space-evenly;\" (click)=\"editRow(i)\"><img src=\"https://rnxt.s3.amazonaws.com/MytIcon/icon-edit%402x.png\" class=\"icon-edit1\" /><span>Edit</span></a>\r\n </td>\r\n <td class=\"action\">\r\n <a style=\"display: flex; justify-content: space-evenly;\" (click)=\"deleteRow(i)\"><img src=\"https://rnxt.s3.amazonaws.com/MytIcon/icon-delete%402x.png\" class=\"deleteIcon\"/><span>Delete</span></a>\r\n </td>\r\n </tr>\r\n </tbody>\r\n</table>\r\n<div (click)=\"addRow()\" class=\"addRowClass\"><div class=\"circle-button\">+</div></div>", 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;text-align:center}.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}.addRowClass{float:right;margin-right:15%}.editInput{border-bottom:1px solid red!important}.action,.addRowClass{cursor:pointer}.action :hover{color:red}.circle-button{width:50px;height:50px;border-radius:50%;background-color:#03a9f4;color:#fff;font-size:25px;display:flex;justify-content:center;align-items:center;cursor:pointer;box-shadow:0 2px 4px #0003}.circle-button:hover{background-color:#03a9f4}\n"] }]
|
|
162
|
+
}], ctorParameters: function () { return [{ type: i1.ChangeService }, { type: i2.I18nService }, { type: i3.SalesforceService }, { type: i4.DataService }]; }, propDecorators: { question: [{
|
|
163
|
+
type: Input
|
|
164
|
+
}], valueChange: [{
|
|
165
|
+
type: Output
|
|
166
|
+
}], apiMeta: [{
|
|
167
|
+
type: Input
|
|
168
|
+
}] } });
|
|
169
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"custom-table.component.js","sourceRoot":"","sources":["../../../../../../projects/nxt-app/src/lib/components/custom-table/custom-table.component.ts","../../../../../../projects/nxt-app/src/lib/components/custom-table/custom-table.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\r\n// HA 19DEC23 imported translation service\r\nimport { I18nService } from '../../i18n.service';\r\nimport { TableWrapper } from '../../model/tableWrapper';\r\nimport { SalesforceService } from '../../services/salesforce.service';\r\nimport { Question } from '../../wrapper';\r\nimport { DataService } from '../../services/data.service';\r\nimport { APIMeta } from '../../interfaces/apimeta';\r\nimport { Observable, Subscription } from 'rxjs';\r\nimport { ChangeService } from '../../services/change.service';\r\n\r\ndeclare var $: any;\r\n\r\n@Component({\r\n  selector: 'app-custom-table',\r\n  templateUrl: './custom-table.component.html',\r\n  styleUrls: ['./custom-table.component.css']\r\n})\r\n\r\nexport class CustomTableComponent implements OnInit {\r\n  @Input() question: Question\r\n  @Output() valueChange: EventEmitter<any> = new EventEmitter<any>();\r\n\r\n  tableInfo: TableWrapper;\r\n  tableHeader = [];\r\n  tableData = [];\r\n  addRowColSpan: number;\r\n  tableSize: number; // HA 28DEC23 table size declaration\r\n  objName: any;\r\n  filterLogic: any;\r\n  fieldMeta: string;\r\n  firStr: string;\r\n  searchBox: boolean = false;\r\n  @Input() apiMeta: string;\r\n  public options: string[];\r\n  isDisabled: boolean = true;\r\n  subscription: Subscription;\r\n\r\n  public labelField: string;\r\n\r\n  constructor(private changeService: ChangeService,public i18nService: I18nService, private sfService: SalesforceService, private dataService: DataService) { }\r\n  // RS 09DEC24 Changed keys\r\n  ngOnInit(): void {\r\n    this.tableHeader = JSON.parse(this.question['fieldsMeta']);\r\n    this.tableSize = 10/this.tableHeader.length;\r\n// 12JUN24 - default table value\r\n    if(this.question?.input){\r\n        this.tableData = this.question?.input;\r\n    }\r\n    if(this.apiMeta !== undefined) {\r\n      this.options = [];\r\n      let apiObj: APIMeta = JSON.parse(this.apiMeta);\r\n      this.labelField = apiObj.field;\r\n      if(apiObj.endpoint){\r\n        this.dataService.apiResponse(apiObj.endpoint)?.subscribe((apiResponse) => {\r\n          let responses;\r\n          if(apiObj.variable){\r\n             // VD 22May24 - handling multiple child objects\r\n            responses =  this.dataService.getValue(apiResponse,apiObj.variable);\r\n            let results = [];\r\n            // HA 19JAN24 To avoid undefined error in console\r\n            for (let i = 0; i < responses?.length; i++) {\r\n              var resp = responses[i];\r\n              results.push(resp);\r\n            }\r\n            this.options = results;\r\n          }else{  // VD 19JAN24 - if response has value(which is array) only\r\n            responses = apiResponse;\r\n            this.options = responses;\r\n          }\r\n          this.options = this.options.map((obj: any) => ({ ...obj, edit: false }));\r\n          // Reference https://www.npmjs.com/package/@ng-select/ng-select\r\n         this.tableData = this.options;\r\n        console.log('tableData', this.tableData);\r\n          \r\n        });\r\n      }\r\n     \r\n      // VD NOV23 - handle the dependent update for dropdown\r\n      let sourceId = apiObj.sourceQuestionId;\r\n      let field = apiObj.field;        // VD 13MAY24 - dynamic field changes\r\n      if(sourceId){\r\n        // // VD 10May24 Subscribe for the changes\r\n        this.subscription = this.changeService.changeAnnounced$.subscribe(\r\n          (changeValue) => {\r\n            if(changeValue != undefined) {\r\n              if(changeValue.valueObj != undefined && changeValue.fromQuestionId == apiObj.sourceQuestionId) {\r\n                console.log('changes happen');\r\n                this.options = this.options.map((obj: any) => ({ ...obj, edit: false }));\r\n                let item = changeValue.valueObj;\r\n                let validItem = true;\r\n                 // VD 13MAY24 - bind dynamic field\r\n                if(this.tableData.length > 0){\r\n                  this.tableData.forEach(element => {\r\n                   // VD 26Jun24 - to handle multiple objects\r\n                    const objElementValue = this.dataService.getValue(element,field);\r\n                    const objItemValue = this.dataService.getValue(item,field)\r\n                    if(objElementValue == objItemValue){\r\n                       validItem = false;\r\n                    }\r\n                  });\r\n                }\r\n                if(validItem){\r\n                  if(this.tableData.length > 0){\r\n                    this.tableData = [...this.tableData,item];\r\n                    this.emitTableDataValue(this.tableData);\r\n                  }else {\r\n                    this.tableData.push(item);\r\n                    this.emitTableDataValue(this.tableData);\r\n                  }\r\n                }\r\n              }\r\n              this.changeService.confirmChange(apiObj.sourceQuestionId);\r\n            }\r\n          }\r\n        );\r\n      }\r\n    }\r\n    console.log('tableData', this.tableData);\r\n    console.log('tableHeader', this.tableHeader);\r\n    console.log('tableInfo', this.tableInfo);\r\n  }\r\n\r\n\r\n  addRow(): void {\r\n    let newItem = {};\r\n      this.tableHeader.forEach(item => {\r\n        if(item.apiName){\r\n          newItem[item.apiName]= \"\";\r\n        }\r\n      });\r\n    const updatedTableData = [...this.tableData, newItem];\r\n    this.tableData = updatedTableData;\r\n    this.emitTableDataValue(updatedTableData);\r\n  }\r\n\r\n  updateRadio(item: any, value: string): void {\r\n    item.value = value;\r\n    this.emitTableDataValue(this.tableData);\r\n  }\r\n  // VD 23Aug24 handle  Type\r\n  updateLabel(rowIndex: number, label: string, value: any): void {\r\n    this.tableData[rowIndex][label] = value;\r\n    this.emitTableDataValue(this.tableData);\r\n  }\r\n  deleteRow(rowIndex: number){\r\n    this.tableData.splice(rowIndex, 1);\r\n  }\r\n  editRow(rowIndex: number){\r\n    var a = 0;\r\n    this.tableData.forEach(element => {\r\n      if(a === rowIndex){\r\n        element.edit = true;\r\n      }\r\n      a++;\r\n    });\r\n  }\r\n\r\n  updateNumber(item: any, label: string, value: string){\r\n    item.value[label] = value;\r\n    this.emitTableDataValue(this.tableData);\r\n  }\r\n\r\n\r\n  emitTableDataValue(updatedTableData: any[]): void {\r\n    this.valueChange.emit(updatedTableData);\r\n  }\r\n}","<table class=\"table table-striped table-bordered\">\r\n  <thead>\r\n    <!-- HA 28DEC23 changed table header values and changed table size logic to evenly visible -->\r\n    <!-- <th><input type=\"checkbox\" (change)=\"selectAll($event.target.checked)\"></th> -->\r\n    <th *ngFor=\"let header of tableHeader; let hi = index\" [class]=\"'col-md-' + tableSize\">\r\n      {{ header.label }}\r\n    </th>\r\n    <th class=\"col-md-2\" colspan=\"2\">Actions</th>\r\n  </thead>\r\n  <tbody *ngIf=\"tableData\">\r\n    <tr *ngFor=\"let item of tableData; let i = index\">\r\n      <!-- <td><input type=\"checkbox\" [(ngModel)]=\"item.selected\" (change)=\"selectItem(item)\"></td> -->\r\n      <td *ngFor=\"let header of tableHeader; let j = index\">\r\n        <div *ngIf=\"header.fldType === 'imagetext'\" [class]=\"'col-md-' + header.size\" style=\"display: flex;\">\r\n          <img style=\"width: 35px; height: 32px; margin-right: 5px;\" [src]=\"item.imageSrc\" [alt]=\"item.altText\">\r\n          <input type=\"text\" [(ngModel)]=\"item[header.fieldName]\" (ngModelChange)=\"updateLabel(i, header.fieldName, item[header.fieldName])\" class=\"she-line-input table-input\">\r\n        </div>\r\n        <div *ngIf=\"header.fldType === 'image'\" [class]=\"'col-md-' + header.size\">\r\n          <img style=\"width: 35px; height: 32px; margin-right: 5px;\" [src]=\"item[header.fieldName]\" [alt]=\"item.altText\">\r\n        </div>\r\n        <!--VD 23Aug24 handle readOnly  -->\r\n        <div *ngIf=\"header.fldType === 'Text' || header.fldType === 'Text'\">\r\n          <!-- VD 26Jun24 - pipe change to handle multiple objects-->\r\n          <input type=\"text\" [readonly]=\"header.readOnly\" [disabled]=\"!item.edit\" [ngClass]=\"{'editInput': item.edit && !header.readOnly}\" [ngModel]=\"'' | getValue: item : header.apiName\" (ngModelChange)=\"updateLabel(i, header.apiName,$event)\" class=\"she-line-input table-input\">\r\n        </div>\r\n        <!--VD 23Aug24 handle Number Type -->\r\n        <div *ngIf=\"header.fldType === 'Number' || header.fldType === 'Number'\">\r\n          <!-- VD 26Jun24 - pipe change to handle multiple objects-->\r\n          <input type=\"Number\" [readonly]=\"header.readOnly\" [disabled]=\"!item.edit\" [ngClass]=\"{'editInput': item.edit && !header.readOnly}\" [ngModel]=\"'' | getValue: item : header.apiName\" (ngModelChange)=\"updateLabel(i, header.apiName,$event)\" class=\"she-line-input table-input\">\r\n        </div>\r\n        <div *ngIf=\"header.fldType === 'radio'\" [class]=\"'col-md-' + header.size\">\r\n          <input type=\"radio\" [name]=\"item.name\" [checked]=\"item.value == header.fieldName\"  (click)=\"updateRadio(item, header.fieldName)\">\r\n        </div>\r\n      </td>\r\n      <td class=\"action\">\r\n        <a style=\"display: flex; justify-content: space-evenly;\" (click)=\"editRow(i)\"><img src=\"https://rnxt.s3.amazonaws.com/MytIcon/icon-edit%402x.png\" class=\"icon-edit1\" /><span>Edit</span></a>\r\n      </td>\r\n      <td class=\"action\">\r\n        <a style=\"display: flex; justify-content: space-evenly;\" (click)=\"deleteRow(i)\"><img src=\"https://rnxt.s3.amazonaws.com/MytIcon/icon-delete%402x.png\" class=\"deleteIcon\"/><span>Delete</span></a>\r\n      </td>\r\n    </tr>\r\n  </tbody>\r\n</table>\r\n<div (click)=\"addRow()\" class=\"addRowClass\"><div class=\"circle-button\">+</div></div>"]}
|