master-control 0.2.23 → 0.2.25

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.
@@ -67,32 +67,48 @@ export class MasterControlService {
67
67
  "matIconName": "edit",
68
68
  "displayTitle": "Edit",
69
69
  "toolTip": "Edit",
70
- "isSelected": true
70
+ "isSelected": false
71
71
  },
72
72
  {
73
73
  "matIconName": "info",
74
74
  "displayTitle": "Info",
75
75
  "toolTip": "Information",
76
- "isSelected": true
76
+ "isSelected": false
77
77
  },
78
78
  {
79
79
  "matIconName": "download",
80
80
  "displayTitle": "Download Documents",
81
81
  "toolTip": "Download Document",
82
- "isSelected": true
82
+ "isSelected": false
83
83
  },
84
84
  {
85
85
  "matIconName": "notifications_active",
86
86
  "displayTitle": "Send Reminder",
87
87
  "toolTip": "Send Reminder",
88
- "isSelected": true
88
+ "isSelected": false
89
89
  },
90
90
  {
91
91
  "matIconName": "link",
92
92
  "displayTitle": "Send Payment Link",
93
93
  "toolTip": "Payment Link",
94
- "isSelected": true
94
+ "isSelected": false
95
95
  },
96
+ {
97
+ "matIconName": "download",
98
+ "displayTitle": "Download Policy Document",
99
+ "toolTip": "Download Policy",
100
+ "isSelected": false
101
+ }, {
102
+ "matIconName": "visibility",
103
+ "displayTitle": "View Policy Document",
104
+ "toolTip": "View Policy",
105
+ "isSelected": false
106
+ }, {
107
+ "matIconName": "visibility",
108
+ "displayTitle": "View new BI",
109
+ "toolTip": "View new BI",
110
+ "isSelected": false
111
+ }
96
112
  ],
97
113
  "userSelectedOptions": {},
98
114
  "showPagination": "Y",
@@ -209,4 +225,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
209
225
  providedIn: 'root'
210
226
  }]
211
227
  }], ctorParameters: () => [] });
212
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"master-control.service.js","sourceRoot":"","sources":["../../../../projects/master-control/src/lib/master-control.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\r\n\r\n@Injectable({\r\n  providedIn: 'root'\r\n})\r\nexport class MasterControlService {\r\n\r\n  configData: any = {\r\n      \"iframe\": {\r\n        \"URLForIframe\": \"N\"\r\n      },\r\n      \"loader\": {\r\n        \"imageURL\": \"\",\r\n        \"imageAltText\": \"\",\r\n        \"text\": \"\",\r\n        \"imageCSS\": {\r\n          \"width\": \"\",\r\n          \"height\": \"\",\r\n          \"borderRadius\": \"\",\r\n          \"boxShadow\": \"\"\r\n        },\r\n        \"cardCSS\": {\r\n          \"width\": \"100%\",\r\n          \"height\": \"100%\",\r\n          \"backgroundColor\": \"#ffffff\",\r\n          \"borderRadius\": \"0px\",\r\n          \"boxShadow\": \"0px 0px 0px 0px rgba(0, 0, 0, 0)\",\r\n          \"alignItems\": \"center\"\r\n        },\r\n        \"textCSS\": {\r\n          \"fontSize\": \"\",\r\n          \"color\": \"\",\r\n          \"textAlign\": \"\",\r\n          \"fontWeight\": \"\"\r\n        },\r\n      \"loaderCSS\": {\r\n        \"display\": \"flex\",\r\n        \"justifyContent\": \"center\",\r\n        \"alignItems\": \"center\",\r\n        \"height\": \"60px\",\r\n        \"gap\": \"8px\",\r\n        \"dot\": {\r\n          \"width\": \"16px\",\r\n          \"height\": \"16px\",\r\n          \"background\": \"#1976d2\",\r\n          \"borderRadius\": \"50%\",\r\n          \"display\": \"inline-block\",\r\n          \"animation\": \"bounce 0.6s infinite alternate\"\r\n        },\r\n        \"dot2\": {\r\n          \"animationDelay\": \"0.2s\"\r\n        },\r\n        \"dot3\": {\r\n          \"animationDelay\": \"0.4s\"\r\n        },\r\n        \"@keyframes bounce\": {\r\n          \"to\": {\r\n            \"opacity\": 0.3,\r\n            \"transform\": \"translateY(-16px)\"\r\n          }\r\n        }\r\n      }\r\n      },\r\n      \"table\": {\r\n        \"showCheckBox\": true,\r\n        \"tableHeaders\": [],\r\n        \"tdData\": [],\r\n        \"showActions\": true,\r\n        \"actionOptions\": [\r\n          {\r\n            \"matIconName\": \"edit\",\r\n            \"displayTitle\": \"Edit\",\r\n            \"toolTip\": \"Edit\",\r\n            \"isSelected\":true\r\n          },\r\n          {\r\n            \"matIconName\": \"info\",\r\n            \"displayTitle\": \"Info\",\r\n            \"toolTip\": \"Information\",\r\n            \"isSelected\":true\r\n          },\r\n          {\r\n            \"matIconName\": \"download\",\r\n            \"displayTitle\": \"Download Documents\",\r\n            \"toolTip\": \"Download Document\",\r\n            \"isSelected\":true\r\n          },\r\n          {\r\n            \"matIconName\": \"notifications_active\",\r\n            \"displayTitle\": \"Send Reminder\",\r\n            \"toolTip\": \"Send Reminder\",\r\n            \"isSelected\":true\r\n          },\r\n          {\r\n            \"matIconName\": \"link\",\r\n            \"displayTitle\": \"Send Payment Link\",\r\n            \"toolTip\": \"Payment Link\",\r\n            \"isSelected\":true\r\n          },\r\n\r\n        ],\r\n        \"userSelectedOptions\": {},\r\n        \"showPagination\": \"Y\",\r\n        \"rowlength\": 3,\r\n        \"columnlength\": 4,\r\n      },\r\n      \"stepper\":{\r\n        \"stepperData\":[\r\n        {\r\n          \"defaultId\":1,\r\n          \"displayLabel\":\"stepper-1\",\r\n          \"imgIconUrl\":'https://cdn.godigit.com/digitPlusAssets/retail-life-icon/svgicon/check_circle.svg'\r\n        },\r\n        {\r\n          \"defaultId\":2,\r\n          \"displayLabel\":\"stepper-2\",\r\n          \"imgIconUrl\":'https://cdn.godigit.com/retail-life/check_circle_Endorsment.svg'\r\n        },\r\n        {\r\n          \"defaultId\":3,\r\n          \"displayLabel\":\"stepper-3\",\r\n          \"imgIconUrl\":'https://cdn.godigit.com/retail-life/Endorsement_pending.svg'\r\n        }\r\n      ]\r\n    }\r\n    }\r\n\r\n  snackbars: any = [\r\n    {\r\n      \"type\": \"Error\",\r\n      \"imageURL\": \"https://cdn.godigit.com/retail-life/alert-icon-lib.svg\",\r\n      \"imageCSS\": \"toaster-img\",\r\n      \"isShowLabel\": true,\r\n      \"labelCSS\": \"toaster-label\",\r\n      \"messageCSS\": \"toaster-msg\",\r\n      \"horizontalPosition\": \"\",\r\n      \"verticalPosition\": \"\",\r\n      \"duration\": 3000,\r\n      \"closeIconImageURL\": \"https://cdn.godigit.com/digitPlusAssets/retail-life-icon/svgicon/cross.svg\",\r\n      \"closeIconCSS\": \"cross\",\r\n      \"labelText\":\"A error toast\",\r\n      \"messageText\":\"Error message here\",\r\n      'toasterCSS':\"error-snackbar-card\"\r\n    },{\r\n      \"type\": \"Warning\",\r\n      \"imageURL\": \"https://cdn.godigit.com/retail-life/nudge-icon-lib.svg\",\r\n      \"imageCSS\": \"toaster-img\",\r\n      \"isShowLabel\": true,\r\n      \"labelCSS\": \"toaster-label\",\r\n      \"messageCSS\": \"toaster-msg\",\r\n      \"horizontalPosition\": \"\",\r\n      \"verticalPosition\": \"\",\r\n      \"duration\": 3000,\r\n      \"closeIconImageURL\": \"https://cdn.godigit.com/digitPlusAssets/retail-life-icon/svgicon/cross.svg\",\r\n      \"closeIconCSS\": \"cross\",\r\n      \"labelText\":\"A warning toast\",\r\n      \"messageText\":\"Warning message here\",\r\n      \"toasterCSS\":\"warning-snackbar-card\"\r\n    },{\r\n      \"type\": \"Success\",\r\n      \"imageURL\": \"https://cdn.godigit.com/retail-life/success-info-lib.svg\",\r\n      \"imageCSS\": \"toaster-img\",\r\n      \"isShowLabel\": true,\r\n      \"labelCSS\": \"toaster-label\",\r\n      \"messageCSS\": \"toaster-msg\",\r\n      \"horizontalPosition\": \"\",\r\n      \"verticalPosition\": \"\",\r\n      \"duration\": 3000,\r\n      \"closeIconImageURL\": \"https://cdn.godigit.com/digitPlusAssets/retail-life-icon/svgicon/cross.svg\",\r\n      \"closeIconCSS\": \"cross\",\r\n      \"labelText\":\"A success toast\",\r\n      \"messageText\":\"Success message here\",\r\n      \"toasterCSS\":\"success-snackbar-card\"\r\n    },{\r\n      \"type\": \"Neutral\",\r\n      \"imageURL\": \"https://cdn.godigit.com/retail-life/neutral-star-lib-icon.svg\",\r\n      \"imageCSS\": \"neutral-image\",\r\n      \"isShowLabel\": true,\r\n      \"labelCSS\": \"neutral-toaster-label\",\r\n      \"messageCSS\": \"neutral-toaster-msg\",\r\n      \"horizontalPosition\": \"\",\r\n      \"verticalPosition\": \"\",\r\n      \"duration\": 3000,\r\n      \"closeIconImageURL\": \"https://cdn.godigit.com/retail-life/neutral-cross-lib-icon.svg\",\r\n      \"closeIconCSS\": \"cross\",\r\n      \"labelText\":\"A neutral toast\",\r\n      \"messageText\":\"Neutral message here\",\r\n      \"toasterCSS\":\"neutral-snackbar-card\"\r\n    }\r\n  ];\r\n  constructor() { }\r\n\r\n  checkIfValueIsEmpty(value: any) {\r\n    if (typeof value === 'string') {\r\n      value = value.trim();\r\n    }\r\n    return (\r\n      value === undefined ||\r\n      value === null ||\r\n      value === '' ||\r\n      (value instanceof Array && value.length === 0) ||\r\n      JSON.stringify(value) === '{}'\r\n    );\r\n  }\r\n\r\n  saveTableFieldState(tableField: any, key: any = 'tableField') {\r\n    localStorage.setItem(key, JSON.stringify(tableField));\r\n  }\r\n\r\n  restoreTableFieldState(key: any = 'tableField'): any | null {\r\n    const data = localStorage.getItem(key);\r\n    return data ? JSON.parse(data) : null;\r\n  }\r\n}\r\n"]}
228
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"master-control.service.js","sourceRoot":"","sources":["../../../../projects/master-control/src/lib/master-control.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\r\n\r\n@Injectable({\r\n  providedIn: 'root'\r\n})\r\nexport class MasterControlService {\r\n\r\n  configData: any = {\r\n      \"iframe\": {\r\n        \"URLForIframe\": \"N\"\r\n      },\r\n      \"loader\": {\r\n        \"imageURL\": \"\",\r\n        \"imageAltText\": \"\",\r\n        \"text\": \"\",\r\n        \"imageCSS\": {\r\n          \"width\": \"\",\r\n          \"height\": \"\",\r\n          \"borderRadius\": \"\",\r\n          \"boxShadow\": \"\"\r\n        },\r\n        \"cardCSS\": {\r\n          \"width\": \"100%\",\r\n          \"height\": \"100%\",\r\n          \"backgroundColor\": \"#ffffff\",\r\n          \"borderRadius\": \"0px\",\r\n          \"boxShadow\": \"0px 0px 0px 0px rgba(0, 0, 0, 0)\",\r\n          \"alignItems\": \"center\"\r\n        },\r\n        \"textCSS\": {\r\n          \"fontSize\": \"\",\r\n          \"color\": \"\",\r\n          \"textAlign\": \"\",\r\n          \"fontWeight\": \"\"\r\n        },\r\n      \"loaderCSS\": {\r\n        \"display\": \"flex\",\r\n        \"justifyContent\": \"center\",\r\n        \"alignItems\": \"center\",\r\n        \"height\": \"60px\",\r\n        \"gap\": \"8px\",\r\n        \"dot\": {\r\n          \"width\": \"16px\",\r\n          \"height\": \"16px\",\r\n          \"background\": \"#1976d2\",\r\n          \"borderRadius\": \"50%\",\r\n          \"display\": \"inline-block\",\r\n          \"animation\": \"bounce 0.6s infinite alternate\"\r\n        },\r\n        \"dot2\": {\r\n          \"animationDelay\": \"0.2s\"\r\n        },\r\n        \"dot3\": {\r\n          \"animationDelay\": \"0.4s\"\r\n        },\r\n        \"@keyframes bounce\": {\r\n          \"to\": {\r\n            \"opacity\": 0.3,\r\n            \"transform\": \"translateY(-16px)\"\r\n          }\r\n        }\r\n      }\r\n      },\r\n      \"table\": {\r\n        \"showCheckBox\": true,\r\n        \"tableHeaders\": [],\r\n        \"tdData\": [],\r\n        \"showActions\": true,\r\n        \"actionOptions\": [\r\n          {\r\n            \"matIconName\": \"edit\",\r\n            \"displayTitle\": \"Edit\",\r\n            \"toolTip\": \"Edit\",\r\n            \"isSelected\":false\r\n          },\r\n          {\r\n            \"matIconName\": \"info\",\r\n            \"displayTitle\": \"Info\",\r\n            \"toolTip\": \"Information\",\r\n            \"isSelected\":false\r\n          },\r\n          {\r\n            \"matIconName\": \"download\",\r\n            \"displayTitle\": \"Download Documents\",\r\n            \"toolTip\": \"Download Document\",\r\n            \"isSelected\":false\r\n          },\r\n          {\r\n            \"matIconName\": \"notifications_active\",\r\n            \"displayTitle\": \"Send Reminder\",\r\n            \"toolTip\": \"Send Reminder\",\r\n            \"isSelected\":false\r\n          },\r\n          {\r\n            \"matIconName\": \"link\",\r\n            \"displayTitle\": \"Send Payment Link\",\r\n            \"toolTip\": \"Payment Link\",\r\n            \"isSelected\":false\r\n          },\r\n           {\r\n            \"matIconName\": \"download\",\r\n            \"displayTitle\": \"Download Policy Document\",\r\n            \"toolTip\": \"Download Policy\",\r\n            \"isSelected\":false\r\n          }, {\r\n            \"matIconName\": \"visibility\",\r\n            \"displayTitle\": \"View Policy Document\",\r\n            \"toolTip\": \"View Policy\",\r\n            \"isSelected\":false\r\n          }, {\r\n            \"matIconName\": \"visibility\",\r\n            \"displayTitle\": \"View new BI\",\r\n            \"toolTip\": \"View new BI\",\r\n            \"isSelected\":false\r\n          }\r\n\r\n        ],\r\n        \"userSelectedOptions\": {},\r\n        \"showPagination\": \"Y\",\r\n        \"rowlength\": 3,\r\n        \"columnlength\": 4,\r\n      },\r\n      \"stepper\":{\r\n        \"stepperData\":[\r\n        {\r\n          \"defaultId\":1,\r\n          \"displayLabel\":\"stepper-1\",\r\n          \"imgIconUrl\":'https://cdn.godigit.com/digitPlusAssets/retail-life-icon/svgicon/check_circle.svg'\r\n        },\r\n        {\r\n          \"defaultId\":2,\r\n          \"displayLabel\":\"stepper-2\",\r\n          \"imgIconUrl\":'https://cdn.godigit.com/retail-life/check_circle_Endorsment.svg'\r\n        },\r\n        {\r\n          \"defaultId\":3,\r\n          \"displayLabel\":\"stepper-3\",\r\n          \"imgIconUrl\":'https://cdn.godigit.com/retail-life/Endorsement_pending.svg'\r\n        }\r\n      ]\r\n    }\r\n    }\r\n\r\n  snackbars: any = [\r\n    {\r\n      \"type\": \"Error\",\r\n      \"imageURL\": \"https://cdn.godigit.com/retail-life/alert-icon-lib.svg\",\r\n      \"imageCSS\": \"toaster-img\",\r\n      \"isShowLabel\": true,\r\n      \"labelCSS\": \"toaster-label\",\r\n      \"messageCSS\": \"toaster-msg\",\r\n      \"horizontalPosition\": \"\",\r\n      \"verticalPosition\": \"\",\r\n      \"duration\": 3000,\r\n      \"closeIconImageURL\": \"https://cdn.godigit.com/digitPlusAssets/retail-life-icon/svgicon/cross.svg\",\r\n      \"closeIconCSS\": \"cross\",\r\n      \"labelText\":\"A error toast\",\r\n      \"messageText\":\"Error message here\",\r\n      'toasterCSS':\"error-snackbar-card\"\r\n    },{\r\n      \"type\": \"Warning\",\r\n      \"imageURL\": \"https://cdn.godigit.com/retail-life/nudge-icon-lib.svg\",\r\n      \"imageCSS\": \"toaster-img\",\r\n      \"isShowLabel\": true,\r\n      \"labelCSS\": \"toaster-label\",\r\n      \"messageCSS\": \"toaster-msg\",\r\n      \"horizontalPosition\": \"\",\r\n      \"verticalPosition\": \"\",\r\n      \"duration\": 3000,\r\n      \"closeIconImageURL\": \"https://cdn.godigit.com/digitPlusAssets/retail-life-icon/svgicon/cross.svg\",\r\n      \"closeIconCSS\": \"cross\",\r\n      \"labelText\":\"A warning toast\",\r\n      \"messageText\":\"Warning message here\",\r\n      \"toasterCSS\":\"warning-snackbar-card\"\r\n    },{\r\n      \"type\": \"Success\",\r\n      \"imageURL\": \"https://cdn.godigit.com/retail-life/success-info-lib.svg\",\r\n      \"imageCSS\": \"toaster-img\",\r\n      \"isShowLabel\": true,\r\n      \"labelCSS\": \"toaster-label\",\r\n      \"messageCSS\": \"toaster-msg\",\r\n      \"horizontalPosition\": \"\",\r\n      \"verticalPosition\": \"\",\r\n      \"duration\": 3000,\r\n      \"closeIconImageURL\": \"https://cdn.godigit.com/digitPlusAssets/retail-life-icon/svgicon/cross.svg\",\r\n      \"closeIconCSS\": \"cross\",\r\n      \"labelText\":\"A success toast\",\r\n      \"messageText\":\"Success message here\",\r\n      \"toasterCSS\":\"success-snackbar-card\"\r\n    },{\r\n      \"type\": \"Neutral\",\r\n      \"imageURL\": \"https://cdn.godigit.com/retail-life/neutral-star-lib-icon.svg\",\r\n      \"imageCSS\": \"neutral-image\",\r\n      \"isShowLabel\": true,\r\n      \"labelCSS\": \"neutral-toaster-label\",\r\n      \"messageCSS\": \"neutral-toaster-msg\",\r\n      \"horizontalPosition\": \"\",\r\n      \"verticalPosition\": \"\",\r\n      \"duration\": 3000,\r\n      \"closeIconImageURL\": \"https://cdn.godigit.com/retail-life/neutral-cross-lib-icon.svg\",\r\n      \"closeIconCSS\": \"cross\",\r\n      \"labelText\":\"A neutral toast\",\r\n      \"messageText\":\"Neutral message here\",\r\n      \"toasterCSS\":\"neutral-snackbar-card\"\r\n    }\r\n  ];\r\n  constructor() { }\r\n\r\n  checkIfValueIsEmpty(value: any) {\r\n    if (typeof value === 'string') {\r\n      value = value.trim();\r\n    }\r\n    return (\r\n      value === undefined ||\r\n      value === null ||\r\n      value === '' ||\r\n      (value instanceof Array && value.length === 0) ||\r\n      JSON.stringify(value) === '{}'\r\n    );\r\n  }\r\n\r\n  saveTableFieldState(tableField: any, key: any = 'tableField') {\r\n    localStorage.setItem(key, JSON.stringify(tableField));\r\n  }\r\n\r\n  restoreTableFieldState(key: any = 'tableField'): any | null {\r\n    const data = localStorage.getItem(key);\r\n    return data ? JSON.parse(data) : null;\r\n  }\r\n}\r\n"]}
@@ -0,0 +1,78 @@
1
+ import { CommonModule } from '@angular/common';
2
+ import { Component, input } from '@angular/core';
3
+ import { FormsModule, ReactiveFormsModule } from '@angular/forms';
4
+ import { MatAutocompleteModule } from '@angular/material/autocomplete';
5
+ import { MatOptionModule } from '@angular/material/core';
6
+ import { MatFormFieldModule } from '@angular/material/form-field';
7
+ import { MatInputModule } from '@angular/material/input';
8
+ import { MatSelectModule } from '@angular/material/select';
9
+ import * as i0 from "@angular/core";
10
+ import * as i1 from "@angular/common";
11
+ export class MenuComponent {
12
+ constructor() { }
13
+ showProfileMenu = false;
14
+ field = input.required();
15
+ inputValue = null;
16
+ onChange = () => { };
17
+ onTouched = () => { };
18
+ writeValue(value) {
19
+ this.inputValue = value;
20
+ }
21
+ registerOnChange(fn) {
22
+ this.onChange = fn;
23
+ }
24
+ registerOnTouched(fn) {
25
+ this.onTouched = fn;
26
+ }
27
+ onValueChange(newValue) {
28
+ this.inputValue = newValue;
29
+ this.onChange(newValue);
30
+ this.onTouched();
31
+ }
32
+ selectionChanged(event) {
33
+ this.inputValue = event.value;
34
+ this.onChange(event.value);
35
+ this.onTouched();
36
+ }
37
+ // onSelectOpened(opened: boolean) {
38
+ // const css = this.field()?.controlStyle;
39
+ // if (opened) {
40
+ // document.body.style.setProperty('--custom-select-option-background-color', css?.dropdownOptionBgColor || '#fff');
41
+ // document.body.style.setProperty('--custom-select-option-font-color', css?.dropdownOptionColor || '#444');
42
+ // document.body.style.setProperty('--custom-select-option-font-weight', css?.dropdownOptionFontWeight || '400');
43
+ // document.body.style.setProperty('--custom-select-option-background-color-focus', css?.focusDropdownOptionBgColor || '#fff');
44
+ // document.body.style.setProperty('--custom-select-option-font-color-focus', css?.focusDropdownOptionColor || '#444');
45
+ // document.body.style.setProperty('--custom-select-option-font-weight-focus', css?.focusDropdownOptionFontWeight || '400');
46
+ // document.body.style.setProperty('--custom-select-option-border-left-focus', css?.focusDropdownOptionBorderLeft || '#ffbb00');
47
+ // document.body.style.setProperty('--custom-select-option-border-radius-focus', css?.focusDropdownOptionBorderRadius || '#ffbb00');
48
+ // } else {
49
+ // document.body.style.removeProperty('--custom-select-option-background-color');
50
+ // document.body.style.removeProperty('--custom-select-option-font-color');
51
+ // document.body.style.removeProperty('--custom-select-option-font-weight');
52
+ // document.body.style.removeProperty('--custom-select-option-background-color-focus');
53
+ // document.body.style.removeProperty('--custom-select-option-font-color-focus');
54
+ // document.body.style.removeProperty('--custom-select-option-font-weight-focus');
55
+ // document.body.style.removeProperty('--custom-select-option-border-left-focus');
56
+ // document.body.style.removeProperty('--custom-select-option-border-radius-focus');
57
+ // }
58
+ // }
59
+ toggleProfileMenu() {
60
+ this.showProfileMenu = !this.showProfileMenu;
61
+ }
62
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MenuComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
63
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.2.13", type: MenuComponent, isStandalone: true, selector: "lib-menu", inputs: { field: { classPropertyName: "field", publicName: "field", isSignal: true, isRequired: true, transformFunction: null } }, ngImport: i0, template: "<div\r\n (click)=\"toggleProfileMenu()\"\r\n class=\"menu-container d-flex align-items-center\"\r\n role=\"button\"\r\n>\r\n<!-- [src]=\"field()?.configData?.prefixImage\" -->\r\n <img\r\n [src]=\"field()?.configData?.prefixImage\"\r\n alt=\"Profile\"\r\n class=\"rounded-circle me-2\"\r\n width=\"36\"\r\n height=\"36\"\r\n />\r\n <span class=\"menu-main-text ps-1 pe-2\">{{field()?.configData?.maintext}}</span>\r\n <span *ngIf=\"field()?.configData?.isShowDropdownArrow\" class=\"arrow\"></span>\r\n</div>\r\n\r\n<div\r\n *ngIf=\"showProfileMenu\"\r\n class=\"profile-menu top-100 end-0 bg-white border border-warning rounded-3 shadow-sm mt-2\"\r\n>\r\n <div class=\"profile-menu-caret\"></div>\r\n <ul class=\"list-unstyled m-0 py-2\">\r\n <li\r\n class=\"px-3 py-2 text-nowrap\"\r\n *ngFor=\"let singleOption of field()?.options\"\r\n >\r\n {{singleOption['label']}}\r\n </li>\r\n </ul>\r\n</div>\r\n", styles: [".menu-container{display:flex;justify-content:space-between;align-items:center;background:#f5f5f5;padding:6px 12px;border:1px solid #F5F5F5;border-radius:25px}.profile-menu-caret{position:relative;top:-11px;right:-50%;width:0;height:0;border-left:10px solid transparent;border-right:10px solid transparent;border-bottom:11px solid #fa0;z-index:1}.profile-menu-caret:after{content:\"\";position:absolute;left:-9.8px;top:1.7px;width:0;height:0;border-left:10px solid transparent;border-right:10px solid transparent;border-bottom:10px solid #fff;z-index:2}.arrow{border-style:solid!important;border-width:0 2px 2px 0!important;border-right:2px solid!important;content:\"\"!important;display:inline-block!important;padding:3px!important;transform:rotate(45deg)!important;vertical-align:middle!important;width:unset!important;height:unset!important;color:#444!important}.menu-main-text{font-size:16px;font-weight:700}\n"], dependencies: [{ kind: "ngmodule", type: MatSelectModule }, { kind: "ngmodule", type: MatFormFieldModule }, { kind: "ngmodule", type: MatAutocompleteModule }, { kind: "ngmodule", type: MatInputModule }, { kind: "ngmodule", type: FormsModule }, { kind: "ngmodule", type: MatOptionModule }, { kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "ngmodule", type: ReactiveFormsModule }] });
64
+ }
65
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MenuComponent, decorators: [{
66
+ type: Component,
67
+ args: [{ selector: 'lib-menu', standalone: true, imports: [
68
+ MatSelectModule,
69
+ MatFormFieldModule,
70
+ MatAutocompleteModule,
71
+ MatInputModule,
72
+ FormsModule,
73
+ MatOptionModule,
74
+ CommonModule,
75
+ ReactiveFormsModule,
76
+ ], template: "<div\r\n (click)=\"toggleProfileMenu()\"\r\n class=\"menu-container d-flex align-items-center\"\r\n role=\"button\"\r\n>\r\n<!-- [src]=\"field()?.configData?.prefixImage\" -->\r\n <img\r\n [src]=\"field()?.configData?.prefixImage\"\r\n alt=\"Profile\"\r\n class=\"rounded-circle me-2\"\r\n width=\"36\"\r\n height=\"36\"\r\n />\r\n <span class=\"menu-main-text ps-1 pe-2\">{{field()?.configData?.maintext}}</span>\r\n <span *ngIf=\"field()?.configData?.isShowDropdownArrow\" class=\"arrow\"></span>\r\n</div>\r\n\r\n<div\r\n *ngIf=\"showProfileMenu\"\r\n class=\"profile-menu top-100 end-0 bg-white border border-warning rounded-3 shadow-sm mt-2\"\r\n>\r\n <div class=\"profile-menu-caret\"></div>\r\n <ul class=\"list-unstyled m-0 py-2\">\r\n <li\r\n class=\"px-3 py-2 text-nowrap\"\r\n *ngFor=\"let singleOption of field()?.options\"\r\n >\r\n {{singleOption['label']}}\r\n </li>\r\n </ul>\r\n</div>\r\n", styles: [".menu-container{display:flex;justify-content:space-between;align-items:center;background:#f5f5f5;padding:6px 12px;border:1px solid #F5F5F5;border-radius:25px}.profile-menu-caret{position:relative;top:-11px;right:-50%;width:0;height:0;border-left:10px solid transparent;border-right:10px solid transparent;border-bottom:11px solid #fa0;z-index:1}.profile-menu-caret:after{content:\"\";position:absolute;left:-9.8px;top:1.7px;width:0;height:0;border-left:10px solid transparent;border-right:10px solid transparent;border-bottom:10px solid #fff;z-index:2}.arrow{border-style:solid!important;border-width:0 2px 2px 0!important;border-right:2px solid!important;content:\"\"!important;display:inline-block!important;padding:3px!important;transform:rotate(45deg)!important;vertical-align:middle!important;width:unset!important;height:unset!important;color:#444!important}.menu-main-text{font-size:16px;font-weight:700}\n"] }]
77
+ }], ctorParameters: () => [] });
78
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"menu.component.js","sourceRoot":"","sources":["../../../../../projects/master-control/src/lib/menu/menu.component.ts","../../../../../projects/master-control/src/lib/menu/menu.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,SAAS,EAAE,KAAK,EAAE,MAAM,eAAe,CAAC;AACjD,OAAO,EAAwB,WAAW,EAAqB,mBAAmB,EAAE,MAAM,gBAAgB,CAAC;AAC3G,OAAO,EAAE,qBAAqB,EAAE,MAAM,gCAAgC,CAAC;AACvE,OAAO,EAAE,eAAe,EAAE,MAAM,wBAAwB,CAAC;AACzD,OAAO,EAAE,kBAAkB,EAAE,MAAM,8BAA8B,CAAC;AAClE,OAAO,EAAE,cAAc,EAAE,MAAM,yBAAyB,CAAC;AAEzD,OAAO,EAAmB,eAAe,EAAE,MAAM,0BAA0B,CAAC;;;AAkB5E,MAAM,OAAO,aAAa;IACxB,gBAAe,CAAC;IAChB,eAAe,GAAG,KAAK,CAAC;IACxB,KAAK,GAAS,KAAK,CAAC,QAAQ,EAAO,CAAC;IACpC,UAAU,GAAQ,IAAI,CAAC;IAEvB,QAAQ,GAAQ,GAAG,EAAE,GAAE,CAAC,CAAC;IACzB,SAAS,GAAQ,GAAG,EAAE,GAAE,CAAC,CAAC;IAE1B,UAAU,CAAC,KAAU;QACnB,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;IAC1B,CAAC;IAED,gBAAgB,CAAC,EAAO;QACtB,IAAI,CAAC,QAAQ,GAAG,EAAE,CAAC;IACrB,CAAC;IAED,iBAAiB,CAAC,EAAO;QACvB,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC;IACtB,CAAC;IAED,aAAa,CAAC,QAAa;QACzB,IAAI,CAAC,UAAU,GAAG,QAAQ,CAAC;QAC3B,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC;QACxB,IAAI,CAAC,SAAS,EAAE,CAAC;IACnB,CAAC;IAED,gBAAgB,CAAC,KAAsB;QACrC,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC,KAAK,CAAC;QAC9B,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;QAC3B,IAAI,CAAC,SAAS,EAAE,CAAC;IACnB,CAAC;IAED,oCAAoC;IACpC,4CAA4C;IAC5C,kBAAkB;IAClB,wHAAwH;IACxH,gHAAgH;IAChH,qHAAqH;IACrH,mIAAmI;IACnI,2HAA2H;IAC3H,gIAAgI;IAChI,oIAAoI;IACpI,wIAAwI;IACxI,aAAa;IACb,qFAAqF;IACrF,+EAA+E;IAC/E,gFAAgF;IAChF,2FAA2F;IAC3F,qFAAqF;IACrF,sFAAsF;IACtF,sFAAsF;IACtF,wFAAwF;IACxF,MAAM;IACN,IAAI;IAEN,iBAAiB;QACf,IAAI,CAAC,eAAe,GAAG,CAAC,IAAI,CAAC,eAAe,CAAC;IAC/C,CAAC;wGA1DY,aAAa;4FAAb,aAAa,uMC1B1B,87BA+BA,08BDjBI,eAAe,8BACf,kBAAkB,8BAClB,qBAAqB,8BACrB,cAAc,8BACd,WAAW,8BACX,eAAe,8BACf,YAAY,+PACZ,mBAAmB;;4FAKV,aAAa;kBAhBzB,SAAS;+BACE,UAAU,cACR,IAAI,WACP;wBACP,eAAe;wBACf,kBAAkB;wBAClB,qBAAqB;wBACrB,cAAc;wBACd,WAAW;wBACX,eAAe;wBACf,YAAY;wBACZ,mBAAmB;qBACpB","sourcesContent":["import { CommonModule } from '@angular/common';\r\nimport { Component, input } from '@angular/core';\r\nimport { ControlValueAccessor, FormsModule, NG_VALUE_ACCESSOR, ReactiveFormsModule } from '@angular/forms';\r\nimport { MatAutocompleteModule } from '@angular/material/autocomplete';\r\nimport { MatOptionModule } from '@angular/material/core';\r\nimport { MatFormFieldModule } from '@angular/material/form-field';\r\nimport { MatInputModule } from '@angular/material/input';\r\nimport { MasterControlService } from '../master-control.service';\r\nimport { MatSelectChange, MatSelectModule } from '@angular/material/select';\r\n\r\n@Component({\r\n  selector: 'lib-menu',\r\n  standalone: true,\r\n  imports: [\r\n    MatSelectModule,\r\n    MatFormFieldModule,\r\n    MatAutocompleteModule,\r\n    MatInputModule,\r\n    FormsModule,\r\n    MatOptionModule,\r\n    CommonModule,\r\n    ReactiveFormsModule,\r\n  ],\r\n  templateUrl: './menu.component.html',\r\n  styleUrl: './menu.component.css'\r\n})\r\nexport class MenuComponent implements ControlValueAccessor {\r\n  constructor() {}\r\n  showProfileMenu = false;\r\n  field : any = input.required<any>();\r\n  inputValue: any = null;\r\n\r\n  onChange: any = () => {};\r\n  onTouched: any = () => {};\r\n\r\n  writeValue(value: any): void {\r\n    this.inputValue = value;\r\n  }\r\n\r\n  registerOnChange(fn: any): void {\r\n    this.onChange = fn;\r\n  }\r\n\r\n  registerOnTouched(fn: any): void {\r\n    this.onTouched = fn;\r\n  }\r\n\r\n  onValueChange(newValue: any): void {\r\n    this.inputValue = newValue;\r\n    this.onChange(newValue);\r\n    this.onTouched();\r\n  }\r\n\r\n  selectionChanged(event: MatSelectChange) {\r\n    this.inputValue = event.value;\r\n    this.onChange(event.value);\r\n    this.onTouched();\r\n  }\r\n\r\n  // onSelectOpened(opened: boolean) {\r\n  //   const css = this.field()?.controlStyle;\r\n  //   if (opened) {\r\n  //     document.body.style.setProperty('--custom-select-option-background-color', css?.dropdownOptionBgColor || '#fff');\r\n  //     document.body.style.setProperty('--custom-select-option-font-color', css?.dropdownOptionColor || '#444');\r\n  //     document.body.style.setProperty('--custom-select-option-font-weight', css?.dropdownOptionFontWeight || '400');\r\n  //     document.body.style.setProperty('--custom-select-option-background-color-focus', css?.focusDropdownOptionBgColor || '#fff');\r\n  //     document.body.style.setProperty('--custom-select-option-font-color-focus', css?.focusDropdownOptionColor || '#444');\r\n  //     document.body.style.setProperty('--custom-select-option-font-weight-focus', css?.focusDropdownOptionFontWeight || '400');\r\n  //     document.body.style.setProperty('--custom-select-option-border-left-focus', css?.focusDropdownOptionBorderLeft || '#ffbb00');\r\n  //     document.body.style.setProperty('--custom-select-option-border-radius-focus', css?.focusDropdownOptionBorderRadius || '#ffbb00');\r\n  //   } else {\r\n  //     document.body.style.removeProperty('--custom-select-option-background-color');\r\n  //     document.body.style.removeProperty('--custom-select-option-font-color');\r\n  //     document.body.style.removeProperty('--custom-select-option-font-weight');\r\n  //     document.body.style.removeProperty('--custom-select-option-background-color-focus');\r\n  //     document.body.style.removeProperty('--custom-select-option-font-color-focus');\r\n  //     document.body.style.removeProperty('--custom-select-option-font-weight-focus');\r\n  //     document.body.style.removeProperty('--custom-select-option-border-left-focus');\r\n  //     document.body.style.removeProperty('--custom-select-option-border-radius-focus');\r\n  //   }\r\n  // }\r\n\r\ntoggleProfileMenu() {\r\n  this.showProfileMenu = !this.showProfileMenu;\r\n}\r\n\r\n\r\n}\r\n","<div\r\n  (click)=\"toggleProfileMenu()\"\r\n  class=\"menu-container d-flex align-items-center\"\r\n  role=\"button\"\r\n>\r\n<!-- [src]=\"field()?.configData?.prefixImage\" -->\r\n  <img\r\n    [src]=\"field()?.configData?.prefixImage\"\r\n    alt=\"Profile\"\r\n    class=\"rounded-circle me-2\"\r\n    width=\"36\"\r\n    height=\"36\"\r\n  />\r\n  <span class=\"menu-main-text ps-1 pe-2\">{{field()?.configData?.maintext}}</span>\r\n  <span *ngIf=\"field()?.configData?.isShowDropdownArrow\" class=\"arrow\"></span>\r\n</div>\r\n\r\n<div\r\n  *ngIf=\"showProfileMenu\"\r\n  class=\"profile-menu top-100 end-0 bg-white border border-warning rounded-3 shadow-sm mt-2\"\r\n>\r\n  <div class=\"profile-menu-caret\"></div>\r\n  <ul class=\"list-unstyled m-0 py-2\">\r\n    <li\r\n      class=\"px-3 py-2 text-nowrap\"\r\n      *ngFor=\"let singleOption of field()?.options\"\r\n    >\r\n      {{singleOption['label']}}\r\n    </li>\r\n  </ul>\r\n</div>\r\n"]}
@@ -21,12 +21,12 @@ export class TabComponent {
21
21
  this.field().selectedIndex = this.selectedIndex;
22
22
  }
23
23
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: TabComponent, deps: [{ token: i1.MasterControlService }], target: i0.ɵɵFactoryTarget.Component });
24
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.2.13", type: TabComponent, isStandalone: true, selector: "lib-tab", inputs: { field: { classPropertyName: "field", publicName: "field", isSignal: true, isRequired: true, transformFunction: null } }, outputs: { selectedIndexChange: "selectedIndexChange" }, ngImport: i0, template: "<mat-tab-group *ngIf=\"field() && field()?.isVisible\" class=\"vertical-tab-indicator\"\r\n[ngClass]=\"{'vertical-class': field()?.configData?.isVerticalTab && field()?.configData?.isVerticalTab === 'true'}\"\r\n[ngStyle]=\"{\r\n '--tab-border-color': field()?.controlStyle?.borderColor ,\r\n '--tab-border-width': field()?.controlStyle?.borderWidth,\r\n '--tab-font-size': field()?.controlStyle?.fontSize,\r\n '--tab-font-weight': field()?.controlStyle?.fontWeight,\r\n '--tab-font-color': field()?.controlStyle?.color,\r\n }\"\r\n[(selectedIndex)]=\"selectedIndex\" (selectedIndexChange)=\"onTabChange($event)\">\r\n <mat-tab *ngFor=\"let data of field()?.options; let i = index\">\r\n <ng-template mat-tab-label>\r\n <img [src]=\"data.value\" alt=\"\" class=\"mx-2\">\r\n {{ data.label }}\r\n </ng-template>\r\n <ng-content select=\"tab[i]\"></ng-content>\r\n </mat-tab>\r\n</mat-tab-group>\r\n", styles: ["*{font-family:mulish!important}::ng-deep .mat-mdc-tab.mdc-tab--active .mdc-tab__text-label{font-weight:var(--tab-font-weight, 800)!important}::ng-deep .mdc-tab__text-label{font-size:var(--tab-font-size, 16px)!important;color:var(--tab-font-color, #444)!important}::ng-deep .mat-mdc-tab-group .mdc-tab-indicator__content--underline{border-color:var(--tab-border-color, #FFBB00)!important;border-width:var(--tab-border-width, 3px)!important;border-top-left-radius:6px!important;border-top-right-radius:6px!important}::ng-deep .mat-mdc-tab-label-container{border-bottom:1px solid #dadada!important}::ng-deep .vertical-class .mdc-tab-indicator .mdc-tab-indicator__content{border:none!important}::ng-deep .vertical-class .mat-mdc-tab.mdc-tab--active .mat-mdc-tab-ripple{border-right:var(--tab-border-width, 4px) solid var(--tab-border-color, #ffbb00)!important;box-shadow:0 2px 4px #00000015;border-left:1px solid #DDDDDD;border-top:1px solid #DDDDDD;border-bottom:1px solid #DDDDDD}::ng-deep .vertical-class .mdc-tab-indicator__content .mdc-tab-indicator__content--underline{border:none!important}::ng-deep .vertical-class .mat-mdc-tab-labels{display:table-row!important}\n"], dependencies: [{ kind: "ngmodule", type: MatTabsModule }, { kind: "directive", type: i2.MatTabLabel, selector: "[mat-tab-label], [matTabLabel]" }, { kind: "component", type: i2.MatTab, selector: "mat-tab", inputs: ["disabled", "label", "aria-label", "aria-labelledby", "labelClass", "bodyClass"], exportAs: ["matTab"] }, { kind: "component", type: i2.MatTabGroup, selector: "mat-tab-group", inputs: ["color", "fitInkBarToContent", "mat-stretch-tabs", "dynamicHeight", "selectedIndex", "headerPosition", "animationDuration", "contentTabIndex", "disablePagination", "disableRipple", "preserveContent", "backgroundColor", "aria-label", "aria-labelledby"], outputs: ["selectedIndexChange", "focusChange", "animationDone", "selectedTabChange"], exportAs: ["matTabGroup"] }, { kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { 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: i3.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }] });
24
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.2.13", type: TabComponent, isStandalone: true, selector: "lib-tab", inputs: { field: { classPropertyName: "field", publicName: "field", isSignal: true, isRequired: true, transformFunction: null } }, outputs: { selectedIndexChange: "selectedIndexChange" }, ngImport: i0, template: "<mat-tab-group *ngIf=\"field() && field()?.isVisible\" class=\"vertical-tab-indicator\"\r\n[ngClass]=\"{'vertical-class': field()?.configData?.isVerticalTab && field()?.configData?.isVerticalTab === 'true'}\"\r\n[ngStyle]=\"{\r\n '--tab-border-color': field()?.controlStyle?.borderColor ,\r\n '--tab-border-width': field()?.controlStyle?.borderWidth,\r\n '--tab-font-size': field()?.controlStyle?.fontSize,\r\n '--tab-font-weight': field()?.controlStyle?.fontWeight,\r\n '--tab-font-color': field()?.controlStyle?.color,\r\n }\"\r\n[(selectedIndex)]=\"selectedIndex\" (selectedIndexChange)=\"onTabChange($event)\">\r\n <mat-tab *ngFor=\"let data of field()?.options; let i = index\">\r\n <ng-template mat-tab-label>\r\n <img [src]=\"data.value\" alt=\"\" class=\"mx-2\">\r\n {{ data.label }}\r\n </ng-template>\r\n <ng-content select=\"tab[i]\"></ng-content>\r\n </mat-tab>\r\n</mat-tab-group>\r\n", styles: ["*{font-family:mulish!important}::ng-deep .mat-mdc-tab.mdc-tab--active .mdc-tab__text-label{font-weight:var(--tab-font-weight, 800)!important}::ng-deep .mdc-tab__text-label{font-size:var(--tab-font-size, 16px)!important;color:var(--tab-font-color, #444)!important}::ng-deep .mat-mdc-tab-group .mdc-tab-indicator__content--underline{border-color:var(--tab-border-color, #FFBB00)!important;border-width:var(--tab-border-width, 3px)!important;border-top-left-radius:6px!important;border-top-right-radius:6px!important}::ng-deep .mat-mdc-tab-label-container{border-bottom:1px solid #dadada!important}::ng-deep .vertical-class .mdc-tab-indicator .mdc-tab-indicator__content{border:none!important}::ng-deep .vertical-class .mat-mdc-tab.mdc-tab--active .mat-mdc-tab-ripple{border-right:var(--tab-border-width, 4px) solid var(--tab-border-color, #ffbb00)!important;box-shadow:0 2px 4px #00000015;border-left:1px solid #DDDDDD;border-top:1px solid #DDDDDD;border-bottom:1px solid #DDDDDD;background:#fff!important}::ng-deep .vertical-class .mdc-tab-indicator__content .mdc-tab-indicator__content--underline{border:none!important}::ng-deep .vertical-class .mat-mdc-tab-labels{display:table-row!important;background:#fafafa!important}\n"], dependencies: [{ kind: "ngmodule", type: MatTabsModule }, { kind: "directive", type: i2.MatTabLabel, selector: "[mat-tab-label], [matTabLabel]" }, { kind: "component", type: i2.MatTab, selector: "mat-tab", inputs: ["disabled", "label", "aria-label", "aria-labelledby", "labelClass", "bodyClass"], exportAs: ["matTab"] }, { kind: "component", type: i2.MatTabGroup, selector: "mat-tab-group", inputs: ["color", "fitInkBarToContent", "mat-stretch-tabs", "dynamicHeight", "selectedIndex", "headerPosition", "animationDuration", "contentTabIndex", "disablePagination", "disableRipple", "preserveContent", "backgroundColor", "aria-label", "aria-labelledby"], outputs: ["selectedIndexChange", "focusChange", "animationDone", "selectedTabChange"], exportAs: ["matTabGroup"] }, { kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { 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: i3.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }] });
25
25
  }
26
26
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: TabComponent, decorators: [{
27
27
  type: Component,
28
- args: [{ selector: 'lib-tab', standalone: true, imports: [MatTabsModule, CommonModule], template: "<mat-tab-group *ngIf=\"field() && field()?.isVisible\" class=\"vertical-tab-indicator\"\r\n[ngClass]=\"{'vertical-class': field()?.configData?.isVerticalTab && field()?.configData?.isVerticalTab === 'true'}\"\r\n[ngStyle]=\"{\r\n '--tab-border-color': field()?.controlStyle?.borderColor ,\r\n '--tab-border-width': field()?.controlStyle?.borderWidth,\r\n '--tab-font-size': field()?.controlStyle?.fontSize,\r\n '--tab-font-weight': field()?.controlStyle?.fontWeight,\r\n '--tab-font-color': field()?.controlStyle?.color,\r\n }\"\r\n[(selectedIndex)]=\"selectedIndex\" (selectedIndexChange)=\"onTabChange($event)\">\r\n <mat-tab *ngFor=\"let data of field()?.options; let i = index\">\r\n <ng-template mat-tab-label>\r\n <img [src]=\"data.value\" alt=\"\" class=\"mx-2\">\r\n {{ data.label }}\r\n </ng-template>\r\n <ng-content select=\"tab[i]\"></ng-content>\r\n </mat-tab>\r\n</mat-tab-group>\r\n", styles: ["*{font-family:mulish!important}::ng-deep .mat-mdc-tab.mdc-tab--active .mdc-tab__text-label{font-weight:var(--tab-font-weight, 800)!important}::ng-deep .mdc-tab__text-label{font-size:var(--tab-font-size, 16px)!important;color:var(--tab-font-color, #444)!important}::ng-deep .mat-mdc-tab-group .mdc-tab-indicator__content--underline{border-color:var(--tab-border-color, #FFBB00)!important;border-width:var(--tab-border-width, 3px)!important;border-top-left-radius:6px!important;border-top-right-radius:6px!important}::ng-deep .mat-mdc-tab-label-container{border-bottom:1px solid #dadada!important}::ng-deep .vertical-class .mdc-tab-indicator .mdc-tab-indicator__content{border:none!important}::ng-deep .vertical-class .mat-mdc-tab.mdc-tab--active .mat-mdc-tab-ripple{border-right:var(--tab-border-width, 4px) solid var(--tab-border-color, #ffbb00)!important;box-shadow:0 2px 4px #00000015;border-left:1px solid #DDDDDD;border-top:1px solid #DDDDDD;border-bottom:1px solid #DDDDDD}::ng-deep .vertical-class .mdc-tab-indicator__content .mdc-tab-indicator__content--underline{border:none!important}::ng-deep .vertical-class .mat-mdc-tab-labels{display:table-row!important}\n"] }]
28
+ args: [{ selector: 'lib-tab', standalone: true, imports: [MatTabsModule, CommonModule], template: "<mat-tab-group *ngIf=\"field() && field()?.isVisible\" class=\"vertical-tab-indicator\"\r\n[ngClass]=\"{'vertical-class': field()?.configData?.isVerticalTab && field()?.configData?.isVerticalTab === 'true'}\"\r\n[ngStyle]=\"{\r\n '--tab-border-color': field()?.controlStyle?.borderColor ,\r\n '--tab-border-width': field()?.controlStyle?.borderWidth,\r\n '--tab-font-size': field()?.controlStyle?.fontSize,\r\n '--tab-font-weight': field()?.controlStyle?.fontWeight,\r\n '--tab-font-color': field()?.controlStyle?.color,\r\n }\"\r\n[(selectedIndex)]=\"selectedIndex\" (selectedIndexChange)=\"onTabChange($event)\">\r\n <mat-tab *ngFor=\"let data of field()?.options; let i = index\">\r\n <ng-template mat-tab-label>\r\n <img [src]=\"data.value\" alt=\"\" class=\"mx-2\">\r\n {{ data.label }}\r\n </ng-template>\r\n <ng-content select=\"tab[i]\"></ng-content>\r\n </mat-tab>\r\n</mat-tab-group>\r\n", styles: ["*{font-family:mulish!important}::ng-deep .mat-mdc-tab.mdc-tab--active .mdc-tab__text-label{font-weight:var(--tab-font-weight, 800)!important}::ng-deep .mdc-tab__text-label{font-size:var(--tab-font-size, 16px)!important;color:var(--tab-font-color, #444)!important}::ng-deep .mat-mdc-tab-group .mdc-tab-indicator__content--underline{border-color:var(--tab-border-color, #FFBB00)!important;border-width:var(--tab-border-width, 3px)!important;border-top-left-radius:6px!important;border-top-right-radius:6px!important}::ng-deep .mat-mdc-tab-label-container{border-bottom:1px solid #dadada!important}::ng-deep .vertical-class .mdc-tab-indicator .mdc-tab-indicator__content{border:none!important}::ng-deep .vertical-class .mat-mdc-tab.mdc-tab--active .mat-mdc-tab-ripple{border-right:var(--tab-border-width, 4px) solid var(--tab-border-color, #ffbb00)!important;box-shadow:0 2px 4px #00000015;border-left:1px solid #DDDDDD;border-top:1px solid #DDDDDD;border-bottom:1px solid #DDDDDD;background:#fff!important}::ng-deep .vertical-class .mdc-tab-indicator__content .mdc-tab-indicator__content--underline{border:none!important}::ng-deep .vertical-class .mat-mdc-tab-labels{display:table-row!important;background:#fafafa!important}\n"] }]
29
29
  }], ctorParameters: () => [{ type: i1.MasterControlService }], propDecorators: { selectedIndexChange: [{
30
30
  type: Output
31
31
  }] } });
32
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFiLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL21hc3Rlci1jb250cm9sL3NyYy9saWIvdGFiL3RhYi5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9tYXN0ZXItY29udHJvbC9zcmMvbGliL3RhYi90YWIuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxTQUFTLEVBQUUsWUFBWSxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDdkUsT0FBTyxFQUFxQixhQUFhLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQzs7Ozs7QUFVMUUsTUFBTSxPQUFPLFlBQVk7SUFLTjtJQUpuQixLQUFLLEdBQVMsS0FBSyxDQUFDLFFBQVEsRUFBTyxDQUFDO0lBQzFCLG1CQUFtQixHQUFHLElBQUksWUFBWSxFQUFVLENBQUM7SUFDM0QsYUFBYSxHQUFHLENBQUMsQ0FBQztJQUVsQixZQUFtQixhQUFvQztRQUFwQyxrQkFBYSxHQUFiLGFBQWEsQ0FBdUI7SUFBRSxDQUFDO0lBRTFELFFBQVE7UUFDSixJQUFJLENBQUMsS0FBSyxFQUFFLENBQUMsYUFBYSxHQUFHLElBQUksQ0FBQyxhQUFhLENBQUM7SUFDcEQsQ0FBQztJQUNDLFdBQVcsQ0FBQyxLQUFhO1FBQ3pCLElBQUksQ0FBQyxhQUFhLEdBQUcsS0FBSyxDQUFDO1FBQzNCLElBQUksQ0FBQyxLQUFLLEVBQUUsQ0FBQyxhQUFhLEdBQUcsSUFBSSxDQUFDLGFBQWEsQ0FBQztJQUNsRCxDQUFDO3dHQWJZLFlBQVk7NEZBQVosWUFBWSwrUENaekIsMDVCQWtCQSwwc0NEVlksYUFBYSxxdUJBQUMsWUFBWTs7NEZBSXpCLFlBQVk7a0JBUHhCLFNBQVM7K0JBQ0UsU0FBUyxjQUNQLElBQUksV0FDUCxDQUFDLGFBQWEsRUFBQyxZQUFZLENBQUM7eUZBTTdCLG1CQUFtQjtzQkFBNUIsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XHJcbmltcG9ydCB7IENvbXBvbmVudCwgRXZlbnRFbWl0dGVyLCBpbnB1dCwgT3V0cHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IE1hdFRhYkNoYW5nZUV2ZW50LCBNYXRUYWJzTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvdGFicyc7XHJcbmltcG9ydCB7IE1hc3RlckNvbnRyb2xTZXJ2aWNlIH0gZnJvbSAnLi4vbWFzdGVyLWNvbnRyb2wuc2VydmljZSc7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogJ2xpYi10YWInLFxyXG4gIHN0YW5kYWxvbmU6IHRydWUsXHJcbiAgaW1wb3J0czogW01hdFRhYnNNb2R1bGUsQ29tbW9uTW9kdWxlXSxcclxuICB0ZW1wbGF0ZVVybDogJy4vdGFiLmNvbXBvbmVudC5odG1sJyxcclxuICBzdHlsZVVybDogJy4vdGFiLmNvbXBvbmVudC5jc3MnXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBUYWJDb21wb25lbnQge1xyXG5maWVsZCA6IGFueSA9IGlucHV0LnJlcXVpcmVkPGFueT4oKTtcclxuQE91dHB1dCgpIHNlbGVjdGVkSW5kZXhDaGFuZ2UgPSBuZXcgRXZlbnRFbWl0dGVyPG51bWJlcj4oKTtcclxuc2VsZWN0ZWRJbmRleCA9IDA7XHJcblxyXG5jb25zdHJ1Y3RvcihwdWJsaWMgbWFzdGVyU2VydmljZSA6IE1hc3RlckNvbnRyb2xTZXJ2aWNlKXt9XHJcblxyXG5uZ09uSW5pdCgpe1xyXG4gICAgdGhpcy5maWVsZCgpLnNlbGVjdGVkSW5kZXggPSB0aGlzLnNlbGVjdGVkSW5kZXg7XHJcbn1cclxuICBvblRhYkNoYW5nZShldmVudDogbnVtYmVyKSB7XHJcbiAgdGhpcy5zZWxlY3RlZEluZGV4ID0gZXZlbnQ7XHJcbiAgdGhpcy5maWVsZCgpLnNlbGVjdGVkSW5kZXggPSB0aGlzLnNlbGVjdGVkSW5kZXg7XHJcbn1cclxufVxyXG4iLCI8bWF0LXRhYi1ncm91cCAqbmdJZj1cImZpZWxkKCkgJiYgZmllbGQoKT8uaXNWaXNpYmxlXCIgY2xhc3M9XCJ2ZXJ0aWNhbC10YWItaW5kaWNhdG9yXCJcclxuW25nQ2xhc3NdPVwieyd2ZXJ0aWNhbC1jbGFzcyc6IGZpZWxkKCk/LmNvbmZpZ0RhdGE/LmlzVmVydGljYWxUYWIgJiYgZmllbGQoKT8uY29uZmlnRGF0YT8uaXNWZXJ0aWNhbFRhYiA9PT0gJ3RydWUnfVwiXHJcbltuZ1N0eWxlXT1cIntcclxuICctLXRhYi1ib3JkZXItY29sb3InOiBmaWVsZCgpPy5jb250cm9sU3R5bGU/LmJvcmRlckNvbG9yICxcclxuICctLXRhYi1ib3JkZXItd2lkdGgnOiBmaWVsZCgpPy5jb250cm9sU3R5bGU/LmJvcmRlcldpZHRoLFxyXG4gICctLXRhYi1mb250LXNpemUnOiBmaWVsZCgpPy5jb250cm9sU3R5bGU/LmZvbnRTaXplLFxyXG4gJy0tdGFiLWZvbnQtd2VpZ2h0JzogZmllbGQoKT8uY29udHJvbFN0eWxlPy5mb250V2VpZ2h0LFxyXG4gJy0tdGFiLWZvbnQtY29sb3InOiBmaWVsZCgpPy5jb250cm9sU3R5bGU/LmNvbG9yLFxyXG4gfVwiXHJcblsoc2VsZWN0ZWRJbmRleCldPVwic2VsZWN0ZWRJbmRleFwiIChzZWxlY3RlZEluZGV4Q2hhbmdlKT1cIm9uVGFiQ2hhbmdlKCRldmVudClcIj5cclxuICAgPG1hdC10YWIgKm5nRm9yPVwibGV0IGRhdGEgb2YgZmllbGQoKT8ub3B0aW9uczsgbGV0IGkgPSBpbmRleFwiPlxyXG4gICAgPG5nLXRlbXBsYXRlIG1hdC10YWItbGFiZWw+XHJcbiAgICAgIDxpbWcgW3NyY109XCJkYXRhLnZhbHVlXCIgYWx0PVwiXCIgY2xhc3M9XCJteC0yXCI+XHJcbiAgICAgIHt7IGRhdGEubGFiZWwgfX1cclxuICAgIDwvbmctdGVtcGxhdGU+XHJcbiAgICA8bmctY29udGVudCBzZWxlY3Q9XCJ0YWJbaV1cIj48L25nLWNvbnRlbnQ+XHJcbiAgPC9tYXQtdGFiPlxyXG48L21hdC10YWItZ3JvdXA+XHJcbiJdfQ==
32
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFiLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL21hc3Rlci1jb250cm9sL3NyYy9saWIvdGFiL3RhYi5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9tYXN0ZXItY29udHJvbC9zcmMvbGliL3RhYi90YWIuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxTQUFTLEVBQUUsWUFBWSxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDdkUsT0FBTyxFQUFxQixhQUFhLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQzs7Ozs7QUFVMUUsTUFBTSxPQUFPLFlBQVk7SUFLTjtJQUpuQixLQUFLLEdBQVMsS0FBSyxDQUFDLFFBQVEsRUFBTyxDQUFDO0lBQzFCLG1CQUFtQixHQUFHLElBQUksWUFBWSxFQUFVLENBQUM7SUFDM0QsYUFBYSxHQUFHLENBQUMsQ0FBQztJQUVsQixZQUFtQixhQUFvQztRQUFwQyxrQkFBYSxHQUFiLGFBQWEsQ0FBdUI7SUFBRSxDQUFDO0lBRTFELFFBQVE7UUFDSixJQUFJLENBQUMsS0FBSyxFQUFFLENBQUMsYUFBYSxHQUFHLElBQUksQ0FBQyxhQUFhLENBQUM7SUFDcEQsQ0FBQztJQUNDLFdBQVcsQ0FBQyxLQUFhO1FBQ3pCLElBQUksQ0FBQyxhQUFhLEdBQUcsS0FBSyxDQUFDO1FBQzNCLElBQUksQ0FBQyxLQUFLLEVBQUUsQ0FBQyxhQUFhLEdBQUcsSUFBSSxDQUFDLGFBQWEsQ0FBQztJQUNsRCxDQUFDO3dHQWJZLFlBQVk7NEZBQVosWUFBWSwrUENaekIsMDVCQWtCQSxpd0NEVlksYUFBYSxxdUJBQUMsWUFBWTs7NEZBSXpCLFlBQVk7a0JBUHhCLFNBQVM7K0JBQ0UsU0FBUyxjQUNQLElBQUksV0FDUCxDQUFDLGFBQWEsRUFBQyxZQUFZLENBQUM7eUZBTTdCLG1CQUFtQjtzQkFBNUIsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XHJcbmltcG9ydCB7IENvbXBvbmVudCwgRXZlbnRFbWl0dGVyLCBpbnB1dCwgT3V0cHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IE1hdFRhYkNoYW5nZUV2ZW50LCBNYXRUYWJzTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvdGFicyc7XHJcbmltcG9ydCB7IE1hc3RlckNvbnRyb2xTZXJ2aWNlIH0gZnJvbSAnLi4vbWFzdGVyLWNvbnRyb2wuc2VydmljZSc7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogJ2xpYi10YWInLFxyXG4gIHN0YW5kYWxvbmU6IHRydWUsXHJcbiAgaW1wb3J0czogW01hdFRhYnNNb2R1bGUsQ29tbW9uTW9kdWxlXSxcclxuICB0ZW1wbGF0ZVVybDogJy4vdGFiLmNvbXBvbmVudC5odG1sJyxcclxuICBzdHlsZVVybDogJy4vdGFiLmNvbXBvbmVudC5jc3MnXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBUYWJDb21wb25lbnQge1xyXG5maWVsZCA6IGFueSA9IGlucHV0LnJlcXVpcmVkPGFueT4oKTtcclxuQE91dHB1dCgpIHNlbGVjdGVkSW5kZXhDaGFuZ2UgPSBuZXcgRXZlbnRFbWl0dGVyPG51bWJlcj4oKTtcclxuc2VsZWN0ZWRJbmRleCA9IDA7XHJcblxyXG5jb25zdHJ1Y3RvcihwdWJsaWMgbWFzdGVyU2VydmljZSA6IE1hc3RlckNvbnRyb2xTZXJ2aWNlKXt9XHJcblxyXG5uZ09uSW5pdCgpe1xyXG4gICAgdGhpcy5maWVsZCgpLnNlbGVjdGVkSW5kZXggPSB0aGlzLnNlbGVjdGVkSW5kZXg7XHJcbn1cclxuICBvblRhYkNoYW5nZShldmVudDogbnVtYmVyKSB7XHJcbiAgdGhpcy5zZWxlY3RlZEluZGV4ID0gZXZlbnQ7XHJcbiAgdGhpcy5maWVsZCgpLnNlbGVjdGVkSW5kZXggPSB0aGlzLnNlbGVjdGVkSW5kZXg7XHJcbn1cclxufVxyXG4iLCI8bWF0LXRhYi1ncm91cCAqbmdJZj1cImZpZWxkKCkgJiYgZmllbGQoKT8uaXNWaXNpYmxlXCIgY2xhc3M9XCJ2ZXJ0aWNhbC10YWItaW5kaWNhdG9yXCJcclxuW25nQ2xhc3NdPVwieyd2ZXJ0aWNhbC1jbGFzcyc6IGZpZWxkKCk/LmNvbmZpZ0RhdGE/LmlzVmVydGljYWxUYWIgJiYgZmllbGQoKT8uY29uZmlnRGF0YT8uaXNWZXJ0aWNhbFRhYiA9PT0gJ3RydWUnfVwiXHJcbltuZ1N0eWxlXT1cIntcclxuICctLXRhYi1ib3JkZXItY29sb3InOiBmaWVsZCgpPy5jb250cm9sU3R5bGU/LmJvcmRlckNvbG9yICxcclxuICctLXRhYi1ib3JkZXItd2lkdGgnOiBmaWVsZCgpPy5jb250cm9sU3R5bGU/LmJvcmRlcldpZHRoLFxyXG4gICctLXRhYi1mb250LXNpemUnOiBmaWVsZCgpPy5jb250cm9sU3R5bGU/LmZvbnRTaXplLFxyXG4gJy0tdGFiLWZvbnQtd2VpZ2h0JzogZmllbGQoKT8uY29udHJvbFN0eWxlPy5mb250V2VpZ2h0LFxyXG4gJy0tdGFiLWZvbnQtY29sb3InOiBmaWVsZCgpPy5jb250cm9sU3R5bGU/LmNvbG9yLFxyXG4gfVwiXHJcblsoc2VsZWN0ZWRJbmRleCldPVwic2VsZWN0ZWRJbmRleFwiIChzZWxlY3RlZEluZGV4Q2hhbmdlKT1cIm9uVGFiQ2hhbmdlKCRldmVudClcIj5cclxuICAgPG1hdC10YWIgKm5nRm9yPVwibGV0IGRhdGEgb2YgZmllbGQoKT8ub3B0aW9uczsgbGV0IGkgPSBpbmRleFwiPlxyXG4gICAgPG5nLXRlbXBsYXRlIG1hdC10YWItbGFiZWw+XHJcbiAgICAgIDxpbWcgW3NyY109XCJkYXRhLnZhbHVlXCIgYWx0PVwiXCIgY2xhc3M9XCJteC0yXCI+XHJcbiAgICAgIHt7IGRhdGEubGFiZWwgfX1cclxuICAgIDwvbmctdGVtcGxhdGU+XHJcbiAgICA8bmctY29udGVudCBzZWxlY3Q9XCJ0YWJbaV1cIj48L25nLWNvbnRlbnQ+XHJcbiAgPC9tYXQtdGFiPlxyXG48L21hdC10YWItZ3JvdXA+XHJcbiJdfQ==
@@ -1,4 +1,4 @@
1
- import { Component, HostListener, input } from '@angular/core';
1
+ import { Component, EventEmitter, HostListener, input, Output } from '@angular/core';
2
2
  import { CommonModule, NgFor, NgIf } from '@angular/common';
3
3
  import { FormsModule } from '@angular/forms';
4
4
  import { MatIconModule } from '@angular/material/icon';
@@ -21,6 +21,7 @@ export class TableComponent {
21
21
  paginationSize = 10;
22
22
  pageNumber = 0;
23
23
  pageSize = 10;
24
+ actionItemClicked = new EventEmitter();
24
25
  constructor(masterControlService) {
25
26
  this.masterControlService = masterControlService;
26
27
  }
@@ -68,6 +69,9 @@ export class TableComponent {
68
69
  }
69
70
  closeActionsPopup() {
70
71
  this.showActionsPopup = false;
72
+ this.field().tableData.userSelectedOptions[this.selectedRow].forEach((checkIcon) => {
73
+ checkIcon.isSelected = false;
74
+ });
71
75
  this.selectedRow = 0;
72
76
  this.highlightedIndex = -1;
73
77
  }
@@ -79,14 +83,29 @@ export class TableComponent {
79
83
  this.pageSize = event.pageSize;
80
84
  console.log(this.pageNumber, this.pageSize);
81
85
  }
86
+ actionClicked(actionSelected, actionIndex) {
87
+ this.field()?.tableData?.userSelectedOptions[this.selectedRow]?.forEach((checkIcon, selectedIndex) => {
88
+ if (checkIcon.matIconName === actionSelected.matIconName && actionIndex === selectedIndex) {
89
+ checkIcon.isSelected = true;
90
+ }
91
+ });
92
+ let emitOBJ = {
93
+ userSelectedOptions: this.field()?.tableData?.userSelectedOptions,
94
+ selectedRowIndex: this.selectedRow,
95
+ selectedActionsIndex: actionIndex,
96
+ };
97
+ this.actionItemClicked.emit(emitOBJ);
98
+ }
82
99
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: TableComponent, deps: [{ token: i1.MasterControlService }], target: i0.ɵɵFactoryTarget.Component });
83
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.2.13", type: TableComponent, isStandalone: true, selector: "lib-table", inputs: { field: { classPropertyName: "field", publicName: "field", isSignal: true, isRequired: true, transformFunction: null }, readonly: { classPropertyName: "readonly", publicName: "readonly", isSignal: true, isRequired: false, transformFunction: null } }, host: { listeners: { "document:keydown.escape": "onEscKey($event)" } }, ngImport: i0, template: "<div class=\"styled-table-container\">\r\n<table *ngIf=\"field()?.tableData?.columnlength && field()?.tableData?.rowlength\" class=\"styled-table\">\r\n <thead>\r\n <tr>\r\n <th *ngIf=\"field()?.tableData?.showCheckBox\"></th>\r\n <th *ngFor=\"let header of field().tableData?.tableHeaders; let i = index; trackBy: trackByIndex\">\r\n <ng-container *ngIf=\"!readonly(); else headerText\">{{header.columnName}}\r\n <!-- <input type=\"text\" [(ngModel)]=\"header.columnName\" (ngModelChange)=\"renameHeader(i, $event)\"\r\n [disabled]=\"readonly()\" class=\"custom_input\" [matTooltip]=\"header.toolTip\" matTooltipPosition=\"above\"> -->\r\n </ng-container>\r\n <ng-template #headerText>{{ header?.columnName }}</ng-template>\r\n </th>\r\n <th *ngIf=\"field()?.tableData?.showActions\">Action</th>\r\n </tr>\r\n </thead>\r\n <tbody>\r\n <tr *ngFor=\"let row of field()?.tableData?.tdData;let rowIndex = index\">\r\n <td *ngIf=\"field()?.tableData?.showCheckBox\"><input type=\"checkbox\"></td>\r\n <td *ngFor=\"let cell of row\">{{ cell }}</td>\r\n <td *ngIf=\"field()?.tableData?.showActions\">\r\n <button class=\"action-btn\" (click)=\"openActionsPopup($event, rowIndex)\" [disabled]=\"readonly()\">\r\n <mat-icon>more_vert</mat-icon>\r\n </button>\r\n </td>\r\n </tr>\r\n </tbody>\r\n</table>\r\n <mat-paginator class=\"custom-paginator\"\r\n [length]=\"field()?.tableData?.tdData?.length\"\r\n [pageSize]=\"paginationSize\"\r\n [pageSizeOptions]=\"[5, 10, 25, 100]\"\r\n (page)=\"pageChanged($event)\"\r\n aria-label=\"Select page\">\r\n </mat-paginator>\r\n</div>\r\n\r\n<div *ngIf=\"showActionsPopup\" class=\"actions-popup-backdrop\" (click)=\"closeActionsPopup()\">\r\n <div class=\"actions-popup-menu\" [ngStyle]=\"{'top.px': popupPosition.top, 'left.px': popupPosition.left}\"\r\n (click)=\"$event.stopPropagation()\">\r\n <div class=\"makeArrow\" [ngStyle]=\"{'left.px': popupPosition.left+25}\"></div>\r\n <ul>\r\n <li *ngFor=\"let actionData of field().tableData?.userSelectedOptions[selectedRow]\" [matTooltip]=\"actionData?.displayTitle\"\r\n matTooltipPosition=\"above\">\r\n <mat-icon>{{actionData?.matIconName}}</mat-icon>\r\n {{actionData?.displayTitle}}\r\n </li>\r\n </ul>\r\n </div>\r\n</div>\r\n", styles: [".styled-table{width:100%;margin:16px 0;font-size:1em;box-shadow:0 0 8px #0000001a}*{font-family:mulish!important}.styled-table th,.styled-table td{border:none;padding:8px 12px;text-align:left}.styled-table thead tr{background-color:#444;color:#fff}.styled-table tbody tr:nth-child(2n){background-color:#f3f3f3}.styled-table tbody tr:hover{background-color:#e0f7fa}.custom_input{width:100%;border:none;background:transparent;font-weight:700;color:#fff}.styled-table th:first-child{border-top-left-radius:8px}.styled-table th:last-child{border-top-right-radius:8px}.popup-backdrop{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#0000004d;display:flex;align-items:center;justify-content:center;z-index:1000}.action-btn{background:none;border:none;cursor:pointer;padding:0}.actions-popup-backdrop{position:fixed;inset:0;background:transparent;z-index:1000}.actions-popup-menu{position:absolute;min-width:260px;background:#fff;border-radius:12px;box-shadow:0 4px 24px #0000002e;padding:0;z-index:1001;color:#333;font-family:inherit;border:1px solid #DDDDDD}.actions-popup-menu ul{list-style:none;margin:0;padding:0 0 8px}.actions-popup-menu li{display:flex;align-items:center;padding:10px 20px;cursor:pointer;font-size:15px;transition:background .2s;border-bottom:1px dashed #DADADA}.actions-popup-menu li mat-icon{margin-right:12px;font-size:20px}.actions-popup-menu li.selected,.actions-popup-menu li:hover{background:#fff6d1;color:#222}.styled-table-container{max-width:100%;overflow-x:auto;max-height:400px;overflow-y:auto}.makeArrow{width:0;height:0;border-top:12px solid transparent;border-bottom:12px solid transparent;border-left:16px solid #fff;border-right:none;position:absolute;top:10px}:host ::ng-deep .custom-paginator .mdc-text-field--outlined .mdc-notched-outline{display:none!important}\n"], dependencies: [{ kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: NgFor, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "ngmodule", type: FormsModule }, { kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "ngmodule", type: MatIconModule }, { kind: "component", type: i3.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "ngmodule", type: MatTooltipModule }, { kind: "directive", type: i4.MatTooltip, selector: "[matTooltip]", inputs: ["matTooltipPosition", "matTooltipPositionAtOrigin", "matTooltipDisabled", "matTooltipShowDelay", "matTooltipHideDelay", "matTooltipTouchGestures", "matTooltip", "matTooltipClass"], exportAs: ["matTooltip"] }, { kind: "ngmodule", type: MatPaginatorModule }, { kind: "component", type: i5.MatPaginator, selector: "mat-paginator", inputs: ["color", "pageIndex", "length", "pageSize", "pageSizeOptions", "hidePageSize", "showFirstLastButtons", "selectConfig", "disabled"], outputs: ["page"], exportAs: ["matPaginator"] }] });
100
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.2.13", type: TableComponent, isStandalone: true, selector: "lib-table", inputs: { field: { classPropertyName: "field", publicName: "field", isSignal: true, isRequired: true, transformFunction: null }, readonly: { classPropertyName: "readonly", publicName: "readonly", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { actionItemClicked: "actionItemClicked" }, host: { listeners: { "document:keydown.escape": "onEscKey($event)" } }, ngImport: i0, template: "<div class=\"styled-table-container\">\r\n <table *ngIf=\"field()?.tableData?.columnlength && field()?.tableData?.rowlength\" class=\"styled-table\">\r\n <thead>\r\n <tr>\r\n <th *ngIf=\"field()?.tableData?.showCheckBox\"></th>\r\n <th *ngFor=\"let header of field().tableData?.tableHeaders; let i = index; trackBy: trackByIndex\">\r\n <ng-container *ngIf=\"!readonly(); else headerText\">{{header.columnName}}\r\n <!-- <input type=\"text\" [(ngModel)]=\"header.columnName\" (ngModelChange)=\"renameHeader(i, $event)\"\r\n [disabled]=\"readonly()\" class=\"custom_input\" [matTooltip]=\"header.toolTip\" matTooltipPosition=\"above\"> -->\r\n </ng-container>\r\n <ng-template #headerText>{{ header?.columnName }}</ng-template>\r\n </th>\r\n <th *ngIf=\"field()?.tableData?.showActions\">Action</th>\r\n </tr>\r\n </thead>\r\n <tbody>\r\n <tr *ngFor=\"let row of field()?.tableData?.tdData;let rowIndex = index\">\r\n <td *ngIf=\"field()?.tableData?.showCheckBox\"><input type=\"checkbox\"></td>\r\n <td *ngFor=\"let cell of row\">{{ cell }}</td>\r\n <td *ngIf=\"field()?.tableData?.showActions\">\r\n <button class=\"action-btn\" (click)=\"openActionsPopup($event, rowIndex)\" [disabled]=\"readonly()\">\r\n <mat-icon>more_vert</mat-icon>\r\n </button>\r\n </td>\r\n </tr>\r\n </tbody>\r\n </table>\r\n <mat-paginator class=\"custom-paginator\" [length]=\"field()?.tableData?.tdData?.length\" [pageSize]=\"paginationSize\"\r\n [pageSizeOptions]=\"[5, 10, 25, 100]\" (page)=\"pageChanged($event)\" aria-label=\"Select page\">\r\n </mat-paginator>\r\n</div>\r\n\r\n<div *ngIf=\"showActionsPopup\" class=\"actions-popup-backdrop\" (click)=\"closeActionsPopup()\">\r\n <div class=\"actions-popup-menu\" [ngStyle]=\"{'top.px': popupPosition.top, 'left.px': popupPosition.left}\"\r\n (click)=\"$event.stopPropagation()\">\r\n <div class=\"makeArrow\" [ngStyle]=\"{'left.px': popupPosition.left+25}\"></div>\r\n <ul>\r\n <li *ngFor=\"let actionData of field().tableData?.userSelectedOptions[selectedRow];let actionIndex = index\"\r\n [matTooltip]=\"actionData?.displayTitle\" matTooltipPosition=\"above\"\r\n (click)=\"actionClicked(actionData,actionIndex)\">\r\n <mat-icon>{{actionData?.matIconName}}</mat-icon>\r\n {{actionData?.displayTitle}}\r\n </li>\r\n </ul>\r\n </div>\r\n</div>", styles: [".styled-table{width:100%;margin:16px 0;font-size:1em;box-shadow:0 0 8px #0000001a}*{font-family:mulish!important}.styled-table th,.styled-table td{border:none;padding:8px 12px;text-align:left}.styled-table thead tr{background-color:#444;color:#fff}.styled-table tbody tr:nth-child(2n){background-color:#f3f3f3}.styled-table tbody tr:hover{background-color:#e0f7fa}.custom_input{width:100%;border:none;background:transparent;font-weight:700;color:#fff}.styled-table th:first-child{border-top-left-radius:8px}.styled-table th:last-child{border-top-right-radius:8px}.popup-backdrop{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#0000004d;display:flex;align-items:center;justify-content:center;z-index:1000}.action-btn{background:none;border:none;cursor:pointer;padding:0}.actions-popup-backdrop{position:fixed;inset:0;background:transparent;z-index:1000}.actions-popup-menu{position:absolute;min-width:260px;background:#fff;border-radius:12px;box-shadow:0 4px 24px #0000002e;padding:0;z-index:1001;color:#333;font-family:inherit;border:1px solid #DDDDDD}.actions-popup-menu ul{list-style:none;margin:0;padding:0 0 8px}.actions-popup-menu li{display:flex;align-items:center;padding:10px 20px;cursor:pointer;font-size:15px;transition:background .2s;border-bottom:1px dashed #DADADA}.actions-popup-menu li mat-icon{margin-right:12px;font-size:20px}.actions-popup-menu li.selected,.actions-popup-menu li:hover{background:#fff6d1;color:#222}.styled-table-container{max-width:100%;overflow-x:auto;max-height:400px;overflow-y:auto}.makeArrow{width:0;height:0;border-top:12px solid transparent;border-bottom:12px solid transparent;border-left:16px solid #fff;border-right:none;position:absolute;top:10px}:host ::ng-deep .custom-paginator .mdc-text-field--outlined .mdc-notched-outline{display:none!important}\n"], dependencies: [{ kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: NgFor, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "ngmodule", type: FormsModule }, { kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "ngmodule", type: MatIconModule }, { kind: "component", type: i3.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "ngmodule", type: MatTooltipModule }, { kind: "directive", type: i4.MatTooltip, selector: "[matTooltip]", inputs: ["matTooltipPosition", "matTooltipPositionAtOrigin", "matTooltipDisabled", "matTooltipShowDelay", "matTooltipHideDelay", "matTooltipTouchGestures", "matTooltip", "matTooltipClass"], exportAs: ["matTooltip"] }, { kind: "ngmodule", type: MatPaginatorModule }, { kind: "component", type: i5.MatPaginator, selector: "mat-paginator", inputs: ["color", "pageIndex", "length", "pageSize", "pageSizeOptions", "hidePageSize", "showFirstLastButtons", "selectConfig", "disabled"], outputs: ["page"], exportAs: ["matPaginator"] }] });
84
101
  }
85
102
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: TableComponent, decorators: [{
86
103
  type: Component,
87
- args: [{ selector: 'lib-table', standalone: true, imports: [NgIf, NgFor, FormsModule, CommonModule, MatIconModule, MatTooltipModule, MatPaginatorModule], template: "<div class=\"styled-table-container\">\r\n<table *ngIf=\"field()?.tableData?.columnlength && field()?.tableData?.rowlength\" class=\"styled-table\">\r\n <thead>\r\n <tr>\r\n <th *ngIf=\"field()?.tableData?.showCheckBox\"></th>\r\n <th *ngFor=\"let header of field().tableData?.tableHeaders; let i = index; trackBy: trackByIndex\">\r\n <ng-container *ngIf=\"!readonly(); else headerText\">{{header.columnName}}\r\n <!-- <input type=\"text\" [(ngModel)]=\"header.columnName\" (ngModelChange)=\"renameHeader(i, $event)\"\r\n [disabled]=\"readonly()\" class=\"custom_input\" [matTooltip]=\"header.toolTip\" matTooltipPosition=\"above\"> -->\r\n </ng-container>\r\n <ng-template #headerText>{{ header?.columnName }}</ng-template>\r\n </th>\r\n <th *ngIf=\"field()?.tableData?.showActions\">Action</th>\r\n </tr>\r\n </thead>\r\n <tbody>\r\n <tr *ngFor=\"let row of field()?.tableData?.tdData;let rowIndex = index\">\r\n <td *ngIf=\"field()?.tableData?.showCheckBox\"><input type=\"checkbox\"></td>\r\n <td *ngFor=\"let cell of row\">{{ cell }}</td>\r\n <td *ngIf=\"field()?.tableData?.showActions\">\r\n <button class=\"action-btn\" (click)=\"openActionsPopup($event, rowIndex)\" [disabled]=\"readonly()\">\r\n <mat-icon>more_vert</mat-icon>\r\n </button>\r\n </td>\r\n </tr>\r\n </tbody>\r\n</table>\r\n <mat-paginator class=\"custom-paginator\"\r\n [length]=\"field()?.tableData?.tdData?.length\"\r\n [pageSize]=\"paginationSize\"\r\n [pageSizeOptions]=\"[5, 10, 25, 100]\"\r\n (page)=\"pageChanged($event)\"\r\n aria-label=\"Select page\">\r\n </mat-paginator>\r\n</div>\r\n\r\n<div *ngIf=\"showActionsPopup\" class=\"actions-popup-backdrop\" (click)=\"closeActionsPopup()\">\r\n <div class=\"actions-popup-menu\" [ngStyle]=\"{'top.px': popupPosition.top, 'left.px': popupPosition.left}\"\r\n (click)=\"$event.stopPropagation()\">\r\n <div class=\"makeArrow\" [ngStyle]=\"{'left.px': popupPosition.left+25}\"></div>\r\n <ul>\r\n <li *ngFor=\"let actionData of field().tableData?.userSelectedOptions[selectedRow]\" [matTooltip]=\"actionData?.displayTitle\"\r\n matTooltipPosition=\"above\">\r\n <mat-icon>{{actionData?.matIconName}}</mat-icon>\r\n {{actionData?.displayTitle}}\r\n </li>\r\n </ul>\r\n </div>\r\n</div>\r\n", styles: [".styled-table{width:100%;margin:16px 0;font-size:1em;box-shadow:0 0 8px #0000001a}*{font-family:mulish!important}.styled-table th,.styled-table td{border:none;padding:8px 12px;text-align:left}.styled-table thead tr{background-color:#444;color:#fff}.styled-table tbody tr:nth-child(2n){background-color:#f3f3f3}.styled-table tbody tr:hover{background-color:#e0f7fa}.custom_input{width:100%;border:none;background:transparent;font-weight:700;color:#fff}.styled-table th:first-child{border-top-left-radius:8px}.styled-table th:last-child{border-top-right-radius:8px}.popup-backdrop{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#0000004d;display:flex;align-items:center;justify-content:center;z-index:1000}.action-btn{background:none;border:none;cursor:pointer;padding:0}.actions-popup-backdrop{position:fixed;inset:0;background:transparent;z-index:1000}.actions-popup-menu{position:absolute;min-width:260px;background:#fff;border-radius:12px;box-shadow:0 4px 24px #0000002e;padding:0;z-index:1001;color:#333;font-family:inherit;border:1px solid #DDDDDD}.actions-popup-menu ul{list-style:none;margin:0;padding:0 0 8px}.actions-popup-menu li{display:flex;align-items:center;padding:10px 20px;cursor:pointer;font-size:15px;transition:background .2s;border-bottom:1px dashed #DADADA}.actions-popup-menu li mat-icon{margin-right:12px;font-size:20px}.actions-popup-menu li.selected,.actions-popup-menu li:hover{background:#fff6d1;color:#222}.styled-table-container{max-width:100%;overflow-x:auto;max-height:400px;overflow-y:auto}.makeArrow{width:0;height:0;border-top:12px solid transparent;border-bottom:12px solid transparent;border-left:16px solid #fff;border-right:none;position:absolute;top:10px}:host ::ng-deep .custom-paginator .mdc-text-field--outlined .mdc-notched-outline{display:none!important}\n"] }]
88
- }], ctorParameters: () => [{ type: i1.MasterControlService }], propDecorators: { onEscKey: [{
104
+ args: [{ selector: 'lib-table', standalone: true, imports: [NgIf, NgFor, FormsModule, CommonModule, MatIconModule, MatTooltipModule, MatPaginatorModule], template: "<div class=\"styled-table-container\">\r\n <table *ngIf=\"field()?.tableData?.columnlength && field()?.tableData?.rowlength\" class=\"styled-table\">\r\n <thead>\r\n <tr>\r\n <th *ngIf=\"field()?.tableData?.showCheckBox\"></th>\r\n <th *ngFor=\"let header of field().tableData?.tableHeaders; let i = index; trackBy: trackByIndex\">\r\n <ng-container *ngIf=\"!readonly(); else headerText\">{{header.columnName}}\r\n <!-- <input type=\"text\" [(ngModel)]=\"header.columnName\" (ngModelChange)=\"renameHeader(i, $event)\"\r\n [disabled]=\"readonly()\" class=\"custom_input\" [matTooltip]=\"header.toolTip\" matTooltipPosition=\"above\"> -->\r\n </ng-container>\r\n <ng-template #headerText>{{ header?.columnName }}</ng-template>\r\n </th>\r\n <th *ngIf=\"field()?.tableData?.showActions\">Action</th>\r\n </tr>\r\n </thead>\r\n <tbody>\r\n <tr *ngFor=\"let row of field()?.tableData?.tdData;let rowIndex = index\">\r\n <td *ngIf=\"field()?.tableData?.showCheckBox\"><input type=\"checkbox\"></td>\r\n <td *ngFor=\"let cell of row\">{{ cell }}</td>\r\n <td *ngIf=\"field()?.tableData?.showActions\">\r\n <button class=\"action-btn\" (click)=\"openActionsPopup($event, rowIndex)\" [disabled]=\"readonly()\">\r\n <mat-icon>more_vert</mat-icon>\r\n </button>\r\n </td>\r\n </tr>\r\n </tbody>\r\n </table>\r\n <mat-paginator class=\"custom-paginator\" [length]=\"field()?.tableData?.tdData?.length\" [pageSize]=\"paginationSize\"\r\n [pageSizeOptions]=\"[5, 10, 25, 100]\" (page)=\"pageChanged($event)\" aria-label=\"Select page\">\r\n </mat-paginator>\r\n</div>\r\n\r\n<div *ngIf=\"showActionsPopup\" class=\"actions-popup-backdrop\" (click)=\"closeActionsPopup()\">\r\n <div class=\"actions-popup-menu\" [ngStyle]=\"{'top.px': popupPosition.top, 'left.px': popupPosition.left}\"\r\n (click)=\"$event.stopPropagation()\">\r\n <div class=\"makeArrow\" [ngStyle]=\"{'left.px': popupPosition.left+25}\"></div>\r\n <ul>\r\n <li *ngFor=\"let actionData of field().tableData?.userSelectedOptions[selectedRow];let actionIndex = index\"\r\n [matTooltip]=\"actionData?.displayTitle\" matTooltipPosition=\"above\"\r\n (click)=\"actionClicked(actionData,actionIndex)\">\r\n <mat-icon>{{actionData?.matIconName}}</mat-icon>\r\n {{actionData?.displayTitle}}\r\n </li>\r\n </ul>\r\n </div>\r\n</div>", styles: [".styled-table{width:100%;margin:16px 0;font-size:1em;box-shadow:0 0 8px #0000001a}*{font-family:mulish!important}.styled-table th,.styled-table td{border:none;padding:8px 12px;text-align:left}.styled-table thead tr{background-color:#444;color:#fff}.styled-table tbody tr:nth-child(2n){background-color:#f3f3f3}.styled-table tbody tr:hover{background-color:#e0f7fa}.custom_input{width:100%;border:none;background:transparent;font-weight:700;color:#fff}.styled-table th:first-child{border-top-left-radius:8px}.styled-table th:last-child{border-top-right-radius:8px}.popup-backdrop{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#0000004d;display:flex;align-items:center;justify-content:center;z-index:1000}.action-btn{background:none;border:none;cursor:pointer;padding:0}.actions-popup-backdrop{position:fixed;inset:0;background:transparent;z-index:1000}.actions-popup-menu{position:absolute;min-width:260px;background:#fff;border-radius:12px;box-shadow:0 4px 24px #0000002e;padding:0;z-index:1001;color:#333;font-family:inherit;border:1px solid #DDDDDD}.actions-popup-menu ul{list-style:none;margin:0;padding:0 0 8px}.actions-popup-menu li{display:flex;align-items:center;padding:10px 20px;cursor:pointer;font-size:15px;transition:background .2s;border-bottom:1px dashed #DADADA}.actions-popup-menu li mat-icon{margin-right:12px;font-size:20px}.actions-popup-menu li.selected,.actions-popup-menu li:hover{background:#fff6d1;color:#222}.styled-table-container{max-width:100%;overflow-x:auto;max-height:400px;overflow-y:auto}.makeArrow{width:0;height:0;border-top:12px solid transparent;border-bottom:12px solid transparent;border-left:16px solid #fff;border-right:none;position:absolute;top:10px}:host ::ng-deep .custom-paginator .mdc-text-field--outlined .mdc-notched-outline{display:none!important}\n"] }]
105
+ }], ctorParameters: () => [{ type: i1.MasterControlService }], propDecorators: { actionItemClicked: [{
106
+ type: Output
107
+ }], onEscKey: [{
89
108
  type: HostListener,
90
109
  args: ['document:keydown.escape', ['$event']]
91
110
  }] } });
92
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table.component.js","sourceRoot":"","sources":["../../../../../projects/master-control/src/lib/table/table.component.ts","../../../../../projects/master-control/src/lib/table/table.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, HostListener, input } from '@angular/core';\r\nimport { CommonModule, NgFor, NgIf } from '@angular/common';\r\nimport { FormsModule } from '@angular/forms';\r\nimport { MatIconModule } from '@angular/material/icon';\r\nimport { MatTooltipModule } from '@angular/material/tooltip';\r\nimport { MasterControlService } from '../master-control.service';\r\nimport { MatPaginatorModule, PageEvent } from '@angular/material/paginator';\r\n@Component({\r\n  selector: 'lib-table',\r\n  standalone: true,\r\n  imports: [NgIf, NgFor, FormsModule, CommonModule, MatIconModule, MatTooltipModule,MatPaginatorModule],\r\n  templateUrl: './table.component.html',\r\n  styleUrl: './table.component.css'\r\n})\r\nexport class TableComponent {\r\n  field: any = input.required<any>();\r\n  readonly = input(false);\r\n  showActionsPopup = false;\r\n  popupPosition = { top: 0, left: 0 };\r\n  selectedRow: any = 0;\r\n  highlightedIndex = -1;\r\n  paginationSize: any = 10;\r\n  pageNumber: any = 0;\r\n  pageSize: any = 10;\r\n  constructor(public masterControlService : MasterControlService) { }\r\n\r\n  ngOnInit() {\r\n    this.setColumns();\r\n  }\r\n  trackByIndex(index: any, item: any) {\r\n    return index;\r\n  }\r\n\r\n  setColumns() {\r\n    let checkConfigData = this.field().configData;\r\n    if(Object.keys(checkConfigData).length > 0){\r\n      this.masterControlService.configData.table = checkConfigData;\r\n    }\r\n    if (this.masterControlService.configData.table.rowlength > 0 && this.masterControlService.configData.table.columnlength > 0) {\r\n      this.field().tableData = this.masterControlService.configData.table;\r\n      for (let i = 0; i < this.masterControlService.configData.table.columnlength; i++) {\r\n        if(Object.keys(checkConfigData).length <= 0){\r\n          let headerObj = {\r\n            \"columnName\": `${'Name - ' + i}`,\r\n            \"isSortingNeeded\": \"Y\",\r\n            \"toolTip\": `${'tooltip - ' + i}`\r\n          }\r\n          const exists = this.field().tableData.tableHeaders.some(\r\n            (header: any) => header.columnName === headerObj.columnName\r\n          );\r\n          if (!exists && this.field().tableData.tableHeaders.length < this.masterControlService.configData.table.columnlength) {\r\n            this.field().tableData.tableHeaders.push(headerObj);\r\n          }\r\n        }\r\n      }\r\n      this.field().tableData.tdData = Array(this.masterControlService.configData.table.rowlength).fill(null).map((_, rowIdx) =>\r\n        Array(this.masterControlService.configData.table.columnlength).fill('').map((_, colIdx) => `Dummy Row ${rowIdx + 1}`)\r\n      );\r\n\r\n      this.masterControlService.saveTableFieldState(this.field());\r\n      this.field().configData = this.field().tableData\r\n    }\r\n  }\r\n\r\n  openActionsPopup(event: MouseEvent, rowIndex: number) {\r\n    event.stopPropagation();\r\n    this.selectedRow = rowIndex;\r\n    this.showActionsPopup = true;\r\n    this.highlightedIndex = 1;\r\n    const rect = (event.target as HTMLElement).getBoundingClientRect();\r\n    this.popupPosition = {\r\n      top: rect.bottom + window.scrollY - 30,\r\n      left: rect.left + window.scrollX - 280,\r\n    };\r\n  }\r\n\r\n  closeActionsPopup() {\r\n    this.showActionsPopup = false;\r\n    this.selectedRow  = 0;\r\n    this.highlightedIndex = -1;\r\n  }\r\n\r\n  @HostListener('document:keydown.escape', ['$event'])\r\n  onEscKey(event: KeyboardEvent) {\r\n    this.closeActionsPopup();\r\n  }\r\n\r\n   pageChanged(event: PageEvent) {\r\n    this.pageNumber = event.pageIndex;\r\n    this.pageSize = event.pageSize;\r\n    console.log(this.pageNumber, this.pageSize);\r\n  }\r\n}\r\n","<div class=\"styled-table-container\">\r\n<table *ngIf=\"field()?.tableData?.columnlength && field()?.tableData?.rowlength\" class=\"styled-table\">\r\n  <thead>\r\n    <tr>\r\n      <th *ngIf=\"field()?.tableData?.showCheckBox\"></th>\r\n      <th *ngFor=\"let header of field().tableData?.tableHeaders; let i = index; trackBy: trackByIndex\">\r\n        <ng-container *ngIf=\"!readonly(); else headerText\">{{header.columnName}}\r\n          <!-- <input type=\"text\" [(ngModel)]=\"header.columnName\" (ngModelChange)=\"renameHeader(i, $event)\"\r\n            [disabled]=\"readonly()\" class=\"custom_input\" [matTooltip]=\"header.toolTip\" matTooltipPosition=\"above\"> -->\r\n        </ng-container>\r\n        <ng-template #headerText>{{ header?.columnName }}</ng-template>\r\n      </th>\r\n      <th *ngIf=\"field()?.tableData?.showActions\">Action</th>\r\n    </tr>\r\n  </thead>\r\n  <tbody>\r\n    <tr *ngFor=\"let row of field()?.tableData?.tdData;let rowIndex = index\">\r\n      <td *ngIf=\"field()?.tableData?.showCheckBox\"><input type=\"checkbox\"></td>\r\n      <td *ngFor=\"let cell of row\">{{ cell }}</td>\r\n      <td *ngIf=\"field()?.tableData?.showActions\">\r\n        <button class=\"action-btn\" (click)=\"openActionsPopup($event, rowIndex)\" [disabled]=\"readonly()\">\r\n          <mat-icon>more_vert</mat-icon>\r\n        </button>\r\n      </td>\r\n    </tr>\r\n  </tbody>\r\n</table>\r\n <mat-paginator class=\"custom-paginator\"\r\n      [length]=\"field()?.tableData?.tdData?.length\"\r\n      [pageSize]=\"paginationSize\"\r\n      [pageSizeOptions]=\"[5, 10, 25, 100]\"\r\n      (page)=\"pageChanged($event)\"\r\n      aria-label=\"Select page\">\r\n    </mat-paginator>\r\n</div>\r\n\r\n<div *ngIf=\"showActionsPopup\" class=\"actions-popup-backdrop\" (click)=\"closeActionsPopup()\">\r\n  <div class=\"actions-popup-menu\" [ngStyle]=\"{'top.px': popupPosition.top, 'left.px': popupPosition.left}\"\r\n    (click)=\"$event.stopPropagation()\">\r\n    <div class=\"makeArrow\" [ngStyle]=\"{'left.px': popupPosition.left+25}\"></div>\r\n    <ul>\r\n      <li *ngFor=\"let actionData of field().tableData?.userSelectedOptions[selectedRow]\" [matTooltip]=\"actionData?.displayTitle\"\r\n        matTooltipPosition=\"above\">\r\n        <mat-icon>{{actionData?.matIconName}}</mat-icon>\r\n        {{actionData?.displayTitle}}\r\n      </li>\r\n    </ul>\r\n  </div>\r\n</div>\r\n"]}
111
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table.component.js","sourceRoot":"","sources":["../../../../../projects/master-control/src/lib/table/table.component.ts","../../../../../projects/master-control/src/lib/table/table.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, HostListener, input, Output } from '@angular/core';\r\nimport { CommonModule, NgFor, NgIf } from '@angular/common';\r\nimport { FormsModule } from '@angular/forms';\r\nimport { MatIconModule } from '@angular/material/icon';\r\nimport { MatTooltipModule } from '@angular/material/tooltip';\r\nimport { MasterControlService } from '../master-control.service';\r\nimport { MatPaginatorModule, PageEvent } from '@angular/material/paginator';\r\n@Component({\r\n  selector: 'lib-table',\r\n  standalone: true,\r\n  imports: [NgIf, NgFor, FormsModule, CommonModule, MatIconModule, MatTooltipModule, MatPaginatorModule],\r\n  templateUrl: './table.component.html',\r\n  styleUrl: './table.component.css'\r\n})\r\nexport class TableComponent {\r\n  field: any = input.required<any>();\r\n  readonly = input(false);\r\n  showActionsPopup = false;\r\n  popupPosition = { top: 0, left: 0 };\r\n  selectedRow: any = 0;\r\n  highlightedIndex = -1;\r\n  paginationSize: any = 10;\r\n  pageNumber: any = 0;\r\n  pageSize: any = 10;\r\n  @Output() actionItemClicked = new EventEmitter<any>();\r\n  constructor(public masterControlService: MasterControlService) { }\r\n\r\n  ngOnInit() {\r\n    this.setColumns();\r\n  }\r\n  trackByIndex(index: any, item: any) {\r\n    return index;\r\n  }\r\n\r\n  setColumns() {\r\n    let checkConfigData = this.field().configData;\r\n    if (Object.keys(checkConfigData).length > 0) {\r\n      this.masterControlService.configData.table = checkConfigData;\r\n    }\r\n    if (this.masterControlService.configData.table.rowlength > 0 && this.masterControlService.configData.table.columnlength > 0) {\r\n      this.field().tableData = this.masterControlService.configData.table;\r\n      for (let i = 0; i < this.masterControlService.configData.table.columnlength; i++) {\r\n        if (Object.keys(checkConfigData).length <= 0) {\r\n          let headerObj = {\r\n            \"columnName\": `${'Name - ' + i}`,\r\n            \"isSortingNeeded\": \"Y\",\r\n            \"toolTip\": `${'tooltip - ' + i}`\r\n          }\r\n          const exists = this.field().tableData.tableHeaders.some(\r\n            (header: any) => header.columnName === headerObj.columnName\r\n          );\r\n          if (!exists && this.field().tableData.tableHeaders.length < this.masterControlService.configData.table.columnlength) {\r\n            this.field().tableData.tableHeaders.push(headerObj);\r\n          }\r\n        }\r\n      }\r\n      this.field().tableData.tdData = Array(this.masterControlService.configData.table.rowlength).fill(null).map((_, rowIdx) =>\r\n        Array(this.masterControlService.configData.table.columnlength).fill('').map((_, colIdx) => `Dummy Row ${rowIdx + 1}`)\r\n      );\r\n\r\n      this.masterControlService.saveTableFieldState(this.field());\r\n      this.field().configData = this.field().tableData\r\n    }\r\n  }\r\n\r\n  openActionsPopup(event: MouseEvent, rowIndex: number) {\r\n    event.stopPropagation();\r\n    this.selectedRow = rowIndex;\r\n    this.showActionsPopup = true;\r\n    this.highlightedIndex = 1;\r\n    const rect = (event.target as HTMLElement).getBoundingClientRect();\r\n    this.popupPosition = {\r\n      top: rect.bottom + window.scrollY - 30,\r\n      left: rect.left + window.scrollX - 280,\r\n    };\r\n  }\r\n\r\n  closeActionsPopup() {\r\n    this.showActionsPopup = false;\r\n    this.field().tableData.userSelectedOptions[this.selectedRow].forEach((checkIcon: any) => {\r\n      checkIcon.isSelected = false;\r\n    });\r\n    this.selectedRow = 0;\r\n    this.highlightedIndex = -1;\r\n  }\r\n\r\n  @HostListener('document:keydown.escape', ['$event'])\r\n  onEscKey(event: KeyboardEvent) {\r\n    this.closeActionsPopup();\r\n  }\r\n\r\n  pageChanged(event: PageEvent) {\r\n    this.pageNumber = event.pageIndex;\r\n    this.pageSize = event.pageSize;\r\n    console.log(this.pageNumber, this.pageSize);\r\n  }\r\n\r\n  actionClicked(actionSelected: any, actionIndex: any) {\r\n    this.field()?.tableData?.userSelectedOptions[this.selectedRow]?.forEach((checkIcon: any, selectedIndex: any) => {\r\n      if (checkIcon.matIconName === actionSelected.matIconName && actionIndex === selectedIndex) {\r\n        checkIcon.isSelected = true;\r\n      }\r\n    });\r\n    let emitOBJ = {\r\n      userSelectedOptions : this.field()?.tableData?.userSelectedOptions,\r\n      selectedRowIndex: this.selectedRow,\r\n      selectedActionsIndex: actionIndex,\r\n    }\r\n    this.actionItemClicked.emit(emitOBJ);\r\n  }\r\n}\r\n","<div class=\"styled-table-container\">\r\n  <table *ngIf=\"field()?.tableData?.columnlength && field()?.tableData?.rowlength\" class=\"styled-table\">\r\n    <thead>\r\n      <tr>\r\n        <th *ngIf=\"field()?.tableData?.showCheckBox\"></th>\r\n        <th *ngFor=\"let header of field().tableData?.tableHeaders; let i = index; trackBy: trackByIndex\">\r\n          <ng-container *ngIf=\"!readonly(); else headerText\">{{header.columnName}}\r\n            <!-- <input type=\"text\" [(ngModel)]=\"header.columnName\" (ngModelChange)=\"renameHeader(i, $event)\"\r\n            [disabled]=\"readonly()\" class=\"custom_input\" [matTooltip]=\"header.toolTip\" matTooltipPosition=\"above\"> -->\r\n          </ng-container>\r\n          <ng-template #headerText>{{ header?.columnName }}</ng-template>\r\n        </th>\r\n        <th *ngIf=\"field()?.tableData?.showActions\">Action</th>\r\n      </tr>\r\n    </thead>\r\n    <tbody>\r\n      <tr *ngFor=\"let row of field()?.tableData?.tdData;let rowIndex = index\">\r\n        <td *ngIf=\"field()?.tableData?.showCheckBox\"><input type=\"checkbox\"></td>\r\n        <td *ngFor=\"let cell of row\">{{ cell }}</td>\r\n        <td *ngIf=\"field()?.tableData?.showActions\">\r\n          <button class=\"action-btn\" (click)=\"openActionsPopup($event, rowIndex)\" [disabled]=\"readonly()\">\r\n            <mat-icon>more_vert</mat-icon>\r\n          </button>\r\n        </td>\r\n      </tr>\r\n    </tbody>\r\n  </table>\r\n  <mat-paginator class=\"custom-paginator\" [length]=\"field()?.tableData?.tdData?.length\" [pageSize]=\"paginationSize\"\r\n    [pageSizeOptions]=\"[5, 10, 25, 100]\" (page)=\"pageChanged($event)\" aria-label=\"Select page\">\r\n  </mat-paginator>\r\n</div>\r\n\r\n<div *ngIf=\"showActionsPopup\" class=\"actions-popup-backdrop\" (click)=\"closeActionsPopup()\">\r\n  <div class=\"actions-popup-menu\" [ngStyle]=\"{'top.px': popupPosition.top, 'left.px': popupPosition.left}\"\r\n    (click)=\"$event.stopPropagation()\">\r\n    <div class=\"makeArrow\" [ngStyle]=\"{'left.px': popupPosition.left+25}\"></div>\r\n    <ul>\r\n      <li *ngFor=\"let actionData of field().tableData?.userSelectedOptions[selectedRow];let actionIndex = index\"\r\n        [matTooltip]=\"actionData?.displayTitle\" matTooltipPosition=\"above\"\r\n        (click)=\"actionClicked(actionData,actionIndex)\">\r\n        <mat-icon>{{actionData?.matIconName}}</mat-icon>\r\n        {{actionData?.displayTitle}}\r\n      </li>\r\n    </ul>\r\n  </div>\r\n</div>"]}