@rangertechnologies/ngnxt 2.1.106 → 2.1.107

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 (143) hide show
  1. package/esm2022/lib/ar.i18n.mjs +29 -0
  2. package/esm2022/lib/components/button/nxt-button.component.mjs +130 -0
  3. package/esm2022/lib/components/custom-button/custom-button.component.mjs +39 -0
  4. package/esm2022/lib/components/custom-calendar/custom-calendar.component.mjs +366 -0
  5. package/esm2022/lib/components/custom-date/custom-date.component.mjs +47 -0
  6. package/esm2022/lib/components/custom-date-picker/custom-date-picker.component.mjs +48 -0
  7. package/esm2022/lib/components/custom-dropdown/custom-dropdown.component.mjs +219 -0
  8. package/esm2022/lib/components/custom-image/custom-image.component.mjs +34 -0
  9. package/esm2022/lib/components/custom-input/custom-input.component.mjs +93 -0
  10. package/esm2022/lib/components/custom-label/custom-label.component.mjs +21 -0
  11. package/esm2022/lib/components/custom-model/custom-model.component.mjs +48 -0
  12. package/esm2022/lib/components/custom-radio/custom-radio.component.mjs +115 -0
  13. package/esm2022/lib/components/custom-rich-text/custom-rich-text.component.mjs +186 -0
  14. package/esm2022/lib/components/custom-table/custom-table.component.mjs +347 -0
  15. package/esm2022/lib/components/custom-text-area/custom-text-area.component.mjs +65 -0
  16. package/esm2022/lib/components/custom-time/custom-time.component.mjs +61 -0
  17. package/esm2022/lib/components/datatable/datatable.component.mjs +801 -0
  18. package/esm2022/lib/components/dependent-table/dependent-table.component.mjs +42 -0
  19. package/esm2022/lib/components/dropdown-with-flag/dropdown-with-flag.component.mjs +39 -0
  20. package/esm2022/lib/components/file-upload/file-upload.component.mjs +279 -0
  21. package/esm2022/lib/components/file-view/file-view.component.mjs +46 -0
  22. package/esm2022/lib/components/loader/loader.component.mjs +23 -0
  23. package/esm2022/lib/components/pagination/pagination.component.mjs +100 -0
  24. package/esm2022/lib/components/pick-location/pick-location.component.mjs +216 -0
  25. package/esm2022/lib/components/search-box/search-box.component.mjs +202 -0
  26. package/esm2022/lib/components/table-appendix/table-appendix.component.mjs +123 -0
  27. package/esm2022/lib/directives/componenthost/componenthost.directive.mjs +19 -0
  28. package/esm2022/lib/en.i18n.mjs +29 -0
  29. package/esm2022/lib/i18n-config.service.mjs +4 -0
  30. package/esm2022/lib/i18n.component.mjs +47 -0
  31. package/esm2022/lib/i18n.module.mjs +38 -0
  32. package/esm2022/lib/i18n.pipe.mjs +25 -0
  33. package/esm2022/lib/i18n.service.mjs +56 -0
  34. package/esm2022/lib/interfaces/actionMeta.mjs +2 -0
  35. package/esm2022/lib/interfaces/apimeta.mjs +2 -0
  36. package/esm2022/lib/interfaces/dependencyMeta.mjs +2 -0
  37. package/esm2022/lib/model/bookletWrapper.mjs +9 -0
  38. package/esm2022/lib/model/changeWrapper.mjs +11 -0
  39. package/esm2022/lib/model/errorWrapper.mjs +6 -0
  40. package/esm2022/lib/model/tableWrapper.mjs +20 -0
  41. package/esm2022/lib/nxt-app.component.mjs +22 -0
  42. package/esm2022/lib/nxt-app.module.mjs +399 -0
  43. package/esm2022/lib/nxt-app.service.mjs +14 -0
  44. package/esm2022/lib/pages/booklet/booklet.component.mjs +541 -0
  45. package/esm2022/lib/pages/builder/element/element.component.mjs +199 -0
  46. package/esm2022/lib/pages/builder/form/form.component.mjs +34 -0
  47. package/esm2022/lib/pages/builder/menu/menu.component.mjs +28 -0
  48. package/esm2022/lib/pages/builder/properties/properties.component.mjs +494 -0
  49. package/esm2022/lib/pages/questionbook/questionbook.component.mjs +458 -0
  50. package/esm2022/lib/pages/questionnaire/questionnaire.component.mjs +2387 -0
  51. package/esm2022/lib/pages/summary-page/summary-page.component.mjs +76 -0
  52. package/esm2022/lib/pipe/date/date.pipe.mjs +28 -0
  53. package/esm2022/lib/pipe/editColumnCheck/edit-column-check.pipe.mjs +28 -0
  54. package/esm2022/lib/pipe/editColumnDropdown/edit-column-dropdown.pipe.mjs +20 -0
  55. package/esm2022/lib/pipe/editColumnType/edit-column-type.pipe.mjs +20 -0
  56. package/esm2022/lib/pipe/get-value.pipe.mjs +50 -0
  57. package/esm2022/lib/pipe/search-filter/search-filter.pipe.mjs +39 -0
  58. package/esm2022/lib/pipe/time/time.pipe.mjs +26 -0
  59. package/esm2022/lib/sample.mjs +3715 -0
  60. package/esm2022/lib/services/change.service.mjs +53 -0
  61. package/esm2022/lib/services/data.service.mjs +80 -0
  62. package/esm2022/lib/services/form-builder.service.mjs +165 -0
  63. package/esm2022/lib/services/salesforce.service.mjs +46 -0
  64. package/esm2022/lib/services/shared.service.mjs +100 -0
  65. package/esm2022/lib/services/storage.service.mjs +44 -0
  66. package/esm2022/lib/tam.i18n.mjs +29 -0
  67. package/esm2022/lib/wrapper.mjs +175 -0
  68. package/esm2022/public-api.mjs +22 -0
  69. package/esm2022/rangertechnologies-ngnxt.mjs +5 -0
  70. package/fesm2022/rangertechnologies-ngnxt.mjs +12895 -0
  71. package/fesm2022/rangertechnologies-ngnxt.mjs.map +1 -0
  72. package/index.d.ts +5 -0
  73. package/lib/ar.i18n.d.ts +24 -0
  74. package/lib/components/button/nxt-button.component.d.ts +38 -0
  75. package/lib/components/custom-button/custom-button.component.d.ts +16 -0
  76. package/lib/components/custom-calendar/custom-calendar.component.d.ts +65 -0
  77. package/lib/components/custom-date/custom-date.component.d.ts +18 -0
  78. package/lib/components/custom-date-picker/custom-date-picker.component.d.ts +19 -0
  79. package/lib/components/custom-dropdown/custom-dropdown.component.d.ts +39 -0
  80. package/lib/components/custom-image/custom-image.component.d.ts +13 -0
  81. package/lib/components/custom-input/custom-input.component.d.ts +31 -0
  82. package/lib/components/custom-label/custom-label.component.d.ts +10 -0
  83. package/lib/components/custom-model/custom-model.component.d.ts +19 -0
  84. package/lib/components/custom-radio/custom-radio.component.d.ts +33 -0
  85. package/lib/components/custom-rich-text/custom-rich-text.component.d.ts +29 -0
  86. package/lib/components/custom-table/custom-table.component.d.ts +65 -0
  87. package/lib/components/custom-text-area/custom-text-area.component.d.ts +22 -0
  88. package/lib/components/custom-time/custom-time.component.d.ts +18 -0
  89. package/lib/components/datatable/datatable.component.d.ts +126 -0
  90. package/lib/components/dependent-table/dependent-table.component.d.ts +15 -0
  91. package/lib/components/dropdown-with-flag/dropdown-with-flag.component.d.ts +16 -0
  92. package/lib/components/file-upload/file-upload.component.d.ts +47 -0
  93. package/lib/components/file-view/file-view.component.d.ts +16 -0
  94. package/lib/components/loader/loader.component.d.ts +11 -0
  95. package/lib/components/pagination/pagination.component.d.ts +36 -0
  96. package/lib/components/pick-location/pick-location.component.d.ts +44 -0
  97. package/lib/components/search-box/search-box.component.d.ts +43 -0
  98. package/lib/components/table-appendix/table-appendix.component.d.ts +30 -0
  99. package/lib/directives/componenthost/componenthost.directive.d.ts +8 -0
  100. package/lib/en.i18n.d.ts +24 -0
  101. package/lib/i18n-config.service.d.ts +2 -0
  102. package/lib/i18n.component.d.ts +11 -0
  103. package/lib/i18n.module.d.ts +9 -0
  104. package/lib/i18n.pipe.d.ts +10 -0
  105. package/lib/i18n.service.d.ts +14 -0
  106. package/lib/interfaces/actionMeta.d.ts +5 -0
  107. package/lib/interfaces/apimeta.d.ts +15 -0
  108. package/lib/interfaces/dependencyMeta.d.ts +8 -0
  109. package/lib/model/bookletWrapper.d.ts +5 -0
  110. package/lib/model/changeWrapper.d.ts +10 -0
  111. package/lib/model/errorWrapper.d.ts +5 -0
  112. package/lib/model/tableWrapper.d.ts +18 -0
  113. package/lib/nxt-app.component.d.ts +8 -0
  114. package/lib/nxt-app.module.d.ts +52 -0
  115. package/lib/nxt-app.service.d.ts +6 -0
  116. package/lib/pages/booklet/booklet.component.d.ts +68 -0
  117. package/lib/pages/builder/element/element.component.d.ts +33 -0
  118. package/lib/pages/builder/form/form.component.d.ts +11 -0
  119. package/lib/pages/builder/menu/menu.component.d.ts +10 -0
  120. package/lib/pages/builder/properties/properties.component.d.ts +575 -0
  121. package/lib/pages/questionbook/questionbook.component.d.ts +68 -0
  122. package/lib/pages/questionnaire/questionnaire.component.d.ts +220 -0
  123. package/lib/pages/summary-page/summary-page.component.d.ts +20 -0
  124. package/lib/pipe/date/date.pipe.d.ts +7 -0
  125. package/lib/pipe/editColumnCheck/edit-column-check.pipe.d.ts +7 -0
  126. package/lib/pipe/editColumnDropdown/edit-column-dropdown.pipe.d.ts +7 -0
  127. package/lib/pipe/editColumnType/edit-column-type.pipe.d.ts +7 -0
  128. package/lib/pipe/get-value.pipe.d.ts +7 -0
  129. package/lib/pipe/search-filter/search-filter.pipe.d.ts +8 -0
  130. package/lib/pipe/time/time.pipe.d.ts +7 -0
  131. package/lib/sample.d.ts +11 -0
  132. package/lib/services/change.service.d.ts +22 -0
  133. package/lib/services/data.service.d.ts +13 -0
  134. package/lib/services/form-builder.service.d.ts +76 -0
  135. package/lib/services/salesforce.service.d.ts +11 -0
  136. package/lib/services/shared.service.d.ts +15 -0
  137. package/lib/services/storage.service.d.ts +13 -0
  138. package/lib/tam.i18n.d.ts +24 -0
  139. package/lib/wrapper.d.ts +203 -0
  140. package/package.json +1 -5
  141. package/public-api.d.ts +15 -0
  142. package/rangertechnologies-ngnxt-2.1.107.tgz +0 -0
  143. package/src/lib/style.css +1817 -0
@@ -0,0 +1,202 @@
1
+ import { Component, Input, Output, EventEmitter, ViewChild, } from "@angular/core";
2
+ import { ChangeWrapper } from "../../model/changeWrapper";
3
+ import * as i0 from "@angular/core";
4
+ import * as i1 from "../../services/data.service";
5
+ import * as i2 from "../../i18n.service";
6
+ import * as i3 from "@angular/common";
7
+ import * as i4 from "@angular/forms";
8
+ export class SearchBoxComponent {
9
+ dataService;
10
+ i18nService;
11
+ placeHolderText;
12
+ auto;
13
+ question;
14
+ apiMeta;
15
+ id;
16
+ readOnly = false; // VD 12Jun24 - readonly change
17
+ searchValueChange = new EventEmitter();
18
+ apiObj;
19
+ SearchItem;
20
+ filterName; // VD 20Aug default filter value as input
21
+ finalResults = [];
22
+ searchKeyWord = '';
23
+ newResult;
24
+ showResult = false;
25
+ noResult = false;
26
+ showSuggestion = true;
27
+ el;
28
+ serv = 'api';
29
+ tkn = '';
30
+ constructor(dataService, i18nService) {
31
+ this.dataService = dataService;
32
+ this.i18nService = i18nService;
33
+ }
34
+ ngOnInit() {
35
+ // VD 03May- search changes
36
+ if (this.apiMeta) {
37
+ let apiObj = JSON.parse(this.apiMeta);
38
+ this.SearchItem = apiObj.field;
39
+ }
40
+ }
41
+ ////RS 03FEB2025
42
+ // Resets state when filterName or apiMeta changes to reflect updated data
43
+ ngOnChanges(changes) {
44
+ if (changes['apiMeta'] && this.apiMeta) {
45
+ this.apiObj = JSON.parse(this.apiMeta);
46
+ this.SearchItem = this.apiObj?.field;
47
+ }
48
+ }
49
+ //RS 03FEB2025
50
+ // Clears search-related data, including results, search term, and suggestions.
51
+ resetComponentState() {
52
+ this.finalResults = [];
53
+ this.filterName = '';
54
+ this.searchKeyWord = '';
55
+ this.showSuggestion = false;
56
+ this.noResult = false;
57
+ }
58
+ clearList() {
59
+ setTimeout(() => {
60
+ this.finalResults = [];
61
+ }, 1000);
62
+ }
63
+ getSourceDataLocal(event) {
64
+ event.preventDefault();
65
+ if (event.target.value.length > 2) {
66
+ this.showSuggestion = true;
67
+ this.finalResults = [];
68
+ this.searchKeyWord = event.target.value;
69
+ this.showResult = false;
70
+ this.getSourceData(event.target.value);
71
+ }
72
+ else {
73
+ this.showSuggestion = false;
74
+ this.finalResults = [];
75
+ this.noResult = false;
76
+ }
77
+ }
78
+ // VD 03May- search changes
79
+ // VD 31NOV24 null check
80
+ // RS 29JAN25
81
+ //Multi-word search across all object values
82
+ getSourceData = (keyword) => {
83
+ if (this.apiMeta) {
84
+ let apiObj = JSON.parse(this.apiMeta);
85
+ this.dataService.apiResponse(apiObj.endpoint).subscribe((apiResponse) => {
86
+ let response;
87
+ if (apiObj.variable) {
88
+ response = this.dataService.getValue(apiResponse, apiObj.variable);
89
+ }
90
+ else {
91
+ response = apiResponse;
92
+ }
93
+ let results = [];
94
+ let searchTerms = keyword.toLowerCase()?.split(" ");
95
+ for (let i = 0; i < response.length; i++) {
96
+ let obj = response[i];
97
+ let combinedValues = this.getCombinedValuesFromColumns(obj, apiObj.field);
98
+ let match = searchTerms.every(term => combinedValues.includes(term));
99
+ if (match) {
100
+ results.push(obj);
101
+ }
102
+ }
103
+ this.noResult = results.length === 0;
104
+ this.finalResults = results;
105
+ });
106
+ }
107
+ };
108
+ // SKS27FEB Helper functions
109
+ getNestedValue(obj, path) {
110
+ //SKS27FEB Convert array indexes to dot notation (e.g., [0] -> .0)
111
+ const processedPath = path.replace(/\[(\d+)\]/g, '.$1');
112
+ const parts = processedPath.split('.');
113
+ let current = obj;
114
+ for (const part of parts) {
115
+ if (!current || typeof current !== 'object')
116
+ return '';
117
+ current = current[part];
118
+ }
119
+ return current !== null && current !== undefined
120
+ ? String(current).toLowerCase().trim()
121
+ : '';
122
+ }
123
+ getCombinedValuesFromColumns(obj, columns) {
124
+ const values = [];
125
+ // SKS28FEB check if columns is an array
126
+ if (typeof columns === 'string' && !Array.isArray(columns)) {
127
+ columns = [columns];
128
+ }
129
+ for (const column of columns) {
130
+ const value = this.getNestedValue(obj, column);
131
+ if (value) {
132
+ values.push(value);
133
+ }
134
+ }
135
+ return values.join(' ');
136
+ }
137
+ // SKS27FEB get value from data specific column
138
+ getValues(element, columns) {
139
+ const result = {};
140
+ // SKS28FEB check if columns is an array
141
+ if (typeof columns === 'string' && !Array.isArray(columns)) {
142
+ columns = [columns];
143
+ }
144
+ columns.forEach((column) => {
145
+ let tempElement = element;
146
+ let flds = column?.split('.');
147
+ for (let i = 0; i < flds.length; i++) {
148
+ let splitFlds = flds[i]?.split('[');
149
+ if (splitFlds.length === 1) {
150
+ tempElement = tempElement[flds[i]] || '';
151
+ }
152
+ else {
153
+ let index = Number(splitFlds[1]?.split(']')[0]);
154
+ tempElement = tempElement[splitFlds[0]]?.[index] || '';
155
+ }
156
+ }
157
+ result[column] = tempElement;
158
+ });
159
+ return result;
160
+ }
161
+ // SKS27FEB column value get funtion
162
+ getKeys(obj) {
163
+ return Object.keys(obj);
164
+ }
165
+ clickItem(event) {
166
+ // console.log('inside clickItem of ' + JSON.stringify(event, null, 2));
167
+ let apiObj = JSON.parse(this.apiMeta);
168
+ this.filterName = event[apiObj.defaultField || apiObj.field[0] || apiObj.field]; //SKS27FEB defaultField is used for showing a search field input if field have array of data
169
+ let change = new ChangeWrapper(); // ChangeWrapper = JSON.parse('{}');
170
+ change.fromQuestionId = this.id;
171
+ change.valueObj = event;
172
+ change.field = apiObj.field;
173
+ this.searchValueChange.emit(change);
174
+ }
175
+ //RS 03FEB2025
176
+ // Resets component state when the component is destroyed
177
+ ngOnDestroy() { this.resetComponentState(); }
178
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: SearchBoxComponent, deps: [{ token: i1.DataService }, { token: i2.I18nService }], target: i0.ɵɵFactoryTarget.Component });
179
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: SearchBoxComponent, selector: "lib-search-box", inputs: { placeHolderText: "placeHolderText", question: "question", apiMeta: "apiMeta", id: "id", readOnly: "readOnly", filterName: "filterName" }, outputs: { searchValueChange: "searchValueChange" }, viewQueries: [{ propertyName: "auto", first: true, predicate: ["auto"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<!-- // VD 12Jun24 - readonly change-->\n<div id=\"autocomplete-input\"> <!-- SKS5NOV25 search icon -->\n <input #auto id=\"searchbox-style\"\n (blur)=\"clearList()\"\n [(ngModel)]=\"filterName\"\n type=\"text\"\n name=\"name\"\n [readOnly]=\"readOnly\"\n [placeholder]=\"placeHolderText\"\n style=\"margin: 0 !important; padding-right: 30px;\"\n class=\"searchInput she-line-input form-control\"\n (focusin)=\"getSourceDataLocal($event)\"\n (input)=\"getSourceDataLocal($event)\">\n <div id=\"selectList\" style=\"position: absolute;position: absolute;background: white;z-index: 2;\">\n <div *ngIf=\"finalResults.length > 0 && showSuggestion\"\n style=\"max-height: 20vh;border: 1px solid #d2d4d6;overflow: scroll; min-width:100px\"\n class=\"suggestions-container\">\n <!-- HA 20DEC23 Uncommented the logic -->\n <!-- VD 03May- search changes -->\n <div *ngFor=\"let item of finalResults\" (click)='clickItem(item)' class=\"hoover\">\n <!-- VD 26Jun24 - id condition removed -->\n <div class=\"grid-x align-middle\" style=\"\">\n <div *ngIf=\"item.thumbnail\" class=\"cell shrink\" style=\"width: 60px; margin-right: 1.6rem;\">\n <img [src]=\"item.thumbnail\" style=\"width: 60px;\" alt=\"\">\n </div>\n <div class=\"cell auto\" style=\"text-align: left; padding:5px 8px 0 8px; display: flex; gap: 5px; \">\n <!--// VD 26JUN24 - pipe changes -->\n <!-- RS 29JAN25 -->\n <div style=\"display: flex;\" *ngFor=\"let key of getKeys(getValues(item, SearchItem))\">\n <div>\n {{ getValues(item, SearchItem)[key] }}\n </div>\n </div> \n </div>\n </div>\n </div>\n <!-- HA 20DEC23 For Commented this for future purpose -->\n <!-- <table class=\"table table-striped table-bordered\">\n <thead>\n <tr>\n <th>{{ 'firstName' | i18n:i18nService.currentLanguage }}</th>\n <th>{{ 'lastName' | i18n:i18nService.currentLanguage }}</th>\n <th>{{ 'division' | i18n:i18nService.currentLanguage }}</th>\n <th>{{ 'numberPlate' | i18n:i18nService.currentLanguage }}</th>\n </tr>\n </thead>\n <tbody>\n <tr *ngFor=\"let item of finalResults\" (click)='clickItem(item)'>\n <td>{{ item.firstName }}</td>\n <td>{{ item.lastName }}</td>\n <td>{{ item.division }}</td>\n <td>{{ item.numberPlate }}</td>\n </tr>\n </tbody>\n </table> -->\n </div>\n</div>\n\n", styles: ["#searchbox-style{background-image:url('data:image/svg+xml;utf8,<svg width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><circle cx=\"11\" cy=\"11\" r=\"7\" stroke=\"%23434555\" stroke-opacity=\"0.65\" stroke-width=\"2\"/><path d=\"M20 20L17 17\" stroke=\"%23434555\" stroke-opacity=\"0.65\" stroke-width=\"2\" stroke-linecap=\"round\"/></svg>');background-position:right 5px center;background-repeat:no-repeat;background-size:24px;padding-right:35px}\n"], dependencies: [{ kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i4.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: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i4.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }] });
180
+ }
181
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: SearchBoxComponent, decorators: [{
182
+ type: Component,
183
+ args: [{ selector: 'lib-search-box', template: "<!-- // VD 12Jun24 - readonly change-->\n<div id=\"autocomplete-input\"> <!-- SKS5NOV25 search icon -->\n <input #auto id=\"searchbox-style\"\n (blur)=\"clearList()\"\n [(ngModel)]=\"filterName\"\n type=\"text\"\n name=\"name\"\n [readOnly]=\"readOnly\"\n [placeholder]=\"placeHolderText\"\n style=\"margin: 0 !important; padding-right: 30px;\"\n class=\"searchInput she-line-input form-control\"\n (focusin)=\"getSourceDataLocal($event)\"\n (input)=\"getSourceDataLocal($event)\">\n <div id=\"selectList\" style=\"position: absolute;position: absolute;background: white;z-index: 2;\">\n <div *ngIf=\"finalResults.length > 0 && showSuggestion\"\n style=\"max-height: 20vh;border: 1px solid #d2d4d6;overflow: scroll; min-width:100px\"\n class=\"suggestions-container\">\n <!-- HA 20DEC23 Uncommented the logic -->\n <!-- VD 03May- search changes -->\n <div *ngFor=\"let item of finalResults\" (click)='clickItem(item)' class=\"hoover\">\n <!-- VD 26Jun24 - id condition removed -->\n <div class=\"grid-x align-middle\" style=\"\">\n <div *ngIf=\"item.thumbnail\" class=\"cell shrink\" style=\"width: 60px; margin-right: 1.6rem;\">\n <img [src]=\"item.thumbnail\" style=\"width: 60px;\" alt=\"\">\n </div>\n <div class=\"cell auto\" style=\"text-align: left; padding:5px 8px 0 8px; display: flex; gap: 5px; \">\n <!--// VD 26JUN24 - pipe changes -->\n <!-- RS 29JAN25 -->\n <div style=\"display: flex;\" *ngFor=\"let key of getKeys(getValues(item, SearchItem))\">\n <div>\n {{ getValues(item, SearchItem)[key] }}\n </div>\n </div> \n </div>\n </div>\n </div>\n <!-- HA 20DEC23 For Commented this for future purpose -->\n <!-- <table class=\"table table-striped table-bordered\">\n <thead>\n <tr>\n <th>{{ 'firstName' | i18n:i18nService.currentLanguage }}</th>\n <th>{{ 'lastName' | i18n:i18nService.currentLanguage }}</th>\n <th>{{ 'division' | i18n:i18nService.currentLanguage }}</th>\n <th>{{ 'numberPlate' | i18n:i18nService.currentLanguage }}</th>\n </tr>\n </thead>\n <tbody>\n <tr *ngFor=\"let item of finalResults\" (click)='clickItem(item)'>\n <td>{{ item.firstName }}</td>\n <td>{{ item.lastName }}</td>\n <td>{{ item.division }}</td>\n <td>{{ item.numberPlate }}</td>\n </tr>\n </tbody>\n </table> -->\n </div>\n</div>\n\n", styles: ["#searchbox-style{background-image:url('data:image/svg+xml;utf8,<svg width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><circle cx=\"11\" cy=\"11\" r=\"7\" stroke=\"%23434555\" stroke-opacity=\"0.65\" stroke-width=\"2\"/><path d=\"M20 20L17 17\" stroke=\"%23434555\" stroke-opacity=\"0.65\" stroke-width=\"2\" stroke-linecap=\"round\"/></svg>');background-position:right 5px center;background-repeat:no-repeat;background-size:24px;padding-right:35px}\n"] }]
184
+ }], ctorParameters: () => [{ type: i1.DataService }, { type: i2.I18nService }], propDecorators: { placeHolderText: [{
185
+ type: Input
186
+ }], auto: [{
187
+ type: ViewChild,
188
+ args: ['auto']
189
+ }], question: [{
190
+ type: Input
191
+ }], apiMeta: [{
192
+ type: Input
193
+ }], id: [{
194
+ type: Input
195
+ }], readOnly: [{
196
+ type: Input
197
+ }], searchValueChange: [{
198
+ type: Output
199
+ }], filterName: [{
200
+ type: Input
201
+ }] } });
202
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"search-box.component.js","sourceRoot":"","sources":["../../../../../../projects/nxt-app/src/lib/components/search-box/search-box.component.ts","../../../../../../projects/nxt-app/src/lib/components/search-box/search-box.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  OnInit,\n  Input,\n  Output,\n  EventEmitter,\n  ElementRef,\n  ViewChild,\n  SimpleChanges,\n} from \"@angular/core\";\nimport { DataService } from '../../services/data.service';\nimport { SalesforceService } from \"../../services/salesforce.service\";\nimport { ActivatedRoute, Params } from \"@angular/router\";\n// VD 23JAN24 removed httpClient import used service file for callout\nimport { APIMeta } from \"../../interfaces/apimeta\";\nimport { ChangeWrapper } from \"../../model/changeWrapper\";\n// HA 19DEC23 imported translation service\nimport { I18nService } from \"../../i18n.service\";\nimport { ChangeDetectorRef } from '@angular/core';\n\n@Component({\n  selector: 'lib-search-box',\n  templateUrl: './search-box.component.html',\n  styleUrls: ['./search-box.component.css']\n})\nexport class SearchBoxComponent implements OnInit {\n  @Input() placeHolderText: string;\n  @ViewChild('auto') auto;\n\n  @Input() question;\n  @Input() apiMeta: string;\n  @Input() id: string;\n  @Input() readOnly = false; // VD 12Jun24 - readonly change\n  @Output() searchValueChange: EventEmitter<ChangeWrapper> = new EventEmitter<ChangeWrapper>();\n   apiObj:any;\n   SearchItem: any;\n\n  @Input() filterName: string; // VD 20Aug default filter value as input\n  public finalResults: any[] = [];\n  public searchKeyWord: string = '';\n  public newResult: any;\n  public showResult = false;\n  public noResult = false;\n  public showSuggestion = true;\n  private el: HTMLElement;\n  private serv: string = 'api';\n  private tkn: string = '';\n  \n  constructor( private dataService: DataService, public i18nService: I18nService) { }\n  ngOnInit(): void {\n    //  VD 03May- search changes\n    if(this.apiMeta){\n      let apiObj: APIMeta = JSON.parse(this.apiMeta);\n      this.SearchItem = apiObj.field;\n    }\n  }\n////RS 03FEB2025\n// Resets state when filterName or apiMeta changes to reflect updated data\nngOnChanges(changes: SimpleChanges): void {\n  if (changes['apiMeta'] && this.apiMeta) {\n    this.apiObj = JSON.parse(this.apiMeta);\n    this.SearchItem = this.apiObj?.field;\n  }\n}\n//RS 03FEB2025\n// Clears search-related data, including results, search term, and suggestions.\nprivate resetComponentState(): void {\n  this.finalResults = [];\n  this.filterName = ''; \n  this.searchKeyWord = '';  \n  this.showSuggestion = false;\n  this.noResult = false;\n}\nclearList(){\n  setTimeout(()=> {\n    this.finalResults = [];\n  }, 1000);\n}\n\ngetSourceDataLocal(event: any) { //to get results list from backend API whenever key is up after the entering atleast one key\n  event.preventDefault();\n  if(event.target.value.length > 2){\n    this.showSuggestion=true;\n    this.finalResults=[];\n    this.searchKeyWord = event.target.value;\n    this.showResult = false;\n    this.getSourceData(event.target.value);\n  } else {\n    this.showSuggestion=false;\n    this.finalResults = [];\n    this.noResult = false;\n  }\n}\n// VD 03May- search changes\n// VD 31NOV24 null check\n// RS 29JAN25\n//Multi-word search across all object values\npublic getSourceData = (keyword: string) => {\n  if (this.apiMeta) {\n    let apiObj: APIMeta = JSON.parse(this.apiMeta);\n    \n    this.dataService.apiResponse(apiObj.endpoint).subscribe((apiResponse) => {\n      let response;\n      if (apiObj.variable) {\n        response = this.dataService.getValue(apiResponse, apiObj.variable);\n      } else {\n        response = apiResponse;\n      }      \n      let results = [];\n      let searchTerms = keyword.toLowerCase()?.split(\" \");\n      for (let i = 0; i < response.length; i++) {\n        let obj = response[i];\n        let combinedValues = this.getCombinedValuesFromColumns(obj, apiObj.field);\n        let match = searchTerms.every(term => combinedValues.includes(term));\n        if (match) {\n          results.push(obj);\n        }\n      }\n      this.noResult = results.length === 0;\n      this.finalResults = results;\n    });\n  }\n};\n// SKS27FEB Helper functions\nprivate getNestedValue(obj: any, path: string): string {\n  //SKS27FEB Convert array indexes to dot notation (e.g., [0] -> .0)\n  const processedPath = path.replace(/\\[(\\d+)\\]/g, '.$1');\n  const parts = processedPath.split('.');\n  let current = obj;\n  \n  for (const part of parts) {\n    if (!current || typeof current !== 'object') return '';\n    current = current[part];\n  }\n  \n  return current !== null && current !== undefined \n    ? String(current).toLowerCase().trim() \n    : '';\n}\n\nprivate getCombinedValuesFromColumns(obj: any, columns: string[]): string {\n  const values: string[] = [];\n  // SKS28FEB check if columns is an array\n  if(typeof columns === 'string' && !Array.isArray(columns)  ) {\n    columns = [columns];\n  }\n  \n  for (const column of columns) {\n    const value = this.getNestedValue(obj, column);\n    if (value) {\n      values.push(value);\n    }\n  }\n  \n  return values.join(' ');\n}\n// SKS27FEB get value from data specific column\npublic getValues(element: any, columns: any): any {\n  const result: any = {};\n  // SKS28FEB check if columns is an array\n  if(typeof columns === 'string' && !Array.isArray(columns)  ) {\n    columns = [columns];\n  }\n  columns.forEach((column) => {\n    let tempElement = element;\n    let flds = column?.split('.');\n    for (let i = 0; i < flds.length; i++) {\n      let splitFlds = flds[i]?.split('[');\n      if (splitFlds.length === 1) {\n        tempElement = tempElement[flds[i]] || '';\n      } else {\n        let index = Number(splitFlds[1]?.split(']')[0]);\n        tempElement = tempElement[splitFlds[0]]?.[index] || '';\n      }\n    }\n    result[column] = tempElement;\n  });\n\n  return result;\n}\n// SKS27FEB column value get funtion\ngetKeys(obj: any): string[] {\n  return Object.keys(obj);\n}\n  public clickItem(event) {\n    // console.log('inside clickItem of ' + JSON.stringify(event, null, 2));\n    let apiObj: APIMeta = JSON.parse(this.apiMeta);\n    this.filterName = event[apiObj.defaultField || apiObj.field[0] || apiObj.field]; //SKS27FEB defaultField is used for showing a search field input if field have array of data\n    let change = new ChangeWrapper(); // ChangeWrapper = JSON.parse('{}');\n    change.fromQuestionId = this.id;\n    change.valueObj = event;\n    change.field = apiObj.field;\n    this.searchValueChange.emit(change);\n  }\n  //RS 03FEB2025\n  // Resets component state when the component is destroyed\n  ngOnDestroy(): void { this.resetComponentState();  }\n}\n    ","<!-- // VD 12Jun24 - readonly change-->\n<div id=\"autocomplete-input\"> <!-- SKS5NOV25 search icon -->\n  <input #auto id=\"searchbox-style\"\n          (blur)=\"clearList()\"\n          [(ngModel)]=\"filterName\"\n          type=\"text\"\n          name=\"name\"\n          [readOnly]=\"readOnly\"\n          [placeholder]=\"placeHolderText\"\n          style=\"margin: 0 !important; padding-right: 30px;\"\n          class=\"searchInput she-line-input form-control\"\n          (focusin)=\"getSourceDataLocal($event)\"\n          (input)=\"getSourceDataLocal($event)\">\n  <div id=\"selectList\" style=\"position: absolute;position: absolute;background: white;z-index: 2;\">\n  <div *ngIf=\"finalResults.length > 0 && showSuggestion\"\n    style=\"max-height: 20vh;border: 1px solid #d2d4d6;overflow: scroll; min-width:100px\"\n       class=\"suggestions-container\">\n      <!-- HA 20DEC23 Uncommented the logic -->\n       <!-- VD 03May- search changes -->\n      <div *ngFor=\"let item of finalResults\" (click)='clickItem(item)' class=\"hoover\">\n        <!-- VD 26Jun24 - id condition removed -->\n          <div class=\"grid-x align-middle\" style=\"\">\n              <div *ngIf=\"item.thumbnail\" class=\"cell shrink\" style=\"width: 60px; margin-right: 1.6rem;\">\n                  <img [src]=\"item.thumbnail\" style=\"width: 60px;\" alt=\"\">\n              </div>\n              <div class=\"cell auto\" style=\"text-align: left; padding:5px 8px 0 8px; display: flex; gap: 5px; \">\n                <!--// VD 26JUN24 - pipe changes -->\n                <!-- RS 29JAN25 -->\n                <div style=\"display: flex;\" *ngFor=\"let key of getKeys(getValues(item, SearchItem))\">\n                  <div>\n                    {{ getValues(item, SearchItem)[key] }}\n                  </div>\n                </div>                \n              </div>\n          </div>\n      </div>\n      <!-- HA 20DEC23 For Commented this for future purpose -->\n      <!-- <table class=\"table table-striped table-bordered\">\n          <thead>\n            <tr>\n              <th>{{ 'firstName' | i18n:i18nService.currentLanguage }}</th>\n              <th>{{ 'lastName' | i18n:i18nService.currentLanguage }}</th>\n              <th>{{ 'division' | i18n:i18nService.currentLanguage }}</th>\n              <th>{{ 'numberPlate' | i18n:i18nService.currentLanguage }}</th>\n            </tr>\n          </thead>\n          <tbody>\n            <tr *ngFor=\"let item of finalResults\" (click)='clickItem(item)'>\n              <td>{{ item.firstName }}</td>\n              <td>{{ item.lastName }}</td>\n              <td>{{ item.division }}</td>\n              <td>{{ item.numberPlate }}</td>\n            </tr>\n          </tbody>\n        </table> -->\n  </div>\n</div>\n\n"]}
@@ -0,0 +1,123 @@
1
+ import { Component, EventEmitter, Input, Output } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ import * as i1 from "../../i18n.service";
4
+ import * as i2 from "@angular/common";
5
+ import * as i3 from "@angular/forms";
6
+ import * as i4 from "../custom-dropdown/custom-dropdown.component";
7
+ import * as i5 from "../file-upload/file-upload.component";
8
+ import * as i6 from "../../i18n.pipe";
9
+ export class TableAppendixComponent {
10
+ i18nService;
11
+ question;
12
+ valueChange = new EventEmitter();
13
+ tableInfo;
14
+ tableHeader;
15
+ tableData;
16
+ addRowColSpan;
17
+ tableAppendix;
18
+ dropDownApi;
19
+ dropDownData;
20
+ constructor(i18nService) {
21
+ this.i18nService = i18nService;
22
+ }
23
+ // RS 09DEC24 Changed keys
24
+ ngOnInit() {
25
+ if (this.question.subText != undefined) {
26
+ this.tableInfo = JSON.parse(this.question.subText);
27
+ this.tableHeader = this.tableInfo.header;
28
+ this.tableData = this.tableInfo.data;
29
+ this.tableAppendix = this.tableInfo.tableAppendix;
30
+ this.dropDownApi = JSON.stringify(this.tableInfo['dropdownApi']);
31
+ this.dropDownData = this.tableInfo['dropdownData'];
32
+ const combinedData = {
33
+ tableData: this.tableData,
34
+ tableAppendix: null
35
+ };
36
+ if (this.tableAppendix) {
37
+ combinedData.tableAppendix = this.tableAppendix;
38
+ }
39
+ this.valueChange.emit(combinedData);
40
+ if (this.tableData?.addRow) {
41
+ this.addRowColSpan = this.tableHeader.length - 2;
42
+ }
43
+ }
44
+ }
45
+ addRow() {
46
+ let newItem = JSON.parse(JSON.stringify(this.tableInfo.newRowDefault));
47
+ const updatedTableData = [...this.tableData, newItem];
48
+ this.tableData = updatedTableData;
49
+ this.emitTableDataValue(updatedTableData, this.tableAppendix);
50
+ }
51
+ updateLabel(rowIndex, label, value) {
52
+ this.tableData[rowIndex][label] = value;
53
+ this.tableData[rowIndex].name = value.replace(/\s+/g, '').toLowerCase();
54
+ this.emitTableDataValue(this.tableData, this.tableAppendix);
55
+ }
56
+ updateNumber(item, label, value) {
57
+ item.value[label] = value;
58
+ this.emitTableDataValue(this.tableData, this.tableAppendix);
59
+ }
60
+ updateToggle(item, header, value) {
61
+ let label = header['fieldName'];
62
+ let toggleValue = header['toggleValue'];
63
+ if (label == 'test1') {
64
+ item.value[label][1] = value ? toggleValue[0] : toggleValue[1];
65
+ }
66
+ else {
67
+ item.value[label] = value ? toggleValue[0] : toggleValue[1];
68
+ }
69
+ this.emitTableDataValue(this.tableData, this.tableAppendix);
70
+ }
71
+ updateDropDown(item, label, value) {
72
+ item.value[label] = value.valueObj['value'];
73
+ this.emitTableDataValue(this.tableData, this.tableAppendix);
74
+ }
75
+ updateCheckText(item, label, value) {
76
+ item.value[label][0] = value;
77
+ this.emitTableDataValue(this.tableData, this.tableAppendix);
78
+ }
79
+ updateTableAppendix(item, label, value) {
80
+ let toggleValue = item.value[0].toggleValue;
81
+ if (item.key == 'dropDownData') {
82
+ item.value[0].value[label] = value.valueObj['empIdName'];
83
+ }
84
+ else if (item.key == 'toggleData') {
85
+ item.value[0].value[label] = value ? toggleValue[0] : toggleValue[1];
86
+ }
87
+ else {
88
+ item.value[0].value[label] = value;
89
+ }
90
+ this.emitTableDataValue(this.tableData, this.tableAppendix);
91
+ }
92
+ emitTableDataValue(updatedTableData, tableAppendix) {
93
+ const combinedData = {
94
+ tableData: updatedTableData,
95
+ tableAppendix: null
96
+ };
97
+ if (tableAppendix) {
98
+ combinedData.tableAppendix = this.tableAppendix;
99
+ }
100
+ this.valueChange.emit(combinedData);
101
+ }
102
+ //This function finds the index of the current test in the list of test keys and returns the key of the previous test.
103
+ // If the current test is the first one, it returns null, as there is no previous test
104
+ getPreviousTestKey(item, currentTest) {
105
+ const testKeys = Object.keys(item.value);
106
+ const currentIndex = testKeys.indexOf(currentTest);
107
+ if (currentIndex > 0) {
108
+ return testKeys[currentIndex - 1];
109
+ }
110
+ return null;
111
+ }
112
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: TableAppendixComponent, deps: [{ token: i1.I18nService }], target: i0.ɵɵFactoryTarget.Component });
113
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: TableAppendixComponent, selector: "app-table-appendix", inputs: { question: "question" }, outputs: { valueChange: "valueChange" }, ngImport: i0, template: "<table class=\"table table-striped table-bordered\">\n <thead class=\"none-border\" *ngIf=\"tableInfo.tableType === 'lockout' && tableInfo.tableHeader\">\n <th></th>\n <th>{{ tableInfo.tableHeader }}</th>\n <th></th>\n </thead>\n <thead>\n <th *ngFor=\"let header of tableHeader; let hi = index\" [class]=\"'col-md-' + header.size\">\n {{ header.label }}\n </th>\n </thead>\n <tbody id=\"safetyMeasuresTableBody\">\n <tr *ngFor=\"let item of tableData; let i = index\">\n <td *ngFor=\"let header of tableHeader; let j = index\">\n <div *ngIf=\"header.type === 'text'\">\n <input type=\"text\" [(ngModel)]=\"item[header.fieldName]\" [placeholder]=\"header.placeholder\" (ngModelChange)=\"tableInfo.tableType != 'lockout' ? updateLabel(i, header.fieldName, item[header.fieldName]) : updateNumber(item, header.fieldName, item[header.fieldName])\" class=\"she-line-input table-input\">\n </div>\n <div *ngIf=\"header.type.includes('number')\">\n <!-- HA 19DEC23 For translation -->\n <input type=\"number\" [(ngModel)]=\"item.value[header.fieldName]\" [disabled]=\"item.value[getPreviousTestKey(item, header.fieldName)] === null && tableInfo.tableType != 'lockout'\" (ngModelChange)=\"updateNumber(item, header.fieldName, item.value[header.fieldName])\" placeholder=\"{{ 'enterValue' | i18n:i18nService.currentLanguage }}\" class=\"she-line-input table-input\">\n </div>\n <div *ngIf=\"header.type === 'dropdown'\">\n <app-custom-dropdown [fromShengel]=\"true\" [options]=\"dropDownData\" \n [selectedValue]=\"item.value[header.fieldName]\" [placeholder]=\"header.placeholder\"\n (valueChange)=\"updateDropDown(item,header.fieldName,$event)\">\n </app-custom-dropdown>\n </div>\n <div *ngIf=\"header.type === 'textcheckbox'\">\n <div style=\"display: flex; justify-content: center;align-items: center;\">\n <input type=\"text\" [(ngModel)]=\"item.value[header.fieldName][0]\" (ngModelChange)=\"updateCheckText(item, header.fieldName, item.value[header.fieldName][0])\" style=\"width: 85px; height: 27px; text-align: center; padding: 5px; border-bottom: none; border-top: 1px solid transparent; border-right: 1px solid transparent; border-left: 1px solid transparent; background: transparent;outline: none;\">\n <label class=\"switch2\">\n <input class=\"switch-input2\" (change)=\"updateToggle(item,header,$event.target.checked)\" \n type=\"checkbox\"\n [checked]=\"item.value[header.fieldName][1] == header.toggleValue[0]\"/>\n <span class=\"switch-label2\" data-on=\"Psi\" data-off=\"Bar\"></span> \n <span class=\"switch-handle2\"></span> \n </label> \n </div>\n </div>\n <div *ngIf=\"header.type === 'labelcheckbox'\">\n <div style=\"display: flex; justify-content: center;align-items: center;\">\n <!-- HA 19DEC23 For translation -->\n <span style=\"text-align:left;\">{{ 'calibrated' | i18n:i18nService.currentLanguage }}</span>\n <label class=\"switch2\">\n <input class=\"switch-input2\" (change)=\"updateToggle(item,header,$event.target.checked)\" \n type=\"checkbox\"\n [checked]=\"item.value[header.fieldName] == header.toggleValue[0]\"/>\n <span class=\"switch-label3\" data-on=\"Yes\" data-off=\"No\"></span> \n <span class=\"switch-handle2\"></span> \n </label> \n </div>\n </div>\n </td>\n </tr>\n <tr *ngIf=\"tableInfo.addRow && tableInfo.tableType === 'lockout'\">\n <td colspan=\"1\">\n <!-- HA 19DEC23 For translation -->\n <b style=\"text-align: center; cursor: pointer;\" id=\"addSafety\" (click)=\"addRow()\">{{ 'addMore' | i18n:i18nService.currentLanguage }} +</b>\n </td>\n </tr>\n <tr *ngIf=\"tableInfo.addRow && tableInfo.tableType != 'lockout'\">\n <td colspan=\"3\">\n <!-- HA 19DEC23 For translation -->\n <b>{{ 'addMore' | i18n:i18nService.currentLanguage }}</b>\n </td>\n <td colspan=\"2\" style=\"text-align: center; cursor: pointer;\" id=\"addSafety\" (click)=\"addRow()\">\n +\n </td>\n </tr>\n <tr *ngFor=\"let item of tableAppendix | keyvalue; let k = index\">\n <td *ngFor=\"let header of tableHeader; let l = index\">\n <div *ngIf=\"header.type === 'text'\" >\n <input type=\"text\" [(ngModel)]=\"item.value[0][header.fieldName]\" (ngModelChange)=\"updateLabel(k, header.fieldName, item[header.fieldName])\" class=\"she-line-input table-input\">\n </div>\n <div *ngIf=\"header.type.includes('dropdown') && item.key == 'dropDownData'\" >\n <!-- HA 19DEC23 For translation -->\n <app-custom-dropdown [fromShengel]=\"true\" [apiMeta]=\"dropDownApi\" \n [selectedValue]=\"item.value[0].value[header.fieldName]\" placeholder=\"---{{'select' | i18n:i18nService.currentLanguage}}---\"\n (valueChange)=\"updateTableAppendix(item,header.fieldName,$event)\">\n </app-custom-dropdown>\n </div>\n <div *ngIf=\"header.type.includes('datetime') && item.key == 'dateData'\">\n <input [(ngModel)]=\"item.value[0].value[header.fieldName]\" type=\"datetime-local\"\n (ngModelChange)=\"updateTableAppendix(item,header.fieldName,$event)\"\n placeholder=\"DD/MM/YYYY HH:MM\">\n </div>\n <div *ngIf=\"header.type.includes('checkbox') && item.key == 'toggleData'\">\n <label class=\"switch2\">\n <input class=\"switch-input2\" (change)=\"updateTableAppendix(item,header.fieldName,$event.target.checked)\" \n type=\"checkbox\"\n [checked]=\"item.value[0].value[header.fieldName] == item.value[0].toggleValue[0]\"/>\n <span class=\"switch-label3\" data-on=\"Safe\" data-off=\"Unsafe\"></span> \n <span class=\"switch-handle2\"></span> \n </label> \n </div>\n <div *ngIf=\"header.type.includes('file') && item.key == 'fileData'\">\n <app-file-upload [limitFileUploading]=\"2\" [allFiles]=\"item.value[0].value[header.fieldName]\" [tableFile]=\"true\"\n (selectedFileData)=\"updateTableAppendix(item ,header.fieldName, $event)\"\n [isDeleteFileButtonVisible]=\"true\"></app-file-upload>\n </div>\n </td>\n </tr>\n </tbody>\n </table>", styles: [".table{width:100%;max-width:100%;margin-bottom:20px;border-collapse:collapse;border-spacing:0}.table-bordered{border:1px solid #ddd}thead{background-color:#03a9f4}thead th{color:#fff;font-size:14px}.table-bordered>tbody>tr>td,.table-bordered>tbody>tr>th,.table-bordered>tfoot>tr>td,.table-bordered>tfoot>tr>th,.table-bordered>thead>tr>td,.table-bordered>thead>tr>th{border:1px solid #ddd}th{text-align:left}thead .permission{text-align:center}.table>tbody>tr>td,.table>tbody>tr>th,.table>tfoot>tr>td,.table>tfoot>tr>th,.table>thead>tr>td,.table>thead>tr>th{padding:8px;line-height:1.42857143;vertical-align:top;border-top:1px solid #ddd}tbody{color:#797979}.table-striped>tbody>tr:nth-of-type(odd){background-color:#f9f9f9}tbody td{font-size:13px}.permission_yes,.permission_no,.permission_na{text-align:center}.none-border th{border:none}.switch2{position:relative;width:73px;height:23.5px;margin-left:5px;margin-top:3px;background:linear-gradient(to bottom,#eee,#fff 25px);background-image:-webkit-linear-gradient(top,#eeeeee,#FFFFFF 25px);border-radius:5px;box-shadow:inset 0 -1px #fff,inset 0 1px 1px #0000000d;cursor:pointer}.switch-input2{position:absolute;top:0;left:0;opacity:0}.switch-label2{position:relative;display:block;height:inherit;font-size:12px;background:#afacac80;color:#000;border-radius:inherit;box-shadow:inset 0 1px 2px #0000001f,inset 0 0 2px #00000026}.switch-label3{position:relative;display:block;height:inherit;font-size:12px;background:red;color:#fff;border-radius:inherit;box-shadow:inset 0 1px 2px #0000001f,inset 0 0 2px #00000026}.switch-label2:before,.switch-label2:after{position:absolute;top:50%;margin-top:-.5em;line-height:1;-webkit-transition:inherit;-moz-transition:inherit;-o-transition:inherit;transition:inherit}.switch-label3:before,.switch-label2:after{position:absolute;top:50%;margin-top:-.5em;line-height:1;-webkit-transition:inherit;-moz-transition:inherit;-o-transition:inherit;transition:inherit}.switch-label2:before{content:attr(data-off);right:11px;text-shadow:0 1px rgba(255,255,255,.5)}.switch-label3:before{content:attr(data-off);right:11px;text-shadow:0 1px rgba(255,255,255,.5)}.switch-label2:after{content:attr(data-on);left:11px;color:#fff;text-shadow:0 1px rgba(0,0,0,.2);opacity:0}.switch-label3:after{content:attr(data-on);left:11px;margin-left:10px;vertical-align:sub;color:#fff;text-shadow:0 1px rgba(0,0,0,.2);opacity:0}.switch-input2:checked~.switch-label2{background:#03a9f4;border-color:#03a9f4;box-shadow:inset 0 1px 2px #00000026,inset 0 0 3px #0003}.switch-input2:checked~.switch-label3{background:#02ad02;border-color:#02ad02;box-shadow:inset 0 1px 2px #00000026,inset 0 0 3px #0003}.switch-input2:checked~.switch-label2:before{opacity:0}.switch-input2:checked~.switch-label3:before{opacity:0}.switch-input2:checked~.switch-label2:after{opacity:1;margin-right:15px}.switch-input2:checked~.switch-label3:after{opacity:1;margin-right:15px}.switch-handle2{position:absolute;top:2px;left:2px;width:18px;height:18px;background:linear-gradient(to bottom,#fff 40%,#f0f0f0);background-image:-webkit-linear-gradient(top,#FFFFFF 40%,#f0f0f0);border-radius:20%;box-shadow:1px 1px 5px #0003}.switch-handle2:before{content:\"\";position:absolute;top:50%;left:50%;margin:-6px 0 0 -6px;width:12px;height:12px;background:linear-gradient(to bottom,#eee,#fff);background-image:-webkit-linear-gradient(top,#eeeeee,#FFFFFF);border-radius:6px;box-shadow:inset 0 1px #00000005}.switch-input2:checked~.switch-handle2{left:51px;box-shadow:-1px 1px 5px #0003}.switch-label2,.switch-handle2,.switch-label3{transition:All .3s ease;-webkit-transition:All .3s ease;-moz-transition:All .3s ease;-o-transition:All .3s ease}\n"], dependencies: [{ kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.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: i3.NumberValueAccessor, selector: "input[type=number][formControlName],input[type=number][formControl],input[type=number][ngModel]" }, { kind: "directive", type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i4.CustomDropdownComponent, selector: "app-custom-dropdown", inputs: ["options", "placeholder", "apiMeta", "selectedValue", "progressBar", "id", "readOnly", "errorMessage", "error", "fromShengel", "question", "referenceField", "token"], outputs: ["valueChange"] }, { kind: "component", type: i5.FileUploadComponent, selector: "app-file-upload", inputs: ["allFiles", "limitFileUploading", "isDeleteFileButtonVisible", "isShowNoFileIcon", "tableFile", "question", "error"], outputs: ["selectedFileData", "deletedFileData"] }, { kind: "pipe", type: i2.KeyValuePipe, name: "keyvalue" }, { kind: "pipe", type: i6.I18nPipe, name: "i18n" }] });
114
+ }
115
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: TableAppendixComponent, decorators: [{
116
+ type: Component,
117
+ args: [{ selector: 'app-table-appendix', template: "<table class=\"table table-striped table-bordered\">\n <thead class=\"none-border\" *ngIf=\"tableInfo.tableType === 'lockout' && tableInfo.tableHeader\">\n <th></th>\n <th>{{ tableInfo.tableHeader }}</th>\n <th></th>\n </thead>\n <thead>\n <th *ngFor=\"let header of tableHeader; let hi = index\" [class]=\"'col-md-' + header.size\">\n {{ header.label }}\n </th>\n </thead>\n <tbody id=\"safetyMeasuresTableBody\">\n <tr *ngFor=\"let item of tableData; let i = index\">\n <td *ngFor=\"let header of tableHeader; let j = index\">\n <div *ngIf=\"header.type === 'text'\">\n <input type=\"text\" [(ngModel)]=\"item[header.fieldName]\" [placeholder]=\"header.placeholder\" (ngModelChange)=\"tableInfo.tableType != 'lockout' ? updateLabel(i, header.fieldName, item[header.fieldName]) : updateNumber(item, header.fieldName, item[header.fieldName])\" class=\"she-line-input table-input\">\n </div>\n <div *ngIf=\"header.type.includes('number')\">\n <!-- HA 19DEC23 For translation -->\n <input type=\"number\" [(ngModel)]=\"item.value[header.fieldName]\" [disabled]=\"item.value[getPreviousTestKey(item, header.fieldName)] === null && tableInfo.tableType != 'lockout'\" (ngModelChange)=\"updateNumber(item, header.fieldName, item.value[header.fieldName])\" placeholder=\"{{ 'enterValue' | i18n:i18nService.currentLanguage }}\" class=\"she-line-input table-input\">\n </div>\n <div *ngIf=\"header.type === 'dropdown'\">\n <app-custom-dropdown [fromShengel]=\"true\" [options]=\"dropDownData\" \n [selectedValue]=\"item.value[header.fieldName]\" [placeholder]=\"header.placeholder\"\n (valueChange)=\"updateDropDown(item,header.fieldName,$event)\">\n </app-custom-dropdown>\n </div>\n <div *ngIf=\"header.type === 'textcheckbox'\">\n <div style=\"display: flex; justify-content: center;align-items: center;\">\n <input type=\"text\" [(ngModel)]=\"item.value[header.fieldName][0]\" (ngModelChange)=\"updateCheckText(item, header.fieldName, item.value[header.fieldName][0])\" style=\"width: 85px; height: 27px; text-align: center; padding: 5px; border-bottom: none; border-top: 1px solid transparent; border-right: 1px solid transparent; border-left: 1px solid transparent; background: transparent;outline: none;\">\n <label class=\"switch2\">\n <input class=\"switch-input2\" (change)=\"updateToggle(item,header,$event.target.checked)\" \n type=\"checkbox\"\n [checked]=\"item.value[header.fieldName][1] == header.toggleValue[0]\"/>\n <span class=\"switch-label2\" data-on=\"Psi\" data-off=\"Bar\"></span> \n <span class=\"switch-handle2\"></span> \n </label> \n </div>\n </div>\n <div *ngIf=\"header.type === 'labelcheckbox'\">\n <div style=\"display: flex; justify-content: center;align-items: center;\">\n <!-- HA 19DEC23 For translation -->\n <span style=\"text-align:left;\">{{ 'calibrated' | i18n:i18nService.currentLanguage }}</span>\n <label class=\"switch2\">\n <input class=\"switch-input2\" (change)=\"updateToggle(item,header,$event.target.checked)\" \n type=\"checkbox\"\n [checked]=\"item.value[header.fieldName] == header.toggleValue[0]\"/>\n <span class=\"switch-label3\" data-on=\"Yes\" data-off=\"No\"></span> \n <span class=\"switch-handle2\"></span> \n </label> \n </div>\n </div>\n </td>\n </tr>\n <tr *ngIf=\"tableInfo.addRow && tableInfo.tableType === 'lockout'\">\n <td colspan=\"1\">\n <!-- HA 19DEC23 For translation -->\n <b style=\"text-align: center; cursor: pointer;\" id=\"addSafety\" (click)=\"addRow()\">{{ 'addMore' | i18n:i18nService.currentLanguage }} +</b>\n </td>\n </tr>\n <tr *ngIf=\"tableInfo.addRow && tableInfo.tableType != 'lockout'\">\n <td colspan=\"3\">\n <!-- HA 19DEC23 For translation -->\n <b>{{ 'addMore' | i18n:i18nService.currentLanguage }}</b>\n </td>\n <td colspan=\"2\" style=\"text-align: center; cursor: pointer;\" id=\"addSafety\" (click)=\"addRow()\">\n +\n </td>\n </tr>\n <tr *ngFor=\"let item of tableAppendix | keyvalue; let k = index\">\n <td *ngFor=\"let header of tableHeader; let l = index\">\n <div *ngIf=\"header.type === 'text'\" >\n <input type=\"text\" [(ngModel)]=\"item.value[0][header.fieldName]\" (ngModelChange)=\"updateLabel(k, header.fieldName, item[header.fieldName])\" class=\"she-line-input table-input\">\n </div>\n <div *ngIf=\"header.type.includes('dropdown') && item.key == 'dropDownData'\" >\n <!-- HA 19DEC23 For translation -->\n <app-custom-dropdown [fromShengel]=\"true\" [apiMeta]=\"dropDownApi\" \n [selectedValue]=\"item.value[0].value[header.fieldName]\" placeholder=\"---{{'select' | i18n:i18nService.currentLanguage}}---\"\n (valueChange)=\"updateTableAppendix(item,header.fieldName,$event)\">\n </app-custom-dropdown>\n </div>\n <div *ngIf=\"header.type.includes('datetime') && item.key == 'dateData'\">\n <input [(ngModel)]=\"item.value[0].value[header.fieldName]\" type=\"datetime-local\"\n (ngModelChange)=\"updateTableAppendix(item,header.fieldName,$event)\"\n placeholder=\"DD/MM/YYYY HH:MM\">\n </div>\n <div *ngIf=\"header.type.includes('checkbox') && item.key == 'toggleData'\">\n <label class=\"switch2\">\n <input class=\"switch-input2\" (change)=\"updateTableAppendix(item,header.fieldName,$event.target.checked)\" \n type=\"checkbox\"\n [checked]=\"item.value[0].value[header.fieldName] == item.value[0].toggleValue[0]\"/>\n <span class=\"switch-label3\" data-on=\"Safe\" data-off=\"Unsafe\"></span> \n <span class=\"switch-handle2\"></span> \n </label> \n </div>\n <div *ngIf=\"header.type.includes('file') && item.key == 'fileData'\">\n <app-file-upload [limitFileUploading]=\"2\" [allFiles]=\"item.value[0].value[header.fieldName]\" [tableFile]=\"true\"\n (selectedFileData)=\"updateTableAppendix(item ,header.fieldName, $event)\"\n [isDeleteFileButtonVisible]=\"true\"></app-file-upload>\n </div>\n </td>\n </tr>\n </tbody>\n </table>", styles: [".table{width:100%;max-width:100%;margin-bottom:20px;border-collapse:collapse;border-spacing:0}.table-bordered{border:1px solid #ddd}thead{background-color:#03a9f4}thead th{color:#fff;font-size:14px}.table-bordered>tbody>tr>td,.table-bordered>tbody>tr>th,.table-bordered>tfoot>tr>td,.table-bordered>tfoot>tr>th,.table-bordered>thead>tr>td,.table-bordered>thead>tr>th{border:1px solid #ddd}th{text-align:left}thead .permission{text-align:center}.table>tbody>tr>td,.table>tbody>tr>th,.table>tfoot>tr>td,.table>tfoot>tr>th,.table>thead>tr>td,.table>thead>tr>th{padding:8px;line-height:1.42857143;vertical-align:top;border-top:1px solid #ddd}tbody{color:#797979}.table-striped>tbody>tr:nth-of-type(odd){background-color:#f9f9f9}tbody td{font-size:13px}.permission_yes,.permission_no,.permission_na{text-align:center}.none-border th{border:none}.switch2{position:relative;width:73px;height:23.5px;margin-left:5px;margin-top:3px;background:linear-gradient(to bottom,#eee,#fff 25px);background-image:-webkit-linear-gradient(top,#eeeeee,#FFFFFF 25px);border-radius:5px;box-shadow:inset 0 -1px #fff,inset 0 1px 1px #0000000d;cursor:pointer}.switch-input2{position:absolute;top:0;left:0;opacity:0}.switch-label2{position:relative;display:block;height:inherit;font-size:12px;background:#afacac80;color:#000;border-radius:inherit;box-shadow:inset 0 1px 2px #0000001f,inset 0 0 2px #00000026}.switch-label3{position:relative;display:block;height:inherit;font-size:12px;background:red;color:#fff;border-radius:inherit;box-shadow:inset 0 1px 2px #0000001f,inset 0 0 2px #00000026}.switch-label2:before,.switch-label2:after{position:absolute;top:50%;margin-top:-.5em;line-height:1;-webkit-transition:inherit;-moz-transition:inherit;-o-transition:inherit;transition:inherit}.switch-label3:before,.switch-label2:after{position:absolute;top:50%;margin-top:-.5em;line-height:1;-webkit-transition:inherit;-moz-transition:inherit;-o-transition:inherit;transition:inherit}.switch-label2:before{content:attr(data-off);right:11px;text-shadow:0 1px rgba(255,255,255,.5)}.switch-label3:before{content:attr(data-off);right:11px;text-shadow:0 1px rgba(255,255,255,.5)}.switch-label2:after{content:attr(data-on);left:11px;color:#fff;text-shadow:0 1px rgba(0,0,0,.2);opacity:0}.switch-label3:after{content:attr(data-on);left:11px;margin-left:10px;vertical-align:sub;color:#fff;text-shadow:0 1px rgba(0,0,0,.2);opacity:0}.switch-input2:checked~.switch-label2{background:#03a9f4;border-color:#03a9f4;box-shadow:inset 0 1px 2px #00000026,inset 0 0 3px #0003}.switch-input2:checked~.switch-label3{background:#02ad02;border-color:#02ad02;box-shadow:inset 0 1px 2px #00000026,inset 0 0 3px #0003}.switch-input2:checked~.switch-label2:before{opacity:0}.switch-input2:checked~.switch-label3:before{opacity:0}.switch-input2:checked~.switch-label2:after{opacity:1;margin-right:15px}.switch-input2:checked~.switch-label3:after{opacity:1;margin-right:15px}.switch-handle2{position:absolute;top:2px;left:2px;width:18px;height:18px;background:linear-gradient(to bottom,#fff 40%,#f0f0f0);background-image:-webkit-linear-gradient(top,#FFFFFF 40%,#f0f0f0);border-radius:20%;box-shadow:1px 1px 5px #0003}.switch-handle2:before{content:\"\";position:absolute;top:50%;left:50%;margin:-6px 0 0 -6px;width:12px;height:12px;background:linear-gradient(to bottom,#eee,#fff);background-image:-webkit-linear-gradient(top,#eeeeee,#FFFFFF);border-radius:6px;box-shadow:inset 0 1px #00000005}.switch-input2:checked~.switch-handle2{left:51px;box-shadow:-1px 1px 5px #0003}.switch-label2,.switch-handle2,.switch-label3{transition:All .3s ease;-webkit-transition:All .3s ease;-moz-transition:All .3s ease;-o-transition:All .3s ease}\n"] }]
118
+ }], ctorParameters: () => [{ type: i1.I18nService }], propDecorators: { question: [{
119
+ type: Input
120
+ }], valueChange: [{
121
+ type: Output
122
+ }] } });
123
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-appendix.component.js","sourceRoot":"","sources":["../../../../../../projects/nxt-app/src/lib/components/table-appendix/table-appendix.component.ts","../../../../../../projects/nxt-app/src/lib/components/table-appendix/table-appendix.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\n// HA 19DEC23 imported translation service\nimport { I18nService } from '../../i18n.service';\nimport { TableWrapper } from '../../model/tableWrapper';\nimport { Question } from '../../wrapper';\n\n@Component({\n  selector: 'app-table-appendix',\n  templateUrl: './table-appendix.component.html',\n  styleUrls: ['./table-appendix.component.css']\n})\nexport class TableAppendixComponent implements OnInit {\n  @Input() question: Question\n  @Output() valueChange: EventEmitter<any> = new EventEmitter<any>();\n\n  tableInfo: TableWrapper;\n  tableHeader: any;\n  tableData: any;\n  addRowColSpan: number;\n  tableAppendix:any;\n  dropDownApi :any;\n  dropDownData:any;\n\n  constructor(public i18nService: I18nService) { }\n  // RS 09DEC24 Changed keys\n  ngOnInit(): void {\n    if(this.question.subText != undefined) {\n      this.tableInfo = JSON.parse(this.question.subText);\n\n      this.tableHeader = this.tableInfo.header;\n      this.tableData = this.tableInfo.data;\n      this.tableAppendix = this.tableInfo.tableAppendix;\n      this.dropDownApi = JSON.stringify(this.tableInfo['dropdownApi']);\n      this.dropDownData = this.tableInfo['dropdownData'];\n      const combinedData = {\n        tableData: this.tableData,\n        tableAppendix: null\n      };\n      if (this.tableAppendix) {\n        combinedData.tableAppendix = this.tableAppendix;\n      }\n      this.valueChange.emit(combinedData);\n\n      if(this.tableData?.addRow) {\n        this.addRowColSpan = this.tableHeader.length - 2;\n      }\n    }\n  }\n\n  addRow(): void {\n    let newItem = JSON.parse(JSON.stringify(this.tableInfo.newRowDefault));\n    const updatedTableData = [...this.tableData, newItem];\n    this.tableData = updatedTableData;\n    this.emitTableDataValue(updatedTableData,this.tableAppendix);\n  }\n\n  updateLabel(rowIndex: number, label: string, value: string): void {\n    this.tableData[rowIndex][label] = value;\n    this.tableData[rowIndex].name = value.replace(/\\s+/g, '').toLowerCase();\n    this.emitTableDataValue(this.tableData,this.tableAppendix);\n  }\n  \n  updateNumber(item: any, label: string, value: string){\n    item.value[label] = value;\n    this.emitTableDataValue(this.tableData,this.tableAppendix);\n  }\n\n  updateToggle(item: any, header: string, value: any){\n    let label = header['fieldName'];\n    let toggleValue = header['toggleValue'];\n    if(label == 'test1'){\n      item.value[label][1] = value ? toggleValue[0] : toggleValue[1];\n    }else{\n      item.value[label] = value ? toggleValue[0] : toggleValue[1];\n    }\n    this.emitTableDataValue(this.tableData,this.tableAppendix);\n  }\n  updateDropDown(item: any, label: string, value: any){\n    item.value[label] = value.valueObj['value'];\n    this.emitTableDataValue(this.tableData,this.tableAppendix);\n  }\n\n  updateCheckText(item: any, label: string, value: any){\n    item.value[label][0] = value;\n    this.emitTableDataValue(this.tableData,this.tableAppendix);\n  }\n\n  updateTableAppendix(item: any, label: string, value: any){\n    let toggleValue = item.value[0].toggleValue;\n    if(item.key == 'dropDownData'){\n      item.value[0].value[label] = value.valueObj['empIdName'];\n    }else if(item.key == 'toggleData'){\n      item.value[0].value[label] = value ? toggleValue[0] : toggleValue[1];\n    }else{\n      item.value[0].value[label] = value;\n    }\n    this.emitTableDataValue(this.tableData,this.tableAppendix);\n  }\n\n  emitTableDataValue(updatedTableData: any[],tableAppendix:any): void {\n    const combinedData = {\n      tableData: updatedTableData,\n      tableAppendix: null\n    };\n    if(tableAppendix){\n      combinedData.tableAppendix = this.tableAppendix;\n    }\n    this.valueChange.emit(combinedData);\n  }\n\n  //This function finds the index of the current test in the list of test keys and returns the key of the previous test. \n  // If the current test is the first one, it returns null, as there is no previous test\n  getPreviousTestKey(item: any, currentTest: string): string {\n    const testKeys = Object.keys(item.value);\n    const currentIndex = testKeys.indexOf(currentTest);\n  \n    if (currentIndex > 0) {\n      return testKeys[currentIndex - 1];\n    }\n\n    return null;\n  }\n\n}\n","<table class=\"table table-striped table-bordered\">\n    <thead class=\"none-border\" *ngIf=\"tableInfo.tableType === 'lockout' && tableInfo.tableHeader\">\n      <th></th>\n      <th>{{ tableInfo.tableHeader }}</th>\n      <th></th>\n    </thead>\n    <thead>\n      <th *ngFor=\"let header of tableHeader; let hi = index\" [class]=\"'col-md-' + header.size\">\n        {{ header.label }}\n      </th>\n    </thead>\n    <tbody id=\"safetyMeasuresTableBody\">\n      <tr *ngFor=\"let item of tableData; let i = index\">\n        <td *ngFor=\"let header of tableHeader; let j = index\">\n          <div *ngIf=\"header.type === 'text'\">\n            <input type=\"text\" [(ngModel)]=\"item[header.fieldName]\" [placeholder]=\"header.placeholder\" (ngModelChange)=\"tableInfo.tableType != 'lockout' ? updateLabel(i, header.fieldName, item[header.fieldName]) : updateNumber(item, header.fieldName, item[header.fieldName])\" class=\"she-line-input table-input\">\n          </div>\n          <div *ngIf=\"header.type.includes('number')\">\n            <!-- HA 19DEC23 For translation -->\n            <input type=\"number\" [(ngModel)]=\"item.value[header.fieldName]\" [disabled]=\"item.value[getPreviousTestKey(item, header.fieldName)] === null && tableInfo.tableType != 'lockout'\" (ngModelChange)=\"updateNumber(item, header.fieldName, item.value[header.fieldName])\" placeholder=\"{{ 'enterValue' | i18n:i18nService.currentLanguage }}\" class=\"she-line-input table-input\">\n          </div>\n          <div *ngIf=\"header.type === 'dropdown'\">\n            <app-custom-dropdown [fromShengel]=\"true\" [options]=\"dropDownData\" \n            [selectedValue]=\"item.value[header.fieldName]\" [placeholder]=\"header.placeholder\"\n            (valueChange)=\"updateDropDown(item,header.fieldName,$event)\">\n            </app-custom-dropdown>\n          </div>\n          <div *ngIf=\"header.type === 'textcheckbox'\">\n            <div style=\"display: flex; justify-content: center;align-items: center;\">\n              <input type=\"text\" [(ngModel)]=\"item.value[header.fieldName][0]\" (ngModelChange)=\"updateCheckText(item, header.fieldName, item.value[header.fieldName][0])\"  style=\"width: 85px; height: 27px; text-align: center; padding: 5px; border-bottom: none; border-top: 1px solid transparent; border-right: 1px solid transparent; border-left: 1px solid transparent; background: transparent;outline: none;\">\n              <label class=\"switch2\">\n                <input  class=\"switch-input2\" (change)=\"updateToggle(item,header,$event.target.checked)\" \n                type=\"checkbox\"\n                [checked]=\"item.value[header.fieldName][1] == header.toggleValue[0]\"/>\n                <span class=\"switch-label2\" data-on=\"Psi\" data-off=\"Bar\"></span> \n                <span class=\"switch-handle2\"></span> \n              </label> \n            </div>\n          </div>\n          <div *ngIf=\"header.type === 'labelcheckbox'\">\n            <div style=\"display: flex; justify-content: center;align-items: center;\">\n              <!-- HA 19DEC23 For translation -->\n              <span style=\"text-align:left;\">{{ 'calibrated' | i18n:i18nService.currentLanguage }}</span>\n              <label class=\"switch2\">\n                <input  class=\"switch-input2\" (change)=\"updateToggle(item,header,$event.target.checked)\" \n                type=\"checkbox\"\n                [checked]=\"item.value[header.fieldName] == header.toggleValue[0]\"/>\n                <span class=\"switch-label3\" data-on=\"Yes\" data-off=\"No\"></span> \n                <span class=\"switch-handle2\"></span> \n              </label> \n            </div>\n          </div>\n        </td>\n      </tr>\n      <tr *ngIf=\"tableInfo.addRow && tableInfo.tableType === 'lockout'\">\n        <td colspan=\"1\">\n          <!-- HA 19DEC23 For translation -->\n          <b style=\"text-align: center; cursor: pointer;\" id=\"addSafety\"  (click)=\"addRow()\">{{ 'addMore' | i18n:i18nService.currentLanguage }} +</b>\n        </td>\n      </tr>\n      <tr *ngIf=\"tableInfo.addRow && tableInfo.tableType != 'lockout'\">\n        <td colspan=\"3\">\n          <!-- HA 19DEC23 For translation -->\n          <b>{{ 'addMore' | i18n:i18nService.currentLanguage }}</b>\n        </td>\n        <td colspan=\"2\" style=\"text-align: center; cursor: pointer;\" id=\"addSafety\"  (click)=\"addRow()\">\n          +\n        </td>\n      </tr>\n      <tr  *ngFor=\"let item of tableAppendix | keyvalue; let k = index\">\n        <td *ngFor=\"let header of tableHeader; let l = index\">\n          <div *ngIf=\"header.type === 'text'\" >\n            <input type=\"text\" [(ngModel)]=\"item.value[0][header.fieldName]\" (ngModelChange)=\"updateLabel(k, header.fieldName, item[header.fieldName])\" class=\"she-line-input table-input\">\n          </div>\n          <div *ngIf=\"header.type.includes('dropdown') && item.key == 'dropDownData'\" >\n            <!-- HA 19DEC23 For translation -->\n            <app-custom-dropdown [fromShengel]=\"true\" [apiMeta]=\"dropDownApi\" \n            [selectedValue]=\"item.value[0].value[header.fieldName]\" placeholder=\"---{{'select' | i18n:i18nService.currentLanguage}}---\"\n            (valueChange)=\"updateTableAppendix(item,header.fieldName,$event)\">\n            </app-custom-dropdown>\n          </div>\n          <div *ngIf=\"header.type.includes('datetime') && item.key == 'dateData'\">\n            <input [(ngModel)]=\"item.value[0].value[header.fieldName]\" type=\"datetime-local\"\n            (ngModelChange)=\"updateTableAppendix(item,header.fieldName,$event)\"\n            placeholder=\"DD/MM/YYYY HH:MM\">\n          </div>\n          <div *ngIf=\"header.type.includes('checkbox') && item.key == 'toggleData'\">\n            <label class=\"switch2\">\n              <input  class=\"switch-input2\" (change)=\"updateTableAppendix(item,header.fieldName,$event.target.checked)\" \n              type=\"checkbox\"\n              [checked]=\"item.value[0].value[header.fieldName] == item.value[0].toggleValue[0]\"/>\n              <span class=\"switch-label3\" data-on=\"Safe\" data-off=\"Unsafe\"></span> \n              <span class=\"switch-handle2\"></span> \n            </label> \n          </div>\n          <div *ngIf=\"header.type.includes('file') && item.key == 'fileData'\">\n            <app-file-upload [limitFileUploading]=\"2\" [allFiles]=\"item.value[0].value[header.fieldName]\" [tableFile]=\"true\"\n            (selectedFileData)=\"updateTableAppendix(item ,header.fieldName, $event)\"\n            [isDeleteFileButtonVisible]=\"true\"></app-file-upload>\n          </div>\n        </td>\n      </tr>\n    </tbody>\n  </table>"]}
@@ -0,0 +1,19 @@
1
+ // VD 06-09-24 directive file to call component dynamically
2
+ import { Directive } from '@angular/core';
3
+ import * as i0 from "@angular/core";
4
+ export class ComponenthostDirective {
5
+ viewContainerRef;
6
+ constructor(viewContainerRef) {
7
+ this.viewContainerRef = viewContainerRef;
8
+ }
9
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ComponenthostDirective, deps: [{ token: i0.ViewContainerRef }], target: i0.ɵɵFactoryTarget.Directive });
10
+ static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.13", type: ComponenthostDirective, isStandalone: true, selector: "[dynamicComponentHost]", ngImport: i0 });
11
+ }
12
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ComponenthostDirective, decorators: [{
13
+ type: Directive,
14
+ args: [{
15
+ selector: '[dynamicComponentHost]',
16
+ standalone: true
17
+ }]
18
+ }], ctorParameters: () => [{ type: i0.ViewContainerRef }] });
19
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tcG9uZW50aG9zdC5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9ueHQtYXBwL3NyYy9saWIvZGlyZWN0aXZlcy9jb21wb25lbnRob3N0L2NvbXBvbmVudGhvc3QuZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLDREQUE0RDtBQUM1RCxPQUFPLEVBQUUsU0FBUyxFQUFvQixNQUFNLGVBQWUsQ0FBQzs7QUFNNUQsTUFBTSxPQUFPLHNCQUFzQjtJQUNkO0lBQW5CLFlBQW1CLGdCQUFrQztRQUFsQyxxQkFBZ0IsR0FBaEIsZ0JBQWdCLENBQWtCO0lBQUcsQ0FBQzt3R0FEOUMsc0JBQXNCOzRGQUF0QixzQkFBc0I7OzRGQUF0QixzQkFBc0I7a0JBSmxDLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLHdCQUF3QjtvQkFDbEMsVUFBVSxFQUFFLElBQUk7aUJBQ2pCIiwic291cmNlc0NvbnRlbnQiOlsiLy8gVkQgMDYtMDktMjQgZGlyZWN0aXZlIGZpbGUgdG8gY2FsbCBjb21wb25lbnQgZHluYW1pY2FsbHkgXG5pbXBvcnQgeyBEaXJlY3RpdmUsIFZpZXdDb250YWluZXJSZWYgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuQERpcmVjdGl2ZSh7XG4gIHNlbGVjdG9yOiAnW2R5bmFtaWNDb21wb25lbnRIb3N0XScsXG4gIHN0YW5kYWxvbmU6IHRydWVcbn0pXG5leHBvcnQgY2xhc3MgQ29tcG9uZW50aG9zdERpcmVjdGl2ZSB7XG4gIGNvbnN0cnVjdG9yKHB1YmxpYyB2aWV3Q29udGFpbmVyUmVmOiBWaWV3Q29udGFpbmVyUmVmKSB7fVxufVxuIl19
@@ -0,0 +1,29 @@
1
+ const enI18n = {
2
+ required: "Required",
3
+ addMore: "Add More",
4
+ select: "Select",
5
+ attachment: "Attachment",
6
+ chooseFiles: "Choose files",
7
+ uploadFile: "Upload File",
8
+ thisFieldIsRequired: "This field is required.",
9
+ pickYourLocation: "Pick Your Location",
10
+ // firstName: "First Name",
11
+ // lastName: "Last Name",
12
+ // division: "Division",
13
+ // numberPlate: "Number Plate",
14
+ calibrated: "Calibrated",
15
+ enterValue: "Enter Value",
16
+ details: "Details", // HA 20FEB24 PTW Details to Details
17
+ pleaseMakeChoice: "Please make a choice",
18
+ attach: "Attach",
19
+ add: "Add",
20
+ zeroOfZero: "0 of 0",
21
+ selectDate: "Select date",
22
+ toBuyTicket: "to buy a ticket",
23
+ pickLocation: "Pick Location",
24
+ enterLocation: "Enter Location",
25
+ searchNearestLocation: "Search Nearest Location",
26
+ currentTheme: "ltr",
27
+ };
28
+ export default enI18n;
29
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZW4uaTE4bi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL254dC1hcHAvc3JjL2xpYi9lbi5pMThuLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE1BQU0sTUFBTSxHQUFHO0lBQ1gsUUFBUSxFQUFFLFVBQVU7SUFDcEIsT0FBTyxFQUFFLFVBQVU7SUFDbkIsTUFBTSxFQUFFLFFBQVE7SUFDaEIsVUFBVSxFQUFFLFlBQVk7SUFDeEIsV0FBVyxFQUFFLGNBQWM7SUFDM0IsVUFBVSxFQUFFLGFBQWE7SUFDekIsbUJBQW1CLEVBQUUseUJBQXlCO0lBQzlDLGdCQUFnQixFQUFFLG9CQUFvQjtJQUN0QywyQkFBMkI7SUFDM0IseUJBQXlCO0lBQ3pCLHdCQUF3QjtJQUN4QiwrQkFBK0I7SUFDL0IsVUFBVSxFQUFFLFlBQVk7SUFDeEIsVUFBVSxFQUFFLGFBQWE7SUFDekIsT0FBTyxFQUFFLFNBQVMsRUFBRSxvQ0FBb0M7SUFDeEQsZ0JBQWdCLEVBQUUsc0JBQXNCO0lBQ3hDLE1BQU0sRUFBRSxRQUFRO0lBQ2hCLEdBQUcsRUFBRSxLQUFLO0lBQ1YsVUFBVSxFQUFFLFFBQVE7SUFDcEIsVUFBVSxFQUFFLGFBQWE7SUFDekIsV0FBVyxFQUFFLGlCQUFpQjtJQUM5QixZQUFZLEVBQUUsZUFBZTtJQUM3QixhQUFhLEVBQUUsZ0JBQWdCO0lBQy9CLHFCQUFxQixFQUFFLHlCQUF5QjtJQUNoRCxZQUFZLEVBQUUsS0FBSztDQUN0QixDQUFBO0FBRUQsZUFBZSxNQUFNLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJjb25zdCBlbkkxOG4gPSB7XG4gICAgcmVxdWlyZWQ6IFwiUmVxdWlyZWRcIixcbiAgICBhZGRNb3JlOiBcIkFkZCBNb3JlXCIsXG4gICAgc2VsZWN0OiBcIlNlbGVjdFwiLFxuICAgIGF0dGFjaG1lbnQ6IFwiQXR0YWNobWVudFwiLFxuICAgIGNob29zZUZpbGVzOiBcIkNob29zZSBmaWxlc1wiLFxuICAgIHVwbG9hZEZpbGU6IFwiVXBsb2FkIEZpbGVcIixcbiAgICB0aGlzRmllbGRJc1JlcXVpcmVkOiBcIlRoaXMgZmllbGQgaXMgcmVxdWlyZWQuXCIsXG4gICAgcGlja1lvdXJMb2NhdGlvbjogXCJQaWNrIFlvdXIgTG9jYXRpb25cIixcbiAgICAvLyBmaXJzdE5hbWU6IFwiRmlyc3QgTmFtZVwiLFxuICAgIC8vIGxhc3ROYW1lOiBcIkxhc3QgTmFtZVwiLFxuICAgIC8vIGRpdmlzaW9uOiBcIkRpdmlzaW9uXCIsXG4gICAgLy8gbnVtYmVyUGxhdGU6IFwiTnVtYmVyIFBsYXRlXCIsXG4gICAgY2FsaWJyYXRlZDogXCJDYWxpYnJhdGVkXCIsXG4gICAgZW50ZXJWYWx1ZTogXCJFbnRlciBWYWx1ZVwiLFxuICAgIGRldGFpbHM6IFwiRGV0YWlsc1wiLCAvLyBIQSAyMEZFQjI0IFBUVyBEZXRhaWxzIHRvIERldGFpbHNcbiAgICBwbGVhc2VNYWtlQ2hvaWNlOiBcIlBsZWFzZSBtYWtlIGEgY2hvaWNlXCIsXG4gICAgYXR0YWNoOiBcIkF0dGFjaFwiLFxuICAgIGFkZDogXCJBZGRcIixcbiAgICB6ZXJvT2ZaZXJvOiBcIjAgb2YgMFwiLFxuICAgIHNlbGVjdERhdGU6IFwiU2VsZWN0IGRhdGVcIixcbiAgICB0b0J1eVRpY2tldDogXCJ0byBidXkgYSB0aWNrZXRcIixcbiAgICBwaWNrTG9jYXRpb246IFwiUGljayBMb2NhdGlvblwiLFxuICAgIGVudGVyTG9jYXRpb246IFwiRW50ZXIgTG9jYXRpb25cIixcbiAgICBzZWFyY2hOZWFyZXN0TG9jYXRpb246IFwiU2VhcmNoIE5lYXJlc3QgTG9jYXRpb25cIixcbiAgICBjdXJyZW50VGhlbWU6IFwibHRyXCIsXG59XG5cbmV4cG9ydCBkZWZhdWx0IGVuSTE4bjsiXX0=
@@ -0,0 +1,4 @@
1
+ // HA 19DEC23 File created for translation
2
+ import { InjectionToken } from '@angular/core';
3
+ export const i18nConfigService = new InjectionToken('i18nConfig');
4
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaTE4bi1jb25maWcuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL254dC1hcHAvc3JjL2xpYi9pMThuLWNvbmZpZy5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLDBDQUEwQztBQUMxQyxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRS9DLE1BQU0sQ0FBQyxNQUFNLGlCQUFpQixHQUFHLElBQUksY0FBYyxDQUFNLFlBQVksQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLy8gSEEgMTlERUMyMyBGaWxlIGNyZWF0ZWQgZm9yIHRyYW5zbGF0aW9uXG5pbXBvcnQgeyBJbmplY3Rpb25Ub2tlbiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5leHBvcnQgY29uc3QgaTE4bkNvbmZpZ1NlcnZpY2UgPSBuZXcgSW5qZWN0aW9uVG9rZW48YW55PignaTE4bkNvbmZpZycpO1xuIl19
@@ -0,0 +1,47 @@
1
+ // HA 19DEC23 File created for translation
2
+ import { Component } from '@angular/core';
3
+ import * as i0 from "@angular/core";
4
+ import * as i1 from "./i18n.service";
5
+ import * as i2 from "@angular/common";
6
+ export class I18nComponent {
7
+ i18nService;
8
+ // @Output() handleEve:EventEmitter<any> = new EventEmitter();
9
+ constructor(i18nService) {
10
+ this.i18nService = i18nService;
11
+ }
12
+ ngOnInit() {
13
+ console.log('ngOnInit component.ts');
14
+ // this.handleEve.emit();
15
+ }
16
+ firstClick(event) {
17
+ console.log('first ', event);
18
+ this.i18nService.languageChange(event);
19
+ // this.handleEve.emit();
20
+ window.location.reload();
21
+ }
22
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: I18nComponent, deps: [{ token: i1.I18nService }], target: i0.ɵɵFactoryTarget.Component });
23
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: I18nComponent, selector: "app-i18n", ngImport: i0, template: `
24
+ <a *ngFor="let lang of i18nService.langList" href="javascript:void(0);" class="not-selected-language" [ngClass]="{'selected-language': i18nService.currentLanguage === lang.lang}"
25
+
26
+ (click)="firstClick(lang.lang)">
27
+ <span class="mr-3">
28
+ {{lang.lang}}
29
+ </span>
30
+ </a>
31
+
32
+ `, isInline: true, styles: [".selected-language{color:green!important;font-weight:700;font-size:24px!important}\n", ".not-selected-language{color:#555;font-weight:700}\n"], dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }] });
33
+ }
34
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: I18nComponent, decorators: [{
35
+ type: Component,
36
+ args: [{ selector: 'app-i18n', template: `
37
+ <a *ngFor="let lang of i18nService.langList" href="javascript:void(0);" class="not-selected-language" [ngClass]="{'selected-language': i18nService.currentLanguage === lang.lang}"
38
+
39
+ (click)="firstClick(lang.lang)">
40
+ <span class="mr-3">
41
+ {{lang.lang}}
42
+ </span>
43
+ </a>
44
+
45
+ `, styles: [".selected-language{color:green!important;font-weight:700;font-size:24px!important}\n", ".not-selected-language{color:#555;font-weight:700}\n"] }]
46
+ }], ctorParameters: () => [{ type: i1.I18nService }] });
47
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaTE4bi5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wcm9qZWN0cy9ueHQtYXBwL3NyYy9saWIvaTE4bi5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsMENBQTBDO0FBQzFDLE9BQU8sRUFBRSxTQUFTLEVBQWdDLE1BQU0sZUFBZSxDQUFDOzs7O0FBMEJ4RSxNQUFNLE9BQU8sYUFBYTtJQUdmO0lBRlQsOERBQThEO0lBQzlELFlBQ1MsV0FBd0I7UUFBeEIsZ0JBQVcsR0FBWCxXQUFXLENBQWE7SUFDOUIsQ0FBQztJQUNKLFFBQVE7UUFDTixPQUFPLENBQUMsR0FBRyxDQUFDLHVCQUF1QixDQUFDLENBQUE7UUFDcEMseUJBQXlCO0lBQzNCLENBQUM7SUFFRCxVQUFVLENBQUMsS0FBSztRQUNkLE9BQU8sQ0FBQyxHQUFHLENBQUMsUUFBUSxFQUFFLEtBQUssQ0FBQyxDQUFDO1FBQzdCLElBQUksQ0FBQyxXQUFXLENBQUMsY0FBYyxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBQ3ZDLHlCQUF5QjtRQUN6QixNQUFNLENBQUMsUUFBUSxDQUFDLE1BQU0sRUFBRSxDQUFDO0lBQzNCLENBQUM7d0dBZlUsYUFBYTs0RkFBYixhQUFhLGdEQVhkOzs7Ozs7Ozs7R0FTVDs7NEZBRVUsYUFBYTtrQkF4QnpCLFNBQVM7K0JBQ0UsVUFBVSxZQVlWOzs7Ozs7Ozs7R0FTVCIsInNvdXJjZXNDb250ZW50IjpbIi8vIEhBIDE5REVDMjMgRmlsZSBjcmVhdGVkIGZvciB0cmFuc2xhdGlvblxuaW1wb3J0IHsgQ29tcG9uZW50LCBFdmVudEVtaXR0ZXIsIE9uSW5pdCwgT3V0cHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBJMThuU2VydmljZSB9IGZyb20gJy4vaTE4bi5zZXJ2aWNlJztcbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2FwcC1pMThuJyxcbiAgc3R5bGVzOiBbXG4gICAgYC5zZWxlY3RlZC1sYW5ndWFnZSB7XG4gIGNvbG9yOiBncmVlbiAhaW1wb3J0YW50O1xuICBmb250LXdlaWdodDogYm9sZDtcbiAgZm9udC1zaXplOiAyNHB4ICFpbXBvcnRhbnQ7XG59YCxcbiAgICBgLm5vdC1zZWxlY3RlZC1sYW5ndWFnZSB7XG4gIGNvbG9yOiAjNTU1NTU1O1xuICBmb250LXdlaWdodDogYm9sZDtcbn1gLFxuICBdLFxuICB0ZW1wbGF0ZTogYFxuICAgPGEgICpuZ0Zvcj1cImxldCBsYW5nIG9mIGkxOG5TZXJ2aWNlLmxhbmdMaXN0XCIgaHJlZj1cImphdmFzY3JpcHQ6dm9pZCgwKTtcIiBjbGFzcz1cIm5vdC1zZWxlY3RlZC1sYW5ndWFnZVwiIFtuZ0NsYXNzXT1cInsnc2VsZWN0ZWQtbGFuZ3VhZ2UnOiBpMThuU2VydmljZS5jdXJyZW50TGFuZ3VhZ2UgPT09IGxhbmcubGFuZ31cIlxuXG4gICAgICAgICAgICAoY2xpY2spPVwiZmlyc3RDbGljayhsYW5nLmxhbmcpXCI+XG4gICAgICAgICAgICA8c3BhbiBjbGFzcz1cIm1yLTNcIj5cbiAgICAgICAgICAgICAgICB7e2xhbmcubGFuZ319XG4gICAgICAgICAgICA8L3NwYW4+XG4gICAgICAgICAgPC9hPlxuXG4gIGAsXG59KVxuZXhwb3J0IGNsYXNzIEkxOG5Db21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xuICAvLyBAT3V0cHV0KCkgaGFuZGxlRXZlOkV2ZW50RW1pdHRlcjxhbnk+ID0gbmV3IEV2ZW50RW1pdHRlcigpO1xuICBjb25zdHJ1Y3RvcihcbiAgICBwdWJsaWMgaTE4blNlcnZpY2U6IEkxOG5TZXJ2aWNlXG4gICkge31cbiAgbmdPbkluaXQoKSB7XG4gICAgY29uc29sZS5sb2coJ25nT25Jbml0IGNvbXBvbmVudC50cycpXG4gICAgLy8gdGhpcy5oYW5kbGVFdmUuZW1pdCgpO1xuICB9XG5cbiAgZmlyc3RDbGljayhldmVudCl7XG4gICAgY29uc29sZS5sb2coJ2ZpcnN0ICcsIGV2ZW50KTtcbiAgICB0aGlzLmkxOG5TZXJ2aWNlLmxhbmd1YWdlQ2hhbmdlKGV2ZW50KTtcbiAgICAvLyB0aGlzLmhhbmRsZUV2ZS5lbWl0KCk7XG4gICAgd2luZG93LmxvY2F0aW9uLnJlbG9hZCgpO1xuICB9XG59XG4iXX0=