@rangertechnologies/ngnxt 2.1.74 → 2.1.76
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-calendar/custom-calendar.component.mjs +18 -16
- package/esm2022/lib/components/custom-dropdown/custom-dropdown.component.mjs +103 -95
- package/esm2022/lib/components/custom-image/custom-image.component.mjs +5 -4
- package/esm2022/lib/components/custom-input/custom-input.component.mjs +6 -5
- package/esm2022/lib/components/custom-label/custom-label.component.mjs +3 -11
- package/esm2022/lib/components/custom-radio/custom-radio.component.mjs +5 -4
- package/esm2022/lib/components/custom-table/custom-table.component.mjs +3 -2
- package/esm2022/lib/components/custom-text-area/custom-text-area.component.mjs +6 -5
- package/esm2022/lib/components/file-upload/file-upload.component.mjs +6 -5
- package/esm2022/lib/components/pick-location/pick-location.component.mjs +5 -3
- package/esm2022/lib/components/search-box/search-box.component.mjs +3 -2
- package/esm2022/lib/components/table-appendix/table-appendix.component.mjs +5 -4
- package/esm2022/lib/pages/booklet/booklet.component.mjs +80 -127
- package/esm2022/lib/pages/questionbook/questionbook.component.mjs +83 -96
- package/esm2022/lib/pages/questionnaire/questionnaire.component.mjs +321 -257
- package/esm2022/lib/pages/summary-page/summary-page.component.mjs +11 -10
- package/esm2022/lib/sample.mjs +3157 -328
- package/esm2022/lib/services/storage.service.mjs +7 -5
- package/esm2022/lib/wrapper.mjs +96 -93
- package/fesm2022/rangertechnologies-ngnxt.mjs +3900 -1075
- package/fesm2022/rangertechnologies-ngnxt.mjs.map +1 -1
- package/lib/components/custom-label/custom-label.component.d.ts +1 -3
- package/lib/pages/booklet/booklet.component.d.ts +2 -8
- package/lib/pages/questionbook/questionbook.component.d.ts +1 -2
- package/lib/wrapper.d.ts +93 -91
- package/package.json +1 -1
- package/rangertechnologies-ngnxt-2.1.76.tgz +0 -0
- package/esm2022/lib/services/code-execution.service.mjs +0 -30
- package/lib/services/code-execution.service.d.ts +0 -9
- package/rangertechnologies-ngnxt-2.1.74.tgz +0 -0
|
@@ -49,106 +49,114 @@ export class CustomDropdownComponent {
|
|
|
49
49
|
//VD 07Aug24 - isDependentField change
|
|
50
50
|
// VD 25Oct24 - changes
|
|
51
51
|
this.placeholder = this.placeholder ? this.placeholder : '---Select option---';
|
|
52
|
-
if (this.apiMeta
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
if (!this.apiObj.isDependentField) {
|
|
63
|
-
this.options = [];
|
|
64
|
-
// VD 09Sep24- setup the query param for api call
|
|
65
|
-
let fullEndPoint;
|
|
66
|
-
if (this.apiObj.endpoint) {
|
|
67
|
-
if (this.apiObj.queryValueReference && this.apiObj.queryField) {
|
|
68
|
-
// process the end point with query param
|
|
69
|
-
let queryReferences = this.apiObj.queryValueReference.split(',');
|
|
70
|
-
let queryParams = [];
|
|
71
|
-
// Iterate over queryReferences and find the corresponding element in referenceData
|
|
72
|
-
queryReferences.forEach(reference => {
|
|
73
|
-
// Find the element in referenceData that matches the current reference
|
|
74
|
-
let matchingElement = this.question?.referenceQueryData.find(element => element.Reference_Field__c === reference);
|
|
75
|
-
// If a matching element is found, get its input value and create a query parameter
|
|
76
|
-
if (matchingElement) {
|
|
77
|
-
queryParams.push(`${reference}=${matchingElement.input}`);
|
|
78
|
-
}
|
|
79
|
-
});
|
|
80
|
-
fullEndPoint = this.apiObj.endpoint + '?' + queryParams.join('&');
|
|
81
|
-
console.log(fullEndPoint);
|
|
82
|
-
}
|
|
83
|
-
else {
|
|
84
|
-
// if no query param get the actual endPoint
|
|
85
|
-
fullEndPoint = this.apiObj.endpoint;
|
|
86
|
-
}
|
|
87
|
-
// VD 19JAN24 - added one more param for authentication
|
|
88
|
-
this.dataService.apiResponse(fullEndPoint)?.subscribe((apiResponse) => {
|
|
89
|
-
// HA 18-JAN-24 Assigned apiresponse directly if we have the response in array also
|
|
90
|
-
// VD 19JAN24 - if response has key with value(which is array)
|
|
91
|
-
let responses;
|
|
92
|
-
if (this.apiObj.variable) {
|
|
93
|
-
// VD 21May24 - handling multiple child objects
|
|
94
|
-
// VD 22May24 - used common service file
|
|
95
|
-
responses = this.dataService.getValue(apiResponse, this.apiObj.variable);
|
|
96
|
-
let results = [];
|
|
97
|
-
// HA 19JAN24 To avoid undefined error in console
|
|
98
|
-
for (let i = 0; i < responses?.length; i++) {
|
|
99
|
-
var resp = responses[i];
|
|
100
|
-
results.push(resp);
|
|
101
|
-
}
|
|
102
|
-
this.options = results;
|
|
103
|
-
}
|
|
104
|
-
else { // VD 19JAN24 - if response has value(which is array) only
|
|
105
|
-
responses = apiResponse;
|
|
106
|
-
this.options = responses;
|
|
107
|
-
}
|
|
108
|
-
// VD 25Oct24 - Store fetched options in local storage
|
|
109
|
-
if (this.uniqueKey) {
|
|
110
|
-
localStorage.setItem(this.uniqueKey, JSON.stringify(this.options));
|
|
111
|
-
}
|
|
112
|
-
// Reference https://www.npmjs.com/package/@ng-select/ng-select
|
|
113
|
-
});
|
|
52
|
+
if (this.apiMeta) {
|
|
53
|
+
try {
|
|
54
|
+
this.apiObj = JSON.parse(this.apiMeta);
|
|
55
|
+
// Check if apiObj and apiObj.field are defined
|
|
56
|
+
if (this.apiObj && this.apiObj.field) {
|
|
57
|
+
this.labelField = this.apiObj.field;
|
|
58
|
+
this.uniqueKey = this.apiObj.uniqueKey;
|
|
59
|
+
const cachedOptions = localStorage.getItem(this.uniqueKey);
|
|
60
|
+
if (cachedOptions) {
|
|
61
|
+
this.options = JSON.parse(cachedOptions);
|
|
114
62
|
}
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
63
|
+
else {
|
|
64
|
+
if (!this.apiObj.isDependentField) {
|
|
65
|
+
this.options = [];
|
|
66
|
+
// VD 09Sep24- setup the query param for api call
|
|
67
|
+
let fullEndPoint;
|
|
68
|
+
if (this.apiObj.endpoint) {
|
|
69
|
+
if (this.apiObj.queryValueReference && this.apiObj.queryField) {
|
|
70
|
+
// process the end point with query param
|
|
71
|
+
let queryReferences = this.apiObj.queryValueReference.split(',');
|
|
72
|
+
let queryParams = [];
|
|
73
|
+
// Iterate over queryReferences and find the corresponding element in referenceData
|
|
74
|
+
queryReferences.forEach(reference => {
|
|
75
|
+
// Find the element in referenceData that matches the current reference
|
|
76
|
+
// RS 09DEC24 Changed keys
|
|
77
|
+
let matchingElement = this.question?.referenceQueryData.find(element => element.referenceField === reference);
|
|
78
|
+
// If a matching element is found, get its input value and create a query parameter
|
|
79
|
+
if (matchingElement) {
|
|
80
|
+
queryParams.push(`${reference}=${matchingElement.input}`);
|
|
81
|
+
}
|
|
82
|
+
});
|
|
83
|
+
fullEndPoint = this.apiObj.endpoint + '?' + queryParams.join('&');
|
|
84
|
+
console.log(fullEndPoint);
|
|
137
85
|
}
|
|
138
86
|
else {
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
}
|
|
142
|
-
// VD 25Oct24 - Store fetched options in local storage
|
|
143
|
-
if (this.uniqueKey) {
|
|
144
|
-
localStorage.setItem(this.uniqueKey, JSON.stringify(this.options));
|
|
87
|
+
// if no query param get the actual endPoint
|
|
88
|
+
fullEndPoint = this.apiObj.endpoint;
|
|
145
89
|
}
|
|
90
|
+
// VD 19JAN24 - added one more param for authentication
|
|
91
|
+
this.dataService.apiResponse(fullEndPoint)?.subscribe((apiResponse) => {
|
|
92
|
+
// HA 18-JAN-24 Assigned apiresponse directly if we have the response in array also
|
|
93
|
+
// VD 19JAN24 - if response has key with value(which is array)
|
|
94
|
+
let responses;
|
|
95
|
+
if (this.apiObj.variable) {
|
|
96
|
+
// VD 21May24 - handling multiple child objects
|
|
97
|
+
// VD 22May24 - used common service file
|
|
98
|
+
responses = this.dataService.getValue(apiResponse, this.apiObj.variable);
|
|
99
|
+
let results = [];
|
|
100
|
+
// HA 19JAN24 To avoid undefined error in console
|
|
101
|
+
for (let i = 0; i < responses?.length; i++) {
|
|
102
|
+
var resp = responses[i];
|
|
103
|
+
results.push(resp);
|
|
104
|
+
}
|
|
105
|
+
this.options = results;
|
|
106
|
+
}
|
|
107
|
+
else { // VD 19JAN24 - if response has value(which is array) only
|
|
108
|
+
responses = apiResponse;
|
|
109
|
+
this.options = responses;
|
|
110
|
+
}
|
|
111
|
+
// VD 25Oct24 - Store fetched options in local storage
|
|
112
|
+
if (this.uniqueKey) {
|
|
113
|
+
localStorage.setItem(this.uniqueKey, JSON.stringify(this.options));
|
|
114
|
+
}
|
|
115
|
+
// Reference https://www.npmjs.com/package/@ng-select/ng-select
|
|
116
|
+
});
|
|
146
117
|
}
|
|
147
|
-
this.changeService.confirmChange(this.apiObj.sourceQuestionId);
|
|
148
118
|
}
|
|
149
|
-
|
|
119
|
+
// VD NOV23 - handle the dependent update for dropdown
|
|
120
|
+
// // VD 09Sep24- push the dependent field values for dropdown
|
|
121
|
+
let sourceId = this.apiObj.sourceQuestionId;
|
|
122
|
+
if (sourceId && this.apiObj.variable || this.apiObj.valueField) {
|
|
123
|
+
// Subscribe for the changes
|
|
124
|
+
this.subscription = this.changeService.changeAnnounced$.subscribe((changeValue) => {
|
|
125
|
+
if (changeValue != undefined) {
|
|
126
|
+
// console.log('inside subscription for the change');
|
|
127
|
+
if (changeValue.valueObj != undefined && changeValue.fromQuestionId == this.apiObj.sourceQuestionId) {
|
|
128
|
+
// this.selectedValue = changeValue.valueObj[this.apiObj.valueField];
|
|
129
|
+
// let value ={};
|
|
130
|
+
// value['name'] = this.selectedValue;
|
|
131
|
+
let responses;
|
|
132
|
+
if (this.apiObj.variable) {
|
|
133
|
+
responses = this.dataService.getValue(changeValue.valueObj, this.apiObj.variable);
|
|
134
|
+
let results = [];
|
|
135
|
+
for (let i = 0; i < responses?.length; i++) {
|
|
136
|
+
var resp = responses[i];
|
|
137
|
+
results.push(resp);
|
|
138
|
+
}
|
|
139
|
+
this.options = results;
|
|
140
|
+
}
|
|
141
|
+
else {
|
|
142
|
+
responses = changeValue.valueObj;
|
|
143
|
+
this.options = responses;
|
|
144
|
+
}
|
|
145
|
+
// VD 25Oct24 - Store fetched options in local storage
|
|
146
|
+
if (this.uniqueKey) {
|
|
147
|
+
localStorage.setItem(this.uniqueKey, JSON.stringify(this.options));
|
|
148
|
+
}
|
|
149
|
+
}
|
|
150
|
+
this.changeService.confirmChange(this.apiObj.sourceQuestionId);
|
|
151
|
+
}
|
|
152
|
+
});
|
|
153
|
+
}
|
|
154
|
+
}
|
|
150
155
|
}
|
|
151
156
|
}
|
|
157
|
+
catch (error) {
|
|
158
|
+
console.error('Error parsing apiMeta:', error);
|
|
159
|
+
}
|
|
152
160
|
}
|
|
153
161
|
}
|
|
154
162
|
// VD 22May24 - used common service file
|
|
@@ -167,11 +175,11 @@ export class CustomDropdownComponent {
|
|
|
167
175
|
}
|
|
168
176
|
}
|
|
169
177
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: CustomDropdownComponent, deps: [{ token: i1.ChangeService }, { token: i2.DataService }, { token: i3.I18nService }], target: i0.ɵɵFactoryTarget.Component });
|
|
170
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: CustomDropdownComponent, selector: "app-custom-dropdown", inputs: { options: "options", placeholder: "placeholder", apiMeta: "apiMeta", selectedValue: "selectedValue", progressBar: "progressBar", id: "id", readOnly: "readOnly", errorMessage: "errorMessage", error: "error", fromShengel: "fromShengel", question: "question", referenceField: "referenceField", token: "token" }, outputs: { valueChange: "valueChange" }, ngImport: i0, template: "<!-- HA 18-JAN-24 Commenting these lines as we don't have to use shengel here -->\n<!-- <select\n [ngClass]=\"{\n 'dt-line dpDown down myt-dropbox myt-border-r myt-font1': progressBar,\n 'custom-select': !progressBar\n }\" class=\"custom-select mr-sm-2 dd-height\" \n [id]=\"id\" \n [(ngModel)]=\"selectedValue\"\n (change)=\"selectChange($event.target.value);\" \n [style.borderColor]=\"error ? 'red' : '#858585'\"\n [style.color]=\"error ? 'red' : ''\">\n <option *ngFor=\"let option of options\" [value]=\"this.apiMeta !== undefined ? option.title : option.
|
|
178
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: CustomDropdownComponent, selector: "app-custom-dropdown", inputs: { options: "options", placeholder: "placeholder", apiMeta: "apiMeta", selectedValue: "selectedValue", progressBar: "progressBar", id: "id", readOnly: "readOnly", errorMessage: "errorMessage", error: "error", fromShengel: "fromShengel", question: "question", referenceField: "referenceField", token: "token" }, outputs: { valueChange: "valueChange" }, ngImport: i0, template: "<!-- HA 18-JAN-24 Commenting these lines as we don't have to use shengel here -->\n<!-- <select\n [ngClass]=\"{\n 'dt-line dpDown down myt-dropbox myt-border-r myt-font1': progressBar,\n 'custom-select': !progressBar\n }\" class=\"custom-select mr-sm-2 dd-height\" \n [id]=\"id\" \n [(ngModel)]=\"selectedValue\"\n (change)=\"selectChange($event.target.value);\" \n [style.borderColor]=\"error ? 'red' : '#858585'\"\n [style.color]=\"error ? 'red' : ''\">\n <option *ngFor=\"let option of options\" [value]=\"this.apiMeta !== undefined ? option.title : option.value\" class=\"option\">{{ this.apiMeta !== undefined ? option.title : option.value }}</option>\n <option *ngIf=\"errorMessage\" value=\"\" disabled hidden>{{ errorMessage }}</option>\n</select> -->\n<!-- // VD 12Jun24 - readonly change-->\n<!-- VD 01Aug24 - validation change-->\n<!-- VD 07Aug24 - isDependentField change-->\n<!-- VD 25Oct24 - changes-->\n<!-- RS 09DEC24 Changed keys--> \n<ng-select\n [class]=\"invalidFieldIds.includes(id) || error ? 'shengel-custom-select invalid' : 'shengel-custom-select'\"\n [(ngModel)]=\"selectedValue\" \n [placeholder]=\"placeholder\"\n [disabled]=\"readOnly\"\n (click)=\"getOptions()\"\n (change)=\"selectChange($event)\"\n [id]=\"id\">\n <ng-option \n *ngFor=\"let option of options\" \n [value]=\"apiObj && !apiObj.isDependentField ? option : option?.value\">\n {{ apiObj && !apiObj.isDependentField && option ? option[labelField] : option?.value }}\n </ng-option> \n</ng-select>\n<span *ngIf=\"error || invalidFieldIds.includes(id)\" class=\"error-msg\">{{errorMessage}}</span>\n", styles: [".ng-select{width:100%}.invalid{border:1px solid red!important}\n"], dependencies: [{ kind: "directive", type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i5.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i5.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i6.NgSelectComponent, selector: "ng-select", inputs: ["markFirst", "dropdownPosition", "loading", "closeOnSelect", "hideSelected", "selectOnTab", "bufferAmount", "selectableGroup", "selectableGroupAsModel", "searchFn", "trackByFn", "clearOnBackspace", "labelForId", "inputAttrs", "readonly", "searchWhileComposing", "minTermLength", "editableSearchTerm", "keyDownFn", "multiple", "addTag", "searchable", "clearable", "isOpen", "items", "compareWith", "clearSearchOnAdd", "bindLabel", "placeholder", "notFoundText", "typeToSearchText", "addTagText", "loadingText", "clearAllText", "virtualScroll", "openOnEnter", "appendTo", "bindValue", "appearance", "maxSelectedItems", "groupBy", "groupValue", "tabIndex", "typeahead"], outputs: ["blur", "focus", "change", "open", "close", "search", "clear", "add", "remove", "scroll", "scrollToEnd"] }, { kind: "component", type: i6.ɵr, selector: "ng-option", inputs: ["disabled", "value"] }] });
|
|
171
179
|
}
|
|
172
180
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: CustomDropdownComponent, decorators: [{
|
|
173
181
|
type: Component,
|
|
174
|
-
args: [{ selector: 'app-custom-dropdown', template: "<!-- HA 18-JAN-24 Commenting these lines as we don't have to use shengel here -->\n<!-- <select\n [ngClass]=\"{\n 'dt-line dpDown down myt-dropbox myt-border-r myt-font1': progressBar,\n 'custom-select': !progressBar\n }\" class=\"custom-select mr-sm-2 dd-height\" \n [id]=\"id\" \n [(ngModel)]=\"selectedValue\"\n (change)=\"selectChange($event.target.value);\" \n [style.borderColor]=\"error ? 'red' : '#858585'\"\n [style.color]=\"error ? 'red' : ''\">\n <option *ngFor=\"let option of options\" [value]=\"this.apiMeta !== undefined ? option.title : option.
|
|
182
|
+
args: [{ selector: 'app-custom-dropdown', template: "<!-- HA 18-JAN-24 Commenting these lines as we don't have to use shengel here -->\n<!-- <select\n [ngClass]=\"{\n 'dt-line dpDown down myt-dropbox myt-border-r myt-font1': progressBar,\n 'custom-select': !progressBar\n }\" class=\"custom-select mr-sm-2 dd-height\" \n [id]=\"id\" \n [(ngModel)]=\"selectedValue\"\n (change)=\"selectChange($event.target.value);\" \n [style.borderColor]=\"error ? 'red' : '#858585'\"\n [style.color]=\"error ? 'red' : ''\">\n <option *ngFor=\"let option of options\" [value]=\"this.apiMeta !== undefined ? option.title : option.value\" class=\"option\">{{ this.apiMeta !== undefined ? option.title : option.value }}</option>\n <option *ngIf=\"errorMessage\" value=\"\" disabled hidden>{{ errorMessage }}</option>\n</select> -->\n<!-- // VD 12Jun24 - readonly change-->\n<!-- VD 01Aug24 - validation change-->\n<!-- VD 07Aug24 - isDependentField change-->\n<!-- VD 25Oct24 - changes-->\n<!-- RS 09DEC24 Changed keys--> \n<ng-select\n [class]=\"invalidFieldIds.includes(id) || error ? 'shengel-custom-select invalid' : 'shengel-custom-select'\"\n [(ngModel)]=\"selectedValue\" \n [placeholder]=\"placeholder\"\n [disabled]=\"readOnly\"\n (click)=\"getOptions()\"\n (change)=\"selectChange($event)\"\n [id]=\"id\">\n <ng-option \n *ngFor=\"let option of options\" \n [value]=\"apiObj && !apiObj.isDependentField ? option : option?.value\">\n {{ apiObj && !apiObj.isDependentField && option ? option[labelField] : option?.value }}\n </ng-option> \n</ng-select>\n<span *ngIf=\"error || invalidFieldIds.includes(id)\" class=\"error-msg\">{{errorMessage}}</span>\n", styles: [".ng-select{width:100%}.invalid{border:1px solid red!important}\n"] }]
|
|
175
183
|
}], ctorParameters: function () { return [{ type: i1.ChangeService }, { type: i2.DataService }, { type: i3.I18nService }]; }, propDecorators: { options: [{
|
|
176
184
|
type: Input
|
|
177
185
|
}], placeholder: [{
|
|
@@ -201,4 +209,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
|
|
|
201
209
|
}], valueChange: [{
|
|
202
210
|
type: Output
|
|
203
211
|
}] } });
|
|
204
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"custom-dropdown.component.js","sourceRoot":"","sources":["../../../../../../projects/nxt-app/src/lib/components/custom-dropdown/custom-dropdown.component.ts","../../../../../../projects/nxt-app/src/lib/components/custom-dropdown/custom-dropdown.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit,Input,Output,EventEmitter, Optional } from '@angular/core';\nimport { Observable, Subscription } from 'rxjs';\nimport { APIMeta } from '../../interfaces/apimeta';\nimport { ChangeWrapper } from '../../model/changeWrapper';\nimport { ChangeService } from '../../services/change.service';\n// HA 19DEC23 imported translation service\nimport { I18nService } from '../../i18n.service';\n// VD 23JAN24 used service file for callout\nimport { DataService } from '../../services/data.service';\n\n@Component({\n  selector: 'app-custom-dropdown',\n  templateUrl: './custom-dropdown.component.html',\n  styleUrls: ['./custom-dropdown.component.css']\n})\nexport class CustomDropdownComponent implements OnInit {\n  @Input() options: string[];\n  @Input() placeholder: string;\n  @Input() apiMeta: string;\n  @Input() selectedValue: string;\n  @Input() progressBar: boolean;\n  @Input() id:string;\n  @Input() readOnly = false; // VD 12Jun24 - readonly change\n  @Input() errorMessage: string;\n  @Input() error:any;\n  @Input() fromShengel: boolean = false;\n  @Input() question:any;\n  @Input() referenceField:string;\n  @Input() token:string;    // VD 19JAN24 - getting token as input\n  @Output() valueChange: EventEmitter<ChangeWrapper> = new EventEmitter<ChangeWrapper>();\n  invalidFieldIds:string[] = [];\n  constructor( \n    private changeService: ChangeService, \n    private dataService: DataService,\n    public i18nService: I18nService,\n        ) { \n    this.changeService.submitValidate$.subscribe((data)=>{\n      // to get the error message's field id's\n      this.invalidFieldIds.push(data);\n    })\n  }\n\n  public labelField: string;\n  public valueField: string;\n  subscription: Subscription;\n  public apiObj:APIMeta;\n  public uniqueKey:string;\n\n  ngOnInit(): void {\n    \n  }\n  getOptions(){\n    console.log('test click');\n    // console.log('inside oninit of custom-dropdown of ' + this.id);\n    // console.log(this.apiMeta);\n    //VD 07Aug24 - isDependentField change\n    // VD 25Oct24 - changes\n    this.placeholder = this.placeholder ? this.placeholder : '---Select option---';\n      if(this.apiMeta !== undefined) {\n        this.apiObj = JSON.parse(this.apiMeta);\n        // VD 25Oct24 changes\n        this.labelField = this.apiObj.field;\n        this.uniqueKey = this.apiObj.uniqueKey;\n        const cachedOptions = localStorage.getItem(this.uniqueKey);\n        if (cachedOptions) {\n          this.options = JSON.parse(cachedOptions);\n        }else {\n          if(!this.apiObj.isDependentField){\n            this.options = [];\n            // VD 09Sep24- setup the query param for api call\n            let fullEndPoint ;\n            if(this.apiObj.endpoint){\n              if(this.apiObj.queryValueReference && this.apiObj.queryField){\n                // process the end point with query param\n                let queryReferences = this.apiObj.queryValueReference.split(',');\n                let queryParams = [];\n                // Iterate over queryReferences and find the corresponding element in referenceData\n                queryReferences.forEach(reference => {\n                    // Find the element in referenceData that matches the current reference\n                    let matchingElement = this.question?.referenceQueryData.find(element => element.Reference_Field__c === reference);\n                    // If a matching element is found, get its input value and create a query parameter\n                    if (matchingElement) {\n                        queryParams.push(`${reference}=${matchingElement.input}`);\n                    }\n                });\n                   fullEndPoint = this.apiObj.endpoint + '?' + queryParams.join('&');\n                   console.log(fullEndPoint);\n              }else {\n                 // if no query param get the actual endPoint\n                   fullEndPoint = this.apiObj.endpoint;\n              }\n              // VD 19JAN24 - added one more param for authentication\n              this.dataService.apiResponse(fullEndPoint)?.subscribe((apiResponse) => {\n                // HA 18-JAN-24 Assigned apiresponse directly if we have the response in array also\n                // VD 19JAN24 - if response has key with value(which is array)\n                let responses;\n                if(this.apiObj.variable){\n                  // VD 21May24 - handling multiple child objects\n                  // VD 22May24 - used common service file\n                  responses = this.dataService.getValue(apiResponse,this.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                // VD 25Oct24 - Store fetched options in local storage\n                if(this.uniqueKey){\n                  localStorage.setItem(this.uniqueKey, JSON.stringify(this.options));\n                }\n                // Reference https://www.npmjs.com/package/@ng-select/ng-select\n              })\n            }\n          }\n            // VD NOV23 - handle the dependent update for dropdown\n            // // VD 09Sep24- push the dependent field values for dropdown\n            let sourceId = this.apiObj.sourceQuestionId;\n            if(sourceId && this.apiObj.variable || this.apiObj.valueField){\n              // Subscribe for the changes\n              this.subscription = this.changeService.changeAnnounced$.subscribe(\n                (changeValue) => {\n                  if(changeValue != undefined) {\n                    // console.log('inside subscription for the change');\n                    if(changeValue.valueObj != undefined && changeValue.fromQuestionId == this.apiObj.sourceQuestionId) {\n                      //  this.selectedValue = changeValue.valueObj[this.apiObj.valueField];\n                      //  let value ={};\n                      //  value['name'] = this.selectedValue;\n                       let responses;\n                       if(this.apiObj.variable){\n                         responses = this.dataService.getValue(changeValue.valueObj,this.apiObj.variable);\n                         let results = [];\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{\n                         responses = changeValue.valueObj;\n                         this.options = responses;\n                       }\n                      // VD 25Oct24 - Store fetched options in local storage\n                      if(this.uniqueKey){\n                        localStorage.setItem(this.uniqueKey, JSON.stringify(this.options));\n                      }\n                      }\n                    this.changeService.confirmChange(this.apiObj.sourceQuestionId);\n                  }\n                }\n              );\n            }\n        }\n      }\n  }\n// VD 22May24 - used common service file\n\n  selectChange(event:any) {\n    console.log('inside selectChange from ' + this.id);\n    // console.log(event);\n    let change = new ChangeWrapper(); // ChangeWrapper = JSON.parse('{}');\n    change.fromQuestionId = this.id;\n    change.valueObj = event ? event : '';\n    change.referenceField = this.referenceField;\n    change.selectedObj = event ? event[this.labelField] : '';\n    this.valueChange.emit(change);\n    // once got value in dropdown remove the error validation\n    if(event){\n      this.invalidFieldIds =[];\n    }\n  }\n}\n","<!-- HA 18-JAN-24 Commenting these lines as we don't have to use shengel here -->\n<!-- <select\n  [ngClass]=\"{\n    'dt-line dpDown down myt-dropbox myt-border-r myt-font1': progressBar,\n    'custom-select': !progressBar\n  }\" class=\"custom-select mr-sm-2 dd-height\" \n  [id]=\"id\" \n  [(ngModel)]=\"selectedValue\"\n  (change)=\"selectChange($event.target.value);\" \n  [style.borderColor]=\"error ? 'red' : '#858585'\"\n  [style.color]=\"error ? 'red' : ''\">\n    <option *ngFor=\"let option of options\" [value]=\"this.apiMeta !== undefined ? option.title : option.Value__c\" class=\"option\">{{ this.apiMeta !== undefined ? option.title : option.Value__c }}</option>\n    <option *ngIf=\"errorMessage\" value=\"\" disabled hidden>{{ errorMessage }}</option>\n</select> -->\n<!-- // VD 12Jun24 - readonly change-->\n<!-- VD 01Aug24 - validation change-->\n<!-- VD 07Aug24 - isDependentField change-->\n<!-- VD 25Oct24 - changes-->\n<ng-select\n            [class]=\"invalidFieldIds.includes(id) || error ? 'shengel-custom-select invalid' : 'shengel-custom-select'\"\n            [(ngModel)]=\"selectedValue\" \n            [placeholder]=\"placeholder\"\n            [disabled]=\"readOnly\"\n            (click) = \"getOptions()\"\n            (change)=\"selectChange($event)\"\n            [id]=\"id\">\n  <ng-option *ngFor=\"let option of options\" [value]=\"apiObj !== undefined && !apiObj.isDependentField ? option : option.Value__c\">{{ apiObj !== undefined && !apiObj.isDependentField ? option[labelField] : option.Value__c  }}</ng-option> \n</ng-select>\n<span *ngIf=\"error || invalidFieldIds.includes(id)\" class=\"error-msg\">{{errorMessage}}</span>\n"]}
|
|
212
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"custom-dropdown.component.js","sourceRoot":"","sources":["../../../../../../projects/nxt-app/src/lib/components/custom-dropdown/custom-dropdown.component.ts","../../../../../../projects/nxt-app/src/lib/components/custom-dropdown/custom-dropdown.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit,Input,Output,EventEmitter, Optional } from '@angular/core';\nimport { Observable, Subscription } from 'rxjs';\nimport { APIMeta } from '../../interfaces/apimeta';\nimport { ChangeWrapper } from '../../model/changeWrapper';\nimport { ChangeService } from '../../services/change.service';\n// HA 19DEC23 imported translation service\nimport { I18nService } from '../../i18n.service';\n// VD 23JAN24 used service file for callout\nimport { DataService } from '../../services/data.service';\n\n@Component({\n  selector: 'app-custom-dropdown',\n  templateUrl: './custom-dropdown.component.html',\n  styleUrls: ['./custom-dropdown.component.css']\n})\nexport class CustomDropdownComponent implements OnInit {\n  @Input() options: string[];\n  @Input() placeholder: string;\n  @Input() apiMeta: string;\n  @Input() selectedValue: string;\n  @Input() progressBar: boolean;\n  @Input() id:string;\n  @Input() readOnly = false; // VD 12Jun24 - readonly change\n  @Input() errorMessage: string;\n  @Input() error:any;\n  @Input() fromShengel: boolean = false;\n  @Input() question:any;\n  @Input() referenceField:string;\n  @Input() token:string;    // VD 19JAN24 - getting token as input\n  @Output() valueChange: EventEmitter<ChangeWrapper> = new EventEmitter<ChangeWrapper>();\n  invalidFieldIds:string[] = [];\n  constructor( \n    private changeService: ChangeService, \n    private dataService: DataService,\n    public i18nService: I18nService,\n        ) { \n    this.changeService.submitValidate$.subscribe((data)=>{\n      // to get the error message's field id's\n      this.invalidFieldIds.push(data);\n    })\n  }\n\n  public labelField: string;\n  public valueField: string;\n  subscription: Subscription;\n  public apiObj:APIMeta;\n  public uniqueKey:string;\n\n  ngOnInit(): void {\n    \n  }\n  getOptions(){\n    console.log('test click');\n    // console.log('inside oninit of custom-dropdown of ' + this.id);\n    // console.log(this.apiMeta);\n    //VD 07Aug24 - isDependentField change\n    // VD 25Oct24 - changes\n    this.placeholder = this.placeholder ? this.placeholder : '---Select option---';\n    if(this.apiMeta) {\n    try {\n      this.apiObj = JSON.parse(this.apiMeta);\n      // Check if apiObj and apiObj.field are defined\n      if (this.apiObj && this.apiObj.field) {\n        this.labelField = this.apiObj.field;\n        this.uniqueKey = this.apiObj.uniqueKey;\n        const cachedOptions = localStorage.getItem(this.uniqueKey);\n        if (cachedOptions) {\n          this.options = JSON.parse(cachedOptions);\n        }else {\n          if(!this.apiObj.isDependentField){\n            this.options = [];\n            // VD 09Sep24- setup the query param for api call\n            let fullEndPoint ;\n            if(this.apiObj.endpoint){\n              if(this.apiObj.queryValueReference && this.apiObj.queryField){\n                // process the end point with query param\n                let queryReferences = this.apiObj.queryValueReference.split(',');\n                let queryParams = [];\n                // Iterate over queryReferences and find the corresponding element in referenceData\n                queryReferences.forEach(reference => {\n                  // Find the element in referenceData that matches the current reference\n                 // RS 09DEC24 Changed keys\n                  let matchingElement = this.question?.referenceQueryData.find(element => element.referenceField === reference);\n               // If a matching element is found, get its input value and create a query parameter\n                  if (matchingElement) {\n                    queryParams.push(`${reference}=${matchingElement.input}`);\n                  }\n                });\n                fullEndPoint = this.apiObj.endpoint + '?' + queryParams.join('&');\n                console.log(fullEndPoint);\n              }else {\n                 // if no query param get the actual endPoint\n                fullEndPoint = this.apiObj.endpoint;\n              }\n              // VD 19JAN24 - added one more param for authentication\n              this.dataService.apiResponse(fullEndPoint)?.subscribe((apiResponse) => {\n                // HA 18-JAN-24 Assigned apiresponse directly if we have the response in array also\n                // VD 19JAN24 - if response has key with value(which is array)\n                let responses;\n                if(this.apiObj.variable){\n                  // VD 21May24 - handling multiple child objects\n                  // VD 22May24 - used common service file\n                  responses = this.dataService.getValue(apiResponse,this.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                // VD 25Oct24 - Store fetched options in local storage\n                if(this.uniqueKey){\n                  localStorage.setItem(this.uniqueKey, JSON.stringify(this.options));\n                }\n                // Reference https://www.npmjs.com/package/@ng-select/ng-select\n              })\n            }\n          }\n            // VD NOV23 - handle the dependent update for dropdown\n            // // VD 09Sep24- push the dependent field values for dropdown\n            let sourceId = this.apiObj.sourceQuestionId;\n            if(sourceId && this.apiObj.variable || this.apiObj.valueField){\n              // Subscribe for the changes\n              this.subscription = this.changeService.changeAnnounced$.subscribe(\n                (changeValue) => {\n                  if(changeValue != undefined) {\n                    // console.log('inside subscription for the change');\n                    if(changeValue.valueObj != undefined && changeValue.fromQuestionId == this.apiObj.sourceQuestionId) {\n                      //  this.selectedValue = changeValue.valueObj[this.apiObj.valueField];\n                      //  let value ={};\n                      //  value['name'] = this.selectedValue;\n                       let responses;\n                       if(this.apiObj.variable){\n                         responses = this.dataService.getValue(changeValue.valueObj,this.apiObj.variable);\n                         let results = [];\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{\n                         responses = changeValue.valueObj;\n                         this.options = responses;\n                       }\n                      // VD 25Oct24 - Store fetched options in local storage\n                      if(this.uniqueKey){\n                        localStorage.setItem(this.uniqueKey, JSON.stringify(this.options));\n                      }\n                      }\n                    this.changeService.confirmChange(this.apiObj.sourceQuestionId);\n                  }\n              }\n            );\n          }\n        }\n      }\n    } catch (error) {\n      console.error('Error parsing apiMeta:', error);\n    }\n  } \n}\n// VD 22May24 - used common service file\n\n  selectChange(event:any) {\n    console.log('inside selectChange from ' + this.id);\n    // console.log(event);\n    let change = new ChangeWrapper(); // ChangeWrapper = JSON.parse('{}');\n    change.fromQuestionId = this.id;\n    change.valueObj = event ? event : '';\n    change.referenceField = this.referenceField;\n    change.selectedObj = event ? event[this.labelField] : '';\n    this.valueChange.emit(change);\n    // once got value in dropdown remove the error validation\n    if(event){\n      this.invalidFieldIds =[];\n    }\n  }\n}\n","<!-- HA 18-JAN-24 Commenting these lines as we don't have to use shengel here -->\n<!-- <select\n  [ngClass]=\"{\n    'dt-line dpDown down myt-dropbox myt-border-r myt-font1': progressBar,\n    'custom-select': !progressBar\n  }\" class=\"custom-select mr-sm-2 dd-height\" \n  [id]=\"id\" \n  [(ngModel)]=\"selectedValue\"\n  (change)=\"selectChange($event.target.value);\" \n  [style.borderColor]=\"error ? 'red' : '#858585'\"\n  [style.color]=\"error ? 'red' : ''\">\n    <option *ngFor=\"let option of options\" [value]=\"this.apiMeta !== undefined ? option.title : option.value\" class=\"option\">{{ this.apiMeta !== undefined ? option.title : option.value }}</option>\n    <option *ngIf=\"errorMessage\" value=\"\" disabled hidden>{{ errorMessage }}</option>\n</select> -->\n<!-- // VD 12Jun24 - readonly change-->\n<!-- VD 01Aug24 - validation change-->\n<!-- VD 07Aug24 - isDependentField change-->\n<!-- VD 25Oct24 - changes-->\n<!-- RS 09DEC24 Changed keys--> \n<ng-select\n  [class]=\"invalidFieldIds.includes(id) || error ? 'shengel-custom-select invalid' : 'shengel-custom-select'\"\n  [(ngModel)]=\"selectedValue\" \n  [placeholder]=\"placeholder\"\n  [disabled]=\"readOnly\"\n  (click)=\"getOptions()\"\n  (change)=\"selectChange($event)\"\n  [id]=\"id\">\n  <ng-option \n    *ngFor=\"let option of options\" \n    [value]=\"apiObj && !apiObj.isDependentField ? option : option?.value\">\n    {{ apiObj && !apiObj.isDependentField && option ? option[labelField] : option?.value }}\n  </ng-option> \n</ng-select>\n<span *ngIf=\"error || invalidFieldIds.includes(id)\" class=\"error-msg\">{{errorMessage}}</span>\n"]}
|
|
@@ -9,10 +9,11 @@ export class CustomImageComponent {
|
|
|
9
9
|
constructor() { }
|
|
10
10
|
ngOnInit() {
|
|
11
11
|
// VD 03Aug24 style changes
|
|
12
|
+
// RS 09DEC24 Changed keys
|
|
12
13
|
if (this.question) {
|
|
13
|
-
this.imageStyle = this.question.
|
|
14
|
-
this.src = this.question.
|
|
15
|
-
this.alt = this.question.
|
|
14
|
+
this.imageStyle = this.question.subTitle ? this.question.subTitle : "height: 150px;width: 200px;";
|
|
15
|
+
this.src = this.question.title ? this.question.title : "";
|
|
16
|
+
this.alt = this.question.helpText ? this.question.helpText : "my image";
|
|
16
17
|
}
|
|
17
18
|
}
|
|
18
19
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: CustomImageComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
@@ -30,4 +31,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
|
|
|
30
31
|
}], question: [{
|
|
31
32
|
type: Input
|
|
32
33
|
}] } });
|
|
33
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
34
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3VzdG9tLWltYWdlLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL254dC1hcHAvc3JjL2xpYi9jb21wb25lbnRzL2N1c3RvbS1pbWFnZS9jdXN0b20taW1hZ2UuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbnh0LWFwcC9zcmMvbGliL2NvbXBvbmVudHMvY3VzdG9tLWltYWdlL2N1c3RvbS1pbWFnZS5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBVSxNQUFNLGVBQWUsQ0FBQzs7QUFPekQsTUFBTSxPQUFPLG9CQUFvQjtJQUN0QixHQUFHLENBQVM7SUFDWixHQUFHLENBQVM7SUFDWixVQUFVLENBQU07SUFDaEIsUUFBUSxDQUFLO0lBRWYsTUFBTSxDQUFTO0lBRXRCLGdCQUFnQixDQUFDO0lBRWpCLFFBQVE7UUFDTiw0QkFBNEI7UUFDNUIsMEJBQTBCO1FBQ3pCLElBQUcsSUFBSSxDQUFDLFFBQVEsRUFBQztZQUNkLElBQUksQ0FBQyxVQUFVLEdBQUcsSUFBSSxDQUFDLFFBQVEsQ0FBQyxRQUFRLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsUUFBUSxDQUFDLENBQUMsQ0FBQyw2QkFBNkIsQ0FBQztZQUNsRyxJQUFJLENBQUMsR0FBRyxHQUFHLElBQUksQ0FBQyxRQUFRLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFFO1lBQzNELElBQUksQ0FBQyxHQUFHLEdBQUcsSUFBSSxDQUFDLFFBQVEsQ0FBQyxRQUFRLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsUUFBUSxDQUFDLENBQUMsQ0FBQyxVQUFVLENBQUM7U0FDMUU7SUFDSixDQUFDO3VHQWxCVSxvQkFBb0I7MkZBQXBCLG9CQUFvQiw0SUNQakMsb0RBQWtEOzsyRkRPckMsb0JBQW9CO2tCQUxoQyxTQUFTOytCQUNFLGtCQUFrQjswRUFLbkIsR0FBRztzQkFBWCxLQUFLO2dCQUNHLEdBQUc7c0JBQVgsS0FBSztnQkFDRyxVQUFVO3NCQUFsQixLQUFLO2dCQUNHLFFBQVE7c0JBQWhCLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIElucHV0LCBPbkluaXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnYXBwLWN1c3RvbS1pbWFnZScsXG4gIHRlbXBsYXRlVXJsOiAnLi9jdXN0b20taW1hZ2UuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi9jdXN0b20taW1hZ2UuY29tcG9uZW50LmNzcyddXG59KVxuZXhwb3J0IGNsYXNzIEN1c3RvbUltYWdlQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0IHtcbiAgQElucHV0KCkgYWx0OiBzdHJpbmc7XG4gIEBJbnB1dCgpIHNyYzogc3RyaW5nO1xuICBASW5wdXQoKSBpbWFnZVN0eWxlOiBhbnk7XG4gIEBJbnB1dCgpIHF1ZXN0aW9uOmFueTtcblxuICBwdWJsaWMgc3R5bGVzOiBzdHJpbmc7XG5cbiAgY29uc3RydWN0b3IoKSB7IH1cblxuICBuZ09uSW5pdCgpOiB2b2lkIHtcbiAgICAvLyBWRCAwM0F1ZzI0IHN0eWxlIGNoYW5nZXMgXG4gICAgLy8gUlMgMDlERUMyNCBDaGFuZ2VkIGtleXNcbiAgICAgaWYodGhpcy5xdWVzdGlvbil7XG4gICAgICAgIHRoaXMuaW1hZ2VTdHlsZSA9IHRoaXMucXVlc3Rpb24uc3ViVGl0bGUgPyB0aGlzLnF1ZXN0aW9uLnN1YlRpdGxlIDogXCJoZWlnaHQ6IDE1MHB4O3dpZHRoOiAyMDBweDtcIjtcbiAgICAgICAgdGhpcy5zcmMgPSB0aGlzLnF1ZXN0aW9uLnRpdGxlID8gdGhpcy5xdWVzdGlvbi50aXRsZSA6IFwiXCIgO1xuICAgICAgICB0aGlzLmFsdCA9IHRoaXMucXVlc3Rpb24uaGVscFRleHQgPyB0aGlzLnF1ZXN0aW9uLmhlbHBUZXh0IDogXCJteSBpbWFnZVwiO1xuICAgICB9XG4gIH1cbn0iLCI8aW1nIHNyYz17e3NyY319IGFsdD17e2FsdH19IHN0eWxlPXt7aW1hZ2VTdHlsZX19PiJdfQ==
|
|
@@ -26,11 +26,12 @@ export class CustomInputComponent {
|
|
|
26
26
|
this.i18nService = i18nService;
|
|
27
27
|
this.dataService = dataService;
|
|
28
28
|
}
|
|
29
|
+
// RS 09DEC24 Changed keys
|
|
29
30
|
ngOnInit() {
|
|
30
31
|
// Since the idValue holds the Parent Question
|
|
31
|
-
if (this.question.
|
|
32
|
+
if (this.question.subText != undefined) {
|
|
32
33
|
this.disabled = true;
|
|
33
|
-
let dependencyObj = JSON.parse(this.question.
|
|
34
|
+
let dependencyObj = JSON.parse(this.question.subText);
|
|
34
35
|
if (dependencyObj.disabled && dependencyObj.disabled == "false") {
|
|
35
36
|
this.disabled = false;
|
|
36
37
|
}
|
|
@@ -61,11 +62,11 @@ export class CustomInputComponent {
|
|
|
61
62
|
this.inputValue.emit(input.target.value);
|
|
62
63
|
}
|
|
63
64
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: CustomInputComponent, deps: [{ token: i1.ChangeService }, { token: i2.I18nService }, { token: i3.DataService }], target: i0.ɵɵFactoryTarget.Component });
|
|
64
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: CustomInputComponent, selector: "app-custom-input", inputs: { value: "value", question: "question", disabled: "disabled", placeholder: "placeholder", error: "error", fromShengel: "fromShengel", readOnly: "readOnly", ngClassValue: "ngClassValue", idValue: "idValue", focusEvent: "focusEvent" }, outputs: { inputValue: "inputValue" }, ngImport: i0, template: " <!-- HA 19DEC23 Included Style value from Salesforce -->\n <!-- HA 18-JAN-24 Added these classes for style, HA 31-JAN-24 Added ternary for style -->\n <!-- HA 02FEB24 question input will hold the value to display -->\n <!-- // VD 12Jun24 - readonly change-->\n <input *ngIf=\"!fromShengel\" type=\"text\" \n [(ngModel)]=\"question.input\" \n [ngClass]=\"ngClassValue\"\n class=\"she-line-input form-control\"\n [id]=\"idValue\"\n (focus)=\"focusEvent\"\n [readOnly]=\"readOnly\"\n [style.border-color]=\"error ? 'red !important' : ''\"\n [style]=\"question?.
|
|
65
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: CustomInputComponent, selector: "app-custom-input", inputs: { value: "value", question: "question", disabled: "disabled", placeholder: "placeholder", error: "error", fromShengel: "fromShengel", readOnly: "readOnly", ngClassValue: "ngClassValue", idValue: "idValue", focusEvent: "focusEvent" }, outputs: { inputValue: "inputValue" }, ngImport: i0, template: " <!-- HA 19DEC23 Included Style value from Salesforce -->\n <!-- HA 18-JAN-24 Added these classes for style, HA 31-JAN-24 Added ternary for style -->\n <!-- HA 02FEB24 question input will hold the value to display -->\n <!-- // VD 12Jun24 - readonly change-->\n <!-- RS 09DEC24 Changed keys--> \n <input *ngIf=\"!fromShengel\" type=\"text\" \n [(ngModel)]=\"question.input\" \n [ngClass]=\"ngClassValue\"\n class=\"she-line-input form-control\"\n [id]=\"idValue\"\n (focus)=\"focusEvent\"\n [readOnly]=\"readOnly\"\n [style.border-color]=\"error ? 'red !important' : ''\"\n [style]=\"question?.style?.inputStyle\"\n [placeholder]=\"placeholder ? placeholder : ''\"\n (input)=\"onInputChange($event)\" />\n\n<input *ngIf=\"fromShengel\" \n [(ngModel)]=\"question.input\"\n type=\"text\" \n [readOnly]=\"readOnly\"\n class=\"she-line-input form-control\" \n [placeholder]=\"placeholder ? placeholder : '' \"\n [disabled]=\"disabled\"\n [style]=\"question?.style?.inputStyle\"\n (input)=\"onInputChange($event)\" />\n<!-- HA 19DEC23 For translation -->\n<span *ngIf=\"error\" class=\"error-msg\">{{question?.errorMessage}}*</span>\n", styles: [".form-control[disabled]{border-radius:5px;background-color:#e9ecef!important}\n"], dependencies: [{ kind: "directive", type: i4.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i5.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i5.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i5.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }] });
|
|
65
66
|
}
|
|
66
67
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: CustomInputComponent, decorators: [{
|
|
67
68
|
type: Component,
|
|
68
|
-
args: [{ selector: 'app-custom-input', template: " <!-- HA 19DEC23 Included Style value from Salesforce -->\n <!-- HA 18-JAN-24 Added these classes for style, HA 31-JAN-24 Added ternary for style -->\n <!-- HA 02FEB24 question input will hold the value to display -->\n <!-- // VD 12Jun24 - readonly change-->\n <input *ngIf=\"!fromShengel\" type=\"text\" \n [(ngModel)]=\"question.input\" \n [ngClass]=\"ngClassValue\"\n class=\"she-line-input form-control\"\n [id]=\"idValue\"\n (focus)=\"focusEvent\"\n [readOnly]=\"readOnly\"\n [style.border-color]=\"error ? 'red !important' : ''\"\n [style]=\"question?.
|
|
69
|
+
args: [{ selector: 'app-custom-input', template: " <!-- HA 19DEC23 Included Style value from Salesforce -->\n <!-- HA 18-JAN-24 Added these classes for style, HA 31-JAN-24 Added ternary for style -->\n <!-- HA 02FEB24 question input will hold the value to display -->\n <!-- // VD 12Jun24 - readonly change-->\n <!-- RS 09DEC24 Changed keys--> \n <input *ngIf=\"!fromShengel\" type=\"text\" \n [(ngModel)]=\"question.input\" \n [ngClass]=\"ngClassValue\"\n class=\"she-line-input form-control\"\n [id]=\"idValue\"\n (focus)=\"focusEvent\"\n [readOnly]=\"readOnly\"\n [style.border-color]=\"error ? 'red !important' : ''\"\n [style]=\"question?.style?.inputStyle\"\n [placeholder]=\"placeholder ? placeholder : ''\"\n (input)=\"onInputChange($event)\" />\n\n<input *ngIf=\"fromShengel\" \n [(ngModel)]=\"question.input\"\n type=\"text\" \n [readOnly]=\"readOnly\"\n class=\"she-line-input form-control\" \n [placeholder]=\"placeholder ? placeholder : '' \"\n [disabled]=\"disabled\"\n [style]=\"question?.style?.inputStyle\"\n (input)=\"onInputChange($event)\" />\n<!-- HA 19DEC23 For translation -->\n<span *ngIf=\"error\" class=\"error-msg\">{{question?.errorMessage}}*</span>\n", styles: [".form-control[disabled]{border-radius:5px;background-color:#e9ecef!important}\n"] }]
|
|
69
70
|
}], ctorParameters: function () { return [{ type: i1.ChangeService }, { type: i2.I18nService }, { type: i3.DataService }]; }, propDecorators: { value: [{
|
|
70
71
|
type: Input
|
|
71
72
|
}], question: [{
|
|
@@ -89,4 +90,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
|
|
|
89
90
|
}], inputValue: [{
|
|
90
91
|
type: Output
|
|
91
92
|
}] } });
|
|
92
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
93
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"custom-input.component.js","sourceRoot":"","sources":["../../../../../../projects/nxt-app/src/lib/components/custom-input/custom-input.component.ts","../../../../../../projects/nxt-app/src/lib/components/custom-input/custom-input.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,KAAK,EAAU,MAAM,EAAE,MAAM,eAAe,CAAC;;;;;;;AAgB/E,MAAM,OAAO,oBAAoB;IAgBX;IAAqC;IAAkC;IAflF,KAAK,CAAc,CAAC,cAAc;IAClC,QAAQ,CAAU;IAClB,QAAQ,GAAY,KAAK,CAAC,CAAC,wBAAwB;IACnD,WAAW,CAAQ;IACnB,KAAK,CAAK;IACV,WAAW,GAAY,KAAK,CAAC;IAC7B,QAAQ,GAAY,KAAK,CAAC,CAAC,+BAA+B;IAE1D,YAAY,CAAK;IACjB,OAAO,CAAK;IACZ,UAAU,CAAM;IACf,UAAU,GAAG,IAAI,YAAY,EAAO,CAAC;IAE/C,YAAY,CAAe;IAE3B,YAAoB,aAA4B,EAAS,WAAwB,EAAU,WAAwB;QAA/F,kBAAa,GAAb,aAAa,CAAe;QAAS,gBAAW,GAAX,WAAW,CAAa;QAAU,gBAAW,GAAX,WAAW,CAAa;IACnH,CAAC;IAED,0BAA0B;IAC1B,QAAQ;QACN,8CAA8C;QAC9C,IAAG,IAAI,CAAC,QAAQ,CAAC,OAAO,IAAI,SAAS,EAAE;YACrC,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;YACrB,IAAI,aAAa,GAAmB,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC;YACtE,IAAG,aAAa,CAAC,QAAQ,IAAI,aAAa,CAAC,QAAQ,IAAI,OAAO,EAAC;gBAC7D,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC;aACvB;iBAAI;gBACH,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;aACtB;YACD,4BAA4B;YAC5B,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,aAAa,CAAC,gBAAgB,CAAC,SAAS,CAC/D,CAAC,WAAW,EAAE,EAAE;gBACd,IAAG,WAAW,IAAI,SAAS,EAAE;oBAC3B,qDAAqD;oBACrD,IAAG,WAAW,CAAC,QAAQ,IAAI,SAAS,IAAI,WAAW,CAAC,cAAc,IAAI,aAAa,CAAC,gBAAgB,EAAE;wBACpG,0CAA0C;wBAC1C,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,WAAW,CAAC,QAAQ,EAAC,aAAa,CAAC,UAAU,CAAC,CAAC;wBACtF,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;qBAClC;oBACD,IAAI,CAAC,aAAa,CAAC,aAAa,CAAC,aAAa,CAAC,gBAAgB,CAAC,CAAC;iBAClE;YACH,CAAC,CACF,CAAC;SACH;IACH,CAAC;IAED,UAAU;IACV,CAAC;IAED,WAAW;QACT,+CAA+C;QAC/C,IAAI,CAAC,YAAY,EAAE,WAAW,EAAE,CAAC;IACnC,CAAC;IAED,aAAa,CAAC,KAAS;QACrB,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;IAC3C,CAAC;uGAzDU,oBAAoB;2FAApB,oBAAoB,iVChBjC,4tCA4BA;;2FDZa,oBAAoB;kBANhC,SAAS;+BACE,kBAAkB;wJAMnB,KAAK;sBAAb,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACG,KAAK;sBAAb,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBAEG,YAAY;sBAApB,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBACI,UAAU;sBAAnB,MAAM","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\nimport { Observable, Subscription } from 'rxjs';\nimport { ChangeService } from '../../services/change.service';\nimport { ChangeWrapper } from '../../model/changeWrapper';\nimport { Question } from '../../wrapper';\nimport { DependencyMeta } from '../../interfaces/dependencyMeta';\n// HA 19DEC23 imported translation service\nimport { I18nService } from '../../i18n.service';\nimport { DataService } from '../../services/data.service';\n\n@Component({\n  selector: 'app-custom-input',\n  templateUrl: './custom-input.component.html',\n  styleUrls: ['./custom-input.component.css']\n})\n\nexport class CustomInputComponent implements OnInit {\n  @Input() value: any | any[]; // input value\n  @Input() question: Question\n  @Input() disabled: boolean = false; // input disabled or not\n  @Input() placeholder:string;\n  @Input() error:any;\n  @Input() fromShengel: boolean = false;\n  @Input() readOnly :boolean = false; // VD 12Jun24 - readonly change\n\n  @Input() ngClassValue:any;\n  @Input() idValue:any;\n  @Input() focusEvent: any;\n  @Output() inputValue = new EventEmitter<any>(); \n\n  subscription: Subscription;\n\n  constructor(private changeService: ChangeService, public i18nService: I18nService, private dataService: DataService) { \n  }\n\n  // RS 09DEC24 Changed keys\n  ngOnInit(): void {\n    // Since the idValue holds the Parent Question\n    if(this.question.subText != undefined) {\n      this.disabled = true;\n      let dependencyObj: DependencyMeta = JSON.parse(this.question.subText);\n      if(dependencyObj.disabled && dependencyObj.disabled == \"false\"){\n        this.disabled = false;\n      }else{\n        this.disabled = true;\n      }\n      // Subscribe for the changes\n      this.subscription = this.changeService.changeAnnounced$.subscribe(\n        (changeValue) => {\n          if(changeValue != undefined) {\n            // console.log('inside subscription for the change');\n            if(changeValue.valueObj != undefined && changeValue.fromQuestionId == dependencyObj.sourceQuestionId) {\n              // VD 20Aug24 handling the multiple object\n              this.value = this.dataService.getValue(changeValue.valueObj,dependencyObj.valueField);\n              this.inputValue.emit(this.value);\n            }\n            this.changeService.confirmChange(dependencyObj.sourceQuestionId);\n          }\n        }\n      );\n    }\n  }\n\n  ngOnChange(): void {\n  }\n\n  ngOnDestroy() {\n    // prevent memory leak when component destroyed\n    this.subscription?.unsubscribe();\n  }\n  \n  onInputChange(input:any){\n    this.inputValue.emit(input.target.value);\n  }\n}\n"," <!-- HA 19DEC23 Included Style value from Salesforce -->\n  <!-- HA 18-JAN-24 Added these classes for style, HA 31-JAN-24 Added ternary for style -->\n  <!-- HA 02FEB24 question input will hold the value to display -->\n  <!-- // VD 12Jun24 - readonly change-->\n  <!-- RS 09DEC24 Changed keys--> \n  <input *ngIf=\"!fromShengel\" type=\"text\" \n       [(ngModel)]=\"question.input\" \n       [ngClass]=\"ngClassValue\"\n       class=\"she-line-input form-control\"\n       [id]=\"idValue\"\n       (focus)=\"focusEvent\"\n       [readOnly]=\"readOnly\"\n       [style.border-color]=\"error ? 'red !important' : ''\"\n       [style]=\"question?.style?.inputStyle\"\n       [placeholder]=\"placeholder ? placeholder : ''\"\n       (input)=\"onInputChange($event)\" />\n\n<input *ngIf=\"fromShengel\" \n       [(ngModel)]=\"question.input\"\n       type=\"text\" \n       [readOnly]=\"readOnly\"\n       class=\"she-line-input form-control\" \n       [placeholder]=\"placeholder ? placeholder : '' \"\n       [disabled]=\"disabled\"\n       [style]=\"question?.style?.inputStyle\"\n       (input)=\"onInputChange($event)\" />\n<!-- HA 19DEC23 For translation -->\n<span *ngIf=\"error\" class=\"error-msg\">{{question?.errorMessage}}*</span>\n"]}
|
|
@@ -1,29 +1,21 @@
|
|
|
1
1
|
import { Component, Input } from '@angular/core';
|
|
2
2
|
import * as i0 from "@angular/core";
|
|
3
|
-
import * as i1 from "@angular/common";
|
|
4
3
|
export class CustomLabelComponent {
|
|
5
4
|
labelValue;
|
|
6
5
|
labelStyle;
|
|
7
|
-
// VD 17-DEC-2024 - warning or Error handling
|
|
8
|
-
error;
|
|
9
|
-
errorMessage;
|
|
10
6
|
constructor() {
|
|
11
7
|
}
|
|
12
8
|
ngOnInit() {
|
|
13
9
|
}
|
|
14
10
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: CustomLabelComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
15
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: CustomLabelComponent, selector: "app-custom-label", inputs: { labelValue: "labelValue", labelStyle: "labelStyle"
|
|
11
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: CustomLabelComponent, selector: "app-custom-label", inputs: { labelValue: "labelValue", labelStyle: "labelStyle" }, ngImport: i0, template: "\n<div style={{labelStyle}}>{{ labelValue }}</div>\n", styles: [".label{margin-top:8px;margin-left:7px}\n"] });
|
|
16
12
|
}
|
|
17
13
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: CustomLabelComponent, decorators: [{
|
|
18
14
|
type: Component,
|
|
19
|
-
args: [{ selector: 'app-custom-label', template: "\n<div style={{labelStyle}}>{{ labelValue }}</div>\n
|
|
15
|
+
args: [{ selector: 'app-custom-label', template: "\n<div style={{labelStyle}}>{{ labelValue }}</div>\n", styles: [".label{margin-top:8px;margin-left:7px}\n"] }]
|
|
20
16
|
}], ctorParameters: function () { return []; }, propDecorators: { labelValue: [{
|
|
21
17
|
type: Input
|
|
22
18
|
}], labelStyle: [{
|
|
23
19
|
type: Input
|
|
24
|
-
}], error: [{
|
|
25
|
-
type: Input
|
|
26
|
-
}], errorMessage: [{
|
|
27
|
-
type: Input
|
|
28
20
|
}] } });
|
|
29
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
21
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3VzdG9tLWxhYmVsLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL254dC1hcHAvc3JjL2xpYi9jb21wb25lbnRzL2N1c3RvbS1sYWJlbC9jdXN0b20tbGFiZWwuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbnh0LWFwcC9zcmMvbGliL2NvbXBvbmVudHMvY3VzdG9tLWxhYmVsL2N1c3RvbS1sYWJlbC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBVSxNQUFNLGVBQWUsQ0FBQzs7QUFRekQsTUFBTSxPQUFPLG9CQUFvQjtJQUV0QixVQUFVLENBQVE7SUFDbEIsVUFBVSxDQUFTO0lBRTVCO0lBQ0EsQ0FBQztJQUVELFFBQVE7SUFDUixDQUFDO3VHQVRVLG9CQUFvQjsyRkFBcEIsb0JBQW9CLHdIQ1JqQyxzREFFQTs7MkZETWEsb0JBQW9CO2tCQUxoQyxTQUFTOytCQUNFLGtCQUFrQjswRUFNbkIsVUFBVTtzQkFBbEIsS0FBSztnQkFDRyxVQUFVO3NCQUFsQixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBJbnB1dCwgT25Jbml0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBDaGFuZ2VTZXJ2aWNlIH0gZnJvbSAnLi4vLi4vc2VydmljZXMvY2hhbmdlLnNlcnZpY2UnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdhcHAtY3VzdG9tLWxhYmVsJyxcbiAgdGVtcGxhdGVVcmw6ICcuL2N1c3RvbS1sYWJlbC5jb21wb25lbnQuaHRtbCcsXG4gIHN0eWxlVXJsczogWycuL2N1c3RvbS1sYWJlbC5jb21wb25lbnQuY3NzJ11cbn0pXG5leHBvcnQgY2xhc3MgQ3VzdG9tTGFiZWxDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xuXG4gIEBJbnB1dCgpIGxhYmVsVmFsdWU6c3RyaW5nO1xuICBASW5wdXQoKSBsYWJlbFN0eWxlOiBzdHJpbmc7XG5cbiAgY29uc3RydWN0b3IoKSB7IFxuICB9XG5cbiAgbmdPbkluaXQoKTogdm9pZCB7XG4gIH1cblxufVxuIiwiXG48ZGl2IHN0eWxlPXt7bGFiZWxTdHlsZX19Pnt7IGxhYmVsVmFsdWUgfX08L2Rpdj5cbiJdfQ==
|