@rangertechnologies/ngnxt 2.1.76 → 2.1.78

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (114) hide show
  1. package/README.md +29 -29
  2. package/esm2022/lib/ar.i18n.mjs +29 -29
  3. package/esm2022/lib/components/custom-button/custom-button.component.mjs +39 -39
  4. package/esm2022/lib/components/custom-calendar/custom-calendar.component.mjs +366 -366
  5. package/esm2022/lib/components/custom-date/custom-date.component.mjs +47 -47
  6. package/esm2022/lib/components/custom-date-picker/custom-date-picker.component.mjs +48 -48
  7. package/esm2022/lib/components/custom-dropdown/custom-dropdown.component.mjs +219 -212
  8. package/esm2022/lib/components/custom-image/custom-image.component.mjs +34 -34
  9. package/esm2022/lib/components/custom-input/custom-input.component.mjs +93 -93
  10. package/esm2022/lib/components/custom-label/custom-label.component.mjs +21 -21
  11. package/esm2022/lib/components/custom-model/custom-model.component.mjs +48 -48
  12. package/esm2022/lib/components/custom-radio/custom-radio.component.mjs +115 -115
  13. package/esm2022/lib/components/custom-table/custom-table.component.mjs +169 -169
  14. package/esm2022/lib/components/custom-text-area/custom-text-area.component.mjs +65 -65
  15. package/esm2022/lib/components/custom-time/custom-time.component.mjs +61 -61
  16. package/esm2022/lib/components/dependent-table/dependent-table.component.mjs +42 -42
  17. package/esm2022/lib/components/dropdown-with-flag/dropdown-with-flag.component.mjs +39 -39
  18. package/esm2022/lib/components/file-upload/file-upload.component.mjs +233 -233
  19. package/esm2022/lib/components/file-view/file-view.component.mjs +46 -46
  20. package/esm2022/lib/components/loader/loader.component.mjs +23 -23
  21. package/esm2022/lib/components/pick-location/pick-location.component.mjs +188 -188
  22. package/esm2022/lib/components/search-box/search-box.component.mjs +130 -130
  23. package/esm2022/lib/components/table-appendix/table-appendix.component.mjs +123 -123
  24. package/esm2022/lib/directives/componenthost/componenthost.directive.mjs +19 -19
  25. package/esm2022/lib/en.i18n.mjs +29 -29
  26. package/esm2022/lib/i18n-config.service.mjs +4 -4
  27. package/esm2022/lib/i18n.component.mjs +47 -47
  28. package/esm2022/lib/i18n.module.mjs +38 -38
  29. package/esm2022/lib/i18n.pipe.mjs +25 -25
  30. package/esm2022/lib/i18n.service.mjs +56 -56
  31. package/esm2022/lib/interfaces/actionMeta.mjs +2 -2
  32. package/esm2022/lib/interfaces/apimeta.mjs +2 -2
  33. package/esm2022/lib/interfaces/dependencyMeta.mjs +2 -2
  34. package/esm2022/lib/model/bookletWrapper.mjs +9 -9
  35. package/esm2022/lib/model/changeWrapper.mjs +11 -11
  36. package/esm2022/lib/model/errorWrapper.mjs +6 -6
  37. package/esm2022/lib/model/tableWrapper.mjs +20 -20
  38. package/esm2022/lib/nxt-app.component.mjs +22 -22
  39. package/esm2022/lib/nxt-app.module.mjs +352 -352
  40. package/esm2022/lib/nxt-app.service.mjs +14 -14
  41. package/esm2022/lib/pages/booklet/booklet.component.mjs +541 -541
  42. package/esm2022/lib/pages/questionbook/questionbook.component.mjs +407 -407
  43. package/esm2022/lib/pages/questionnaire/questionnaire.component.mjs +2373 -2373
  44. package/esm2022/lib/pages/summary-page/summary-page.component.mjs +76 -76
  45. package/esm2022/lib/pipe/get-value.pipe.mjs +50 -50
  46. package/esm2022/lib/sample.mjs +3430 -3430
  47. package/esm2022/lib/services/change.service.mjs +53 -53
  48. package/esm2022/lib/services/data.service.mjs +80 -80
  49. package/esm2022/lib/services/salesforce.service.mjs +46 -46
  50. package/esm2022/lib/services/shared.service.mjs +100 -100
  51. package/esm2022/lib/services/storage.service.mjs +44 -44
  52. package/esm2022/lib/tam.i18n.mjs +29 -29
  53. package/esm2022/lib/wrapper.mjs +175 -175
  54. package/esm2022/public-api.mjs +15 -15
  55. package/esm2022/rangertechnologies-ngnxt.mjs +4 -4
  56. package/fesm2022/rangertechnologies-ngnxt.mjs +9812 -9805
  57. package/fesm2022/rangertechnologies-ngnxt.mjs.map +1 -1
  58. package/index.d.ts +5 -5
  59. package/lib/ar.i18n.d.ts +24 -24
  60. package/lib/components/custom-button/custom-button.component.d.ts +16 -16
  61. package/lib/components/custom-calendar/custom-calendar.component.d.ts +65 -65
  62. package/lib/components/custom-date/custom-date.component.d.ts +18 -18
  63. package/lib/components/custom-date-picker/custom-date-picker.component.d.ts +19 -19
  64. package/lib/components/custom-dropdown/custom-dropdown.component.d.ts +39 -39
  65. package/lib/components/custom-image/custom-image.component.d.ts +13 -13
  66. package/lib/components/custom-input/custom-input.component.d.ts +31 -31
  67. package/lib/components/custom-label/custom-label.component.d.ts +10 -10
  68. package/lib/components/custom-model/custom-model.component.d.ts +19 -19
  69. package/lib/components/custom-radio/custom-radio.component.d.ts +33 -33
  70. package/lib/components/custom-table/custom-table.component.d.ts +43 -43
  71. package/lib/components/custom-text-area/custom-text-area.component.d.ts +22 -22
  72. package/lib/components/custom-time/custom-time.component.d.ts +18 -18
  73. package/lib/components/dependent-table/dependent-table.component.d.ts +15 -15
  74. package/lib/components/dropdown-with-flag/dropdown-with-flag.component.d.ts +16 -16
  75. package/lib/components/file-upload/file-upload.component.d.ts +42 -42
  76. package/lib/components/file-view/file-view.component.d.ts +16 -16
  77. package/lib/components/loader/loader.component.d.ts +11 -11
  78. package/lib/components/pick-location/pick-location.component.d.ts +42 -42
  79. package/lib/components/search-box/search-box.component.d.ts +40 -40
  80. package/lib/components/table-appendix/table-appendix.component.d.ts +30 -30
  81. package/lib/directives/componenthost/componenthost.directive.d.ts +8 -8
  82. package/lib/en.i18n.d.ts +24 -24
  83. package/lib/i18n-config.service.d.ts +2 -2
  84. package/lib/i18n.component.d.ts +11 -11
  85. package/lib/i18n.module.d.ts +9 -9
  86. package/lib/i18n.pipe.d.ts +10 -10
  87. package/lib/i18n.service.d.ts +14 -14
  88. package/lib/interfaces/actionMeta.d.ts +5 -5
  89. package/lib/interfaces/apimeta.d.ts +14 -13
  90. package/lib/interfaces/dependencyMeta.d.ts +8 -8
  91. package/lib/model/bookletWrapper.d.ts +5 -5
  92. package/lib/model/changeWrapper.d.ts +10 -10
  93. package/lib/model/errorWrapper.d.ts +5 -5
  94. package/lib/model/tableWrapper.d.ts +18 -18
  95. package/lib/nxt-app.component.d.ts +8 -8
  96. package/lib/nxt-app.module.d.ts +46 -46
  97. package/lib/nxt-app.service.d.ts +6 -6
  98. package/lib/pages/booklet/booklet.component.d.ts +68 -68
  99. package/lib/pages/questionbook/questionbook.component.d.ts +66 -66
  100. package/lib/pages/questionnaire/questionnaire.component.d.ts +218 -218
  101. package/lib/pages/summary-page/summary-page.component.d.ts +20 -20
  102. package/lib/pipe/get-value.pipe.d.ts +7 -7
  103. package/lib/sample.d.ts +10 -10
  104. package/lib/services/change.service.d.ts +22 -22
  105. package/lib/services/data.service.d.ts +13 -13
  106. package/lib/services/salesforce.service.d.ts +11 -11
  107. package/lib/services/shared.service.d.ts +15 -15
  108. package/lib/services/storage.service.d.ts +13 -13
  109. package/lib/tam.i18n.d.ts +24 -24
  110. package/lib/wrapper.d.ts +203 -203
  111. package/package.json +1 -1
  112. package/public-api.d.ts +10 -10
  113. package/rangertechnologies-ngnxt-2.1.78.tgz +0 -0
  114. package/rangertechnologies-ngnxt-2.1.76.tgz +0 -0
@@ -1,212 +1,219 @@
1
- import { Component, Input, Output, EventEmitter } from '@angular/core';
2
- import { ChangeWrapper } from '../../model/changeWrapper';
3
- import * as i0 from "@angular/core";
4
- import * as i1 from "../../services/change.service";
5
- import * as i2 from "../../services/data.service";
6
- import * as i3 from "../../i18n.service";
7
- import * as i4 from "@angular/common";
8
- import * as i5 from "@angular/forms";
9
- import * as i6 from "@ng-select/ng-select";
10
- export class CustomDropdownComponent {
11
- changeService;
12
- dataService;
13
- i18nService;
14
- options;
15
- placeholder;
16
- apiMeta;
17
- selectedValue;
18
- progressBar;
19
- id;
20
- readOnly = false; // VD 12Jun24 - readonly change
21
- errorMessage;
22
- error;
23
- fromShengel = false;
24
- question;
25
- referenceField;
26
- token; // VD 19JAN24 - getting token as input
27
- valueChange = new EventEmitter();
28
- invalidFieldIds = [];
29
- constructor(changeService, dataService, i18nService) {
30
- this.changeService = changeService;
31
- this.dataService = dataService;
32
- this.i18nService = i18nService;
33
- this.changeService.submitValidate$.subscribe((data) => {
34
- // to get the error message's field id's
35
- this.invalidFieldIds.push(data);
36
- });
37
- }
38
- labelField;
39
- valueField;
40
- subscription;
41
- apiObj;
42
- uniqueKey;
43
- ngOnInit() {
44
- }
45
- getOptions() {
46
- console.log('test click');
47
- // console.log('inside oninit of custom-dropdown of ' + this.id);
48
- // console.log(this.apiMeta);
49
- //VD 07Aug24 - isDependentField change
50
- // VD 25Oct24 - changes
51
- this.placeholder = this.placeholder ? this.placeholder : '---Select option---';
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);
62
- }
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);
85
- }
86
- else {
87
- // if no query param get the actual endPoint
88
- fullEndPoint = this.apiObj.endpoint;
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
- });
117
- }
118
- }
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
- }
155
- }
156
- }
157
- catch (error) {
158
- console.error('Error parsing apiMeta:', error);
159
- }
160
- }
161
- }
162
- // VD 22May24 - used common service file
163
- selectChange(event) {
164
- console.log('inside selectChange from ' + this.id);
165
- // console.log(event);
166
- let change = new ChangeWrapper(); // ChangeWrapper = JSON.parse('{}');
167
- change.fromQuestionId = this.id;
168
- change.valueObj = event ? event : '';
169
- change.referenceField = this.referenceField;
170
- change.selectedObj = event ? event[this.labelField] : '';
171
- this.valueChange.emit(change);
172
- // once got value in dropdown remove the error validation
173
- if (event) {
174
- this.invalidFieldIds = [];
175
- }
176
- }
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 });
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"] }] });
179
- }
180
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: CustomDropdownComponent, decorators: [{
181
- type: Component,
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"] }]
183
- }], ctorParameters: function () { return [{ type: i1.ChangeService }, { type: i2.DataService }, { type: i3.I18nService }]; }, propDecorators: { options: [{
184
- type: Input
185
- }], placeholder: [{
186
- type: Input
187
- }], apiMeta: [{
188
- type: Input
189
- }], selectedValue: [{
190
- type: Input
191
- }], progressBar: [{
192
- type: Input
193
- }], id: [{
194
- type: Input
195
- }], readOnly: [{
196
- type: Input
197
- }], errorMessage: [{
198
- type: Input
199
- }], error: [{
200
- type: Input
201
- }], fromShengel: [{
202
- type: Input
203
- }], question: [{
204
- type: Input
205
- }], referenceField: [{
206
- type: Input
207
- }], token: [{
208
- type: Input
209
- }], valueChange: [{
210
- type: Output
211
- }] } });
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"]}
1
+ import { Component, Input, Output, EventEmitter } from '@angular/core';
2
+ import { ChangeWrapper } from '../../model/changeWrapper';
3
+ import * as i0 from "@angular/core";
4
+ import * as i1 from "../../services/change.service";
5
+ import * as i2 from "../../services/data.service";
6
+ import * as i3 from "../../i18n.service";
7
+ import * as i4 from "@angular/common";
8
+ import * as i5 from "@angular/forms";
9
+ import * as i6 from "@ng-select/ng-select";
10
+ export class CustomDropdownComponent {
11
+ changeService;
12
+ dataService;
13
+ i18nService;
14
+ options;
15
+ placeholder;
16
+ apiMeta;
17
+ selectedValue;
18
+ progressBar;
19
+ id;
20
+ readOnly = false; // VD 12Jun24 - readonly change
21
+ errorMessage;
22
+ error;
23
+ fromShengel = false;
24
+ question;
25
+ referenceField;
26
+ token; // VD 19JAN24 - getting token as input
27
+ valueChange = new EventEmitter();
28
+ invalidFieldIds = [];
29
+ constructor(changeService, dataService, i18nService) {
30
+ this.changeService = changeService;
31
+ this.dataService = dataService;
32
+ this.i18nService = i18nService;
33
+ this.changeService.submitValidate$.subscribe((data) => {
34
+ // to get the error message's field id's
35
+ this.invalidFieldIds.push(data);
36
+ });
37
+ }
38
+ labelField;
39
+ valueField;
40
+ subscription;
41
+ apiObj;
42
+ uniqueKey;
43
+ ngOnInit() {
44
+ }
45
+ getOptions() {
46
+ console.log('test click');
47
+ // console.log('inside oninit of custom-dropdown of ' + this.id);
48
+ // console.log(this.apiMeta);
49
+ //VD 07Aug24 - isDependentField change
50
+ // VD 25Oct24 - changes
51
+ this.placeholder = this.placeholder ? this.placeholder : '---Select option---';
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);
62
+ }
63
+ else {
64
+ if (!this.apiObj.isDependentField) {
65
+ this.options = [];
66
+ }
67
+ // VD 09Sep24- setup the query param for api call // MR 08JAN24 DependentField API Fix moved below logic from above if condition
68
+ let fullEndPoint;
69
+ if (this.apiObj.endpoint) {
70
+ if (this.apiObj.queryValueReference && this.apiObj.queryField) {
71
+ // process the end point with query param
72
+ let queryReferences = this.apiObj.queryValueReference.split(',');
73
+ let queryFields = this.apiObj.queryField.split(','); // MR 08JAN24 similar to above valuereference get list of QUERY Fields
74
+ let queryValues = this.apiObj.queryValue.split(','); // MR 08JAN24 similar to above valuereference get list of QUERY Values (Default)
75
+ let queryParams = [];
76
+ let qIndex = 0; // MR 08JAN24 Query Index
77
+ // Iterate over queryReferences and find the corresponding element in referenceData
78
+ queryReferences.forEach(reference => {
79
+ // Find the element in referenceData that matches the current reference
80
+ // RS 09DEC24 Changed keys
81
+ let matchingElement = this.question?.referenceQueryData.find(element => element.referenceField === reference);
82
+ // If a matching element is found, get its input value and create a query parameter
83
+ if (reference && matchingElement) { // MR 08JAN24 if reference exist & matching element found
84
+ queryParams.push(`${queryFields[qIndex]}=${matchingElement.input}`); // MR 08JAN24 removed reference
85
+ }
86
+ else { // MR 08JAN24 included option for multiple query params and default value in case of reference is not found
87
+ queryParams.push(`${queryFields[qIndex]}=${queryValues[qIndex]}`);
88
+ }
89
+ qIndex++;
90
+ });
91
+ fullEndPoint = this.apiObj.endpoint + '?' + queryParams.join('&');
92
+ console.log(fullEndPoint);
93
+ }
94
+ else {
95
+ // if no query param get the actual endPoint
96
+ fullEndPoint = this.apiObj.endpoint;
97
+ }
98
+ // VD 19JAN24 - added one more param for authentication
99
+ this.dataService.apiResponse(fullEndPoint)?.subscribe((apiResponse) => {
100
+ // HA 18-JAN-24 Assigned apiresponse directly if we have the response in array also
101
+ // VD 19JAN24 - if response has key with value(which is array)
102
+ let responses;
103
+ if (this.apiObj.variable) {
104
+ // VD 21May24 - handling multiple child objects
105
+ // VD 22May24 - used common service file
106
+ responses = this.dataService.getValue(apiResponse, this.apiObj.variable);
107
+ let results = [];
108
+ // HA 19JAN24 To avoid undefined error in console
109
+ for (let i = 0; i < responses?.length; i++) {
110
+ var resp = responses[i];
111
+ results.push(resp);
112
+ }
113
+ this.options = results;
114
+ }
115
+ else { // VD 19JAN24 - if response has value(which is array) only
116
+ responses = apiResponse;
117
+ this.options = responses;
118
+ }
119
+ // VD 25Oct24 - Store fetched options in local storage
120
+ if (this.uniqueKey) {
121
+ localStorage.setItem(this.uniqueKey, JSON.stringify(this.options));
122
+ }
123
+ // Reference https://www.npmjs.com/package/@ng-select/ng-select
124
+ });
125
+ }
126
+ // VD NOV23 - handle the dependent update for dropdown
127
+ // VD 09Sep24- push the dependent field values for dropdown
128
+ let sourceId = this.apiObj.sourceQuestionId;
129
+ if (sourceId && this.apiObj.variable || this.apiObj.valueField) {
130
+ // Subscribe for the changes
131
+ this.subscription = this.changeService.changeAnnounced$.subscribe((changeValue) => {
132
+ if (changeValue != undefined) {
133
+ // console.log('inside subscription for the change');
134
+ if (changeValue.valueObj != undefined && changeValue.fromQuestionId == this.apiObj.sourceQuestionId) {
135
+ // this.selectedValue = changeValue.valueObj[this.apiObj.valueField];
136
+ // let value ={};
137
+ // value['name'] = this.selectedValue;
138
+ let responses;
139
+ if (this.apiObj.variable) {
140
+ responses = this.dataService.getValue(changeValue.valueObj, this.apiObj.variable);
141
+ let results = [];
142
+ for (let i = 0; i < responses?.length; i++) {
143
+ var resp = responses[i];
144
+ results.push(resp);
145
+ }
146
+ this.options = results;
147
+ }
148
+ else {
149
+ responses = changeValue.valueObj;
150
+ this.options = responses;
151
+ }
152
+ // VD 25Oct24 - Store fetched options in local storage
153
+ if (this.uniqueKey) {
154
+ localStorage.setItem(this.uniqueKey, JSON.stringify(this.options));
155
+ }
156
+ }
157
+ this.changeService.confirmChange(this.apiObj.sourceQuestionId);
158
+ }
159
+ });
160
+ }
161
+ }
162
+ }
163
+ }
164
+ catch (error) {
165
+ console.error('Error parsing apiMeta:', error);
166
+ }
167
+ }
168
+ }
169
+ // VD 22May24 - used common service file
170
+ selectChange(event) {
171
+ console.log('inside selectChange from ' + this.id);
172
+ // console.log(event);
173
+ let change = new ChangeWrapper(); // ChangeWrapper = JSON.parse('{}');
174
+ change.fromQuestionId = this.id;
175
+ change.valueObj = event ? event : '';
176
+ change.referenceField = this.referenceField;
177
+ change.selectedObj = event ? event[this.labelField] : '';
178
+ this.valueChange.emit(change);
179
+ // once got value in dropdown remove the error validation
180
+ if (event) {
181
+ this.invalidFieldIds = [];
182
+ }
183
+ }
184
+ 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 });
185
+ 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 -->\r\n<!-- <select\r\n [ngClass]=\"{\r\n 'dt-line dpDown down myt-dropbox myt-border-r myt-font1': progressBar,\r\n 'custom-select': !progressBar\r\n }\" class=\"custom-select mr-sm-2 dd-height\" \r\n [id]=\"id\" \r\n [(ngModel)]=\"selectedValue\"\r\n (change)=\"selectChange($event.target.value);\" \r\n [style.borderColor]=\"error ? 'red' : '#858585'\"\r\n [style.color]=\"error ? 'red' : ''\">\r\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>\r\n <option *ngIf=\"errorMessage\" value=\"\" disabled hidden>{{ errorMessage }}</option>\r\n</select> -->\r\n<!-- // VD 12Jun24 - readonly change-->\r\n<!-- VD 01Aug24 - validation change-->\r\n<!-- VD 07Aug24 - isDependentField change-->\r\n<!-- VD 25Oct24 - changes-->\r\n<!-- RS 09DEC24 Changed keys--> \r\n<ng-select\r\n [class]=\"invalidFieldIds.includes(id) || error ? 'shengel-custom-select invalid' : 'shengel-custom-select'\"\r\n [(ngModel)]=\"selectedValue\" \r\n [placeholder]=\"placeholder\"\r\n [disabled]=\"readOnly\"\r\n (click)=\"getOptions()\"\r\n (change)=\"selectChange($event)\"\r\n [id]=\"id\">\r\n <ng-option \r\n *ngFor=\"let option of options\" \r\n [value]=\"apiObj && !apiObj.isDependentField ? option : option?.value\">\r\n {{ apiObj && !apiObj.isDependentField && option ? option[labelField] : option?.value }}\r\n </ng-option> \r\n</ng-select>\r\n<span *ngIf=\"error || invalidFieldIds.includes(id)\" class=\"error-msg\">{{errorMessage}}</span>\r\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"] }] });
186
+ }
187
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: CustomDropdownComponent, decorators: [{
188
+ type: Component,
189
+ args: [{ selector: 'app-custom-dropdown', template: "<!-- HA 18-JAN-24 Commenting these lines as we don't have to use shengel here -->\r\n<!-- <select\r\n [ngClass]=\"{\r\n 'dt-line dpDown down myt-dropbox myt-border-r myt-font1': progressBar,\r\n 'custom-select': !progressBar\r\n }\" class=\"custom-select mr-sm-2 dd-height\" \r\n [id]=\"id\" \r\n [(ngModel)]=\"selectedValue\"\r\n (change)=\"selectChange($event.target.value);\" \r\n [style.borderColor]=\"error ? 'red' : '#858585'\"\r\n [style.color]=\"error ? 'red' : ''\">\r\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>\r\n <option *ngIf=\"errorMessage\" value=\"\" disabled hidden>{{ errorMessage }}</option>\r\n</select> -->\r\n<!-- // VD 12Jun24 - readonly change-->\r\n<!-- VD 01Aug24 - validation change-->\r\n<!-- VD 07Aug24 - isDependentField change-->\r\n<!-- VD 25Oct24 - changes-->\r\n<!-- RS 09DEC24 Changed keys--> \r\n<ng-select\r\n [class]=\"invalidFieldIds.includes(id) || error ? 'shengel-custom-select invalid' : 'shengel-custom-select'\"\r\n [(ngModel)]=\"selectedValue\" \r\n [placeholder]=\"placeholder\"\r\n [disabled]=\"readOnly\"\r\n (click)=\"getOptions()\"\r\n (change)=\"selectChange($event)\"\r\n [id]=\"id\">\r\n <ng-option \r\n *ngFor=\"let option of options\" \r\n [value]=\"apiObj && !apiObj.isDependentField ? option : option?.value\">\r\n {{ apiObj && !apiObj.isDependentField && option ? option[labelField] : option?.value }}\r\n </ng-option> \r\n</ng-select>\r\n<span *ngIf=\"error || invalidFieldIds.includes(id)\" class=\"error-msg\">{{errorMessage}}</span>\r\n", styles: [".ng-select{width:100%}.invalid{border:1px solid red!important}\n"] }]
190
+ }], ctorParameters: function () { return [{ type: i1.ChangeService }, { type: i2.DataService }, { type: i3.I18nService }]; }, propDecorators: { options: [{
191
+ type: Input
192
+ }], placeholder: [{
193
+ type: Input
194
+ }], apiMeta: [{
195
+ type: Input
196
+ }], selectedValue: [{
197
+ type: Input
198
+ }], progressBar: [{
199
+ type: Input
200
+ }], id: [{
201
+ type: Input
202
+ }], readOnly: [{
203
+ type: Input
204
+ }], errorMessage: [{
205
+ type: Input
206
+ }], error: [{
207
+ type: Input
208
+ }], fromShengel: [{
209
+ type: Input
210
+ }], question: [{
211
+ type: Input
212
+ }], referenceField: [{
213
+ type: Input
214
+ }], token: [{
215
+ type: Input
216
+ }], valueChange: [{
217
+ type: Output
218
+ }] } });
219
+ //# 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';\r\nimport { Observable, Subscription } from 'rxjs';\r\nimport { APIMeta } from '../../interfaces/apimeta';\r\nimport { ChangeWrapper } from '../../model/changeWrapper';\r\nimport { ChangeService } from '../../services/change.service';\r\n// HA 19DEC23 imported translation service\r\nimport { I18nService } from '../../i18n.service';\r\n// VD 23JAN24 used service file for callout\r\nimport { DataService } from '../../services/data.service';\r\n\r\n@Component({\r\n  selector: 'app-custom-dropdown',\r\n  templateUrl: './custom-dropdown.component.html',\r\n  styleUrls: ['./custom-dropdown.component.css']\r\n})\r\nexport class CustomDropdownComponent implements OnInit {\r\n  @Input() options: string[];\r\n  @Input() placeholder: string;\r\n  @Input() apiMeta: string;\r\n  @Input() selectedValue: string;\r\n  @Input() progressBar: boolean;\r\n  @Input() id:string;\r\n  @Input() readOnly = false; // VD 12Jun24 - readonly change\r\n  @Input() errorMessage: string;\r\n  @Input() error:any;\r\n  @Input() fromShengel: boolean = false;\r\n  @Input() question:any;\r\n  @Input() referenceField:string;\r\n  @Input() token:string;    // VD 19JAN24 - getting token as input\r\n  @Output() valueChange: EventEmitter<ChangeWrapper> = new EventEmitter<ChangeWrapper>();\r\n  invalidFieldIds:string[] = [];\r\n  constructor( \r\n    private changeService: ChangeService, \r\n    private dataService: DataService,\r\n    public i18nService: I18nService,\r\n        ) { \r\n    this.changeService.submitValidate$.subscribe((data)=>{\r\n      // to get the error message's field id's\r\n      this.invalidFieldIds.push(data);\r\n    })\r\n  }\r\n\r\n  public labelField: string;\r\n  public valueField: string;\r\n  subscription: Subscription;\r\n  public apiObj:APIMeta;\r\n  public uniqueKey:string;\r\n\r\n  ngOnInit(): void {\r\n    \r\n  }\r\n  getOptions(){\r\n    console.log('test click');\r\n    // console.log('inside oninit of custom-dropdown of ' + this.id);\r\n    // console.log(this.apiMeta);\r\n    //VD 07Aug24 - isDependentField change\r\n    // VD 25Oct24 - changes\r\n    this.placeholder = this.placeholder ? this.placeholder : '---Select option---';\r\n    if(this.apiMeta) {\r\n    try {\r\n      this.apiObj = JSON.parse(this.apiMeta);\r\n      // Check if apiObj and apiObj.field are defined\r\n      if (this.apiObj && this.apiObj.field) {\r\n        this.labelField = this.apiObj.field;\r\n        this.uniqueKey = this.apiObj.uniqueKey;\r\n        const cachedOptions = localStorage.getItem(this.uniqueKey);\r\n        if (cachedOptions) {\r\n          this.options = JSON.parse(cachedOptions);\r\n        }else {\r\n          if(!this.apiObj.isDependentField){\r\n            this.options = [];\r\n          }\r\n\r\n          // VD 09Sep24- setup the query param for api call // MR 08JAN24 DependentField API Fix moved below logic from above if condition\r\n          let fullEndPoint ;\r\n          if(this.apiObj.endpoint) {\r\n            if(this.apiObj.queryValueReference && this.apiObj.queryField) {\r\n              // process the end point with query param\r\n              let queryReferences = this.apiObj.queryValueReference.split(',');\r\n              let queryFields = this.apiObj.queryField.split(',');    // MR 08JAN24 similar to above valuereference get list of QUERY Fields\r\n              let queryValues = this.apiObj.queryValue.split(',');    // MR 08JAN24 similar to above valuereference get list of QUERY Values (Default)\r\n              let queryParams = [];\r\n              let qIndex = 0;                                         // MR 08JAN24 Query Index\r\n              // Iterate over queryReferences and find the corresponding element in referenceData\r\n              queryReferences.forEach(reference => {\r\n                // Find the element in referenceData that matches the current reference\r\n                // RS 09DEC24 Changed keys\r\n                let matchingElement = this.question?.referenceQueryData.find(element => element.referenceField === reference);\r\n              // If a matching element is found, get its input value and create a query parameter\r\n                if (reference && matchingElement) {   // MR 08JAN24 if reference exist & matching element found\r\n                  queryParams.push(`${queryFields[qIndex]}=${matchingElement.input}`);    // MR 08JAN24 removed reference\r\n                } else {    // MR 08JAN24 included option for multiple query params and default value in case of reference is not found\r\n                  queryParams.push(`${queryFields[qIndex]}=${queryValues[qIndex]}`);\r\n                }\r\n\r\n                qIndex++;\r\n              });\r\n              fullEndPoint = this.apiObj.endpoint + '?' + queryParams.join('&');\r\n              console.log(fullEndPoint);\r\n            } else {\r\n                // if no query param get the actual endPoint\r\n              fullEndPoint = this.apiObj.endpoint;\r\n            }\r\n\r\n            // VD 19JAN24 - added one more param for authentication\r\n            this.dataService.apiResponse(fullEndPoint)?.subscribe((apiResponse) => {\r\n              // HA 18-JAN-24 Assigned apiresponse directly if we have the response in array also\r\n              // VD 19JAN24 - if response has key with value(which is array)\r\n              let responses;\r\n              if(this.apiObj.variable){\r\n                // VD 21May24 - handling multiple child objects\r\n                // VD 22May24 - used common service file\r\n                responses = this.dataService.getValue(apiResponse,this.apiObj.variable);\r\n                let results = [];\r\n                // HA 19JAN24 To avoid undefined error in console\r\n                for (let i = 0; i < responses?.length; i++) {\r\n                  var resp = responses[i];\r\n                  results.push(resp);\r\n                }\r\n                this.options = results;\r\n              }else{  // VD 19JAN24 - if response has value(which is array) only\r\n                responses = apiResponse;\r\n                this.options = responses;\r\n              }\r\n              // VD 25Oct24 - Store fetched options in local storage\r\n              if(this.uniqueKey){\r\n                localStorage.setItem(this.uniqueKey, JSON.stringify(this.options));\r\n              }\r\n              // Reference https://www.npmjs.com/package/@ng-select/ng-select\r\n            })\r\n          }\r\n\r\n          // VD NOV23 - handle the dependent update for dropdown\r\n          // VD 09Sep24- push the dependent field values for dropdown\r\n          let sourceId = this.apiObj.sourceQuestionId;\r\n          if(sourceId && this.apiObj.variable || this.apiObj.valueField){\r\n            // Subscribe for the changes\r\n            this.subscription = this.changeService.changeAnnounced$.subscribe(\r\n              (changeValue) => {\r\n                if(changeValue != undefined) {\r\n                  // console.log('inside subscription for the change');\r\n                  if(changeValue.valueObj != undefined && changeValue.fromQuestionId == this.apiObj.sourceQuestionId) {\r\n                    //  this.selectedValue = changeValue.valueObj[this.apiObj.valueField];\r\n                    //  let value ={};\r\n                    //  value['name'] = this.selectedValue;\r\n                      let responses;\r\n                      if(this.apiObj.variable){\r\n                        responses = this.dataService.getValue(changeValue.valueObj,this.apiObj.variable);\r\n                        let results = [];\r\n                        for (let i = 0; i < responses?.length; i++) {\r\n                          var resp = responses[i];\r\n                          results.push(resp);\r\n                        }\r\n                        this.options = results;\r\n                      }else{\r\n                        responses = changeValue.valueObj;\r\n                        this.options = responses;\r\n                      }\r\n                    // VD 25Oct24 - Store fetched options in local storage\r\n                    if(this.uniqueKey){\r\n                      localStorage.setItem(this.uniqueKey, JSON.stringify(this.options));\r\n                    }\r\n                    }\r\n                  this.changeService.confirmChange(this.apiObj.sourceQuestionId);\r\n                }\r\n            }\r\n          );\r\n          }\r\n        }\r\n      }\r\n    } catch (error) {\r\n      console.error('Error parsing apiMeta:', error);\r\n    }\r\n  } \r\n}\r\n// VD 22May24 - used common service file\r\n\r\n  selectChange(event:any) {\r\n    console.log('inside selectChange from ' + this.id);\r\n    // console.log(event);\r\n    let change = new ChangeWrapper(); // ChangeWrapper = JSON.parse('{}');\r\n    change.fromQuestionId = this.id;\r\n    change.valueObj = event ? event : '';\r\n    change.referenceField = this.referenceField;\r\n    change.selectedObj = event ? event[this.labelField] : '';\r\n    this.valueChange.emit(change);\r\n    // once got value in dropdown remove the error validation\r\n    if(event){\r\n      this.invalidFieldIds =[];\r\n    }\r\n  }\r\n}\r\n","<!-- HA 18-JAN-24 Commenting these lines as we don't have to use shengel here -->\r\n<!-- <select\r\n  [ngClass]=\"{\r\n    'dt-line dpDown down myt-dropbox myt-border-r myt-font1': progressBar,\r\n    'custom-select': !progressBar\r\n  }\" class=\"custom-select mr-sm-2 dd-height\" \r\n  [id]=\"id\" \r\n  [(ngModel)]=\"selectedValue\"\r\n  (change)=\"selectChange($event.target.value);\" \r\n  [style.borderColor]=\"error ? 'red' : '#858585'\"\r\n  [style.color]=\"error ? 'red' : ''\">\r\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>\r\n    <option *ngIf=\"errorMessage\" value=\"\" disabled hidden>{{ errorMessage }}</option>\r\n</select> -->\r\n<!-- // VD 12Jun24 - readonly change-->\r\n<!-- VD 01Aug24 - validation change-->\r\n<!-- VD 07Aug24 - isDependentField change-->\r\n<!-- VD 25Oct24 - changes-->\r\n<!-- RS 09DEC24 Changed keys--> \r\n<ng-select\r\n  [class]=\"invalidFieldIds.includes(id) || error ? 'shengel-custom-select invalid' : 'shengel-custom-select'\"\r\n  [(ngModel)]=\"selectedValue\" \r\n  [placeholder]=\"placeholder\"\r\n  [disabled]=\"readOnly\"\r\n  (click)=\"getOptions()\"\r\n  (change)=\"selectChange($event)\"\r\n  [id]=\"id\">\r\n  <ng-option \r\n    *ngFor=\"let option of options\" \r\n    [value]=\"apiObj && !apiObj.isDependentField ? option : option?.value\">\r\n    {{ apiObj && !apiObj.isDependentField && option ? option[labelField] : option?.value }}\r\n  </ng-option> \r\n</ng-select>\r\n<span *ngIf=\"error || invalidFieldIds.includes(id)\" class=\"error-msg\">{{errorMessage}}</span>\r\n"]}