@rangertechnologies/ngnxt 2.1.68 → 2.1.70
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-dropdown/custom-dropdown.component.mjs +95 -72
- package/esm2022/lib/interfaces/apimeta.mjs +1 -1
- package/fesm2022/rangertechnologies-ngnxt.mjs +94 -71
- package/fesm2022/rangertechnologies-ngnxt.mjs.map +1 -1
- package/lib/components/custom-dropdown/custom-dropdown.component.d.ts +2 -0
- package/lib/interfaces/apimeta.d.ts +1 -0
- package/package.json +1 -1
- package/rangertechnologies-ngnxt-2.1.70.tgz +0 -0
- package/rangertechnologies-ngnxt-2.1.68.tgz +0 -0
|
@@ -39,94 +39,117 @@ export class CustomDropdownComponent {
|
|
|
39
39
|
valueField;
|
|
40
40
|
subscription;
|
|
41
41
|
apiObj;
|
|
42
|
+
uniqueKey;
|
|
42
43
|
ngOnInit() {
|
|
44
|
+
}
|
|
45
|
+
getOptions() {
|
|
46
|
+
console.log('test click');
|
|
43
47
|
// console.log('inside oninit of custom-dropdown of ' + this.id);
|
|
44
48
|
// console.log(this.apiMeta);
|
|
45
49
|
//VD 07Aug24 - isDependentField change
|
|
50
|
+
// VD 25Oct24 - changes
|
|
46
51
|
this.placeholder = this.placeholder ? this.placeholder : '---Select option---';
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
if (this.apiObj.
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
//
|
|
62
|
-
let
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
// VD 19JAN24 - added one more param for authentication
|
|
76
|
-
this.dataService.apiResponse(fullEndPoint)?.subscribe((apiResponse) => {
|
|
77
|
-
// HA 18-JAN-24 Assigned apiresponse directly if we have the response in array also
|
|
78
|
-
// VD 19JAN24 - if response has key with value(which is array)
|
|
79
|
-
let responses;
|
|
80
|
-
if (this.apiObj.variable) {
|
|
81
|
-
// VD 21May24 - handling multiple child objects
|
|
82
|
-
// VD 22May24 - used common service file
|
|
83
|
-
responses = this.dataService.getValue(apiResponse, this.apiObj.variable);
|
|
84
|
-
let results = [];
|
|
85
|
-
// HA 19JAN24 To avoid undefined error in console
|
|
86
|
-
for (let i = 0; i < responses?.length; i++) {
|
|
87
|
-
var resp = responses[i];
|
|
88
|
-
results.push(resp);
|
|
89
|
-
}
|
|
90
|
-
this.options = results;
|
|
52
|
+
const cachedOptions = localStorage.getItem(this.uniqueKey);
|
|
53
|
+
if (cachedOptions) {
|
|
54
|
+
this.options = JSON.parse(cachedOptions);
|
|
55
|
+
}
|
|
56
|
+
else {
|
|
57
|
+
if (this.apiMeta !== undefined) {
|
|
58
|
+
this.apiObj = JSON.parse(this.apiMeta);
|
|
59
|
+
if (!this.apiObj.isDependentField) {
|
|
60
|
+
this.options = [];
|
|
61
|
+
this.labelField = this.apiObj.field;
|
|
62
|
+
// VD 09Sep24- setup the query param for api call
|
|
63
|
+
let fullEndPoint;
|
|
64
|
+
if (this.apiObj.endpoint) {
|
|
65
|
+
if (this.apiObj.queryValueReference && this.apiObj.queryField) {
|
|
66
|
+
// process the end point with query param
|
|
67
|
+
let queryReferences = this.apiObj.queryValueReference.split(',');
|
|
68
|
+
let queryParams = [];
|
|
69
|
+
// Iterate over queryReferences and find the corresponding element in referenceData
|
|
70
|
+
queryReferences.forEach(reference => {
|
|
71
|
+
// Find the element in referenceData that matches the current reference
|
|
72
|
+
let matchingElement = this.question?.referenceQueryData.find(element => element.Reference_Field__c === reference);
|
|
73
|
+
// If a matching element is found, get its input value and create a query parameter
|
|
74
|
+
if (matchingElement) {
|
|
75
|
+
queryParams.push(`${reference}=${matchingElement.input}`);
|
|
76
|
+
}
|
|
77
|
+
});
|
|
78
|
+
fullEndPoint = this.apiObj.endpoint + '?' + queryParams.join('&');
|
|
79
|
+
console.log(fullEndPoint);
|
|
91
80
|
}
|
|
92
|
-
else {
|
|
93
|
-
|
|
94
|
-
|
|
81
|
+
else {
|
|
82
|
+
// if no query param get the actual endPoint
|
|
83
|
+
fullEndPoint = this.apiObj.endpoint;
|
|
95
84
|
}
|
|
96
|
-
//
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
let sourceId = this.apiObj.sourceQuestionId;
|
|
103
|
-
if (sourceId && this.apiObj.variable || this.apiObj.valueField) {
|
|
104
|
-
// Subscribe for the changes
|
|
105
|
-
this.subscription = this.changeService.changeAnnounced$.subscribe((changeValue) => {
|
|
106
|
-
if (changeValue != undefined) {
|
|
107
|
-
// console.log('inside subscription for the change');
|
|
108
|
-
if (changeValue.valueObj != undefined && changeValue.fromQuestionId == this.apiObj.sourceQuestionId) {
|
|
109
|
-
// this.selectedValue = changeValue.valueObj[this.apiObj.valueField];
|
|
110
|
-
// let value ={};
|
|
111
|
-
// value['name'] = this.selectedValue;
|
|
85
|
+
// VD 19JAN24 - added one more param for authentication
|
|
86
|
+
this.dataService.apiResponse(fullEndPoint)?.subscribe((apiResponse) => {
|
|
87
|
+
// HA 18-JAN-24 Assigned apiresponse directly if we have the response in array also
|
|
88
|
+
// VD 19JAN24 - if response has key with value(which is array)
|
|
89
|
+
// VD 25Oct24 changes
|
|
90
|
+
this.uniqueKey = this.dataService.getValue(apiResponse, this.apiObj.uniqueKey);
|
|
112
91
|
let responses;
|
|
113
92
|
if (this.apiObj.variable) {
|
|
114
|
-
|
|
93
|
+
// VD 21May24 - handling multiple child objects
|
|
94
|
+
// VD 22May24 - used common service file
|
|
95
|
+
responses = this.dataService.getValue(apiResponse, this.apiObj.variable);
|
|
115
96
|
let results = [];
|
|
97
|
+
// HA 19JAN24 To avoid undefined error in console
|
|
116
98
|
for (let i = 0; i < responses?.length; i++) {
|
|
117
99
|
var resp = responses[i];
|
|
118
100
|
results.push(resp);
|
|
119
101
|
}
|
|
120
102
|
this.options = results;
|
|
121
103
|
}
|
|
122
|
-
else {
|
|
123
|
-
responses =
|
|
104
|
+
else { // VD 19JAN24 - if response has value(which is array) only
|
|
105
|
+
responses = apiResponse;
|
|
124
106
|
this.options = responses;
|
|
125
107
|
}
|
|
126
|
-
|
|
127
|
-
|
|
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
|
+
});
|
|
128
114
|
}
|
|
129
|
-
}
|
|
115
|
+
}
|
|
116
|
+
// VD NOV23 - handle the dependent update for dropdown
|
|
117
|
+
// // VD 09Sep24- push the dependent field values for dropdown
|
|
118
|
+
let sourceId = this.apiObj.sourceQuestionId;
|
|
119
|
+
if (sourceId && this.apiObj.variable || this.apiObj.valueField) {
|
|
120
|
+
// Subscribe for the changes
|
|
121
|
+
this.subscription = this.changeService.changeAnnounced$.subscribe((changeValue) => {
|
|
122
|
+
if (changeValue != undefined) {
|
|
123
|
+
// console.log('inside subscription for the change');
|
|
124
|
+
if (changeValue.valueObj != undefined && changeValue.fromQuestionId == this.apiObj.sourceQuestionId) {
|
|
125
|
+
// this.selectedValue = changeValue.valueObj[this.apiObj.valueField];
|
|
126
|
+
// let value ={};
|
|
127
|
+
// value['name'] = this.selectedValue;
|
|
128
|
+
// VD 25Oct24 changes
|
|
129
|
+
this.uniqueKey = this.dataService.getValue(changeValue.valueObj, this.apiObj.uniqueKey);
|
|
130
|
+
let responses;
|
|
131
|
+
if (this.apiObj.variable) {
|
|
132
|
+
responses = this.dataService.getValue(changeValue.valueObj, this.apiObj.variable);
|
|
133
|
+
let results = [];
|
|
134
|
+
for (let i = 0; i < responses?.length; i++) {
|
|
135
|
+
var resp = responses[i];
|
|
136
|
+
results.push(resp);
|
|
137
|
+
}
|
|
138
|
+
this.options = results;
|
|
139
|
+
}
|
|
140
|
+
else {
|
|
141
|
+
responses = changeValue.valueObj;
|
|
142
|
+
this.options = responses;
|
|
143
|
+
}
|
|
144
|
+
// VD 25Oct24 - Store fetched options in local storage
|
|
145
|
+
if (this.uniqueKey) {
|
|
146
|
+
localStorage.setItem(this.uniqueKey, JSON.stringify(this.options));
|
|
147
|
+
}
|
|
148
|
+
}
|
|
149
|
+
this.changeService.confirmChange(this.apiObj.sourceQuestionId);
|
|
150
|
+
}
|
|
151
|
+
});
|
|
152
|
+
}
|
|
130
153
|
}
|
|
131
154
|
}
|
|
132
155
|
}
|
|
@@ -146,11 +169,11 @@ export class CustomDropdownComponent {
|
|
|
146
169
|
}
|
|
147
170
|
}
|
|
148
171
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: CustomDropdownComponent, deps: [{ token: i1.ChangeService }, { token: i2.DataService }, { token: i3.I18nService }], target: i0.ɵɵFactoryTarget.Component });
|
|
149
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", 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__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<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 (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", 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", "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"] }] });
|
|
172
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", 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__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", 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", "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"] }] });
|
|
150
173
|
}
|
|
151
174
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: CustomDropdownComponent, decorators: [{
|
|
152
175
|
type: Component,
|
|
153
|
-
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__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<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 (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", styles: [".ng-select{width:100%}.invalid{border:1px solid red!important}\n"] }]
|
|
176
|
+
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__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", styles: [".ng-select{width:100%}.invalid{border:1px solid red!important}\n"] }]
|
|
154
177
|
}], ctorParameters: function () { return [{ type: i1.ChangeService }, { type: i2.DataService }, { type: i3.I18nService }]; }, propDecorators: { options: [{
|
|
155
178
|
type: Input
|
|
156
179
|
}], placeholder: [{
|
|
@@ -180,4 +203,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImpo
|
|
|
180
203
|
}], valueChange: [{
|
|
181
204
|
type: Output
|
|
182
205
|
}] } });
|
|
183
|
-
//# 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\n  ngOnInit(): void {\n    // console.log('inside oninit of custom-dropdown of ' + this.id);\n    // console.log(this.apiMeta);\n    //VD 07Aug24 - isDependentField change\n    this.placeholder = this.placeholder ? this.placeholder : '---Select option---';\n    if(this.apiMeta !== undefined) {\n      this.apiObj = JSON.parse(this.apiMeta);\n      if(!this.apiObj.isDependentField){\n      this.options = [];\n      this.labelField = this.apiObj.field;\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          // 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                }\n              this.changeService.confirmChange(this.apiObj.sourceQuestionId);\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<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            (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"]}
|
|
206
|
+
//# 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    const cachedOptions = localStorage.getItem(this.uniqueKey);\n    if (cachedOptions) {\n      this.options = JSON.parse(cachedOptions);\n    }else {\n      if(this.apiMeta !== undefined) {\n        this.apiObj = JSON.parse(this.apiMeta);\n        if(!this.apiObj.isDependentField){\n        this.options = [];\n        this.labelField = this.apiObj.field;\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            // VD 25Oct24 changes\n            this.uniqueKey = this.dataService.getValue(apiResponse,this.apiObj.uniqueKey);\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                  // VD 25Oct24 changes\n                  this.uniqueKey = this.dataService.getValue(changeValue.valueObj,this.apiObj.uniqueKey);\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"]}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
export {};
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXBpbWV0YS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL254dC1hcHAvc3JjL2xpYi9pbnRlcmZhY2VzL2FwaW1ldGEudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBpbnRlcmZhY2UgQVBJTWV0YSB7XG4gICAgLy8gVkQgTk92MjMgLSBhZGRlZCB2YXJpYWJsZXMgZm9yIGRlcGVuZGVudCB1cGRhdGVcbiAgICBzb3VyY2VRdWVzdGlvbklkOnN0cmluZztcbiAgICB2YWx1ZUZpZWxkOnN0cmluZztcbiAgICBsYWJlbEZpZWxkOnN0cmluZztcbiAgICBlbmRwb2ludDogc3RyaW5nO1xuICAgIHZhcmlhYmxlOiBzdHJpbmc7XG4gICAgZmllbGQ6IHN0cmluZztcbiAgICAvL1ZEIDA3QXVnMjQgLSBpc0RlcGVuZGVudEZpZWxkIGNoYW5nZVxuICAgIGlzRGVwZW5kZW50RmllbGQ6Ym9vbGVhbjtcbiAgICBkZXBlbmRlbnRWYWx1ZTpzdHJpbmc7XG4gICAgLy8gVkQgMDlTZXAyNCAtIHF1ZXJ5UGFyYW0gY2hhbmdlcyBmb3IgYXBpIGRhdGEgXG4gICAgcXVlcnlGaWVsZDpzdHJpbmc7XG4gICAgcXVlcnlWYWx1ZVJlZmVyZW5jZTpzdHJpbmc7XG4gICAgLy9WRCAyNW9jdC0yNCAtIGNoYW5nZXMobmVlZCB0byBkb2N1bWVudClcbiAgICB1bmlxdWVLZXk6IHN0cmluZztcblxufVxuIl19
|
|
@@ -1821,94 +1821,117 @@ class CustomDropdownComponent {
|
|
|
1821
1821
|
valueField;
|
|
1822
1822
|
subscription;
|
|
1823
1823
|
apiObj;
|
|
1824
|
+
uniqueKey;
|
|
1824
1825
|
ngOnInit() {
|
|
1826
|
+
}
|
|
1827
|
+
getOptions() {
|
|
1828
|
+
console.log('test click');
|
|
1825
1829
|
// console.log('inside oninit of custom-dropdown of ' + this.id);
|
|
1826
1830
|
// console.log(this.apiMeta);
|
|
1827
1831
|
//VD 07Aug24 - isDependentField change
|
|
1832
|
+
// VD 25Oct24 - changes
|
|
1828
1833
|
this.placeholder = this.placeholder ? this.placeholder : '---Select option---';
|
|
1829
|
-
|
|
1830
|
-
|
|
1831
|
-
|
|
1832
|
-
|
|
1833
|
-
|
|
1834
|
-
|
|
1835
|
-
|
|
1836
|
-
if (this.apiObj.
|
|
1837
|
-
|
|
1838
|
-
|
|
1839
|
-
|
|
1840
|
-
|
|
1841
|
-
|
|
1842
|
-
|
|
1843
|
-
//
|
|
1844
|
-
let
|
|
1845
|
-
|
|
1846
|
-
|
|
1847
|
-
|
|
1848
|
-
|
|
1849
|
-
|
|
1850
|
-
|
|
1851
|
-
|
|
1852
|
-
|
|
1853
|
-
|
|
1854
|
-
|
|
1855
|
-
|
|
1856
|
-
|
|
1857
|
-
// VD 19JAN24 - added one more param for authentication
|
|
1858
|
-
this.dataService.apiResponse(fullEndPoint)?.subscribe((apiResponse) => {
|
|
1859
|
-
// HA 18-JAN-24 Assigned apiresponse directly if we have the response in array also
|
|
1860
|
-
// VD 19JAN24 - if response has key with value(which is array)
|
|
1861
|
-
let responses;
|
|
1862
|
-
if (this.apiObj.variable) {
|
|
1863
|
-
// VD 21May24 - handling multiple child objects
|
|
1864
|
-
// VD 22May24 - used common service file
|
|
1865
|
-
responses = this.dataService.getValue(apiResponse, this.apiObj.variable);
|
|
1866
|
-
let results = [];
|
|
1867
|
-
// HA 19JAN24 To avoid undefined error in console
|
|
1868
|
-
for (let i = 0; i < responses?.length; i++) {
|
|
1869
|
-
var resp = responses[i];
|
|
1870
|
-
results.push(resp);
|
|
1871
|
-
}
|
|
1872
|
-
this.options = results;
|
|
1834
|
+
const cachedOptions = localStorage.getItem(this.uniqueKey);
|
|
1835
|
+
if (cachedOptions) {
|
|
1836
|
+
this.options = JSON.parse(cachedOptions);
|
|
1837
|
+
}
|
|
1838
|
+
else {
|
|
1839
|
+
if (this.apiMeta !== undefined) {
|
|
1840
|
+
this.apiObj = JSON.parse(this.apiMeta);
|
|
1841
|
+
if (!this.apiObj.isDependentField) {
|
|
1842
|
+
this.options = [];
|
|
1843
|
+
this.labelField = this.apiObj.field;
|
|
1844
|
+
// VD 09Sep24- setup the query param for api call
|
|
1845
|
+
let fullEndPoint;
|
|
1846
|
+
if (this.apiObj.endpoint) {
|
|
1847
|
+
if (this.apiObj.queryValueReference && this.apiObj.queryField) {
|
|
1848
|
+
// process the end point with query param
|
|
1849
|
+
let queryReferences = this.apiObj.queryValueReference.split(',');
|
|
1850
|
+
let queryParams = [];
|
|
1851
|
+
// Iterate over queryReferences and find the corresponding element in referenceData
|
|
1852
|
+
queryReferences.forEach(reference => {
|
|
1853
|
+
// Find the element in referenceData that matches the current reference
|
|
1854
|
+
let matchingElement = this.question?.referenceQueryData.find(element => element.Reference_Field__c === reference);
|
|
1855
|
+
// If a matching element is found, get its input value and create a query parameter
|
|
1856
|
+
if (matchingElement) {
|
|
1857
|
+
queryParams.push(`${reference}=${matchingElement.input}`);
|
|
1858
|
+
}
|
|
1859
|
+
});
|
|
1860
|
+
fullEndPoint = this.apiObj.endpoint + '?' + queryParams.join('&');
|
|
1861
|
+
console.log(fullEndPoint);
|
|
1873
1862
|
}
|
|
1874
|
-
else {
|
|
1875
|
-
|
|
1876
|
-
|
|
1863
|
+
else {
|
|
1864
|
+
// if no query param get the actual endPoint
|
|
1865
|
+
fullEndPoint = this.apiObj.endpoint;
|
|
1877
1866
|
}
|
|
1878
|
-
//
|
|
1879
|
-
|
|
1880
|
-
|
|
1881
|
-
|
|
1882
|
-
|
|
1883
|
-
|
|
1884
|
-
let sourceId = this.apiObj.sourceQuestionId;
|
|
1885
|
-
if (sourceId && this.apiObj.variable || this.apiObj.valueField) {
|
|
1886
|
-
// Subscribe for the changes
|
|
1887
|
-
this.subscription = this.changeService.changeAnnounced$.subscribe((changeValue) => {
|
|
1888
|
-
if (changeValue != undefined) {
|
|
1889
|
-
// console.log('inside subscription for the change');
|
|
1890
|
-
if (changeValue.valueObj != undefined && changeValue.fromQuestionId == this.apiObj.sourceQuestionId) {
|
|
1891
|
-
// this.selectedValue = changeValue.valueObj[this.apiObj.valueField];
|
|
1892
|
-
// let value ={};
|
|
1893
|
-
// value['name'] = this.selectedValue;
|
|
1867
|
+
// VD 19JAN24 - added one more param for authentication
|
|
1868
|
+
this.dataService.apiResponse(fullEndPoint)?.subscribe((apiResponse) => {
|
|
1869
|
+
// HA 18-JAN-24 Assigned apiresponse directly if we have the response in array also
|
|
1870
|
+
// VD 19JAN24 - if response has key with value(which is array)
|
|
1871
|
+
// VD 25Oct24 changes
|
|
1872
|
+
this.uniqueKey = this.dataService.getValue(apiResponse, this.apiObj.uniqueKey);
|
|
1894
1873
|
let responses;
|
|
1895
1874
|
if (this.apiObj.variable) {
|
|
1896
|
-
|
|
1875
|
+
// VD 21May24 - handling multiple child objects
|
|
1876
|
+
// VD 22May24 - used common service file
|
|
1877
|
+
responses = this.dataService.getValue(apiResponse, this.apiObj.variable);
|
|
1897
1878
|
let results = [];
|
|
1879
|
+
// HA 19JAN24 To avoid undefined error in console
|
|
1898
1880
|
for (let i = 0; i < responses?.length; i++) {
|
|
1899
1881
|
var resp = responses[i];
|
|
1900
1882
|
results.push(resp);
|
|
1901
1883
|
}
|
|
1902
1884
|
this.options = results;
|
|
1903
1885
|
}
|
|
1904
|
-
else {
|
|
1905
|
-
responses =
|
|
1886
|
+
else { // VD 19JAN24 - if response has value(which is array) only
|
|
1887
|
+
responses = apiResponse;
|
|
1906
1888
|
this.options = responses;
|
|
1907
1889
|
}
|
|
1908
|
-
|
|
1909
|
-
|
|
1890
|
+
// VD 25Oct24 - Store fetched options in local storage
|
|
1891
|
+
if (this.uniqueKey) {
|
|
1892
|
+
localStorage.setItem(this.uniqueKey, JSON.stringify(this.options));
|
|
1893
|
+
}
|
|
1894
|
+
// Reference https://www.npmjs.com/package/@ng-select/ng-select
|
|
1895
|
+
});
|
|
1910
1896
|
}
|
|
1911
|
-
}
|
|
1897
|
+
}
|
|
1898
|
+
// VD NOV23 - handle the dependent update for dropdown
|
|
1899
|
+
// // VD 09Sep24- push the dependent field values for dropdown
|
|
1900
|
+
let sourceId = this.apiObj.sourceQuestionId;
|
|
1901
|
+
if (sourceId && this.apiObj.variable || this.apiObj.valueField) {
|
|
1902
|
+
// Subscribe for the changes
|
|
1903
|
+
this.subscription = this.changeService.changeAnnounced$.subscribe((changeValue) => {
|
|
1904
|
+
if (changeValue != undefined) {
|
|
1905
|
+
// console.log('inside subscription for the change');
|
|
1906
|
+
if (changeValue.valueObj != undefined && changeValue.fromQuestionId == this.apiObj.sourceQuestionId) {
|
|
1907
|
+
// this.selectedValue = changeValue.valueObj[this.apiObj.valueField];
|
|
1908
|
+
// let value ={};
|
|
1909
|
+
// value['name'] = this.selectedValue;
|
|
1910
|
+
// VD 25Oct24 changes
|
|
1911
|
+
this.uniqueKey = this.dataService.getValue(changeValue.valueObj, this.apiObj.uniqueKey);
|
|
1912
|
+
let responses;
|
|
1913
|
+
if (this.apiObj.variable) {
|
|
1914
|
+
responses = this.dataService.getValue(changeValue.valueObj, this.apiObj.variable);
|
|
1915
|
+
let results = [];
|
|
1916
|
+
for (let i = 0; i < responses?.length; i++) {
|
|
1917
|
+
var resp = responses[i];
|
|
1918
|
+
results.push(resp);
|
|
1919
|
+
}
|
|
1920
|
+
this.options = results;
|
|
1921
|
+
}
|
|
1922
|
+
else {
|
|
1923
|
+
responses = changeValue.valueObj;
|
|
1924
|
+
this.options = responses;
|
|
1925
|
+
}
|
|
1926
|
+
// VD 25Oct24 - Store fetched options in local storage
|
|
1927
|
+
if (this.uniqueKey) {
|
|
1928
|
+
localStorage.setItem(this.uniqueKey, JSON.stringify(this.options));
|
|
1929
|
+
}
|
|
1930
|
+
}
|
|
1931
|
+
this.changeService.confirmChange(this.apiObj.sourceQuestionId);
|
|
1932
|
+
}
|
|
1933
|
+
});
|
|
1934
|
+
}
|
|
1912
1935
|
}
|
|
1913
1936
|
}
|
|
1914
1937
|
}
|
|
@@ -1928,11 +1951,11 @@ class CustomDropdownComponent {
|
|
|
1928
1951
|
}
|
|
1929
1952
|
}
|
|
1930
1953
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: CustomDropdownComponent, deps: [{ token: ChangeService }, { token: DataService }, { token: I18nService }], target: i0.ɵɵFactoryTarget.Component });
|
|
1931
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", 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__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<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 (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", styles: [".ng-select{width:100%}.invalid{border:1px solid red!important}\n"], dependencies: [{ kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.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", "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"] }] });
|
|
1954
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", 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__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", styles: [".ng-select{width:100%}.invalid{border:1px solid red!important}\n"], dependencies: [{ kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.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", "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"] }] });
|
|
1932
1955
|
}
|
|
1933
1956
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: CustomDropdownComponent, decorators: [{
|
|
1934
1957
|
type: Component,
|
|
1935
|
-
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__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<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 (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", styles: [".ng-select{width:100%}.invalid{border:1px solid red!important}\n"] }]
|
|
1958
|
+
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__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", styles: [".ng-select{width:100%}.invalid{border:1px solid red!important}\n"] }]
|
|
1936
1959
|
}], ctorParameters: function () { return [{ type: ChangeService }, { type: DataService }, { type: I18nService }]; }, propDecorators: { options: [{
|
|
1937
1960
|
type: Input
|
|
1938
1961
|
}], placeholder: [{
|