@rangertechnologies/ngnxt 2.1.244 → 2.1.246
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/environments/version.mjs +2 -2
- package/esm2022/lib/components/button/nxt-button.component.mjs +5 -15
- package/esm2022/lib/components/custom-dropdown/custom-dropdown.component.mjs +11 -1
- package/esm2022/lib/components/custom-radio/custom-radio.component.mjs +8 -1
- package/esm2022/lib/components/datatable/datatable.component.mjs +53 -45
- package/esm2022/lib/components/list-view-filter/list-view-filter.component.mjs +9 -18
- package/esm2022/lib/components/nxt-input/nxt-input.component.mjs +28 -18
- package/esm2022/lib/components/pagination/pagination.component.mjs +10 -6
- package/esm2022/lib/components/search-box/search-box.component.mjs +40 -27
- package/esm2022/lib/pages/builder/properties/common-fields.constants.mjs +6 -5
- package/esm2022/lib/pages/builder/properties/properties.component.mjs +33 -39
- package/esm2022/lib/pages/pdfDesigner/pdf-properties/pdf-properties.component.mjs +13 -8
- package/esm2022/lib/pipe/button-styles.pipe.mjs +26 -0
- package/esm2022/lib/pipe/custom-translate.pipe.mjs +10 -7
- package/esm2022/lib/pipe/get-value.pipe.mjs +2 -1
- package/esm2022/lib/pipe/question-by-row.pipe.mjs +51 -0
- package/esm2022/lib/pipe/search-filter/search-filter.pipe.mjs +2 -1
- package/esm2022/lib/services/form-builder.service.mjs +5 -1
- package/fesm2022/rangertechnologies-ngnxt.mjs +292 -179
- package/fesm2022/rangertechnologies-ngnxt.mjs.map +1 -1
- package/lib/components/button/nxt-button.component.d.ts +0 -3
- package/lib/components/datatable/datatable.component.d.ts +1 -2
- package/lib/components/list-view-filter/list-view-filter.component.d.ts +2 -5
- package/lib/components/nxt-input/nxt-input.component.d.ts +7 -4
- package/lib/components/pagination/pagination.component.d.ts +3 -2
- package/lib/pages/builder/properties/common-fields.constants.d.ts +29 -0
- package/lib/pages/builder/properties/properties.component.d.ts +32 -4
- package/lib/pages/pdfDesigner/pdf-properties/pdf-properties.component.d.ts +3 -2
- package/lib/pipe/button-styles.pipe.d.ts +9 -0
- package/lib/pipe/custom-translate.pipe.d.ts +1 -0
- package/lib/pipe/question-by-row.pipe.d.ts +9 -0
- package/package.json +1 -1
- package/rangertechnologies-ngnxt-2.1.246.tgz +0 -0
- package/rangertechnologies-ngnxt-2.1.244.tgz +0 -0
|
@@ -24,6 +24,8 @@ export class NxtPagination {
|
|
|
24
24
|
/** Display small pagination buttons */
|
|
25
25
|
small = false;
|
|
26
26
|
totalPages = [];
|
|
27
|
+
startIndex = 0;
|
|
28
|
+
endIndex = 0;
|
|
27
29
|
constructor() { }
|
|
28
30
|
ngOnInit() {
|
|
29
31
|
this.pageSize = this.pageSize ?? 10; // Ensure a default value
|
|
@@ -31,6 +33,7 @@ export class NxtPagination {
|
|
|
31
33
|
if (this.collectionSize) {
|
|
32
34
|
this.totalPages = new Array(Math.ceil(this.collectionSize / Number(this.pageSize)));
|
|
33
35
|
}
|
|
36
|
+
this.updateIndexes();
|
|
34
37
|
}
|
|
35
38
|
ngOnChanges(changes) {
|
|
36
39
|
this.pageSize = this.pageSize ?? 10; // Ensure a default value
|
|
@@ -38,16 +41,16 @@ export class NxtPagination {
|
|
|
38
41
|
if (this.collectionSize) {
|
|
39
42
|
this.totalPages = new Array(Math.ceil(this.collectionSize / Number(this.pageSize)));
|
|
40
43
|
}
|
|
44
|
+
this.updateIndexes();
|
|
41
45
|
}
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
get endIndex() {
|
|
46
|
-
return Math.min(Number(this.startIndex) + Number(this.pageSize), this.collectionSize);
|
|
46
|
+
updateIndexes() {
|
|
47
|
+
this.startIndex = (this.currentPage - 1) * Number(this.pageSize);
|
|
48
|
+
this.endIndex = Math.min(this.startIndex + Number(this.pageSize), this.collectionSize);
|
|
47
49
|
}
|
|
48
50
|
/** Set page number */
|
|
49
51
|
selectPageNumber(pageNumber) {
|
|
50
52
|
this.currentPage = pageNumber;
|
|
53
|
+
this.updateIndexes();
|
|
51
54
|
this.emit();
|
|
52
55
|
}
|
|
53
56
|
/** Set next page number */
|
|
@@ -68,6 +71,7 @@ export class NxtPagination {
|
|
|
68
71
|
// this.currentPage = this.totalPages.length;
|
|
69
72
|
// }
|
|
70
73
|
this.currentPage = 1;
|
|
74
|
+
this.updateIndexes();
|
|
71
75
|
this.emit(); // Emit an event if necessary
|
|
72
76
|
}
|
|
73
77
|
emit() {
|
|
@@ -98,4 +102,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
98
102
|
}], small: [{
|
|
99
103
|
type: Input
|
|
100
104
|
}] } });
|
|
101
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"pagination.component.js","sourceRoot":"","sources":["../../../../../../projects/nxt-app/src/lib/components/pagination/pagination.component.ts","../../../../../../projects/nxt-app/src/lib/components/pagination/pagination.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport { Component, EventEmitter, Input, OnInit, Output, SimpleChanges } from '@angular/core';\nimport { FormsModule } from '@angular/forms';\nimport { NxtCustomTranslatePipe } from '../../pipe/custom-translate.pipe';\n\n\n@Component({\n  selector: 'nxt-pagination',\n  standalone: true,\n  imports: [CommonModule, FormsModule, NxtCustomTranslatePipe],\n  templateUrl: './pagination.component.html',\n  styleUrl: './pagination.component.css'\n})\nexport class NxtPagination implements OnInit {\n  @Output() event = new EventEmitter<any>;\n  // page size Options\n  @Input() pageSizeOptions: number[] = [5, 10, 15, 20, 50];\n  /** The total number of records */\n  @Input() collectionSize = 0;\n\n  /** The number of records to display */\n  @Input() pageSize = 10;\n\n  /** Current page */\n  @Input() currentPage = 1;\n\n  /** The number of buttons to show either side of the current page */\n  @Input() maxSize = 2;\n\n  /** Display the First/Last buttons */\n  @Input() firstLastButtons = false;\n\n  /** Display the Next/Previous buttons */\n  @Input() nextPreviousButtons = true;\n\n  /** Display small pagination buttons */\n  @Input() small = false;\n\n  totalPages: any[] = [];\n\n  constructor() {}\n\n  ngOnInit(): void {\n    this.pageSize = this.pageSize ?? 10; // Ensure a default value\n    this.currentPage = this.currentPage === 0 ? 1 : this.currentPage\n    if (this.collectionSize) {\n      this.totalPages = new Array(Math.ceil(this.collectionSize / Number(this.pageSize)));\n    }\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    this.pageSize = this.pageSize ?? 10; // Ensure a default value\n    this.currentPage = this.currentPage === 0 ? 1 : this.currentPage ?? 1\n    if (this.collectionSize) {\n      this.totalPages = new Array(Math.ceil(this.collectionSize / Number(this.pageSize)));\n    }\n  }\n  get startIndex(): number {\n    return (this.currentPage - 1) * Number(this.pageSize);\n  }\n\n  get endIndex(): number {\n    return Math.min( Number(this.startIndex) + Number(this.pageSize), this.collectionSize);\n  }\n  /** Set page number */\n  selectPageNumber(pageNumber: number) {\n    this.currentPage = pageNumber;\n    this.emit()\n  }\n\n  /** Set next page number */\n  next() {\n    const nextPage = this.currentPage + 1;\n    nextPage <= this.totalPages.length && this.selectPageNumber(nextPage);\n  }\n\n  /** Set previous page number */\n  previous() {\n    const previousPage = this.currentPage - 1;\n    previousPage >= 1 && this.selectPageNumber(previousPage);\n  }\n  onPageSizeChange(newSize:any): void {\n    this.pageSize = newSize; // Update the pageSize\n    this.totalPages = new Array(Math.ceil(this.collectionSize / this.pageSize));\n    // Ensure the current page is within bounds\n    // if (this.currentPage > this.totalPages.length) {\n    //   this.currentPage = this.totalPages.length;\n    // }\n    this.currentPage = 1\n    this.emit(); // Emit an event if necessary\n  }    \n  emit(){\n    this.event.emit({\"length\":this.collectionSize, \"pageSize\": this.pageSize, \"pageIndex\" : this.currentPage})\n  }\n}","<!-- SKS24JAN25 -->\n<div class=\"flex content-space-between main-cont\">\n    <div class=\"info\">\n     <div *ngIf=\"endIndex\">\n     {{'APP.SHOWING_DATA' | nxtCustomTranslate : 'Showing data'}}  {{ startIndex + 1 }} {{'APP.TO' | nxtCustomTranslate : 'to'}} {{ endIndex }} {{'APP.OF' | nxtCustomTranslate : 'of'}}  {{ collectionSize }} {{'APP.ENTRIES' | nxtCustomTranslate : 'entries'}} \n    </div>\n   </div>\n    <div>\n     <ul [class]=\"small ? 'pagination pagination-sm' : 'pagination'\" style=\"align-items: center; padding-top: 18px;\">\n        <!-- select button -->\n       <div style=\"font-size: 14px; font-weight: 400; padding-right: 10px; align-items: center;\" for=\"perPage\">{{'APP.RESULT_PER_PAGE' | nxtCustomTranslate : 'Result per page'}}</div>\n       <div class=\"dropdown-wrapper\">\n         <select id=\"perPage\" [ngModel]=\"pageSize\" (ngModelChange)=\"onPageSizeChange($event)\">\n           <option *ngFor=\"let size of pageSizeOptions\" [value]=\"size\">{{ size }}</option>\n         </select>\n         <svg class=\"dropdown-arrow\" width=\"9\" height=\"6\" viewBox=\"0 0 9 6\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n           <path fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M0.684136 0.767477C0.922999 0.5378 1.30282 0.545248 1.5325 0.784111L4.5 3.93431L7.4675 0.784111C7.69718 0.545248 8.077 0.5378 8.31587 0.767477C8.55473 0.997153 8.56218 1.37698 8.3325 1.61584L4.9325 5.21584C4.81938 5.33349 4.66321 5.39998 4.5 5.39998C4.33679 5.39998 4.18062 5.33349 4.0675 5.21584L0.667501 1.61584C0.437825 1.37698 0.445272 0.997153 0.684136 0.767477Z\" fill=\"#626262\"/>\n          </svg>   \n       </div>     \n       <!-- first button -->\n       <li [class]=\"currentPage === 1 ? 'page-item disabled' : 'page-item'\" *ngIf=\"firstLastButtons\" >\n         <button class=\"page-link\" (click)=\"selectPageNumber(1)\">««</button>\n       </li>\n       <!-- last button -->\n       <li [class]=\"currentPage === totalPages.length ? 'page-item disabled' : 'page-item'\" *ngIf=\"firstLastButtons\">\n         <button class=\"page-link\" (click)=\"selectPageNumber(totalPages.length)\">»»</button>\n       </li>\n       <!-- previous button -->\n       <li [class]=\"currentPage === 1 ? 'page-item disabled' : 'page-item'\" *ngIf=\"nextPreviousButtons\" >\n         <button class=\"page-link\" (click)=\"previous()\">«</button>\n       </li>\n       <!-- page numbers -->\n       <ng-container *ngFor=\"let p of totalPages; index as i\">\n         <li *ngIf=\"i + 1 >= currentPage - maxSize && i + 1 <= currentPage + maxSize\" [class]=\"currentPage === i + 1 ? 'page-item active' : 'page-item'\">\n           <button class=\"page-link\" (click)=\"selectPageNumber(i + 1)\">\n             {{ i + 1 }}\n           </button>\n         </li>\n       </ng-container>\n       <!-- next button -->\n       <li [class]=\"currentPage === totalPages.length ? 'page-item disabled' : 'page-item'\" *ngIf=\"nextPreviousButtons\">\n         <button class=\"page-link\" (click)=\"next()\">»</button>\n       </li>\n     </ul>\n    </div>\n </div>\n   "]}
|
|
105
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"pagination.component.js","sourceRoot":"","sources":["../../../../../../projects/nxt-app/src/lib/components/pagination/pagination.component.ts","../../../../../../projects/nxt-app/src/lib/components/pagination/pagination.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport { Component, EventEmitter, Input, OnInit, Output, SimpleChanges } from '@angular/core';\nimport { FormsModule } from '@angular/forms';\nimport { NxtCustomTranslatePipe } from '../../pipe/custom-translate.pipe';\n\n\n@Component({\n  selector: 'nxt-pagination',\n  standalone: true,\n  imports: [CommonModule, FormsModule, NxtCustomTranslatePipe],\n  templateUrl: './pagination.component.html',\n  styleUrl: './pagination.component.css'\n})\nexport class NxtPagination implements OnInit {\n  @Output() event = new EventEmitter<any>;\n  // page size Options\n  @Input() pageSizeOptions: number[] = [5, 10, 15, 20, 50];\n  /** The total number of records */\n  @Input() collectionSize = 0;\n\n  /** The number of records to display */\n  @Input() pageSize = 10;\n\n  /** Current page */\n  @Input() currentPage = 1;\n\n  /** The number of buttons to show either side of the current page */\n  @Input() maxSize = 2;\n\n  /** Display the First/Last buttons */\n  @Input() firstLastButtons = false;\n\n  /** Display the Next/Previous buttons */\n  @Input() nextPreviousButtons = true;\n\n  /** Display small pagination buttons */\n  @Input() small = false;\n\n  totalPages: any[] = [];\n  startIndex = 0;\n  endIndex = 0;\n\n  constructor() {}\n\n  ngOnInit(): void {\n    this.pageSize = this.pageSize ?? 10; // Ensure a default value\n    this.currentPage = this.currentPage === 0 ? 1 : this.currentPage\n    if (this.collectionSize) {\n      this.totalPages = new Array(Math.ceil(this.collectionSize / Number(this.pageSize)));\n    }\n    this.updateIndexes();\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    this.pageSize = this.pageSize ?? 10; // Ensure a default value\n    this.currentPage = this.currentPage === 0 ? 1 : this.currentPage ?? 1\n    if (this.collectionSize) {\n      this.totalPages = new Array(Math.ceil(this.collectionSize / Number(this.pageSize)));\n    }\n    this.updateIndexes();\n  }\n  updateIndexes() {\n    this.startIndex = (this.currentPage - 1) * Number(this.pageSize);\n    this.endIndex = Math.min(this.startIndex + Number(this.pageSize), this.collectionSize);\n  }\n\n  /** Set page number */\n  selectPageNumber(pageNumber: number) {\n    this.currentPage = pageNumber;\n    this.updateIndexes();\n    this.emit()\n  }\n\n  /** Set next page number */\n  next() {\n    const nextPage = this.currentPage + 1;\n    nextPage <= this.totalPages.length && this.selectPageNumber(nextPage);\n  }\n\n  /** Set previous page number */\n  previous() {\n    const previousPage = this.currentPage - 1;\n    previousPage >= 1 && this.selectPageNumber(previousPage);\n  }\n  onPageSizeChange(newSize:any): void {\n    this.pageSize = newSize; // Update the pageSize\n    this.totalPages = new Array(Math.ceil(this.collectionSize / this.pageSize));\n    // Ensure the current page is within bounds\n    // if (this.currentPage > this.totalPages.length) {\n    //   this.currentPage = this.totalPages.length;\n    // }\n    this.currentPage = 1\n    this.updateIndexes();\n    this.emit(); // Emit an event if necessary\n  }    \n  emit(){\n    this.event.emit({\"length\":this.collectionSize, \"pageSize\": this.pageSize, \"pageIndex\" : this.currentPage})\n  }\n}","<!-- SKS24JAN25 -->\n<div class=\"flex content-space-between main-cont\">\n    <div class=\"info\">\n     <div *ngIf=\"endIndex\">\n     {{'APP.SHOWING_DATA' | nxtCustomTranslate : 'Showing data'}}  {{ startIndex + 1 }} {{'APP.TO' | nxtCustomTranslate : 'to'}} {{ endIndex }} {{'APP.OF' | nxtCustomTranslate : 'of'}}  {{ collectionSize }} {{'APP.ENTRIES' | nxtCustomTranslate : 'entries'}} \n    </div>\n   </div>\n    <div>\n     <ul [class]=\"small ? 'pagination pagination-sm' : 'pagination'\" style=\"align-items: center; padding-top: 18px;\">\n        <!-- select button -->\n       <div style=\"font-size: 14px; font-weight: 400; padding-right: 10px; align-items: center;\" for=\"perPage\">{{'APP.RESULT_PER_PAGE' | nxtCustomTranslate : 'Result per page'}}</div>\n       <div class=\"dropdown-wrapper\">\n         <select id=\"perPage\" [ngModel]=\"pageSize\" (ngModelChange)=\"onPageSizeChange($event)\">\n           <option *ngFor=\"let size of pageSizeOptions\" [value]=\"size\">{{ size }}</option>\n         </select>\n         <svg class=\"dropdown-arrow\" width=\"9\" height=\"6\" viewBox=\"0 0 9 6\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n           <path fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M0.684136 0.767477C0.922999 0.5378 1.30282 0.545248 1.5325 0.784111L4.5 3.93431L7.4675 0.784111C7.69718 0.545248 8.077 0.5378 8.31587 0.767477C8.55473 0.997153 8.56218 1.37698 8.3325 1.61584L4.9325 5.21584C4.81938 5.33349 4.66321 5.39998 4.5 5.39998C4.33679 5.39998 4.18062 5.33349 4.0675 5.21584L0.667501 1.61584C0.437825 1.37698 0.445272 0.997153 0.684136 0.767477Z\" fill=\"#626262\"/>\n          </svg>   \n       </div>     \n       <!-- first button -->\n       <li [class]=\"currentPage === 1 ? 'page-item disabled' : 'page-item'\" *ngIf=\"firstLastButtons\" >\n         <button class=\"page-link\" (click)=\"selectPageNumber(1)\">««</button>\n       </li>\n       <!-- last button -->\n       <li [class]=\"currentPage === totalPages.length ? 'page-item disabled' : 'page-item'\" *ngIf=\"firstLastButtons\">\n         <button class=\"page-link\" (click)=\"selectPageNumber(totalPages.length)\">»»</button>\n       </li>\n       <!-- previous button -->\n       <li [class]=\"currentPage === 1 ? 'page-item disabled' : 'page-item'\" *ngIf=\"nextPreviousButtons\" >\n         <button class=\"page-link\" (click)=\"previous()\">«</button>\n       </li>\n       <!-- page numbers -->\n       <ng-container *ngFor=\"let p of totalPages; index as i\">\n         <li *ngIf=\"i + 1 >= currentPage - maxSize && i + 1 <= currentPage + maxSize\" [class]=\"currentPage === i + 1 ? 'page-item active' : 'page-item'\">\n           <button class=\"page-link\" (click)=\"selectPageNumber(i + 1)\">\n             {{ i + 1 }}\n           </button>\n         </li>\n       </ng-container>\n       <!-- next button -->\n       <li [class]=\"currentPage === totalPages.length ? 'page-item disabled' : 'page-item'\" *ngIf=\"nextPreviousButtons\">\n         <button class=\"page-link\" (click)=\"next()\">»</button>\n       </li>\n     </ul>\n    </div>\n </div>\n   "]}
|
|
@@ -66,6 +66,10 @@ export class NxtSearchBox {
|
|
|
66
66
|
if (this.question?.input && typeof this.question?.input === 'object' && !Array.isArray(this.question?.input)) {
|
|
67
67
|
this.clickItem(this.question?.input);
|
|
68
68
|
}
|
|
69
|
+
else if (Array.isArray(this.question?.input)) {
|
|
70
|
+
this.filterName = '';
|
|
71
|
+
this.viewFilterName = '';
|
|
72
|
+
}
|
|
69
73
|
else {
|
|
70
74
|
this.filterName = this.question?.input;
|
|
71
75
|
this.viewFilterName = this.question?.input;
|
|
@@ -181,33 +185,42 @@ export class NxtSearchBox {
|
|
|
181
185
|
searchFromApi(keyword) {
|
|
182
186
|
this.isLoading = true;
|
|
183
187
|
this.finalResults.set([]);
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
|
|
187
|
-
|
|
188
|
-
|
|
189
|
-
|
|
190
|
-
|
|
191
|
-
|
|
192
|
-
|
|
193
|
-
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
|
|
198
|
-
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
|
|
202
|
-
|
|
203
|
-
|
|
204
|
-
|
|
205
|
-
error: (error) => {
|
|
206
|
-
this.isLoading = false;
|
|
207
|
-
this.noResult = true;
|
|
208
|
-
this.finalResults.set([]);
|
|
188
|
+
if (!this.apiMeta.endpoint && Array.isArray(this.question?.input)) {
|
|
189
|
+
this.isLoading = false;
|
|
190
|
+
this.processSearchResults(this.question?.input, keyword);
|
|
191
|
+
}
|
|
192
|
+
else {
|
|
193
|
+
let finalGetCall = this.apiMeta.endpoint;
|
|
194
|
+
// SKS18JUL25 query params creation
|
|
195
|
+
const isFieldArray = Array.isArray(this.apiMeta?.queryParameter);
|
|
196
|
+
const fields = isFieldArray ? this.apiMeta.queryParameter : [this.apiMeta.queryParameter]; // always an array now
|
|
197
|
+
// Build query params string
|
|
198
|
+
const queryParams = fields
|
|
199
|
+
.map(field => `${field}=${this.searchKeyWord}`)
|
|
200
|
+
.join('&');
|
|
201
|
+
// Check if endpoint already has query params
|
|
202
|
+
if (queryParams && queryParams !== '') {
|
|
203
|
+
if (this.apiMeta.endpoint.includes('?')) {
|
|
204
|
+
finalGetCall += `&${queryParams}`;
|
|
205
|
+
}
|
|
206
|
+
else {
|
|
207
|
+
finalGetCall += `?${queryParams}`;
|
|
208
|
+
}
|
|
209
209
|
}
|
|
210
|
-
|
|
210
|
+
this.dataService.apiResponse(finalGetCall)
|
|
211
|
+
.pipe(takeUntil(this.destroy$))
|
|
212
|
+
.subscribe({
|
|
213
|
+
next: (apiResponse) => {
|
|
214
|
+
this.isLoading = false;
|
|
215
|
+
this.processSearchResults(apiResponse, keyword);
|
|
216
|
+
},
|
|
217
|
+
error: (error) => {
|
|
218
|
+
this.isLoading = false;
|
|
219
|
+
this.noResult = true;
|
|
220
|
+
this.finalResults.set([]);
|
|
221
|
+
}
|
|
222
|
+
});
|
|
223
|
+
}
|
|
211
224
|
}
|
|
212
225
|
searchFromStaticData(keyword) {
|
|
213
226
|
const response = this.countryService.getCountryData(this.apiMeta.field);
|
|
@@ -414,4 +427,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
414
427
|
type: HostListener,
|
|
415
428
|
args: ['document:keydown.escape', ['$event']]
|
|
416
429
|
}] } });
|
|
417
|
-
//# 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 { Component, OnInit, OnDestroy, OnChanges, Input, Output, EventEmitter, ViewChild, ElementRef, SimpleChanges, signal, WritableSignal, TrackByFunction, HostListener} from \"@angular/core\";\nimport { DataService } from '../../services/data.service';\nimport { ChangeWrapper } from \"../../model/changeWrapper\";\nimport { I18nService } from \"../../i18n.service\";\nimport { CommonModule } from \"@angular/common\";\nimport { FormsModule } from \"@angular/forms\";\nimport { NxtInput } from \"../nxt-input/nxt-input.component\";\nimport { CountryService } from \"../../services/country.service\";\nimport { Subject, debounceTime, distinctUntilChanged, takeUntil } from \"rxjs\";\n\n@Component({\n  selector: 'nxt-search-box',\n  standalone: true,\n  imports: [\n    CommonModule,\n    FormsModule,\n    NxtInput\n  ],\n  templateUrl: './search-box.component.html',\n  styleUrls: ['./search-box.component.css']\n})\nexport class NxtSearchBox implements OnInit, OnChanges, OnDestroy {\n  @Input() placeHolderText: string = '';\n  @Input() question: any;\n  @Input() apiMeta: any;\n  @Input() id: string = '';\n  @Input() readOnly = false;\n  @Input() mode: 'view' | 'edit' | 'print' = 'edit';\n  @Input() from: any;\n  \n  @Output() searchValueChange: EventEmitter<any> = new EventEmitter<any>();\n  @ViewChild('searchWrapper', { static: true }) searchWrapper!: ElementRef;\n\n  SearchItem: any;\n  public finalResults: WritableSignal<any[]> = signal([]);\n  public searchKeyWord: string = '';\n  public newResult: any;\n  public showResult = false;\n  public noResult = false;\n  public showSuggestion = false;\n  public isLoading = false;\n  public viewFilterName: string = '';\n  public isSingleFieldChange = false;\n  public valueObj: any;\n  public inputFocused = false;\n  public lastSearchLength = 0;\n  public filterName =''\n\n  private destroy$ = new Subject<void>();\n  private searchSubject = new Subject<string>();\n\n  // TrackBy function for performance optimization\n  trackByFn: TrackByFunction<any> = (index: number, item: any) => {\n    return item.id || item.name || index;\n  };\n\n  constructor(private dataService: DataService, public i18nService: I18nService, private countryService: CountryService, private elementRef: ElementRef) {\n    if(this.question?.input && typeof this.question?.input === 'object' && !Array.isArray(this.question?.input)){\n      this.clickItem(this.question?.input)\n    } else {\n      this.filterName = this.question?.input\n    }    \n    // Setup debounced search\n    this.searchSubject\n      .pipe(\n        debounceTime(300),\n        distinctUntilChanged(),\n        takeUntil(this.destroy$)\n      )\n      .subscribe(keyword => {\n        if(this.lastSearchLength > 2) this.performSearch(keyword);\n      });\n  }\n\n  ngOnInit(): void {\n    if(this.question?.input && typeof this.question?.input === 'object' && !Array.isArray(this.question?.input)){\n      this.clickItem(this.question?.input)\n    } else {\n      this.filterName = this.question?.input\n      this.viewFilterName = this.question?.input\n    }\n    this.parseApiMeta();\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if(changes['question']){\n      // if(this.question?.input && typeof this.question?.input === 'object' && !Array.isArray(this.question?.input)){\n      //   this.clickItem(this.question?.input)\n      // } else {\n      //   this.filterName = this.question?.input\n      // }\n    }\n    if (changes['mode']) {\n      this.mode = changes['mode'].currentValue;\n    }\n    if (changes['apiMeta'] && this.apiMeta) {\n      this.parseApiMeta();\n    }\n  }\n\n  ngOnDestroy(): void {\n    this.destroy$.next();\n    this.destroy$.complete();\n    this.resetComponentState();\n  }\n\n  // Handle clicks outside the search component\n  @HostListener('document:click', ['$event'])\n  onDocumentClick(event: Event): void {\n    if (!this.elementRef.nativeElement.contains(event.target as Node)) {\n      this.hideSuggestions();\n    }\n  }\n\n  // Handle escape key to close suggestions\n  @HostListener('document:keydown.escape', ['$event'])\n  onEscapeKey(event: KeyboardEvent): void {\n    this.hideSuggestions();\n  }\n\n  private parseApiMeta(): void {\n    if (this.apiMeta) {\n      this.apiMeta = typeof this.apiMeta === 'object' ? this.apiMeta : JSON.parse(this.apiMeta || '{}');\n      this.SearchItem = this.apiMeta.field || [];\n    }\n  }\n\n  private resetComponentState(): void {\n    this.finalResults.set([]);\n    this.searchKeyWord = '';\n    this.showSuggestion = false;\n    this.noResult = false;\n    this.isLoading = false;\n    this.inputFocused = false;\n    this.lastSearchLength = 0;\n  }\n\n  private hideSuggestions(): void {\n    this.showSuggestion = false;\n    this.inputFocused = false;\n  }\n\n  onInputFocus(): void {\n    this.inputFocused = true;\n    // Trigger a search with an empty keyword to show all data\n    if (!this.searchKeyWord) {\n      // this.performSearch('');\n    } else if (this.finalResults().length > 0) {\n      this.showSuggestion = true;\n    }\n  }\n\n  onInputBlur(): void {\n    // Don't immediately hide suggestions to allow for clicking\n    // The document click handler will handle hiding\n  }\n\n  clearList(): void {\n    // Remove the setTimeout delay that was causing issues\n    this.hideSuggestions();\n  }\n\n  getSourceDataLocal(event: any): void {\n    if (!event?.value) {\n      this.resetComponentState();\n      return;\n    }\n\n    const searchValue =  event.value.includes('|') ? event.value.split('|')[0].trim() : event.value.trim();\n    const currentLength = searchValue.length;\n    \n    // Always update the search keyword\n    this.searchKeyWord = searchValue;\n    \n    // Handle the case where user types 3+ characters\n    if (currentLength > 2 && !this.isSingleFieldChange) {\n      this.showSuggestion = !event.question?.singleFieldChange;\n      this.showResult = false;\n      this.noResult = false;\n      // Always perform search when we have 3+ characters\n      this.lastSearchLength = currentLength;\n      this.searchSubject.next(searchValue);\n      \n    } else if (currentLength <= 2) {\n      // When length is 2 or less, hide suggestions but keep the search keyword\n      this.isSingleFieldChange = false;\n      this.showSuggestion = false;\n      this.noResult = false;\n      this.lastSearchLength = currentLength;\n      this.searchSubject.next(searchValue);\n      this.finalResults.set([]);\n    }\n  }\n\n  private performSearch(keyword: string): void {\n    if (!this.apiMeta) return;\n\n    this.parseApiMeta();\n    \n    if (!this.apiMeta.isStaticData) {\n      this.searchFromApi(keyword);\n    } else {\n      this.searchFromStaticData(keyword);\n    }\n  }\n\n  private searchFromApi(keyword: string): void {\n    this.isLoading = true;\n    this.finalResults.set([]);\n    let finalGetCall = this.apiMeta.endpoint;\n    // SKS18JUL25 query params creation\n    // const isFieldArray = Array.isArray(this.apiMeta?.field);\n    // const fields = isFieldArray ? this.apiMeta.field : [this.apiMeta.field]; // always an array now\n    // // Build query params string\n    // const queryParams = fields\n    //   .map(field => `${field}=${this.searchKeyWord}`)\n    //   .join('&');\n    // // Check if endpoint already has query params\n    // if (this.apiMeta.endpoint.includes('?')) {\n    //   finalGetCall += `&${queryParams}`;\n    // } else {\n    //   finalGetCall += `?${queryParams}`;\n    // }\n\n    this.dataService.apiResponse(finalGetCall)\n      .pipe(takeUntil(this.destroy$))\n      .subscribe({\n        next: (apiResponse) => {\n          this.isLoading = false;\n          this.processSearchResults(apiResponse, keyword);\n        },\n        error: (error) => {\n          this.isLoading = false;\n          this.noResult = true;\n          this.finalResults.set([]);\n        }\n      });\n  }\n\n  private searchFromStaticData(keyword: string): void {\n    const response = this.countryService.getCountryData(this.apiMeta.field);\n    this.processSearchResults(response, keyword);\n  }\n\n  private processSearchResults(apiResponse: any, keyword: string): void {\n    let response;\n  \n    if (this.apiMeta.variable) {\n      response = this.dataService.getValue(apiResponse, this.apiMeta.variable);\n    } else {\n      response = apiResponse;\n    }\n  \n    if (!Array.isArray(response)) {\n      this.noResult = true;\n      this.finalResults.set([]);\n      return;\n    }\n  \n    if (!keyword) {\n      // If no keyword, show all results\n      this.finalResults.set(response);\n      this.noResult = response.length === 0;\n      this.showSuggestion = true; // Ensure suggestions are visible\n    } else {\n      // Filter results based on the keyword\n      const searchTerms = keyword.toLowerCase().split(\" \").filter(term => term.length > 0);\n      const results = response.filter(obj => {\n        const combinedValues = this.getCombinedValuesFromColumns(obj, this.apiMeta.field);\n        return searchTerms.every(term => combinedValues.includes(term));\n      });\n  \n      this.noResult = results.length === 0;\n      this.finalResults.set(results);\n      this.showSuggestion = true; // Show suggestions only if there are results\n    }\n  }\n\n  private getNestedValue(obj: any, path: string): string {\n    if (!obj || !path) return '';\n    \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\n  private getCombinedValuesFromColumns(obj: any, columns: string[]): string {\n    if (!obj || !columns) return '';\n    \n    const columnArray = Array.isArray(columns) ? columns : [columns];\n    const values: string[] = [];\n\n    for (const column of columnArray) {\n      const value = this.getNestedValue(obj, column);\n      if (value) {\n        values.push(value);\n      }\n    }\n\n    return values.join(' ');\n  }\n\n  public getValues(element: any, columns: any): any {\n    const result: any = {};\n    if (!element || !columns) return result;\n\n    const columnArray = Array.isArray(columns) ? columns : [columns];\n    \n    columnArray.forEach((column) => {\n      if (!column) return;\n      \n      let tempElement = element;\n      const fields = column.split('.');\n      \n      for (const field of fields) {\n        if (!tempElement) break;\n        \n        const splitFields = field.split('[');\n        if (splitFields.length === 1) {\n          tempElement = tempElement[field];\n        } else {\n          const indexMatch = splitFields[1]?.match(/(\\d+)\\]/);\n          if (indexMatch) {\n            const index = Number(indexMatch[1]);\n            tempElement = tempElement[splitFields[0]]?.[index];\n          }\n        }\n      }\n      \n      result[column] = tempElement || '';\n    });\n\n    return result;\n  }\n\n  getKeys(obj: any): string[] {\n    return obj ? Object.keys(obj) : [];\n  }\n\n  public clickItem(event: any): void {\n    if (!this.apiMeta) return;\n  \n    this.parseApiMeta();\n    \n    const values = this.getValues(event, this.SearchItem);\n    const displayValue = Object.values(values)\n      .filter(val => val)\n      .join(' | ');\n    \n    if (this.mode !== 'edit') {\n      this.viewFilterName = displayValue;\n    }\n    this.filterName = displayValue;\n    this.ngOnChanges({})\n  \n    const defaultField = this.apiMeta.defaultField || \n      (Array.isArray(this.apiMeta?.field) ? this.apiMeta?.field?.[0] : this.apiMeta.field);\n    \n    const change = new ChangeWrapper();\n    change.fromQuestionId = this.id;\n    change.valueObj = event;\n    change.field = defaultField;\n    \n    this.valueObj = event;\n    \n    this.hideSuggestions();\n    \n    this.searchValueChange.emit({\n      question: this.question,\n      value: change\n    });\n  }\n\n  removeCharacters(questionText: string): string {\n    if (!questionText) return '';\n    return questionText.replace(/<[^>]*>/g, '');\n  }\n\n  inputValue(event: any, ques: any): void {\n    this.filterName = event.trim()\n    if (!ques?.singleFieldChange || !this.apiMeta) return;\n\n    this.isSingleFieldChange = true;\n    this.parseApiMeta();\n\n    const defaultField = this.apiMeta.defaultField || \n      (Array.isArray(this.apiMeta?.field) ? this.apiMeta?.field?.[0] : this.apiMeta.field);\n\n    const change = new ChangeWrapper();\n    change.fromQuestionId = this.id;\n    change.valueObj = this.valueObj;\n    change.field = defaultField;\n    change.referenceField = this.question.referenceField;\n    \n    this.filterName = this.viewFilterName;\n    \n    this.searchValueChange.emit({\n      question: ques,\n      value: change\n    });\n  }\n\n  highlightText(text: string, searchTerm: string): string {\n    if (!text || !searchTerm) return text || '';\n\n    // Sanitize the input text\n    const sanitizedText = this.sanitizeHtml(text);\n    const terms = searchTerm.toLowerCase().split(' ').filter(term => term.length > 0);\n    \n    if (terms.length === 0) return sanitizedText;\n\n    // Escape special regex characters\n    const escapedTerms = terms.map(term => \n      term.replace(/[.*+?^${}()|[\\]\\\\]/g, '\\\\$&')\n    );\n\n    const regex = new RegExp(`(${escapedTerms.join('|')})`, 'gi');\n    return sanitizedText.replace(regex, '<span class=\"highlight\">$1</span>');\n  }\n\n  private sanitizeHtml(text: string): string {\n    return text\n      .replace(/&/g, '&amp;')\n      .replace(/</g, '&lt;')\n      .replace(/>/g, '&gt;')\n      .replace(/\"/g, '&quot;')\n      .replace(/'/g, '&#39;');\n  }\n  removeValueEmit(){\n    this.clickItem(null)\n  }\n}","<!-- VD 12Jun24 - readonly change -->\n<div class=\"search-wrapper\" #searchWrapper>\n  <nxt-input \n    [type]=\"'list'\" \n    [mode]=\"mode\" \n    [from]=\"from\"\n    [value]=\"mode === 'edit' ? filterName : viewFilterName\"\n    [labelFont]=\"question.font\" \n    [label]=\"removeCharacters(question?.questionText)\" \n    [labelColor]=\"question.fontColor\"\n    [labelSize]=\"question.fontSize\" \n    [inputValueSize]=\"question.fontSize\" \n    [labelWeight]=\"question.fontWeight\"\n    [inputWeight]=\"question.fontWeight\" \n    [showLabel]=\"question.style?.showLabel\" \n    inputBorder=\"none\" \n    svgHeight=\"20px\"\n    svgWidth=\"20px\" \n    [placeholder]=\"placeHolderText\" \n    [required]=\"question.isOptional\" \n    inputBgColor=\"#FAFAFA\"\n    [inputId]=\"question.trackingId\" \n    [errorMessages]=\"{ required: 'This field is required' }\"\n    [inputIconLeftSrc]=\"question.iconLeftSrc\" \n    (inputValue)=\"getSourceDataLocal($event); inputValue($event.value, $event.question)\" \n    (onFocus)=\"onInputFocus()\"\n    (onBlur)=\"onInputBlur()\"\n    [showSuggestion]=\"showSuggestion\" \n    ariaOwns=\"selectList\" \n    ariaHasPopup=\"listbox\" \n    [isLoading]=\"isLoading\" \n    [question]=\"question\"\n    (removeValueEmit)=\"removeValueEmit()\">\n  </nxt-input>\n\n  <div id=\"selectList\" class=\"suggestion-wrapper\" role=\"listbox\" *ngIf=\"showSuggestion\">\n    <div *ngIf=\"finalResults().length > 0\" class=\"nxt-suggestions-container\">\n      <div *ngFor=\"let item of finalResults(); trackBy: trackByFn\" \n           (click)=\"clickItem(item)\" \n           class=\"suggestion-item\" \n           role=\"option\"\n           tabindex=\"0\"\n           (keydown.enter)=\"clickItem(item)\"\n           (keydown.space)=\"clickItem(item)\">\n        <div class=\"item-content\">\n          <div class=\"item-details\">\n            <div *ngIf=\"item.thumbnail\" class=\"thumbnail-wrapper\">\n              <img [src]=\"item.thumbnail\" [alt]=\"item.name + ' avatar'\" />\n            </div>\n            <div class=\"item-text\">\n              <!-- Primary text (first key) -->\n              <ng-container *ngIf=\"getKeys(getValues(item, SearchItem)).length > 0\">\n                <div class=\"item-name primary\" \n                     [innerHTML]=\"highlightText(getValues(item, SearchItem)[getKeys(getValues(item, SearchItem))[0]], searchKeyWord)\">\n                </div>\n              </ng-container>\n              \n              <!-- Secondary text (remaining keys) -->\n              <div class=\"item-secondary\" *ngIf=\"getKeys(getValues(item, SearchItem)).length > 1\">\n                <ng-container *ngFor=\"let key of getKeys(getValues(item, SearchItem)); let i = index\">\n                  <ng-container *ngIf=\"i > 0\">\n                    <span class=\"secondary-text\" \n                          [innerHTML]=\"highlightText(getValues(item, SearchItem)[key], searchKeyWord)\">\n                    </span>\n                    <span class=\"separator\" *ngIf=\"i < getKeys(getValues(item, SearchItem)).length - 1\"> | </span>\n                  </ng-container>\n                </ng-container>\n              </div>\n            </div>\n          </div>\n        </div>\n      </div>\n    </div>\n\n    <div *ngIf=\"noResult && searchKeyWord\" class=\"no-results\">\n      <div class=\"no-results-content\">\n        <svg width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"1\">\n          <circle cx=\"11\" cy=\"11\" r=\"8\"></circle>\n          <path d=\"m21 21-4.35-4.35\"></path>\n        </svg>\n        <p>No results found for \"{{searchKeyWord}}\"</p>\n      </div>\n    </div>\n  </div>\n</div>"]}
|
|
430
|
+
//# 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 { Component, OnInit, OnDestroy, OnChanges, Input, Output, EventEmitter, ViewChild, ElementRef, SimpleChanges, signal, WritableSignal, TrackByFunction, HostListener} from \"@angular/core\";\nimport { DataService } from '../../services/data.service';\nimport { ChangeWrapper } from \"../../model/changeWrapper\";\nimport { I18nService } from \"../../i18n.service\";\nimport { CommonModule } from \"@angular/common\";\nimport { FormsModule } from \"@angular/forms\";\nimport { NxtInput } from \"../nxt-input/nxt-input.component\";\nimport { CountryService } from \"../../services/country.service\";\nimport { Subject, debounceTime, distinctUntilChanged, takeUntil } from \"rxjs\";\n\n@Component({\n  selector: 'nxt-search-box',\n  standalone: true,\n  imports: [\n    CommonModule,\n    FormsModule,\n    NxtInput\n  ],\n  templateUrl: './search-box.component.html',\n  styleUrls: ['./search-box.component.css']\n})\nexport class NxtSearchBox implements OnInit, OnChanges, OnDestroy {\n  @Input() placeHolderText: string = '';\n  @Input() question: any;\n  @Input() apiMeta: any;\n  @Input() id: string = '';\n  @Input() readOnly = false;\n  @Input() mode: 'view' | 'edit' | 'print' = 'edit';\n  @Input() from: any;\n  \n  @Output() searchValueChange: EventEmitter<any> = new EventEmitter<any>();\n  @ViewChild('searchWrapper', { static: true }) searchWrapper!: ElementRef;\n\n  SearchItem: any;\n  public finalResults: WritableSignal<any[]> = signal([]);\n  public searchKeyWord: string = '';\n  public newResult: any;\n  public showResult = false;\n  public noResult = false;\n  public showSuggestion = false;\n  public isLoading = false;\n  public viewFilterName: string = '';\n  public isSingleFieldChange = false;\n  public valueObj: any;\n  public inputFocused = false;\n  public lastSearchLength = 0;\n  public filterName =''\n\n  private destroy$ = new Subject<void>();\n  private searchSubject = new Subject<string>();\n\n  // TrackBy function for performance optimization\n  trackByFn: TrackByFunction<any> = (index: number, item: any) => {\n    return item.id || item.name || index;\n  };\n\n  constructor(private dataService: DataService, public i18nService: I18nService, private countryService: CountryService, private elementRef: ElementRef) {\n    if(this.question?.input && typeof this.question?.input === 'object' && !Array.isArray(this.question?.input)){\n      this.clickItem(this.question?.input)\n    } else {\n      this.filterName = this.question?.input\n    }    \n    // Setup debounced search\n    this.searchSubject\n      .pipe(\n        debounceTime(300),\n        distinctUntilChanged(),\n        takeUntil(this.destroy$)\n      )\n      .subscribe(keyword => {\n        if(this.lastSearchLength > 2) this.performSearch(keyword);\n      });\n  }\n\n  ngOnInit(): void {\n    if(this.question?.input && typeof this.question?.input === 'object' && !Array.isArray(this.question?.input)){\n      this.clickItem(this.question?.input)\n    } else if(Array.isArray(this.question?.input)){\n      this.filterName = ''\n      this.viewFilterName = ''\n    } else {\n      this.filterName = this.question?.input\n      this.viewFilterName = this.question?.input\n    }\n    this.parseApiMeta();\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if(changes['question']){\n      // if(this.question?.input && typeof this.question?.input === 'object' && !Array.isArray(this.question?.input)){\n      //   this.clickItem(this.question?.input)\n      // } else {\n      //   this.filterName = this.question?.input\n      // }\n    }\n    if (changes['mode']) {\n      this.mode = changes['mode'].currentValue;\n    }\n    if (changes['apiMeta'] && this.apiMeta) {\n      this.parseApiMeta();\n    }\n  }\n\n  ngOnDestroy(): void {\n    this.destroy$.next();\n    this.destroy$.complete();\n    this.resetComponentState();\n  }\n\n  // Handle clicks outside the search component\n  @HostListener('document:click', ['$event'])\n  onDocumentClick(event: Event): void {\n    if (!this.elementRef.nativeElement.contains(event.target as Node)) {\n      this.hideSuggestions();\n    }\n  }\n\n  // Handle escape key to close suggestions\n  @HostListener('document:keydown.escape', ['$event'])\n  onEscapeKey(event: KeyboardEvent): void {\n    this.hideSuggestions();\n  }\n\n  private parseApiMeta(): void {\n    if (this.apiMeta) {\n      this.apiMeta = typeof this.apiMeta === 'object' ? this.apiMeta : JSON.parse(this.apiMeta || '{}');\n      this.SearchItem = this.apiMeta.field || [];\n    }\n  }\n\n  private resetComponentState(): void {\n    this.finalResults.set([]);\n    this.searchKeyWord = '';\n    this.showSuggestion = false;\n    this.noResult = false;\n    this.isLoading = false;\n    this.inputFocused = false;\n    this.lastSearchLength = 0;\n  }\n\n  private hideSuggestions(): void {\n    this.showSuggestion = false;\n    this.inputFocused = false;\n  }\n\n  onInputFocus(): void {\n    this.inputFocused = true;\n    // Trigger a search with an empty keyword to show all data\n    if (!this.searchKeyWord) {\n      // this.performSearch('');\n    } else if (this.finalResults().length > 0) {\n      this.showSuggestion = true;\n    }\n  }\n\n  onInputBlur(): void {\n    // Don't immediately hide suggestions to allow for clicking\n    // The document click handler will handle hiding\n  }\n\n  clearList(): void {\n    // Remove the setTimeout delay that was causing issues\n    this.hideSuggestions();\n  }\n\n  getSourceDataLocal(event: any): void {\n    if (!event?.value) {\n      this.resetComponentState();\n      return;\n    }\n\n    const searchValue =  event.value.includes('|') ? event.value.split('|')[0].trim() : event.value.trim();\n    const currentLength = searchValue.length;\n    \n    // Always update the search keyword\n    this.searchKeyWord = searchValue;\n    \n    // Handle the case where user types 3+ characters\n    if (currentLength > 2 && !this.isSingleFieldChange) {\n      this.showSuggestion = !event.question?.singleFieldChange;\n      this.showResult = false;\n      this.noResult = false;\n      // Always perform search when we have 3+ characters\n      this.lastSearchLength = currentLength;\n      this.searchSubject.next(searchValue);\n      \n    } else if (currentLength <= 2) {\n      // When length is 2 or less, hide suggestions but keep the search keyword\n      this.isSingleFieldChange = false;\n      this.showSuggestion = false;\n      this.noResult = false;\n      this.lastSearchLength = currentLength;\n      this.searchSubject.next(searchValue);\n      this.finalResults.set([]);\n    }\n  }\n\n  private performSearch(keyword: string): void {\n    if (!this.apiMeta) return;\n\n    this.parseApiMeta();\n    \n    if (!this.apiMeta.isStaticData) {\n      this.searchFromApi(keyword);\n    } else {\n      this.searchFromStaticData(keyword);\n    }\n  }\n\n  private searchFromApi(keyword: string): void {\n    this.isLoading = true;\n    this.finalResults.set([]);\n    if(!this.apiMeta.endpoint && Array.isArray(this.question?.input) ){\n      this.isLoading = false;\n      this.processSearchResults(this.question?.input, keyword);\n    } else {\n      let finalGetCall = this.apiMeta.endpoint;\n      // SKS18JUL25 query params creation\n      const isFieldArray = Array.isArray(this.apiMeta?.queryParameter);\n      const fields = isFieldArray ? this.apiMeta.queryParameter : [this.apiMeta.queryParameter]; // always an array now\n      // Build query params string\n      const queryParams = fields\n        .map(field => `${field}=${this.searchKeyWord}`)\n        .join('&');\n      // Check if endpoint already has query params\n      if(queryParams && queryParams !== ''){\n        if (this.apiMeta.endpoint.includes('?')) {\n          finalGetCall += `&${queryParams}`;\n        } else {\n          finalGetCall += `?${queryParams}`;\n        }\n      }\n      this.dataService.apiResponse(finalGetCall)\n      .pipe(takeUntil(this.destroy$))\n      .subscribe({\n        next: (apiResponse) => {\n          this.isLoading = false;\n          this.processSearchResults(apiResponse, keyword);\n        },\n        error: (error) => {\n          this.isLoading = false;\n          this.noResult = true;\n          this.finalResults.set([]);\n        }\n      });\n    }\n  }\n\n  private searchFromStaticData(keyword: string): void {\n    const response = this.countryService.getCountryData(this.apiMeta.field);\n    this.processSearchResults(response, keyword);\n  }\n\n  private processSearchResults(apiResponse: any, keyword: string): void {\n    let response;\n  \n    if (this.apiMeta.variable) {\n      response = this.dataService.getValue(apiResponse, this.apiMeta.variable);\n    } else {\n      response = apiResponse;\n    }\n  \n    if (!Array.isArray(response)) {\n      this.noResult = true;\n      this.finalResults.set([]);\n      return;\n    }\n  \n    if (!keyword) {\n      // If no keyword, show all results\n      this.finalResults.set(response);\n      this.noResult = response.length === 0;\n      this.showSuggestion = true; // Ensure suggestions are visible\n    } else {\n      // Filter results based on the keyword\n      const searchTerms = keyword.toLowerCase().split(\" \").filter(term => term.length > 0);\n      const results = response.filter(obj => {\n        const combinedValues = this.getCombinedValuesFromColumns(obj, this.apiMeta.field);\n        return searchTerms.every(term => combinedValues.includes(term));\n      });\n  \n      this.noResult = results.length === 0;\n      this.finalResults.set(results);\n      this.showSuggestion = true; // Show suggestions only if there are results\n    }\n  }\n\n  private getNestedValue(obj: any, path: string): string {\n    if (!obj || !path) return '';\n    \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\n  private getCombinedValuesFromColumns(obj: any, columns: string[]): string {\n    if (!obj || !columns) return '';\n    \n    const columnArray = Array.isArray(columns) ? columns : [columns];\n    const values: string[] = [];\n\n    for (const column of columnArray) {\n      const value = this.getNestedValue(obj, column);\n      if (value) {\n        values.push(value);\n      }\n    }\n\n    return values.join(' ');\n  }\n\n  public getValues(element: any, columns: any): any {\n    const result: any = {};\n    if (!element || !columns) return result;\n\n    const columnArray = Array.isArray(columns) ? columns : [columns];\n    \n    columnArray.forEach((column) => {\n      if (!column) return;\n      \n      let tempElement = element;\n      const fields = column.split('.');\n      \n      for (const field of fields) {\n        if (!tempElement) break;\n        \n        const splitFields = field.split('[');\n        if (splitFields.length === 1) {\n          tempElement = tempElement[field];\n        } else {\n          const indexMatch = splitFields[1]?.match(/(\\d+)\\]/);\n          if (indexMatch) {\n            const index = Number(indexMatch[1]);\n            tempElement = tempElement[splitFields[0]]?.[index];\n          }\n        }\n      }\n      \n      result[column] = tempElement || '';\n    });\n\n    return result;\n  }\n\n  getKeys(obj: any): string[] {\n    return obj ? Object.keys(obj) : [];\n  }\n\n  public clickItem(event: any): void {\n    if (!this.apiMeta) return;\n  \n    this.parseApiMeta();\n    \n    const values = this.getValues(event, this.SearchItem);\n    const displayValue = Object.values(values)\n      .filter(val => val)\n      .join(' | ');\n    \n    if (this.mode !== 'edit') {\n      this.viewFilterName = displayValue;\n    }\n    this.filterName = displayValue;\n    this.ngOnChanges({})\n  \n    const defaultField = this.apiMeta.defaultField || \n      (Array.isArray(this.apiMeta?.field) ? this.apiMeta?.field?.[0] : this.apiMeta.field);\n    \n    const change = new ChangeWrapper();\n    change.fromQuestionId = this.id;\n    change.valueObj = event;\n    change.field = defaultField;\n    \n    this.valueObj = event;\n    \n    this.hideSuggestions();\n    \n    this.searchValueChange.emit({\n      question: this.question,\n      value: change\n    });\n  }\n\n  removeCharacters(questionText: string): string {\n    if (!questionText) return '';\n    return questionText.replace(/<[^>]*>/g, '');\n  }\n\n  inputValue(event: any, ques: any): void {\n    this.filterName = event.trim()\n    if (!ques?.singleFieldChange || !this.apiMeta) return;\n\n    this.isSingleFieldChange = true;\n    this.parseApiMeta();\n\n    const defaultField = this.apiMeta.defaultField || \n      (Array.isArray(this.apiMeta?.field) ? this.apiMeta?.field?.[0] : this.apiMeta.field);\n\n    const change = new ChangeWrapper();\n    change.fromQuestionId = this.id;\n    change.valueObj = this.valueObj;\n    change.field = defaultField;\n    change.referenceField = this.question.referenceField;\n    \n    this.filterName = this.viewFilterName;\n    \n    this.searchValueChange.emit({\n      question: ques,\n      value: change\n    });\n  }\n\n  highlightText(text: string, searchTerm: string): string {\n    if (!text || !searchTerm) return text || '';\n\n    // Sanitize the input text\n    const sanitizedText = this.sanitizeHtml(text);\n    const terms = searchTerm.toLowerCase().split(' ').filter(term => term.length > 0);\n    \n    if (terms.length === 0) return sanitizedText;\n\n    // Escape special regex characters\n    const escapedTerms = terms.map(term => \n      term.replace(/[.*+?^${}()|[\\]\\\\]/g, '\\\\$&')\n    );\n\n    const regex = new RegExp(`(${escapedTerms.join('|')})`, 'gi');\n    return sanitizedText.replace(regex, '<span class=\"highlight\">$1</span>');\n  }\n\n  private sanitizeHtml(text: string): string {\n    return text\n      .replace(/&/g, '&amp;')\n      .replace(/</g, '&lt;')\n      .replace(/>/g, '&gt;')\n      .replace(/\"/g, '&quot;')\n      .replace(/'/g, '&#39;');\n  }\n  removeValueEmit(){\n    this.clickItem(null)\n  }\n}","<!-- VD 12Jun24 - readonly change -->\n<div class=\"search-wrapper\" #searchWrapper>\n  <nxt-input \n    [type]=\"'list'\" \n    [mode]=\"mode\" \n    [from]=\"from\"\n    [value]=\"mode === 'edit' ? filterName : viewFilterName\"\n    [labelFont]=\"question.font\" \n    [label]=\"removeCharacters(question?.questionText)\" \n    [labelColor]=\"question.fontColor\"\n    [labelSize]=\"question.fontSize\" \n    [inputValueSize]=\"question.fontSize\" \n    [labelWeight]=\"question.fontWeight\"\n    [inputWeight]=\"question.fontWeight\" \n    [showLabel]=\"question.style?.showLabel\" \n    inputBorder=\"none\" \n    svgHeight=\"20px\"\n    svgWidth=\"20px\" \n    [placeholder]=\"placeHolderText\" \n    [required]=\"question.isOptional\" \n    inputBgColor=\"#FAFAFA\"\n    [inputId]=\"question.trackingId\" \n    [errorMessages]=\"{ required: 'This field is required' }\"\n    [inputIconLeftSrc]=\"question.iconLeftSrc\" \n    (inputValue)=\"getSourceDataLocal($event); inputValue($event.value, $event.question)\" \n    (onFocus)=\"onInputFocus()\"\n    (onBlur)=\"onInputBlur()\"\n    [showSuggestion]=\"showSuggestion\" \n    ariaOwns=\"selectList\" \n    ariaHasPopup=\"listbox\" \n    [isLoading]=\"isLoading\" \n    [question]=\"question\"\n    (removeValueEmit)=\"removeValueEmit()\">\n  </nxt-input>\n\n  <div id=\"selectList\" class=\"suggestion-wrapper\" role=\"listbox\" *ngIf=\"showSuggestion\">\n    <div *ngIf=\"finalResults().length > 0\" class=\"nxt-suggestions-container\">\n      <div *ngFor=\"let item of finalResults(); trackBy: trackByFn\" \n           (click)=\"clickItem(item)\" \n           class=\"suggestion-item\" \n           role=\"option\"\n           tabindex=\"0\"\n           (keydown.enter)=\"clickItem(item)\"\n           (keydown.space)=\"clickItem(item)\">\n        <div class=\"item-content\">\n          <div class=\"item-details\">\n            <div *ngIf=\"item.thumbnail\" class=\"thumbnail-wrapper\">\n              <img [src]=\"item.thumbnail\" [alt]=\"item.name + ' avatar'\" />\n            </div>\n            <div class=\"item-text\">\n              <!-- Primary text (first key) -->\n              <ng-container *ngIf=\"getKeys(getValues(item, SearchItem)).length > 0\">\n                <div class=\"item-name primary\" \n                     [innerHTML]=\"highlightText(getValues(item, SearchItem)[getKeys(getValues(item, SearchItem))[0]], searchKeyWord)\">\n                </div>\n              </ng-container>\n              \n              <!-- Secondary text (remaining keys) -->\n              <div class=\"item-secondary\" *ngIf=\"getKeys(getValues(item, SearchItem)).length > 1\">\n                <ng-container *ngFor=\"let key of getKeys(getValues(item, SearchItem)); let i = index\">\n                  <ng-container *ngIf=\"i > 0\">\n                    <span class=\"secondary-text\" \n                          [innerHTML]=\"highlightText(getValues(item, SearchItem)[key], searchKeyWord)\">\n                    </span>\n                    <span class=\"separator\" *ngIf=\"i < getKeys(getValues(item, SearchItem)).length - 1\"> | </span>\n                  </ng-container>\n                </ng-container>\n              </div>\n            </div>\n          </div>\n        </div>\n      </div>\n    </div>\n\n    <div *ngIf=\"noResult && searchKeyWord\" class=\"no-results\">\n      <div class=\"no-results-content\">\n        <svg width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"1\">\n          <circle cx=\"11\" cy=\"11\" r=\"8\"></circle>\n          <path d=\"m21 21-4.35-4.35\"></path>\n        </svg>\n        <p>No results found for \"{{searchKeyWord}}\"</p>\n      </div>\n    </div>\n  </div>\n</div>"]}
|
|
@@ -2,14 +2,14 @@
|
|
|
2
2
|
export const COMMON_ELEMENT_PROPS = [
|
|
3
3
|
{ label: 'Is Label', placeholder: 'Enter Text', type: 'checkbox', key: 'style.showLabel' },
|
|
4
4
|
{ label: 'primaryKey', placeholder: 'Enter Text', type: 'checkbox', key: 'primaryKey' },
|
|
5
|
-
{ label: 'Label', placeholder: 'Field label', type: 'text', key: 'questionText' },
|
|
6
|
-
{ label: 'Place Holder', placeholder: 'Enter Text', type: 'text', key: 'question' },
|
|
5
|
+
{ label: 'Label', placeholder: 'Field label', type: 'text', key: 'questionText', isTranslate: true },
|
|
6
|
+
{ label: 'Place Holder', placeholder: 'Enter Text', type: 'text', key: 'question', isTranslate: true },
|
|
7
7
|
{ label: 'Element', type: 'number', key: 'questionNumber' },
|
|
8
8
|
{ label: 'Size', type: 'number', key: 'size' }
|
|
9
9
|
];
|
|
10
10
|
export const COMMON_FIELD_PROPS = [
|
|
11
11
|
{ label: '', type: 'toggleGroup', key: 'toggleOptions' },
|
|
12
|
-
{ label: 'Help Text', placeholder: 'Enter Text', type: 'text', key: 'helpText' },
|
|
12
|
+
{ label: 'Help Text', placeholder: 'Enter Text', type: 'text', key: 'helpText', isTranslate: true },
|
|
13
13
|
{ label: 'Default Value', placeholder: 'Enter Text', type: 'text', key: 'defaultValue' },
|
|
14
14
|
{ label: 'Reference Field', placeholder: 'Reference Field', type: 'text', key: 'referenceField' },
|
|
15
15
|
{
|
|
@@ -18,6 +18,7 @@ export const COMMON_FIELD_PROPS = [
|
|
|
18
18
|
{ label: 'End Point', placeholder: 'endpoint', type: 'text', key: 'subText.endpoint' },
|
|
19
19
|
{ label: 'Variable', placeholder: 'variable', type: 'text', key: 'subText.variable' },
|
|
20
20
|
{ label: 'Field', placeholder: 'field', type: 'text', key: 'subText.field' },
|
|
21
|
+
{ label: 'Query Parameter', placeholder: 'field', type: 'text', key: 'subText.queryParameter' },
|
|
21
22
|
{ label: 'Default Field', placeholder: 'defaultField', type: 'text', key: 'subText.defaultField' },
|
|
22
23
|
{ label: 'Label Field', placeholder: 'labelField', type: 'text', key: 'subText.labelField' },
|
|
23
24
|
{ label: 'Value Field', placeholder: 'valueField', type: 'text', key: 'subText.valueField' },
|
|
@@ -66,7 +67,7 @@ export const COMMON_OPTIONS_FIELD = [
|
|
|
66
67
|
}
|
|
67
68
|
];
|
|
68
69
|
export const COMMON_COLUMN_FIELD = [
|
|
69
|
-
{ label: "headerLabels", placeholder: "Employee Details", type: "text", targetArray: "fieldsMeta", targetArrayKey: "uniqueIdentifier", key: "label" },
|
|
70
|
+
{ label: "headerLabels", placeholder: "Employee Details", type: "text", targetArray: "fieldsMeta", targetArrayKey: "uniqueIdentifier", key: "label", isTranslate: true },
|
|
70
71
|
{ label: "apiName", placeholder: "Employee Details", type: "text", targetArray: "fieldsMeta", targetArrayKey: "uniqueIdentifier", key: "apiName" },
|
|
71
72
|
{
|
|
72
73
|
label: "Summary Column", placeholder: "Summary Column", type: "subQuestion", targetArray: "fieldsMeta", targetArrayKey: "uniqueIdentifier", key: "summaryColumn",
|
|
@@ -86,4 +87,4 @@ export const COMMON_COLUMN_FIELD = [
|
|
|
86
87
|
]
|
|
87
88
|
}
|
|
88
89
|
];
|
|
89
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"common-fields.constants.js","sourceRoot":"","sources":["../../../../../../../projects/nxt-app/src/lib/pages/builder/properties/common-fields.constants.ts"],"names":[],"mappings":"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","sourcesContent":["//AP-25JUN25- common-fields.constants.ts\n\nexport const COMMON_ELEMENT_PROPS = [\n    { label: 'Is Label', placeholder: 'Enter Text', type: 'checkbox', key: 'style.showLabel' },\n    { label: 'primaryKey', placeholder: 'Enter Text', type: 'checkbox', key: 'primaryKey' },\n    { label: 'Label', placeholder: 'Field label', type: 'text', key: 'questionText' },\n    { label: 'Place Holder', placeholder: 'Enter Text', type: 'text', key: 'question' },\n    { label: 'Element', type: 'number', key: 'questionNumber' },\n    { label: 'Size', type: 'number', key: 'size' }\n  ];\n  \nexport const COMMON_FIELD_PROPS = [\n    { label: '', type: 'toggleGroup', key: 'toggleOptions' },\n    { label: 'Help Text', placeholder: 'Enter Text', type: 'text', key: 'helpText' },\n    { label: 'Default Value', placeholder: 'Enter Text', type: 'text', key: 'defaultValue' },\n    { label: 'Reference Field', placeholder: 'Reference Field', type: 'text', key: 'referenceField' },\n    {\n      label: 'Sub Text', type: 'subQuestion', key: 'isSubText',\n      subQuestion: [\n        { label: 'End Point', placeholder: 'endpoint', type: 'text', key: 'subText.endpoint' },\n        { label: 'Variable', placeholder: 'variable', type: 'text', key: 'subText.variable' },\n        { label: 'Field', placeholder: 'field', type: 'text', key: 'subText.field' },\n        { label: 'Default Field', placeholder: 'defaultField', type: 'text', key: 'subText.defaultField' },\n        { label: 'Label Field', placeholder: 'labelField', type: 'text', key: 'subText.labelField' },\n        { label: 'Value Field', placeholder: 'valueField', type: 'text', key: 'subText.valueField' },\n        { label: 'Source Question Id', placeholder: 'sourceQuestionId', type: 'text', key: 'subText.sourceQuestionId' },\n        { label: 'Dependent Value', placeholder: 'dependentValue', type: 'text', key: 'subText.dependentValue' },\n        { label: 'Dependent Field', placeholder: 'isDependentField', type: 'boolean', key: 'subText.isDependentField' },\n        { label: 'Query Field', placeholder: 'queryField', type: 'text', key: 'subText.queryField' },\n        { label: 'Query Value', placeholder: 'queryValue', type: 'text', key: 'subText.queryValue' },\n        { label: 'Query Value Ref', placeholder: 'queryValueRef', type: 'text', key: 'subText.queryValueReference' },\n        { label: 'Unique Key', placeholder: 'uniqueKey', type: 'text', key: 'subText.uniqueKey' }\n      ]\n    }\n  ];\n  \nexport const COMMON_APPEARANCE_PROPS = [\n    {\n      label: 'Select Font', type: 'select', key: 'font', required: true,\n      options: [{label:'Helvetica Neue',value:'Helvetica Neue'},{label:'Arial',value:'Arial'},{label:'Times New Roman',value:'Times New Roman'},{label:'Roboto',value:'Roboto'}]\n    },\n    { label: 'Font Color', type: 'color', key: 'fontColor', required: true },\n    {\n      label: 'Font Size', type: 'select', key: 'fontSize', required: true,\n      options: [\n        { label: 'Small', value: '12px' },\n        { label: 'Medium', value: '14px' },\n        { label: 'Large', value: '16px' }\n      ]\n    },\n    {\n      label: 'Font Width', type: 'select', key: 'fontWeight', required: true,\n      options: [\n        { value: '400', label: '400-Normal' },\n        { value: '500', label: '500-Medium' },\n        { value: '600', label: '600-Semi Bold' },\n        { value: '700', label: '700-Bold' }\n      ]\n    },\n    { label: 'Duplicate Field', type: 'button-toggle', key: 'duplicateField', defaultValue: false }\n    \n  ];\n\nexport const COMMON_OPTIONS_FIELD = [\n    {\n      label: 'Options',\n      type: 'options-type',\n      key: 'options',\n      addOptionLabel: 'Add Option',\n      icon: 'plus'\n    }\n  ];\nexport const COMMON_COLUMN_FIELD = [\n  { label: \"headerLabels\", placeholder: \"Employee Details\", type: \"text\", targetArray: \"fieldsMeta\", targetArrayKey: \"uniqueIdentifier\", key: \"label\" },\n  { label: \"apiName\", placeholder: \"Employee Details\", type: \"text\", targetArray: \"fieldsMeta\", targetArrayKey: \"uniqueIdentifier\", key: \"apiName\" }, \n  {\n    label: \"Summary Column\", placeholder: \"Summary Column\", type: \"subQuestion\", targetArray: \"fieldsMeta\", targetArrayKey: \"uniqueIdentifier\", key: \"summaryColumn\",\n    subQuestion: [\n      { label: \"Type\", placeholder: \"Employee Details\", type: \"text\", targetArray: \"fieldsMeta\", targetArrayKey: \"uniqueIdentifier\", key: \"fldType\" },\n      { label: \"Operation\", placeholder: \"Employee Details\", type: \"text\", targetArray: \"fieldsMeta\", targetArrayKey: \"uniqueIdentifier\", key: \"operation\" },\n      { label: \"Operands\", placeholder: \"Employee Details\", type: \"array\", targetArray: \"fieldsMeta\", targetArrayKey: \"uniqueIdentifier\", key: \"operands\" },\n    ]\n  },\n  {\n    label: \"Summary Row\", placeholder: \"Summary Row\", type: \"subQuestion\", targetArray: \"fieldsMeta\", targetArrayKey: \"uniqueIdentifier\", key: \"summaryRow\",\n    subQuestion: [\n      { label: \"Type\", placeholder: \"Employee Details\", type: \"text\", targetArray: \"fieldsMeta\", targetArrayKey: \"uniqueIdentifier\", key: \"fldType\" },\n      { label: \"operation\", placeholder: \"operation\", type: \"text\", targetArray: \"fieldsMeta\", targetArrayKey: \"uniqueIdentifier\", key: \"operation\" },\n      { label: \"column\", placeholder: \"Employee Details\", type: \"radio\", targetArray: \"fieldsMeta\", targetArrayKey: \"uniqueIdentifier\", key: \"column\" },\n      { label: \"operands\", placeholder: \"Employee Details\", type: \"array\", targetArray: \"fieldsMeta\", targetArrayKey: \"uniqueIdentifier\", key: \"operands\" },\n    ]\n  }\n]"]}
|
|
90
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"common-fields.constants.js","sourceRoot":"","sources":["../../../../../../../projects/nxt-app/src/lib/pages/builder/properties/common-fields.constants.ts"],"names":[],"mappings":"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","sourcesContent":["//AP-25JUN25- common-fields.constants.ts\n\nexport const COMMON_ELEMENT_PROPS = [\n    { label: 'Is Label', placeholder: 'Enter Text', type: 'checkbox', key: 'style.showLabel' },\n    { label: 'primaryKey', placeholder: 'Enter Text', type: 'checkbox', key: 'primaryKey' },\n    { label: 'Label', placeholder: 'Field label', type: 'text', key: 'questionText', isTranslate: true },\n    { label: 'Place Holder', placeholder: 'Enter Text', type: 'text', key: 'question' , isTranslate: true},\n    { label: 'Element', type: 'number', key: 'questionNumber' },\n    { label: 'Size', type: 'number', key: 'size' }\n  ];\n  \nexport const COMMON_FIELD_PROPS = [\n    { label: '', type: 'toggleGroup', key: 'toggleOptions' },\n    { label: 'Help Text', placeholder: 'Enter Text', type: 'text', key: 'helpText', isTranslate: true },\n    { label: 'Default Value', placeholder: 'Enter Text', type: 'text', key: 'defaultValue' },\n    { label: 'Reference Field', placeholder: 'Reference Field', type: 'text', key: 'referenceField' },\n    {\n      label: 'Sub Text', type: 'subQuestion', key: 'isSubText',\n      subQuestion: [\n        { label: 'End Point', placeholder: 'endpoint', type: 'text', key: 'subText.endpoint' },\n        { label: 'Variable', placeholder: 'variable', type: 'text', key: 'subText.variable' },\n        { label: 'Field', placeholder: 'field', type: 'text', key: 'subText.field' },\n        { label: 'Query Parameter', placeholder: 'field', type: 'text', key: 'subText.queryParameter' },\n        { label: 'Default Field', placeholder: 'defaultField', type: 'text', key: 'subText.defaultField' },\n        { label: 'Label Field', placeholder: 'labelField', type: 'text', key: 'subText.labelField' },\n        { label: 'Value Field', placeholder: 'valueField', type: 'text', key: 'subText.valueField' },\n        { label: 'Source Question Id', placeholder: 'sourceQuestionId', type: 'text', key: 'subText.sourceQuestionId' },\n        { label: 'Dependent Value', placeholder: 'dependentValue', type: 'text', key: 'subText.dependentValue' },\n        { label: 'Dependent Field', placeholder: 'isDependentField', type: 'boolean', key: 'subText.isDependentField' },\n        { label: 'Query Field', placeholder: 'queryField', type: 'text', key: 'subText.queryField' },\n        { label: 'Query Value', placeholder: 'queryValue', type: 'text', key: 'subText.queryValue' },\n        { label: 'Query Value Ref', placeholder: 'queryValueRef', type: 'text', key: 'subText.queryValueReference' },\n        { label: 'Unique Key', placeholder: 'uniqueKey', type: 'text', key: 'subText.uniqueKey' }\n      ]\n    }\n  ];\n  \nexport const COMMON_APPEARANCE_PROPS = [\n    {\n      label: 'Select Font', type: 'select', key: 'font', required: true,\n      options: [{label:'Helvetica Neue',value:'Helvetica Neue'},{label:'Arial',value:'Arial'},{label:'Times New Roman',value:'Times New Roman'},{label:'Roboto',value:'Roboto'}]\n    },\n    { label: 'Font Color', type: 'color', key: 'fontColor', required: true },\n    {\n      label: 'Font Size', type: 'select', key: 'fontSize', required: true,\n      options: [\n        { label: 'Small', value: '12px' },\n        { label: 'Medium', value: '14px' },\n        { label: 'Large', value: '16px' }\n      ]\n    },\n    {\n      label: 'Font Width', type: 'select', key: 'fontWeight', required: true,\n      options: [\n        { value: '400', label: '400-Normal' },\n        { value: '500', label: '500-Medium' },\n        { value: '600', label: '600-Semi Bold' },\n        { value: '700', label: '700-Bold' }\n      ]\n    },\n    { label: 'Duplicate Field', type: 'button-toggle', key: 'duplicateField', defaultValue: false }\n    \n  ];\n\nexport const COMMON_OPTIONS_FIELD = [\n    {\n      label: 'Options',\n      type: 'options-type',\n      key: 'options',\n      addOptionLabel: 'Add Option',\n      icon: 'plus'\n    }\n  ];\nexport const COMMON_COLUMN_FIELD = [\n  { label: \"headerLabels\", placeholder: \"Employee Details\", type: \"text\", targetArray: \"fieldsMeta\", targetArrayKey: \"uniqueIdentifier\", key: \"label\", isTranslate: true },\n  { label: \"apiName\", placeholder: \"Employee Details\", type: \"text\", targetArray: \"fieldsMeta\", targetArrayKey: \"uniqueIdentifier\", key: \"apiName\" }, \n  {\n    label: \"Summary Column\", placeholder: \"Summary Column\", type: \"subQuestion\", targetArray: \"fieldsMeta\", targetArrayKey: \"uniqueIdentifier\", key: \"summaryColumn\",\n    subQuestion: [\n      { label: \"Type\", placeholder: \"Employee Details\", type: \"text\", targetArray: \"fieldsMeta\", targetArrayKey: \"uniqueIdentifier\", key: \"fldType\" },\n      { label: \"Operation\", placeholder: \"Employee Details\", type: \"text\", targetArray: \"fieldsMeta\", targetArrayKey: \"uniqueIdentifier\", key: \"operation\" },\n      { label: \"Operands\", placeholder: \"Employee Details\", type: \"array\", targetArray: \"fieldsMeta\", targetArrayKey: \"uniqueIdentifier\", key: \"operands\" },\n    ]\n  },\n  {\n    label: \"Summary Row\", placeholder: \"Summary Row\", type: \"subQuestion\", targetArray: \"fieldsMeta\", targetArrayKey: \"uniqueIdentifier\", key: \"summaryRow\",\n    subQuestion: [\n      { label: \"Type\", placeholder: \"Employee Details\", type: \"text\", targetArray: \"fieldsMeta\", targetArrayKey: \"uniqueIdentifier\", key: \"fldType\" },\n      { label: \"operation\", placeholder: \"operation\", type: \"text\", targetArray: \"fieldsMeta\", targetArrayKey: \"uniqueIdentifier\", key: \"operation\" },\n      { label: \"column\", placeholder: \"Employee Details\", type: \"radio\", targetArray: \"fieldsMeta\", targetArrayKey: \"uniqueIdentifier\", key: \"column\" },\n      { label: \"operands\", placeholder: \"Employee Details\", type: \"array\", targetArray: \"fieldsMeta\", targetArrayKey: \"uniqueIdentifier\", key: \"operands\" },\n    ]\n  }\n]"]}
|