@rangertechnologies/ngnxt 2.1.74 → 2.1.76

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