@rangertechnologies/ngnxt 2.1.68 → 2.1.69
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 +88 -72
- package/esm2022/lib/interfaces/apimeta.mjs +1 -1
- package/fesm2022/rangertechnologies-ngnxt.mjs +87 -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.69.tgz +0 -0
- package/rangertechnologies-ngnxt-2.1.68.tgz +0 -0
|
@@ -39,94 +39,110 @@ 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
|
-
// // VD 09Sep24- push the dependent field values for dropdown
|
|
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
|
+
this.uniqueKey = apiResponse[this.apiObj.uniqueKey];
|
|
112
90
|
let responses;
|
|
113
91
|
if (this.apiObj.variable) {
|
|
114
|
-
|
|
92
|
+
// VD 21May24 - handling multiple child objects
|
|
93
|
+
// VD 22May24 - used common service file
|
|
94
|
+
responses = this.dataService.getValue(apiResponse, this.apiObj.variable);
|
|
115
95
|
let results = [];
|
|
96
|
+
// HA 19JAN24 To avoid undefined error in console
|
|
116
97
|
for (let i = 0; i < responses?.length; i++) {
|
|
117
98
|
var resp = responses[i];
|
|
118
99
|
results.push(resp);
|
|
119
100
|
}
|
|
120
101
|
this.options = results;
|
|
121
102
|
}
|
|
122
|
-
else {
|
|
123
|
-
responses =
|
|
103
|
+
else { // VD 19JAN24 - if response has value(which is array) only
|
|
104
|
+
responses = apiResponse;
|
|
124
105
|
this.options = responses;
|
|
125
106
|
}
|
|
126
|
-
|
|
127
|
-
|
|
107
|
+
// VD 25Oct24 - Store fetched options in local storage
|
|
108
|
+
if (this.uniqueKey) {
|
|
109
|
+
localStorage.setItem(this.uniqueKey, JSON.stringify(this.options));
|
|
110
|
+
}
|
|
111
|
+
// Reference https://www.npmjs.com/package/@ng-select/ng-select
|
|
112
|
+
});
|
|
128
113
|
}
|
|
129
|
-
}
|
|
114
|
+
}
|
|
115
|
+
// VD NOV23 - handle the dependent update for dropdown
|
|
116
|
+
// // VD 09Sep24- push the dependent field values for dropdown
|
|
117
|
+
let sourceId = this.apiObj.sourceQuestionId;
|
|
118
|
+
if (sourceId && this.apiObj.variable || this.apiObj.valueField) {
|
|
119
|
+
// Subscribe for the changes
|
|
120
|
+
this.subscription = this.changeService.changeAnnounced$.subscribe((changeValue) => {
|
|
121
|
+
if (changeValue != undefined) {
|
|
122
|
+
// console.log('inside subscription for the change');
|
|
123
|
+
if (changeValue.valueObj != undefined && changeValue.fromQuestionId == this.apiObj.sourceQuestionId) {
|
|
124
|
+
// this.selectedValue = changeValue.valueObj[this.apiObj.valueField];
|
|
125
|
+
// let value ={};
|
|
126
|
+
// value['name'] = this.selectedValue;
|
|
127
|
+
let responses;
|
|
128
|
+
if (this.apiObj.variable) {
|
|
129
|
+
responses = this.dataService.getValue(changeValue.valueObj, this.apiObj.variable);
|
|
130
|
+
let results = [];
|
|
131
|
+
for (let i = 0; i < responses?.length; i++) {
|
|
132
|
+
var resp = responses[i];
|
|
133
|
+
results.push(resp);
|
|
134
|
+
}
|
|
135
|
+
this.options = results;
|
|
136
|
+
}
|
|
137
|
+
else {
|
|
138
|
+
responses = changeValue.valueObj;
|
|
139
|
+
this.options = responses;
|
|
140
|
+
}
|
|
141
|
+
}
|
|
142
|
+
this.changeService.confirmChange(this.apiObj.sourceQuestionId);
|
|
143
|
+
}
|
|
144
|
+
});
|
|
145
|
+
}
|
|
130
146
|
}
|
|
131
147
|
}
|
|
132
148
|
}
|
|
@@ -146,11 +162,11 @@ export class CustomDropdownComponent {
|
|
|
146
162
|
}
|
|
147
163
|
}
|
|
148
164
|
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"] }] });
|
|
165
|
+
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
166
|
}
|
|
151
167
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: CustomDropdownComponent, decorators: [{
|
|
152
168
|
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"] }]
|
|
169
|
+
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
170
|
}], ctorParameters: function () { return [{ type: i1.ChangeService }, { type: i2.DataService }, { type: i3.I18nService }]; }, propDecorators: { options: [{
|
|
155
171
|
type: Input
|
|
156
172
|
}], placeholder: [{
|
|
@@ -180,4 +196,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImpo
|
|
|
180
196
|
}], valueChange: [{
|
|
181
197
|
type: Output
|
|
182
198
|
}] } });
|
|
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":"AAAA,OAAO,EAAE,SAAS,EAAS,KAAK,EAAC,MAAM,EAAC,YAAY,EAAY,MAAM,eAAe,CAAC;AAGtF,OAAO,EAAE,aAAa,EAAE,MAAM,2BAA2B,CAAC;;;;;;;;AAY1D,MAAM,OAAO,uBAAuB;IAiBxB;IACA;IACD;IAlBA,OAAO,CAAW;IAClB,WAAW,CAAS;IACpB,OAAO,CAAS;IAChB,aAAa,CAAS;IACtB,WAAW,CAAU;IACrB,EAAE,CAAQ;IACV,QAAQ,GAAG,KAAK,CAAC,CAAC,+BAA+B;IACjD,YAAY,CAAS;IACrB,KAAK,CAAK;IACV,WAAW,GAAY,KAAK,CAAC;IAC7B,QAAQ,CAAK;IACb,cAAc,CAAQ;IACtB,KAAK,CAAQ,CAAI,sCAAsC;IACtD,WAAW,GAAgC,IAAI,YAAY,EAAiB,CAAC;IACvF,eAAe,GAAY,EAAE,CAAC;IAC9B,YACU,aAA4B,EAC5B,WAAwB,EACzB,WAAwB;QAFvB,kBAAa,GAAb,aAAa,CAAe;QAC5B,gBAAW,GAAX,WAAW,CAAa;QACzB,gBAAW,GAAX,WAAW,CAAa;QAE/B,IAAI,CAAC,aAAa,CAAC,eAAe,CAAC,SAAS,CAAC,CAAC,IAAI,EAAC,EAAE;YACnD,wCAAwC;YACxC,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAClC,CAAC,CAAC,CAAA;IACJ,CAAC;IAEM,UAAU,CAAS;IACnB,UAAU,CAAS;IAC1B,YAAY,CAAe;IACpB,MAAM,CAAS;IAEtB,QAAQ;QACN,iEAAiE;QACjE,6BAA6B;QAC7B,sCAAsC;QACtC,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,qBAAqB,CAAC;QAC/E,IAAG,IAAI,CAAC,OAAO,KAAK,SAAS,EAAE;YAC7B,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;YACvC,IAAG,CAAC,IAAI,CAAC,MAAM,CAAC,gBAAgB,EAAC;gBACjC,IAAI,CAAC,OAAO,GAAG,EAAE,CAAC;gBAClB,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC;gBACpC,iDAAiD;gBACjD,IAAI,YAAY,CAAE;gBAClB,IAAG,IAAI,CAAC,MAAM,CAAC,QAAQ,EAAC;oBACtB,IAAG,IAAI,CAAC,MAAM,CAAC,mBAAmB,IAAI,IAAI,CAAC,MAAM,CAAC,UAAU,EAAC;wBAC3D,yCAAyC;wBACzC,IAAI,eAAe,GAAG,IAAI,CAAC,MAAM,CAAC,mBAAmB,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;wBACjE,IAAI,WAAW,GAAG,EAAE,CAAC;wBACrB,mFAAmF;wBACnF,eAAe,CAAC,OAAO,CAAC,SAAS,CAAC,EAAE;4BAChC,uEAAuE;4BACvE,IAAI,eAAe,GAAG,IAAI,CAAC,QAAQ,EAAE,kBAAkB,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE,CAAC,OAAO,CAAC,kBAAkB,KAAK,SAAS,CAAC,CAAC;4BAClH,mFAAmF;4BACnF,IAAI,eAAe,EAAE;gCACjB,WAAW,CAAC,IAAI,CAAC,GAAG,SAAS,IAAI,eAAe,CAAC,KAAK,EAAE,CAAC,CAAC;6BAC7D;wBACL,CAAC,CAAC,CAAC;wBACA,YAAY,GAAG,IAAI,CAAC,MAAM,CAAC,QAAQ,GAAG,GAAG,GAAG,WAAW,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;wBAClE,OAAO,CAAC,GAAG,CAAC,YAAY,CAAC,CAAC;qBAC9B;yBAAK;wBACH,4CAA4C;wBAC1C,YAAY,GAAG,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC;qBACxC;oBACD,uDAAuD;oBACvD,IAAI,CAAC,WAAW,CAAC,WAAW,CAAC,YAAY,CAAC,EAAE,SAAS,CAAC,CAAC,WAAW,EAAE,EAAE;wBACpE,mFAAmF;wBACnF,8DAA8D;wBAC9D,IAAI,SAAS,CAAC;wBACd,IAAG,IAAI,CAAC,MAAM,CAAC,QAAQ,EAAC;4BACtB,+CAA+C;4BAC/C,wCAAwC;4BACxC,SAAS,GAAG,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,WAAW,EAAC,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC;4BACxE,IAAI,OAAO,GAAG,EAAE,CAAC;4BACjB,iDAAiD;4BACjD,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,SAAS,EAAE,MAAM,EAAE,CAAC,EAAE,EAAE;gCAC1C,IAAI,IAAI,GAAG,SAAS,CAAC,CAAC,CAAC,CAAC;gCACxB,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;6BACpB;4BACD,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC;yBACxB;6BAAI,EAAG,0DAA0D;4BAChE,SAAS,GAAG,WAAW,CAAC;4BACxB,IAAI,CAAC,OAAO,GAAG,SAAS,CAAC;yBAC1B;wBACD,+DAA+D;oBACjE,CAAC,CAAC,CAAA;iBACH;aACF;YACC,sDAAsD;YACtD,8DAA8D;YAC9D,IAAI,QAAQ,GAAG,IAAI,CAAC,MAAM,CAAC,gBAAgB,CAAC;YAC5C,IAAG,QAAQ,IAAI,IAAI,CAAC,MAAM,CAAC,QAAQ,IAAI,IAAI,CAAC,MAAM,CAAC,UAAU,EAAC;gBAC5D,4BAA4B;gBAC5B,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,aAAa,CAAC,gBAAgB,CAAC,SAAS,CAC/D,CAAC,WAAW,EAAE,EAAE;oBACd,IAAG,WAAW,IAAI,SAAS,EAAE;wBAC3B,qDAAqD;wBACrD,IAAG,WAAW,CAAC,QAAQ,IAAI,SAAS,IAAI,WAAW,CAAC,cAAc,IAAI,IAAI,CAAC,MAAM,CAAC,gBAAgB,EAAE;4BAClG,sEAAsE;4BACtE,kBAAkB;4BAClB,uCAAuC;4BACtC,IAAI,SAAS,CAAC;4BACd,IAAG,IAAI,CAAC,MAAM,CAAC,QAAQ,EAAC;gCACtB,SAAS,GAAG,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,WAAW,CAAC,QAAQ,EAAC,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC;gCACjF,IAAI,OAAO,GAAG,EAAE,CAAC;gCACjB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,SAAS,EAAE,MAAM,EAAE,CAAC,EAAE,EAAE;oCAC1C,IAAI,IAAI,GAAG,SAAS,CAAC,CAAC,CAAC,CAAC;oCACxB,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;iCACpB;gCACD,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC;6BACxB;iCAAI;gCACH,SAAS,GAAG,WAAW,CAAC,QAAQ,CAAC;gCACjC,IAAI,CAAC,OAAO,GAAG,SAAS,CAAC;6BAC1B;yBACD;wBACH,IAAI,CAAC,aAAa,CAAC,aAAa,CAAC,IAAI,CAAC,MAAM,CAAC,gBAAgB,CAAC,CAAC;qBAChE;gBACH,CAAC,CACF,CAAC;aACH;SACF;IACH,CAAC;IACH,wCAAwC;IAEtC,YAAY,CAAC,KAAS;QACpB,OAAO,CAAC,GAAG,CAAC,2BAA2B,GAAG,IAAI,CAAC,EAAE,CAAC,CAAC;QACnD,sBAAsB;QACtB,IAAI,MAAM,GAAG,IAAI,aAAa,EAAE,CAAC,CAAC,oCAAoC;QACtE,MAAM,CAAC,cAAc,GAAG,IAAI,CAAC,EAAE,CAAC;QAChC,MAAM,CAAC,QAAQ,GAAG,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC;QACrC,MAAM,CAAC,cAAc,GAAG,IAAI,CAAC,cAAc,CAAC;QAC5C,MAAM,CAAC,WAAW,GAAG,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;QACzD,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QAC9B,yDAAyD;QACzD,IAAG,KAAK,EAAC;YACP,IAAI,CAAC,eAAe,GAAE,EAAE,CAAC;SAC1B;IACH,CAAC;wGAzIU,uBAAuB;4FAAvB,uBAAuB,kaCfpC,mkDA2BA;;4FDZa,uBAAuB;kBALnC,SAAS;+BACE,qBAAqB;wJAKtB,OAAO;sBAAf,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACG,aAAa;sBAArB,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACG,EAAE;sBAAV,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,YAAY;sBAApB,KAAK;gBACG,KAAK;sBAAb,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,cAAc;sBAAtB,KAAK;gBACG,KAAK;sBAAb,KAAK;gBACI,WAAW;sBAApB,MAAM","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"]}
|
|
199
|
+
//# 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            this.uniqueKey = 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                   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  }\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,110 @@ 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
|
-
// // VD 09Sep24- push the dependent field values for dropdown
|
|
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
|
+
this.uniqueKey = apiResponse[this.apiObj.uniqueKey];
|
|
1894
1872
|
let responses;
|
|
1895
1873
|
if (this.apiObj.variable) {
|
|
1896
|
-
|
|
1874
|
+
// VD 21May24 - handling multiple child objects
|
|
1875
|
+
// VD 22May24 - used common service file
|
|
1876
|
+
responses = this.dataService.getValue(apiResponse, this.apiObj.variable);
|
|
1897
1877
|
let results = [];
|
|
1878
|
+
// HA 19JAN24 To avoid undefined error in console
|
|
1898
1879
|
for (let i = 0; i < responses?.length; i++) {
|
|
1899
1880
|
var resp = responses[i];
|
|
1900
1881
|
results.push(resp);
|
|
1901
1882
|
}
|
|
1902
1883
|
this.options = results;
|
|
1903
1884
|
}
|
|
1904
|
-
else {
|
|
1905
|
-
responses =
|
|
1885
|
+
else { // VD 19JAN24 - if response has value(which is array) only
|
|
1886
|
+
responses = apiResponse;
|
|
1906
1887
|
this.options = responses;
|
|
1907
1888
|
}
|
|
1908
|
-
|
|
1909
|
-
|
|
1889
|
+
// VD 25Oct24 - Store fetched options in local storage
|
|
1890
|
+
if (this.uniqueKey) {
|
|
1891
|
+
localStorage.setItem(this.uniqueKey, JSON.stringify(this.options));
|
|
1892
|
+
}
|
|
1893
|
+
// Reference https://www.npmjs.com/package/@ng-select/ng-select
|
|
1894
|
+
});
|
|
1910
1895
|
}
|
|
1911
|
-
}
|
|
1896
|
+
}
|
|
1897
|
+
// VD NOV23 - handle the dependent update for dropdown
|
|
1898
|
+
// // VD 09Sep24- push the dependent field values for dropdown
|
|
1899
|
+
let sourceId = this.apiObj.sourceQuestionId;
|
|
1900
|
+
if (sourceId && this.apiObj.variable || this.apiObj.valueField) {
|
|
1901
|
+
// Subscribe for the changes
|
|
1902
|
+
this.subscription = this.changeService.changeAnnounced$.subscribe((changeValue) => {
|
|
1903
|
+
if (changeValue != undefined) {
|
|
1904
|
+
// console.log('inside subscription for the change');
|
|
1905
|
+
if (changeValue.valueObj != undefined && changeValue.fromQuestionId == this.apiObj.sourceQuestionId) {
|
|
1906
|
+
// this.selectedValue = changeValue.valueObj[this.apiObj.valueField];
|
|
1907
|
+
// let value ={};
|
|
1908
|
+
// value['name'] = this.selectedValue;
|
|
1909
|
+
let responses;
|
|
1910
|
+
if (this.apiObj.variable) {
|
|
1911
|
+
responses = this.dataService.getValue(changeValue.valueObj, this.apiObj.variable);
|
|
1912
|
+
let results = [];
|
|
1913
|
+
for (let i = 0; i < responses?.length; i++) {
|
|
1914
|
+
var resp = responses[i];
|
|
1915
|
+
results.push(resp);
|
|
1916
|
+
}
|
|
1917
|
+
this.options = results;
|
|
1918
|
+
}
|
|
1919
|
+
else {
|
|
1920
|
+
responses = changeValue.valueObj;
|
|
1921
|
+
this.options = responses;
|
|
1922
|
+
}
|
|
1923
|
+
}
|
|
1924
|
+
this.changeService.confirmChange(this.apiObj.sourceQuestionId);
|
|
1925
|
+
}
|
|
1926
|
+
});
|
|
1927
|
+
}
|
|
1912
1928
|
}
|
|
1913
1929
|
}
|
|
1914
1930
|
}
|
|
@@ -1928,11 +1944,11 @@ class CustomDropdownComponent {
|
|
|
1928
1944
|
}
|
|
1929
1945
|
}
|
|
1930
1946
|
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"] }] });
|
|
1947
|
+
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
1948
|
}
|
|
1933
1949
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: CustomDropdownComponent, decorators: [{
|
|
1934
1950
|
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"] }]
|
|
1951
|
+
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
1952
|
}], ctorParameters: function () { return [{ type: ChangeService }, { type: DataService }, { type: I18nService }]; }, propDecorators: { options: [{
|
|
1937
1953
|
type: Input
|
|
1938
1954
|
}], placeholder: [{
|