@cqa-lib/cqa-ui 0.1.1 → 1.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (121) hide show
  1. package/esm2020/lib/action-menu/action-menu.component.mjs +42 -0
  2. package/esm2020/lib/assets/images/image-assets.constants.mjs +28 -0
  3. package/esm2020/lib/badge/badge.component.mjs +141 -0
  4. package/esm2020/lib/button/button.component.mjs +232 -0
  5. package/esm2020/lib/column-visibility/column-visibility.component.mjs +69 -0
  6. package/esm2020/lib/dashboards/chart-card/chart-card.component.mjs +22 -0
  7. package/esm2020/lib/dashboards/coverage-module-card/coverage-module-card.component.mjs +104 -0
  8. package/esm2020/lib/dashboards/dashboard-header/dashboard-header.component.mjs +82 -0
  9. package/esm2020/lib/dashboards/failed-test-cases-card/failed-test-cases-card.component.mjs +60 -0
  10. package/esm2020/lib/dashboards/heat-error-map-cell/heat-error-map-cell.component.mjs +45 -0
  11. package/esm2020/lib/dashboards/insight-card/insight-card.component.mjs +201 -0
  12. package/esm2020/lib/dashboards/metrics-card/metrics-block.component.mjs +41 -0
  13. package/esm2020/lib/dashboards/metrics-card/metrics-card-item.interface.mjs +2 -0
  14. package/esm2020/lib/dashboards/metrics-card/metrics-card.component.mjs +62 -0
  15. package/esm2020/lib/dashboards/progress-text-card/progress-text-card.component.mjs +46 -0
  16. package/esm2020/lib/dashboards/test-distribution-card/test-distribution-card.component.mjs +35 -0
  17. package/esm2020/lib/dialog/dialog.component.mjs +127 -0
  18. package/esm2020/lib/dropdown-button/dropdown-button.component.mjs +189 -0
  19. package/esm2020/lib/dynamic-select/dynamic-select-field.component.mjs +160 -0
  20. package/esm2020/lib/empty-state/empty-state.component.mjs +37 -0
  21. package/esm2020/lib/filters/dynamic-filter/dynamic-filter.component.mjs +239 -0
  22. package/esm2020/lib/full-table-loader/full-table-loader.component.mjs +16 -0
  23. package/esm2020/lib/inline-sort/inline-sort.component.mjs +58 -0
  24. package/esm2020/lib/other-button/other-button.component.mjs +76 -0
  25. package/esm2020/lib/pagination/pagination.component.mjs +102 -0
  26. package/{dist/cqa-ui/esm2020 → esm2020}/lib/search-bar/search-bar.component.mjs +3 -3
  27. package/{dist/cqa-ui/esm2020 → esm2020}/lib/segment-control/segment-control.component.mjs +3 -3
  28. package/esm2020/lib/selected-filters/selected-filters.component.mjs +27 -0
  29. package/esm2020/lib/table/dynamic-table/dynamic-cell.directive.mjs +35 -0
  30. package/esm2020/lib/table/dynamic-table/dynamic-table.component.mjs +258 -0
  31. package/esm2020/lib/table-action-toolbar/table-action-toolbar.component.mjs +52 -0
  32. package/esm2020/lib/table-data-loader/table-data-loader.component.mjs +19 -0
  33. package/esm2020/lib/templates/table-template.component.mjs +365 -0
  34. package/esm2020/lib/ui-kit.module.mjs +248 -0
  35. package/esm2020/lib/utils/metadata-colors.util.mjs +100 -0
  36. package/esm2020/lib/utils/tw-overlay-container.mjs +22 -0
  37. package/esm2020/public-api.mjs +38 -0
  38. package/fesm2015/cqa-lib-cqa-ui.mjs +3661 -0
  39. package/fesm2015/cqa-lib-cqa-ui.mjs.map +1 -0
  40. package/fesm2020/cqa-lib-cqa-ui.mjs +3615 -0
  41. package/fesm2020/cqa-lib-cqa-ui.mjs.map +1 -0
  42. package/lib/action-menu/action-menu.component.d.ts +17 -0
  43. package/lib/assets/images/image-assets.constants.d.ts +20 -0
  44. package/lib/badge/badge.component.d.ts +25 -0
  45. package/{dist/cqa-ui/lib → lib}/button/button.component.d.ts +6 -5
  46. package/lib/column-visibility/column-visibility.component.d.ts +33 -0
  47. package/lib/dashboards/chart-card/chart-card.component.d.ts +8 -0
  48. package/lib/dashboards/coverage-module-card/coverage-module-card.component.d.ts +44 -0
  49. package/lib/dashboards/dashboard-header/dashboard-header.component.d.ts +30 -0
  50. package/lib/dashboards/failed-test-cases-card/failed-test-cases-card.component.d.ts +28 -0
  51. package/lib/dashboards/heat-error-map-cell/heat-error-map-cell.component.d.ts +14 -0
  52. package/lib/dashboards/insight-card/insight-card.component.d.ts +73 -0
  53. package/lib/dashboards/metrics-card/metrics-block.component.d.ts +12 -0
  54. package/lib/dashboards/metrics-card/metrics-card-item.interface.d.ts +12 -0
  55. package/lib/dashboards/metrics-card/metrics-card.component.d.ts +17 -0
  56. package/lib/dashboards/progress-text-card/progress-text-card.component.d.ts +13 -0
  57. package/lib/dashboards/test-distribution-card/test-distribution-card.component.d.ts +29 -0
  58. package/lib/dropdown-button/dropdown-button.component.d.ts +32 -0
  59. package/lib/dynamic-select/dynamic-select-field.component.d.ts +43 -0
  60. package/lib/empty-state/empty-state.component.d.ts +20 -0
  61. package/lib/filters/dynamic-filter/dynamic-filter.component.d.ts +56 -0
  62. package/lib/full-table-loader/full-table-loader.component.d.ts +6 -0
  63. package/lib/inline-sort/inline-sort.component.d.ts +12 -0
  64. package/lib/other-button/other-button.component.d.ts +37 -0
  65. package/lib/pagination/pagination.component.d.ts +37 -0
  66. package/lib/selected-filters/selected-filters.component.d.ts +17 -0
  67. package/lib/table/dynamic-table/dynamic-cell.directive.d.ts +16 -0
  68. package/lib/table/dynamic-table/dynamic-table.component.d.ts +72 -0
  69. package/lib/table-action-toolbar/table-action-toolbar.component.d.ts +34 -0
  70. package/lib/table-data-loader/table-data-loader.component.d.ts +7 -0
  71. package/lib/templates/table-template.component.d.ts +90 -0
  72. package/lib/ui-kit.module.d.ts +52 -0
  73. package/lib/utils/metadata-colors.util.d.ts +50 -0
  74. package/lib/utils/tw-overlay-container.d.ts +12 -0
  75. package/package.json +23 -49
  76. package/public-api.d.ts +37 -0
  77. package/src/lib/assets/images/.gitkeep +0 -0
  78. package/src/lib/assets/images/DashboardIcon.png +0 -0
  79. package/src/lib/assets/images/FilesIcon.png +0 -0
  80. package/src/lib/assets/images/README.md +66 -0
  81. package/src/lib/assets/images/ReportsIcon.png +0 -0
  82. package/src/lib/assets/images/SearchIcon.png +0 -0
  83. package/src/lib/assets/images/StepsIcon.png +0 -0
  84. package/src/lib/assets/images/TestCaseIcon.png +0 -0
  85. package/src/lib/assets/images/analytics-chart-icon.svg +11 -0
  86. package/src/lib/assets/images/checklist-add-icon.svg +10 -0
  87. package/src/lib/assets/images/document-gear-icon.svg +9 -0
  88. package/src/lib/assets/images/empty-state-default-icon.svg +8 -0
  89. package/src/lib/assets/images/image-assets.constants.ts +38 -0
  90. package/src/lib/assets/images/search-debug-icon.svg +8 -0
  91. package/src/lib/assets/images/test-case-icon.svg +9 -0
  92. package/src/lib/assets/images/upload-folder-icon.svg +7 -0
  93. package/src/lib/utils/metadata-colors.constants.js +33 -0
  94. package/storybook-static/assets/images/README.md +66 -0
  95. package/styles.css +1 -0
  96. package/dist/cqa-ui/README.md +0 -226
  97. package/dist/cqa-ui/esm2020/lib/button/button.component.mjs +0 -257
  98. package/dist/cqa-ui/esm2020/lib/dialog/dialog.component.mjs +0 -127
  99. package/dist/cqa-ui/esm2020/lib/ui-kit.module.mjs +0 -69
  100. package/dist/cqa-ui/esm2020/public-api.mjs +0 -10
  101. package/dist/cqa-ui/fesm2015/cqa-lib-cqa-ui.mjs +0 -895
  102. package/dist/cqa-ui/fesm2015/cqa-lib-cqa-ui.mjs.map +0 -1
  103. package/dist/cqa-ui/fesm2020/cqa-lib-cqa-ui.mjs +0 -881
  104. package/dist/cqa-ui/fesm2020/cqa-lib-cqa-ui.mjs.map +0 -1
  105. package/dist/cqa-ui/lib/ui-kit.module.d.ts +0 -15
  106. package/dist/cqa-ui/package.json +0 -56
  107. package/dist/cqa-ui/public-api.d.ts +0 -9
  108. package/dist/cqa-ui/styles.css +0 -1
  109. /package/{dist/cqa-ui/cqa-lib-cqa-ui.d.ts → cqa-lib-cqa-ui.d.ts} +0 -0
  110. /package/{dist/cqa-ui/esm2020 → esm2020}/cqa-lib-cqa-ui.mjs +0 -0
  111. /package/{dist/cqa-ui/esm2020 → esm2020}/lib/dialog/dialog-ref.mjs +0 -0
  112. /package/{dist/cqa-ui/esm2020 → esm2020}/lib/dialog/dialog.models.mjs +0 -0
  113. /package/{dist/cqa-ui/esm2020 → esm2020}/lib/dialog/dialog.service.mjs +0 -0
  114. /package/{dist/cqa-ui/esm2020 → esm2020}/lib/dialog/dialog.tokens.mjs +0 -0
  115. /package/{dist/cqa-ui/lib → lib}/dialog/dialog-ref.d.ts +0 -0
  116. /package/{dist/cqa-ui/lib → lib}/dialog/dialog.component.d.ts +0 -0
  117. /package/{dist/cqa-ui/lib → lib}/dialog/dialog.models.d.ts +0 -0
  118. /package/{dist/cqa-ui/lib → lib}/dialog/dialog.service.d.ts +0 -0
  119. /package/{dist/cqa-ui/lib → lib}/dialog/dialog.tokens.d.ts +0 -0
  120. /package/{dist/cqa-ui/lib → lib}/search-bar/search-bar.component.d.ts +0 -0
  121. /package/{dist/cqa-ui/lib → lib}/segment-control/segment-control.component.d.ts +0 -0
@@ -0,0 +1,42 @@
1
+ import { Component, EventEmitter, Input, Output } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ import * as i1 from "@angular/material/button";
4
+ import * as i2 from "@angular/material/icon";
5
+ import * as i3 from "@angular/material/menu";
6
+ export class ActionMenuButtonComponent {
7
+ constructor() {
8
+ this.view = new EventEmitter();
9
+ this.edit = new EventEmitter();
10
+ this.delete = new EventEmitter();
11
+ }
12
+ navigateToTestCase(id) {
13
+ if (id === undefined || id === null)
14
+ return;
15
+ this.view.emit(id);
16
+ }
17
+ editTestCase(row) {
18
+ if (!row)
19
+ return;
20
+ this.edit.emit(row);
21
+ }
22
+ deleteTestCase(row) {
23
+ if (!row)
24
+ return;
25
+ this.delete.emit(row);
26
+ }
27
+ }
28
+ ActionMenuButtonComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: ActionMenuButtonComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
29
+ ActionMenuButtonComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.4.0", type: ActionMenuButtonComponent, selector: "cqa-action-menu-button", inputs: { row: "row" }, outputs: { view: "view", edit: "edit", delete: "delete" }, ngImport: i0, template: "<div id=\"cqa-ui-root\">\n <button class=\"action-menu-btn\" [matMenuTriggerFor]=\"actionMenu\" (click)=\"$event.stopPropagation()\" mat-icon-button\n type=\"button\" aria-label=\"More actions\">\n <mat-icon>more_horiz</mat-icon>\n </button>\n\n <mat-menu #actionMenu=\"matMenu\" class=\"action-menu\" xPosition=\"after\" yPosition=\"below\" hasBackdrop=\"true\">\n <button mat-menu-item (click)=\"navigateToTestCase(row?.id)\">\n <mat-icon>visibility</mat-icon>\n <span>View</span>\n </button>\n <button mat-menu-item (click)=\"editTestCase(row)\">\n <mat-icon>edit_square</mat-icon>\n <span>Edit</span>\n </button>\n <button mat-menu-item (click)=\"deleteTestCase(row)\" class=\"delete-menu-item\">\n <mat-icon>delete</mat-icon>\n <span>Delete</span>\n </button>\n </mat-menu>\n</div>", components: [{ type: i1.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { type: i2.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { type: i3.MatMenu, selector: "mat-menu", exportAs: ["matMenu"] }, { type: i3.MatMenuItem, selector: "[mat-menu-item]", inputs: ["disabled", "disableRipple", "role"], exportAs: ["matMenuItem"] }], directives: [{ type: i3.MatMenuTrigger, selector: "[mat-menu-trigger-for], [matMenuTriggerFor]", exportAs: ["matMenuTrigger"] }] });
30
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: ActionMenuButtonComponent, decorators: [{
31
+ type: Component,
32
+ args: [{ selector: 'cqa-action-menu-button', template: "<div id=\"cqa-ui-root\">\n <button class=\"action-menu-btn\" [matMenuTriggerFor]=\"actionMenu\" (click)=\"$event.stopPropagation()\" mat-icon-button\n type=\"button\" aria-label=\"More actions\">\n <mat-icon>more_horiz</mat-icon>\n </button>\n\n <mat-menu #actionMenu=\"matMenu\" class=\"action-menu\" xPosition=\"after\" yPosition=\"below\" hasBackdrop=\"true\">\n <button mat-menu-item (click)=\"navigateToTestCase(row?.id)\">\n <mat-icon>visibility</mat-icon>\n <span>View</span>\n </button>\n <button mat-menu-item (click)=\"editTestCase(row)\">\n <mat-icon>edit_square</mat-icon>\n <span>Edit</span>\n </button>\n <button mat-menu-item (click)=\"deleteTestCase(row)\" class=\"delete-menu-item\">\n <mat-icon>delete</mat-icon>\n <span>Delete</span>\n </button>\n </mat-menu>\n</div>", styles: [] }]
33
+ }], propDecorators: { row: [{
34
+ type: Input
35
+ }], view: [{
36
+ type: Output
37
+ }], edit: [{
38
+ type: Output
39
+ }], delete: [{
40
+ type: Output
41
+ }] } });
42
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWN0aW9uLW1lbnUuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vc3JjL2xpYi9hY3Rpb24tbWVudS9hY3Rpb24tbWVudS5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi9zcmMvbGliL2FjdGlvbi1tZW51L2FjdGlvbi1tZW51LmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsWUFBWSxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7Ozs7O0FBWXZFLE1BQU0sT0FBTyx5QkFBeUI7SUFMdEM7UUFRWSxTQUFJLEdBQUcsSUFBSSxZQUFZLEVBQW1CLENBQUM7UUFDM0MsU0FBSSxHQUFHLElBQUksWUFBWSxFQUFpQixDQUFDO1FBQ3pDLFdBQU0sR0FBRyxJQUFJLFlBQVksRUFBaUIsQ0FBQztLQWdCdEQ7SUFkQyxrQkFBa0IsQ0FBQyxFQUFvQjtRQUNyQyxJQUFJLEVBQUUsS0FBSyxTQUFTLElBQUksRUFBRSxLQUFLLElBQUk7WUFBRSxPQUFPO1FBQzVDLElBQUksQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQyxDQUFDO0lBQ3JCLENBQUM7SUFFRCxZQUFZLENBQUMsR0FBbUI7UUFDOUIsSUFBSSxDQUFDLEdBQUc7WUFBRSxPQUFPO1FBQ2pCLElBQUksQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDO0lBQ3RCLENBQUM7SUFFRCxjQUFjLENBQUMsR0FBbUI7UUFDaEMsSUFBSSxDQUFDLEdBQUc7WUFBRSxPQUFPO1FBQ2pCLElBQUksQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDO0lBQ3hCLENBQUM7O3NIQXBCVSx5QkFBeUI7MEdBQXpCLHlCQUF5QixpSkNadEMsODBCQW9CTTsyRkRSTyx5QkFBeUI7a0JBTHJDLFNBQVM7K0JBQ0Usd0JBQXdCOzhCQUt6QixHQUFHO3NCQUFYLEtBQUs7Z0JBRUksSUFBSTtzQkFBYixNQUFNO2dCQUNHLElBQUk7c0JBQWIsTUFBTTtnQkFDRyxNQUFNO3NCQUFmLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIEV2ZW50RW1pdHRlciwgSW5wdXQsIE91dHB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5leHBvcnQgaW50ZXJmYWNlIEFjdGlvbk1lbnVSb3cge1xuICBpZDogbnVtYmVyIHwgc3RyaW5nO1xuICBba2V5OiBzdHJpbmddOiBhbnk7XG59XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2NxYS1hY3Rpb24tbWVudS1idXR0b24nLFxuICB0ZW1wbGF0ZVVybDogJy4vYWN0aW9uLW1lbnUuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFtdXG59KVxuZXhwb3J0IGNsYXNzIEFjdGlvbk1lbnVCdXR0b25Db21wb25lbnQge1xuICBASW5wdXQoKSByb3c/OiBBY3Rpb25NZW51Um93O1xuXG4gIEBPdXRwdXQoKSB2aWV3ID0gbmV3IEV2ZW50RW1pdHRlcjxudW1iZXIgfCBzdHJpbmc+KCk7XG4gIEBPdXRwdXQoKSBlZGl0ID0gbmV3IEV2ZW50RW1pdHRlcjxBY3Rpb25NZW51Um93PigpO1xuICBAT3V0cHV0KCkgZGVsZXRlID0gbmV3IEV2ZW50RW1pdHRlcjxBY3Rpb25NZW51Um93PigpO1xuXG4gIG5hdmlnYXRlVG9UZXN0Q2FzZShpZD86IG51bWJlciB8IHN0cmluZyk6IHZvaWQge1xuICAgIGlmIChpZCA9PT0gdW5kZWZpbmVkIHx8IGlkID09PSBudWxsKSByZXR1cm47XG4gICAgdGhpcy52aWV3LmVtaXQoaWQpO1xuICB9XG5cbiAgZWRpdFRlc3RDYXNlKHJvdz86IEFjdGlvbk1lbnVSb3cpOiB2b2lkIHtcbiAgICBpZiAoIXJvdykgcmV0dXJuO1xuICAgIHRoaXMuZWRpdC5lbWl0KHJvdyk7XG4gIH1cblxuICBkZWxldGVUZXN0Q2FzZShyb3c/OiBBY3Rpb25NZW51Um93KTogdm9pZCB7XG4gICAgaWYgKCFyb3cpIHJldHVybjtcbiAgICB0aGlzLmRlbGV0ZS5lbWl0KHJvdyk7XG4gIH1cbn1cblxuXG4iLCI8ZGl2IGlkPVwiY3FhLXVpLXJvb3RcIj5cbiAgPGJ1dHRvbiBjbGFzcz1cImFjdGlvbi1tZW51LWJ0blwiIFttYXRNZW51VHJpZ2dlckZvcl09XCJhY3Rpb25NZW51XCIgKGNsaWNrKT1cIiRldmVudC5zdG9wUHJvcGFnYXRpb24oKVwiIG1hdC1pY29uLWJ1dHRvblxuICAgIHR5cGU9XCJidXR0b25cIiBhcmlhLWxhYmVsPVwiTW9yZSBhY3Rpb25zXCI+XG4gICAgPG1hdC1pY29uPm1vcmVfaG9yaXo8L21hdC1pY29uPlxuICA8L2J1dHRvbj5cblxuICA8bWF0LW1lbnUgI2FjdGlvbk1lbnU9XCJtYXRNZW51XCIgY2xhc3M9XCJhY3Rpb24tbWVudVwiIHhQb3NpdGlvbj1cImFmdGVyXCIgeVBvc2l0aW9uPVwiYmVsb3dcIiBoYXNCYWNrZHJvcD1cInRydWVcIj5cbiAgICA8YnV0dG9uIG1hdC1tZW51LWl0ZW0gKGNsaWNrKT1cIm5hdmlnYXRlVG9UZXN0Q2FzZShyb3c/LmlkKVwiPlxuICAgICAgPG1hdC1pY29uPnZpc2liaWxpdHk8L21hdC1pY29uPlxuICAgICAgPHNwYW4+Vmlldzwvc3Bhbj5cbiAgICA8L2J1dHRvbj5cbiAgICA8YnV0dG9uIG1hdC1tZW51LWl0ZW0gKGNsaWNrKT1cImVkaXRUZXN0Q2FzZShyb3cpXCI+XG4gICAgICA8bWF0LWljb24+ZWRpdF9zcXVhcmU8L21hdC1pY29uPlxuICAgICAgPHNwYW4+RWRpdDwvc3Bhbj5cbiAgICA8L2J1dHRvbj5cbiAgICA8YnV0dG9uIG1hdC1tZW51LWl0ZW0gKGNsaWNrKT1cImRlbGV0ZVRlc3RDYXNlKHJvdylcIiBjbGFzcz1cImRlbGV0ZS1tZW51LWl0ZW1cIj5cbiAgICAgIDxtYXQtaWNvbj5kZWxldGU8L21hdC1pY29uPlxuICAgICAgPHNwYW4+RGVsZXRlPC9zcGFuPlxuICAgIDwvYnV0dG9uPlxuICA8L21hdC1tZW51PlxuPC9kaXY+Il19
@@ -0,0 +1,28 @@
1
+ /**
2
+ * Image assets constants for the UI library
3
+ *
4
+ * Place your image files in src/lib/assets/images/ and reference them here
5
+ *
6
+ * Usage in components:
7
+ * import { EMPTY_STATE_IMAGES } from '../assets/images/image-assets.constants';
8
+ * imageUrl: EMPTY_STATE_IMAGES.TEST_CASE
9
+ */
10
+ export const EMPTY_STATE_IMAGES = {
11
+ // Test Case icon (document with gear)
12
+ TEST_CASE: 'assets/images/TestCaseIcon.png',
13
+ // Search/Debug icon (magnifying glass with question mark)
14
+ SEARCH_DEBUG: 'assets/images/SearchIcon.png',
15
+ // Upload/Folder icon (folder with upload arrow and plus)
16
+ UPLOAD_FOLDER: 'assets/images/FilesIcon.png',
17
+ // Dashboard overview
18
+ DASHBOARD: 'assets/images/DashboardIcon.png',
19
+ // Checklist/Add icon (clipboard with plus)
20
+ CHECKLIST_ADD: 'assets/images/StepsIcon.png',
21
+ // Document/Gear icon (document with gear overlay)
22
+ DOCUMENT_GEAR: 'assets/images/document-gear-icon.svg',
23
+ // Analytics/Chart icon (bar chart)
24
+ ANALYTICS_CHART: 'assets/images/ReportsIcon.png',
25
+ // Default empty state icon
26
+ DEFAULT: 'assets/images/SearchIcon.png',
27
+ };
28
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW1hZ2UtYXNzZXRzLmNvbnN0YW50cy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3NyYy9saWIvYXNzZXRzL2ltYWdlcy9pbWFnZS1hc3NldHMuY29uc3RhbnRzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOzs7Ozs7OztHQVFHO0FBRUgsTUFBTSxDQUFDLE1BQU0sa0JBQWtCLEdBQUc7SUFDaEMsc0NBQXNDO0lBQ3RDLFNBQVMsRUFBRSxnQ0FBZ0M7SUFFM0MsMERBQTBEO0lBQzFELFlBQVksRUFBRSw4QkFBOEI7SUFFNUMseURBQXlEO0lBQ3pELGFBQWEsRUFBRSw2QkFBNkI7SUFFNUMscUJBQXFCO0lBQ3JCLFNBQVMsRUFBRSxpQ0FBaUM7SUFFNUMsMkNBQTJDO0lBQzNDLGFBQWEsRUFBRSw2QkFBNkI7SUFFNUMsa0RBQWtEO0lBQ2xELGFBQWEsRUFBRSxzQ0FBc0M7SUFFckQsbUNBQW1DO0lBQ25DLGVBQWUsRUFBRSwrQkFBK0I7SUFFaEQsMkJBQTJCO0lBQzNCLE9BQU8sRUFBRSw4QkFBOEI7Q0FDL0IsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogSW1hZ2UgYXNzZXRzIGNvbnN0YW50cyBmb3IgdGhlIFVJIGxpYnJhcnlcbiAqIFxuICogUGxhY2UgeW91ciBpbWFnZSBmaWxlcyBpbiBzcmMvbGliL2Fzc2V0cy9pbWFnZXMvIGFuZCByZWZlcmVuY2UgdGhlbSBoZXJlXG4gKiBcbiAqIFVzYWdlIGluIGNvbXBvbmVudHM6XG4gKiBpbXBvcnQgeyBFTVBUWV9TVEFURV9JTUFHRVMgfSBmcm9tICcuLi9hc3NldHMvaW1hZ2VzL2ltYWdlLWFzc2V0cy5jb25zdGFudHMnO1xuICogaW1hZ2VVcmw6IEVNUFRZX1NUQVRFX0lNQUdFUy5URVNUX0NBU0VcbiAqL1xuXG5leHBvcnQgY29uc3QgRU1QVFlfU1RBVEVfSU1BR0VTID0ge1xuICAvLyBUZXN0IENhc2UgaWNvbiAoZG9jdW1lbnQgd2l0aCBnZWFyKVxuICBURVNUX0NBU0U6ICdhc3NldHMvaW1hZ2VzL1Rlc3RDYXNlSWNvbi5wbmcnLFxuICBcbiAgLy8gU2VhcmNoL0RlYnVnIGljb24gKG1hZ25pZnlpbmcgZ2xhc3Mgd2l0aCBxdWVzdGlvbiBtYXJrKVxuICBTRUFSQ0hfREVCVUc6ICdhc3NldHMvaW1hZ2VzL1NlYXJjaEljb24ucG5nJyxcbiAgXG4gIC8vIFVwbG9hZC9Gb2xkZXIgaWNvbiAoZm9sZGVyIHdpdGggdXBsb2FkIGFycm93IGFuZCBwbHVzKVxuICBVUExPQURfRk9MREVSOiAnYXNzZXRzL2ltYWdlcy9GaWxlc0ljb24ucG5nJyxcblxuICAvLyBEYXNoYm9hcmQgb3ZlcnZpZXdcbiAgREFTSEJPQVJEOiAnYXNzZXRzL2ltYWdlcy9EYXNoYm9hcmRJY29uLnBuZycsXG4gIFxuICAvLyBDaGVja2xpc3QvQWRkIGljb24gKGNsaXBib2FyZCB3aXRoIHBsdXMpXG4gIENIRUNLTElTVF9BREQ6ICdhc3NldHMvaW1hZ2VzL1N0ZXBzSWNvbi5wbmcnLFxuICBcbiAgLy8gRG9jdW1lbnQvR2VhciBpY29uIChkb2N1bWVudCB3aXRoIGdlYXIgb3ZlcmxheSlcbiAgRE9DVU1FTlRfR0VBUjogJ2Fzc2V0cy9pbWFnZXMvZG9jdW1lbnQtZ2Vhci1pY29uLnN2ZycsXG4gIFxuICAvLyBBbmFseXRpY3MvQ2hhcnQgaWNvbiAoYmFyIGNoYXJ0KVxuICBBTkFMWVRJQ1NfQ0hBUlQ6ICdhc3NldHMvaW1hZ2VzL1JlcG9ydHNJY29uLnBuZycsXG4gIFxuICAvLyBEZWZhdWx0IGVtcHR5IHN0YXRlIGljb25cbiAgREVGQVVMVDogJ2Fzc2V0cy9pbWFnZXMvU2VhcmNoSWNvbi5wbmcnLFxufSBhcyBjb25zdDtcblxuZXhwb3J0IHR5cGUgRW1wdHlTdGF0ZUltYWdlS2V5ID0ga2V5b2YgdHlwZW9mIEVNUFRZX1NUQVRFX0lNQUdFUztcblxuIl19
@@ -0,0 +1,141 @@
1
+ import { Component, Input } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ import * as i1 from "@angular/material/icon";
4
+ import * as i2 from "@angular/common";
5
+ export class BadgeComponent {
6
+ constructor() {
7
+ this.label = '';
8
+ this.variant = 'default';
9
+ }
10
+ get badgeClasses() {
11
+ const baseClasses = [
12
+ 'cqa-inline-flex',
13
+ 'cqa-items-center',
14
+ 'cqa-justify-center',
15
+ 'cqa-rounded-[6px]',
16
+ 'cqa-font-normal',
17
+ 'cqa-leading-[17px]'
18
+ ];
19
+ // Only apply variant-specific Tailwind classes if custom colors are not provided
20
+ if (!this.backgroundColor && !this.textColor) {
21
+ switch (this.variant) {
22
+ case 'error':
23
+ return [...baseClasses, 'cqa-bg-red-100', 'cqa-text-red-800'].join(' ');
24
+ case 'warning':
25
+ return [...baseClasses, 'cqa-bg-yellow-100', 'cqa-text-yellow-800'].join(' ');
26
+ case 'info':
27
+ return [...baseClasses, 'cqa-bg-blue-100', 'cqa-text-blue-800'].join(' ');
28
+ case 'success':
29
+ return [...baseClasses, 'cqa-bg-green-100', 'cqa-text-green-800'].join(' ');
30
+ case 'outline':
31
+ return [...baseClasses, 'cqa-bg-transparent', 'cqa-text-gray-800'].join(' ');
32
+ default:
33
+ return [...baseClasses, 'cqa-bg-gray-100', 'cqa-text-gray-800'].join(' ');
34
+ }
35
+ }
36
+ // If custom colors are provided, only return base classes
37
+ return baseClasses.join(' ');
38
+ }
39
+ get badgeStyles() {
40
+ const styles = {};
41
+ if (this.backgroundColor) {
42
+ styles['background-color'] = this.backgroundColor;
43
+ }
44
+ else if (this.variant === 'outline') {
45
+ styles['background-color'] = 'transparent';
46
+ }
47
+ if (this.textColor) {
48
+ styles['color'] = this.textColor;
49
+ }
50
+ return styles;
51
+ }
52
+ get iconContainerClasses() {
53
+ const baseClasses = [
54
+ 'cqa-inline-flex',
55
+ 'cqa-items-center',
56
+ 'cqa-justify-center',
57
+ 'cqa-flex-shrink-0',
58
+ 'cqa-mr-1.5'
59
+ ];
60
+ // No circular background for any variant - just return base classes
61
+ return baseClasses.join(' ');
62
+ }
63
+ get iconContainerStyles() {
64
+ const styles = {
65
+ 'display': 'inline-flex',
66
+ 'align-items': 'center',
67
+ 'justify-content': 'center'
68
+ };
69
+ // No circular background - only apply custom icon background color if explicitly provided
70
+ if (this.iconBackgroundColor) {
71
+ styles['background-color'] = this.iconBackgroundColor;
72
+ // If custom background is provided, add circle dimensions
73
+ styles['width'] = '16px';
74
+ styles['height'] = '16px';
75
+ styles['min-width'] = '16px';
76
+ styles['min-height'] = '16px';
77
+ styles['border-radius'] = '50%';
78
+ }
79
+ return styles;
80
+ }
81
+ get iconClasses() {
82
+ const baseClasses = [];
83
+ // Only apply white text class if custom icon color is not provided
84
+ if (!this.iconColor) {
85
+ return [...baseClasses, 'cqa-text-white'].join(' ');
86
+ }
87
+ return baseClasses.join(' ');
88
+ }
89
+ get iconStyles() {
90
+ const styles = {
91
+ 'font-size': '14px',
92
+ 'width': '14px',
93
+ 'height': '14px',
94
+ 'line-height': '14px'
95
+ };
96
+ if (this.iconColor) {
97
+ styles['color'] = this.iconColor;
98
+ }
99
+ else {
100
+ // Use variant-specific text color for icon (no white background anymore)
101
+ switch (this.variant) {
102
+ case 'error':
103
+ styles['color'] = '#991B1B'; // red-800
104
+ break;
105
+ case 'warning':
106
+ styles['color'] = '#854D0E'; // yellow-800
107
+ break;
108
+ case 'info':
109
+ styles['color'] = '#1E40AF'; // blue-800
110
+ break;
111
+ case 'success':
112
+ styles['color'] = '#166534'; // green-800
113
+ break;
114
+ default:
115
+ styles['color'] = this.textColor || '#374151'; // gray-700 default
116
+ }
117
+ }
118
+ return styles;
119
+ }
120
+ }
121
+ BadgeComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: BadgeComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
122
+ BadgeComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.4.0", type: BadgeComponent, selector: "cqa-badge", inputs: { label: "label", icon: "icon", variant: "variant", backgroundColor: "backgroundColor", textColor: "textColor", iconBackgroundColor: "iconBackgroundColor", iconColor: "iconColor" }, ngImport: i0, template: "<div id=\"cqa-ui-root\" style=\"display: inline-block;\">\n <span \n [ngClass]=\"badgeClasses\" \n [ngStyle]=\"badgeStyles\"\n class=\"cqa-font-inter cqa-font-normal cqa-text-sm cqa-leading-[17px] cqa-py-[4px] cqa-px-3\">\n <span \n *ngIf=\"icon\" \n [ngClass]=\"iconContainerClasses\"\n [ngStyle]=\"iconContainerStyles\">\n <mat-icon \n [ngClass]=\"iconClasses\"\n [ngStyle]=\"iconStyles\">{{ icon }}</mat-icon>\n </span>\n {{ label }}\n </span>\n</div>\n\n", components: [{ type: i1.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }], directives: [{ type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i2.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] });
123
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: BadgeComponent, decorators: [{
124
+ type: Component,
125
+ args: [{ selector: 'cqa-badge', template: "<div id=\"cqa-ui-root\" style=\"display: inline-block;\">\n <span \n [ngClass]=\"badgeClasses\" \n [ngStyle]=\"badgeStyles\"\n class=\"cqa-font-inter cqa-font-normal cqa-text-sm cqa-leading-[17px] cqa-py-[4px] cqa-px-3\">\n <span \n *ngIf=\"icon\" \n [ngClass]=\"iconContainerClasses\"\n [ngStyle]=\"iconContainerStyles\">\n <mat-icon \n [ngClass]=\"iconClasses\"\n [ngStyle]=\"iconStyles\">{{ icon }}</mat-icon>\n </span>\n {{ label }}\n </span>\n</div>\n\n", styles: [] }]
126
+ }], propDecorators: { label: [{
127
+ type: Input
128
+ }], icon: [{
129
+ type: Input
130
+ }], variant: [{
131
+ type: Input
132
+ }], backgroundColor: [{
133
+ type: Input
134
+ }], textColor: [{
135
+ type: Input
136
+ }], iconBackgroundColor: [{
137
+ type: Input
138
+ }], iconColor: [{
139
+ type: Input
140
+ }] } });
141
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"badge.component.js","sourceRoot":"","sources":["../../../../../src/lib/badge/badge.component.ts","../../../../../src/lib/badge/badge.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input } from '@angular/core';\n\nexport type BadgeVariant = 'warning' | 'error' | 'info' | 'success' | 'default' | 'outline';\n\n@Component({\n  selector: 'cqa-badge',\n  templateUrl: './badge.component.html',\n  styleUrls: []\n})\nexport class BadgeComponent {\n  @Input() label: string = '';\n  @Input() icon?: string;\n  @Input() variant: BadgeVariant = 'default';\n  @Input() backgroundColor?: string;\n  @Input() textColor?: string;\n  @Input() iconBackgroundColor?: string;\n  @Input() iconColor?: string;\n\n  get badgeClasses(): string {\n    const baseClasses = [\n      'cqa-inline-flex',\n      'cqa-items-center',\n      'cqa-justify-center',\n      'cqa-rounded-[6px]',\n      'cqa-font-normal',\n      'cqa-leading-[17px]'\n    ];\n    \n    // Only apply variant-specific Tailwind classes if custom colors are not provided\n    if (!this.backgroundColor && !this.textColor) {\n      switch (this.variant) {\n        case 'error':\n          return [...baseClasses, 'cqa-bg-red-100', 'cqa-text-red-800'].join(' ');\n        case 'warning':\n          return [...baseClasses, 'cqa-bg-yellow-100', 'cqa-text-yellow-800'].join(' ');\n        case 'info':\n          return [...baseClasses, 'cqa-bg-blue-100', 'cqa-text-blue-800'].join(' ');\n        case 'success':\n          return [...baseClasses, 'cqa-bg-green-100', 'cqa-text-green-800'].join(' ');\n        case 'outline':\n          return [...baseClasses, 'cqa-bg-transparent', 'cqa-text-gray-800'].join(' ');\n        default:\n          return [...baseClasses, 'cqa-bg-gray-100', 'cqa-text-gray-800'].join(' ');\n      }\n    }\n    \n    // If custom colors are provided, only return base classes\n    return baseClasses.join(' ');\n  }\n\n  get badgeStyles(): { [key: string]: string } {\n    const styles: { [key: string]: string } = {};\n    \n    if (this.backgroundColor) {\n      styles['background-color'] = this.backgroundColor;\n    } else if (this.variant === 'outline') {\n      styles['background-color'] = 'transparent';\n    }\n    \n    if (this.textColor) {\n      styles['color'] = this.textColor;\n    }\n    \n    return styles;\n  }\n\n  get iconContainerClasses(): string {\n    const baseClasses = [\n      'cqa-inline-flex',\n      'cqa-items-center',\n      'cqa-justify-center',\n      'cqa-flex-shrink-0',\n      'cqa-mr-1.5'\n    ];\n    \n    // No circular background for any variant - just return base classes\n    return baseClasses.join(' ');\n  }\n\n  get iconContainerStyles(): { [key: string]: string } {\n    const styles: { [key: string]: string } = {\n      'display': 'inline-flex',\n      'align-items': 'center',\n      'justify-content': 'center'\n    };\n    \n    // No circular background - only apply custom icon background color if explicitly provided\n    if (this.iconBackgroundColor) {\n      styles['background-color'] = this.iconBackgroundColor;\n      // If custom background is provided, add circle dimensions\n      styles['width'] = '16px';\n      styles['height'] = '16px';\n      styles['min-width'] = '16px';\n      styles['min-height'] = '16px';\n      styles['border-radius'] = '50%';\n    }\n    \n    return styles;\n  }\n\n  get iconClasses(): string {\n    const baseClasses: string[] = [];\n    \n    // Only apply white text class if custom icon color is not provided\n    if (!this.iconColor) {\n      return [...baseClasses, 'cqa-text-white'].join(' ');\n    }\n    \n    return baseClasses.join(' ');\n  }\n\n  get iconStyles(): { [key: string]: string } {\n    const styles: { [key: string]: string } = {\n      'font-size': '14px',\n      'width': '14px',\n      'height': '14px',\n      'line-height': '14px'\n    };\n    \n    if (this.iconColor) {\n      styles['color'] = this.iconColor;\n    } else {\n      // Use variant-specific text color for icon (no white background anymore)\n      switch (this.variant) {\n        case 'error':\n          styles['color'] = '#991B1B'; // red-800\n          break;\n        case 'warning':\n          styles['color'] = '#854D0E'; // yellow-800\n          break;\n        case 'info':\n          styles['color'] = '#1E40AF'; // blue-800\n          break;\n        case 'success':\n          styles['color'] = '#166534'; // green-800\n          break;\n        default:\n          styles['color'] = this.textColor || '#374151'; // gray-700 default\n      }\n    }\n    \n    return styles;\n  }\n}\n\n","<div id=\"cqa-ui-root\" style=\"display: inline-block;\">\n  <span \n    [ngClass]=\"badgeClasses\" \n    [ngStyle]=\"badgeStyles\"\n    class=\"cqa-font-inter cqa-font-normal cqa-text-sm cqa-leading-[17px] cqa-py-[4px] cqa-px-3\">\n    <span \n      *ngIf=\"icon\" \n      [ngClass]=\"iconContainerClasses\"\n      [ngStyle]=\"iconContainerStyles\">\n      <mat-icon \n        [ngClass]=\"iconClasses\"\n        [ngStyle]=\"iconStyles\">{{ icon }}</mat-icon>\n    </span>\n    {{ label }}\n  </span>\n</div>\n\n"]}
@@ -0,0 +1,232 @@
1
+ import { Component, Input, Output, EventEmitter, HostListener } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ import * as i1 from "@angular/material/icon";
4
+ import * as i2 from "@angular/common";
5
+ export class ButtonComponent {
6
+ constructor() {
7
+ this.variant = 'filled';
8
+ this.disabled = false;
9
+ this.iconPosition = 'start';
10
+ this.fullWidth = false;
11
+ this.type = 'button';
12
+ this.clicked = new EventEmitter();
13
+ // Internal state tracking
14
+ this.isHovered = false;
15
+ this.isFocused = false;
16
+ this.isPressed = false;
17
+ }
18
+ get hasIcon() {
19
+ return !!this.icon;
20
+ }
21
+ get buttonClasses() {
22
+ const baseClasses = [
23
+ 'cqa-inline-flex',
24
+ 'cqa-items-center',
25
+ 'cqa-justify-center',
26
+ 'cqa-gap-2',
27
+ 'cqa-py-[10px]',
28
+ 'cqa-rounded-[8px]',
29
+ 'cqa-text-[12.3px]',
30
+ 'cqa-leading-[17.5px]',
31
+ 'cqa-font-medium',
32
+ 'cqa-border',
33
+ ];
34
+ if (this.disabled) {
35
+ baseClasses.push('cqa-cursor-not-allowed');
36
+ }
37
+ if (this.fullWidth) {
38
+ baseClasses.push('cqa-w-full');
39
+ }
40
+ // Add variant and state specific classes
41
+ const variantClasses = this.getVariantClasses();
42
+ return [...baseClasses, ...variantClasses, ...(this.customClass ? [this.customClass] : [])].join(' ');
43
+ }
44
+ getVariantClasses() {
45
+ const classes = [];
46
+ if (this.variant === 'filled') {
47
+ if (this.disabled) {
48
+ classes.push('cqa-bg-primary-muted');
49
+ }
50
+ else {
51
+ classes.push('cqa-bg-primary cqa-text-white');
52
+ if (this.isHovered) {
53
+ classes.push('cqa-bg-primary-hover');
54
+ }
55
+ }
56
+ }
57
+ else if (this.variant === 'grey-solid') {
58
+ // Neutral grey solid style
59
+ if (this.disabled) {
60
+ classes.push('cqa-bg-grey-400', 'cqa-border', 'cqa-border-primary-muted');
61
+ }
62
+ else {
63
+ classes.push('cqa-bg-grey-400', 'cqa-border', 'cqa-border-primary-muted');
64
+ if (this.isHovered) {
65
+ classes.push('cqa-bg-grey-200');
66
+ }
67
+ }
68
+ }
69
+ else if (this.variant === 'outlined') {
70
+ if (this.disabled) {
71
+ classes.push('cqa-bg-transparent', 'cqa-border', 'cqa-border-primary-muted');
72
+ }
73
+ else {
74
+ if (this.isFocused) {
75
+ classes.push('cqa-bg-primary-surface-alt', 'cqa-border', 'cqa-border-primary-hover', 'cqa-shadow-[0px_4px_4px_rgba(0,0,0,0.25)]');
76
+ }
77
+ else if (this.isHovered || this.isPressed) {
78
+ classes.push('cqa-bg-primary-surface', 'cqa-border', 'cqa-border-primary');
79
+ }
80
+ else {
81
+ classes.push('cqa-bg-transparent', 'cqa-border', 'cqa-border-slate');
82
+ }
83
+ }
84
+ }
85
+ else if (this.variant === 'text') {
86
+ if (this.disabled) {
87
+ classes.push('cqa-bg-transparent', 'cqa-border-none');
88
+ }
89
+ else {
90
+ classes.push('cqa-bg-transparent', 'cqa-border-none');
91
+ if (this.isHovered || this.isFocused || this.isPressed) {
92
+ classes.push('cqa-bg-primary-surface');
93
+ }
94
+ }
95
+ }
96
+ else if (this.variant === 'elevated') {
97
+ if (this.disabled) {
98
+ classes.push('cqa-bg-primary-muted', 'cqa-shadow-none');
99
+ }
100
+ else {
101
+ if (this.isFocused) {
102
+ classes.push('cqa-bg-primary-surface-alt', 'cqa-shadow-[0px_4px_4px_rgba(0,0,0,0.25)]');
103
+ }
104
+ else if (this.isPressed) {
105
+ classes.push('cqa-bg-primary-surface', 'cqa-shadow-[0px_1px_2px_rgba(0,0,0,0.3),0px_1px_3px_1px_rgba(0,0,0,0.15)]');
106
+ }
107
+ else if (this.isHovered) {
108
+ classes.push('cqa-bg-primary-surface-alt', 'cqa-shadow-[0px_1px_2px_rgba(0,0,0,0.3),0px_2px_6px_2px_rgba(0,0,0,0.15)]');
109
+ }
110
+ else {
111
+ classes.push('cqa-bg-primary-surface', 'cqa-shadow-[0px_1px_2px_rgba(0,0,0,0.3),0px_1px_3px_1px_rgba(0,0,0,0.15)]');
112
+ }
113
+ }
114
+ }
115
+ else if (this.variant === 'tonal') {
116
+ if (this.disabled) {
117
+ classes.push('cqa-bg-primary-muted');
118
+ }
119
+ else {
120
+ if (this.isHovered) {
121
+ classes.push('cqa-bg-tonal-hover', 'cqa-shadow-[0px_1px_2px_rgba(0,0,0,0.3),0px_1px_3px_1px_rgba(0,0,0,0.15)]');
122
+ }
123
+ else {
124
+ classes.push('cqa-bg-primary-surface-alt');
125
+ }
126
+ }
127
+ }
128
+ return classes;
129
+ }
130
+ get textClass() {
131
+ if (this.disabled) {
132
+ if (this.variant === 'outlined' || this.variant === 'text') {
133
+ return 'cqa-text-ink';
134
+ }
135
+ return 'cqa-text-ink-muted';
136
+ }
137
+ switch (this.variant) {
138
+ case 'filled':
139
+ return 'cqa-text-surface-default';
140
+ case 'grey-solid':
141
+ return 'cqa-text-black-100';
142
+ case 'outlined':
143
+ if (this.isFocused || this.isHovered || this.isPressed) {
144
+ return 'cqa-text-primary-hover';
145
+ }
146
+ return 'cqa-text-slate';
147
+ case 'text':
148
+ case 'elevated':
149
+ return 'cqa-text-primary-hover';
150
+ case 'tonal':
151
+ return 'cqa-text-ink';
152
+ default:
153
+ return '';
154
+ }
155
+ }
156
+ onMouseEnter() {
157
+ if (!this.disabled) {
158
+ this.isHovered = true;
159
+ }
160
+ }
161
+ onMouseLeave() {
162
+ this.isHovered = false;
163
+ this.isPressed = false;
164
+ }
165
+ onMouseDown() {
166
+ if (!this.disabled) {
167
+ this.isPressed = true;
168
+ }
169
+ }
170
+ onMouseUp() {
171
+ this.isPressed = false;
172
+ }
173
+ onFocus() {
174
+ if (!this.disabled) {
175
+ this.isFocused = true;
176
+ }
177
+ }
178
+ onBlur() {
179
+ this.isFocused = false;
180
+ this.isPressed = false;
181
+ }
182
+ onClick(event) {
183
+ if (!this.disabled) {
184
+ this.clicked.emit(event);
185
+ }
186
+ }
187
+ }
188
+ ButtonComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: ButtonComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
189
+ ButtonComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.4.0", type: ButtonComponent, selector: "cqa-button", inputs: { variant: "variant", disabled: "disabled", icon: "icon", iconPosition: "iconPosition", fullWidth: "fullWidth", iconColor: "iconColor", type: "type", text: "text", customClass: "customClass" }, outputs: { clicked: "clicked" }, host: { listeners: { "mouseenter": "onMouseEnter()", "mouseleave": "onMouseLeave()", "mousedown": "onMouseDown()", "mouseup": "onMouseUp()", "focus": "onFocus()", "blur": "onBlur()" } }, ngImport: i0, template: "<div id=\"cqa-ui-root\">\n <button\n [ngClass]=\"\n text && icon && iconPosition === 'start' ? 'cqa-pr-[24px] cqa-pl-[16px]' :\n text && icon && iconPosition === 'end' ? 'cqa-pl-[24px] cqa-pr-[16px]' :\n text && !icon ? 'cqa-px-[24px]' : !text && icon ? 'cqa-px-[12px]' : 'cqa-px-[24px]'\"\n [type]=\"type\"\n [disabled]=\"disabled\"\n [attr.aria-disabled]=\"disabled\"\n [class]=\"buttonClasses\"\n (click)=\"onClick($event)\"\n >\n\n <mat-icon *ngIf=\"icon && iconPosition === 'start'\" class=\"!cqa-w-[18px] !cqa-h-[18px] !cqa-text-[18px]\" [style.color]=\"iconColor\">\n {{ icon }}\n </mat-icon>\n\n <!-- Dynamic text support -->\n <span *ngIf=\"text\">{{text}}</span>\n\n <ng-content *ngIf=\"!text\" ></ng-content>\n\n <mat-icon *ngIf=\"icon && iconPosition === 'end'\" class=\"!cqa-w-[18px] !cqa-h-[18px] !cqa-text-[18px]\" [style.color]=\"iconColor\">\n {{ icon }}\n </mat-icon>\n\n </button>\n</div>", components: [{ type: i1.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }], directives: [{ type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] });
190
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: ButtonComponent, decorators: [{
191
+ type: Component,
192
+ args: [{ selector: 'cqa-button', template: "<div id=\"cqa-ui-root\">\n <button\n [ngClass]=\"\n text && icon && iconPosition === 'start' ? 'cqa-pr-[24px] cqa-pl-[16px]' :\n text && icon && iconPosition === 'end' ? 'cqa-pl-[24px] cqa-pr-[16px]' :\n text && !icon ? 'cqa-px-[24px]' : !text && icon ? 'cqa-px-[12px]' : 'cqa-px-[24px]'\"\n [type]=\"type\"\n [disabled]=\"disabled\"\n [attr.aria-disabled]=\"disabled\"\n [class]=\"buttonClasses\"\n (click)=\"onClick($event)\"\n >\n\n <mat-icon *ngIf=\"icon && iconPosition === 'start'\" class=\"!cqa-w-[18px] !cqa-h-[18px] !cqa-text-[18px]\" [style.color]=\"iconColor\">\n {{ icon }}\n </mat-icon>\n\n <!-- Dynamic text support -->\n <span *ngIf=\"text\">{{text}}</span>\n\n <ng-content *ngIf=\"!text\" ></ng-content>\n\n <mat-icon *ngIf=\"icon && iconPosition === 'end'\" class=\"!cqa-w-[18px] !cqa-h-[18px] !cqa-text-[18px]\" [style.color]=\"iconColor\">\n {{ icon }}\n </mat-icon>\n\n </button>\n</div>", styles: [] }]
193
+ }], propDecorators: { variant: [{
194
+ type: Input
195
+ }], disabled: [{
196
+ type: Input
197
+ }], icon: [{
198
+ type: Input
199
+ }], iconPosition: [{
200
+ type: Input
201
+ }], fullWidth: [{
202
+ type: Input
203
+ }], iconColor: [{
204
+ type: Input
205
+ }], type: [{
206
+ type: Input
207
+ }], text: [{
208
+ type: Input
209
+ }], customClass: [{
210
+ type: Input
211
+ }], clicked: [{
212
+ type: Output
213
+ }], onMouseEnter: [{
214
+ type: HostListener,
215
+ args: ['mouseenter']
216
+ }], onMouseLeave: [{
217
+ type: HostListener,
218
+ args: ['mouseleave']
219
+ }], onMouseDown: [{
220
+ type: HostListener,
221
+ args: ['mousedown']
222
+ }], onMouseUp: [{
223
+ type: HostListener,
224
+ args: ['mouseup']
225
+ }], onFocus: [{
226
+ type: HostListener,
227
+ args: ['focus']
228
+ }], onBlur: [{
229
+ type: HostListener,
230
+ args: ['blur']
231
+ }] } });
232
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"button.component.js","sourceRoot":"","sources":["../../../../../src/lib/button/button.component.ts","../../../../../src/lib/button/button.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, Output, EventEmitter, HostListener } from '@angular/core';\n\nexport type ButtonVariant = 'filled' | 'outlined' | 'text' | 'elevated' | 'tonal' | 'grey-solid';\n\n@Component({\n  selector: 'cqa-button',\n  templateUrl: './button.component.html',\n  styleUrls: []\n})\nexport class ButtonComponent {\n  @Input() variant: ButtonVariant = 'filled';\n  @Input() disabled: boolean = false;\n  @Input() icon?: string;\n      @Input() iconPosition: 'start' | 'end' = 'start';\n      @Input() fullWidth: boolean = false;\n  @Input() iconColor?: string;\n  @Input() type: 'button' | 'submit' | 'reset' = 'button';\n  @Input() text?: string;\n  @Input() customClass?: string;\n  @Output() clicked = new EventEmitter<MouseEvent>();\n\n  // Internal state tracking\n  isHovered: boolean = false;\n  isFocused: boolean = false;\n  isPressed: boolean = false;\n\n  get hasIcon(): boolean {\n    return !!this.icon;\n  }\n\n  get buttonClasses(): string {\n    const baseClasses = [\n      'cqa-inline-flex',\n      'cqa-items-center',\n      'cqa-justify-center',\n      'cqa-gap-2',\n      'cqa-py-[10px]',\n      'cqa-rounded-[8px]',\n      'cqa-text-[12.3px]',\n      'cqa-leading-[17.5px]',\n      'cqa-font-medium',\n      'cqa-border',\n    ];\n\n        if (this.disabled) {\n      baseClasses.push('cqa-cursor-not-allowed');\n    }\n\n        if (this.fullWidth) {\n          baseClasses.push('cqa-w-full');\n        }\n\n    // Add variant and state specific classes\n    const variantClasses = this.getVariantClasses();\n    \n    return [...baseClasses, ...variantClasses, ...(this.customClass ? [this.customClass] : [])].join(' ');\n  }\n\n  private getVariantClasses(): string[] {\n    const classes: string[] = [];\n\n    if (this.variant === 'filled') {\n      if (this.disabled) {\n        classes.push('cqa-bg-primary-muted');\n      } else {\n        classes.push('cqa-bg-primary cqa-text-white');\n        if (this.isHovered) {\n          classes.push('cqa-bg-primary-hover');\n        }\n      }\n    } else if (this.variant === 'grey-solid') {\n      // Neutral grey solid style\n      if (this.disabled) {\n        classes.push('cqa-bg-grey-400', 'cqa-border', 'cqa-border-primary-muted');\n      } else {\n        classes.push('cqa-bg-grey-400', 'cqa-border', 'cqa-border-primary-muted');\n        if (this.isHovered) {\n          classes.push('cqa-bg-grey-200');\n        }\n      }\n    } else if (this.variant === 'outlined') {\n      if (this.disabled) {\n        classes.push('cqa-bg-transparent', 'cqa-border', 'cqa-border-primary-muted');\n      } else {\n        if (this.isFocused) {\n          classes.push('cqa-bg-primary-surface-alt', 'cqa-border', 'cqa-border-primary-hover', 'cqa-shadow-[0px_4px_4px_rgba(0,0,0,0.25)]');\n        } else if (this.isHovered || this.isPressed) {\n          classes.push('cqa-bg-primary-surface', 'cqa-border', 'cqa-border-primary');\n        } else {\n          classes.push('cqa-bg-transparent', 'cqa-border', 'cqa-border-slate');\n        }\n      }\n    } else if (this.variant === 'text') {\n      if (this.disabled) {\n        classes.push('cqa-bg-transparent', 'cqa-border-none');\n      } else {\n        classes.push('cqa-bg-transparent', 'cqa-border-none');\n        if (this.isHovered || this.isFocused || this.isPressed) {\n          classes.push('cqa-bg-primary-surface');\n        }\n      }\n    } else if (this.variant === 'elevated') {\n      if (this.disabled) {\n        classes.push('cqa-bg-primary-muted', 'cqa-shadow-none');\n      } else {\n        if (this.isFocused) {\n          classes.push('cqa-bg-primary-surface-alt', 'cqa-shadow-[0px_4px_4px_rgba(0,0,0,0.25)]');\n        } else if (this.isPressed) {\n          classes.push('cqa-bg-primary-surface', 'cqa-shadow-[0px_1px_2px_rgba(0,0,0,0.3),0px_1px_3px_1px_rgba(0,0,0,0.15)]');\n        } else if (this.isHovered) {\n          classes.push('cqa-bg-primary-surface-alt', 'cqa-shadow-[0px_1px_2px_rgba(0,0,0,0.3),0px_2px_6px_2px_rgba(0,0,0,0.15)]');\n        } else {\n          classes.push('cqa-bg-primary-surface', 'cqa-shadow-[0px_1px_2px_rgba(0,0,0,0.3),0px_1px_3px_1px_rgba(0,0,0,0.15)]');\n        }\n      }\n    } else if (this.variant === 'tonal') {\n      if (this.disabled) {\n        classes.push('cqa-bg-primary-muted');\n      } else {\n        if (this.isHovered) {\n          classes.push('cqa-bg-tonal-hover', 'cqa-shadow-[0px_1px_2px_rgba(0,0,0,0.3),0px_1px_3px_1px_rgba(0,0,0,0.15)]');\n        } else {\n          classes.push('cqa-bg-primary-surface-alt');\n        }\n      }\n    }\n\n    return classes;\n  }\n\n  get textClass(): string {\n    if (this.disabled) {\n      if (this.variant === 'outlined' || this.variant === 'text') {\n        return 'cqa-text-ink';\n      }\n      return 'cqa-text-ink-muted';\n    }\n\n    switch (this.variant) {\n      case 'filled':\n        return 'cqa-text-surface-default';\n      case 'grey-solid':\n        return 'cqa-text-black-100';\n      case 'outlined':\n        if (this.isFocused || this.isHovered || this.isPressed) {\n          return 'cqa-text-primary-hover';\n        }\n        return 'cqa-text-slate';\n      case 'text':\n      case 'elevated':\n        return 'cqa-text-primary-hover';\n      case 'tonal':\n        return 'cqa-text-ink';\n      default:\n        return '';\n    }\n  }\n\n  @HostListener('mouseenter')\n  onMouseEnter() {\n    if (!this.disabled) {\n      this.isHovered = true;\n    }\n  }\n\n  @HostListener('mouseleave')\n  onMouseLeave() {\n    this.isHovered = false;\n    this.isPressed = false;\n  }\n\n  @HostListener('mousedown')\n  onMouseDown() {\n    if (!this.disabled) {\n      this.isPressed = true;\n    }\n  }\n\n  @HostListener('mouseup')\n  onMouseUp() {\n    this.isPressed = false;\n  }\n\n  @HostListener('focus')\n  onFocus() {\n    if (!this.disabled) {\n      this.isFocused = true;\n    }\n  }\n\n  @HostListener('blur')\n  onBlur() {\n    this.isFocused = false;\n    this.isPressed = false;\n  }\n\n  onClick(event: MouseEvent) {\n    if (!this.disabled) {\n      this.clicked.emit(event);\n    }\n  }\n}\n\n","<div id=\"cqa-ui-root\">\n  <button\n    [ngClass]=\"\n    text && icon && iconPosition === 'start' ? 'cqa-pr-[24px] cqa-pl-[16px]' :\n    text && icon && iconPosition === 'end' ? 'cqa-pl-[24px] cqa-pr-[16px]' :\n    text && !icon ? 'cqa-px-[24px]' : !text && icon ? 'cqa-px-[12px]' : 'cqa-px-[24px]'\"\n    [type]=\"type\"\n    [disabled]=\"disabled\"\n    [attr.aria-disabled]=\"disabled\"\n    [class]=\"buttonClasses\"\n    (click)=\"onClick($event)\"\n  >\n\n    <mat-icon *ngIf=\"icon && iconPosition === 'start'\" class=\"!cqa-w-[18px] !cqa-h-[18px] !cqa-text-[18px]\" [style.color]=\"iconColor\">\n      {{ icon }}\n    </mat-icon>\n\n    <!-- Dynamic text support -->\n    <span *ngIf=\"text\">{{text}}</span>\n\n    <ng-content *ngIf=\"!text\" ></ng-content>\n\n    <mat-icon *ngIf=\"icon && iconPosition === 'end'\" class=\"!cqa-w-[18px] !cqa-h-[18px] !cqa-text-[18px]\" [style.color]=\"iconColor\">\n      {{ icon }}\n    </mat-icon>\n\n  </button>\n</div>"]}
@@ -0,0 +1,69 @@
1
+ import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ import * as i1 from "../button/button.component";
4
+ import * as i2 from "@angular/material/menu";
5
+ import * as i3 from "@angular/material/checkbox";
6
+ import * as i4 from "@angular/material/radio";
7
+ import * as i5 from "@angular/common";
8
+ import * as i6 from "@angular/forms";
9
+ export class ColumnVisibilityComponent {
10
+ constructor() {
11
+ this.isStepGroup = false;
12
+ // Dynamic columns (preferred). Each item defines the id used as key and the label to render.
13
+ this.columns = [];
14
+ // Start with an empty visibility map; keys will be added from 'columns'
15
+ this.columnVisibility = {};
16
+ this.selectedAutoRefreshInterval = 0; // 0 = Off
17
+ this.columnVisibilityChange = new EventEmitter();
18
+ this.autoRefreshChange = new EventEmitter();
19
+ }
20
+ ngOnChanges(changes) {
21
+ // When dynamic columns change, ensure we have keys in the visibility map
22
+ if (changes['columns'] && Array.isArray(this.columns) && this.columns.length) {
23
+ for (const col of this.columns) {
24
+ if (this.columnVisibility[col.id] === undefined) {
25
+ this.columnVisibility[col.id] = true;
26
+ }
27
+ }
28
+ }
29
+ }
30
+ get areAllColumnsSelected() {
31
+ const keys = this.getTogglableKeys();
32
+ return keys.every(k => !!this.columnVisibility[k]);
33
+ }
34
+ toggleAllColumns(checked) {
35
+ const keys = this.getTogglableKeys();
36
+ for (const k of keys) {
37
+ this.columnVisibility[k] = checked;
38
+ }
39
+ this.saveColumnPreferences();
40
+ }
41
+ saveColumnPreferences() {
42
+ this.columnVisibilityChange.emit({ ...this.columnVisibility });
43
+ }
44
+ onAutoRefreshChange() {
45
+ this.autoRefreshChange.emit(this.selectedAutoRefreshInterval);
46
+ }
47
+ getTogglableKeys() {
48
+ return Array.isArray(this.columns) ? this.columns.map(c => c.id) : [];
49
+ }
50
+ }
51
+ ColumnVisibilityComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: ColumnVisibilityComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
52
+ ColumnVisibilityComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.4.0", type: ColumnVisibilityComponent, selector: "cqa-column-visibility", inputs: { isStepGroup: "isStepGroup", columns: "columns", columnVisibility: "columnVisibility", selectedAutoRefreshInterval: "selectedAutoRefreshInterval" }, outputs: { columnVisibilityChange: "columnVisibilityChange", autoRefreshChange: "autoRefreshChange" }, usesOnChanges: true, ngImport: i0, template: "<div id=\"cqa-ui-root\">\n <cqa-button variant=\"grey-solid\" icon=\"settings\" [matMenuTriggerFor]=\"settingsMenu\" aria-label=\"Settings\">\n </cqa-button>\n\n <mat-menu #settingsMenu=\"matMenu\" class=\"table-settings-menu\">\n <div class=\"settings-menu-content cqa-p-[17px]\" (click)=\"$event.stopPropagation()\">\n <div class=\"settings-section cqa-mb-3\">\n <h4 class=\"settings-title cqa-font-bold cqa-text-[14px] cqa-leading-[20px] cqa-mb-2\">Show Columns</h4>\n <div class=\"settings-options cqa-flex cqa-flex-col cqa-gap-2 cqa-text-[14px] cqa-leading-[20px]\">\n <mat-checkbox [checked]=\"areAllColumnsSelected\" (change)=\"toggleAllColumns($event.checked)\"\n class=\"select-all-checkbox\">\n {{ areAllColumnsSelected ? 'Unselect All' : 'Select All' }}\n </mat-checkbox>\n <!-- Dynamic column list -->\n <ng-container *ngIf=\"columns?.length\">\n <mat-checkbox *ngFor=\"let col of columns\" [(ngModel)]=\"columnVisibility[col.id]\"\n (change)=\"saveColumnPreferences()\">\n {{ col.label }}\n </mat-checkbox>\n </ng-container>\n </div>\n </div>\n\n <div class=\"settings-section\">\n <h4 class=\"settings-title cqa-font-bold cqa-text-[14px] cqa-leading-[20px] cqa-mb-2\">Auto refresh every</h4>\n <div class=\"refresh-options\">\n <mat-radio-group [(ngModel)]=\"selectedAutoRefreshInterval\" (change)=\"onAutoRefreshChange()\"\n class=\"cqa-flex cqa-flex-col cqa-gap-2 cqa-text-[14px] cqa-leading-[20px]\">\n <label><mat-radio-button [value]=\"10000\">10 Seconds</mat-radio-button></label>\n <label><mat-radio-button [value]=\"20000\">20 Seconds</mat-radio-button></label>\n <label><mat-radio-button [value]=\"30000\">30 Seconds</mat-radio-button></label>\n <label><mat-radio-button [value]=\"0\">Off</mat-radio-button></label>\n </mat-radio-group>\n </div>\n </div>\n </div>\n </mat-menu>", components: [{ type: i1.ButtonComponent, selector: "cqa-button", inputs: ["variant", "disabled", "icon", "iconPosition", "fullWidth", "iconColor", "type", "text", "customClass"], outputs: ["clicked"] }, { type: i2.MatMenu, selector: "mat-menu", exportAs: ["matMenu"] }, { type: i3.MatCheckbox, selector: "mat-checkbox", inputs: ["disableRipple", "color", "tabIndex", "aria-label", "aria-labelledby", "aria-describedby", "id", "required", "labelPosition", "name", "value", "checked", "disabled", "indeterminate"], outputs: ["change", "indeterminateChange"], exportAs: ["matCheckbox"] }, { type: i4.MatRadioButton, selector: "mat-radio-button", inputs: ["disableRipple", "tabIndex"], exportAs: ["matRadioButton"] }], directives: [{ type: i2.MatMenuTrigger, selector: "[mat-menu-trigger-for], [matMenuTriggerFor]", exportAs: ["matMenuTrigger"] }, { type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i5.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i6.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i6.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { type: i4.MatRadioGroup, selector: "mat-radio-group", exportAs: ["matRadioGroup"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
53
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: ColumnVisibilityComponent, decorators: [{
54
+ type: Component,
55
+ args: [{ selector: 'cqa-column-visibility', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div id=\"cqa-ui-root\">\n <cqa-button variant=\"grey-solid\" icon=\"settings\" [matMenuTriggerFor]=\"settingsMenu\" aria-label=\"Settings\">\n </cqa-button>\n\n <mat-menu #settingsMenu=\"matMenu\" class=\"table-settings-menu\">\n <div class=\"settings-menu-content cqa-p-[17px]\" (click)=\"$event.stopPropagation()\">\n <div class=\"settings-section cqa-mb-3\">\n <h4 class=\"settings-title cqa-font-bold cqa-text-[14px] cqa-leading-[20px] cqa-mb-2\">Show Columns</h4>\n <div class=\"settings-options cqa-flex cqa-flex-col cqa-gap-2 cqa-text-[14px] cqa-leading-[20px]\">\n <mat-checkbox [checked]=\"areAllColumnsSelected\" (change)=\"toggleAllColumns($event.checked)\"\n class=\"select-all-checkbox\">\n {{ areAllColumnsSelected ? 'Unselect All' : 'Select All' }}\n </mat-checkbox>\n <!-- Dynamic column list -->\n <ng-container *ngIf=\"columns?.length\">\n <mat-checkbox *ngFor=\"let col of columns\" [(ngModel)]=\"columnVisibility[col.id]\"\n (change)=\"saveColumnPreferences()\">\n {{ col.label }}\n </mat-checkbox>\n </ng-container>\n </div>\n </div>\n\n <div class=\"settings-section\">\n <h4 class=\"settings-title cqa-font-bold cqa-text-[14px] cqa-leading-[20px] cqa-mb-2\">Auto refresh every</h4>\n <div class=\"refresh-options\">\n <mat-radio-group [(ngModel)]=\"selectedAutoRefreshInterval\" (change)=\"onAutoRefreshChange()\"\n class=\"cqa-flex cqa-flex-col cqa-gap-2 cqa-text-[14px] cqa-leading-[20px]\">\n <label><mat-radio-button [value]=\"10000\">10 Seconds</mat-radio-button></label>\n <label><mat-radio-button [value]=\"20000\">20 Seconds</mat-radio-button></label>\n <label><mat-radio-button [value]=\"30000\">30 Seconds</mat-radio-button></label>\n <label><mat-radio-button [value]=\"0\">Off</mat-radio-button></label>\n </mat-radio-group>\n </div>\n </div>\n </div>\n </mat-menu>", styles: [] }]
56
+ }], propDecorators: { isStepGroup: [{
57
+ type: Input
58
+ }], columns: [{
59
+ type: Input
60
+ }], columnVisibility: [{
61
+ type: Input
62
+ }], selectedAutoRefreshInterval: [{
63
+ type: Input
64
+ }], columnVisibilityChange: [{
65
+ type: Output
66
+ }], autoRefreshChange: [{
67
+ type: Output
68
+ }] } });
69
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"column-visibility.component.js","sourceRoot":"","sources":["../../../../../src/lib/column-visibility/column-visibility.component.ts","../../../../../src/lib/column-visibility/column-visibility.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,uBAAuB,EAAE,SAAS,EAAE,YAAY,EAAE,KAAK,EAAa,MAAM,EAAiB,MAAM,eAAe,CAAC;;;;;;;;AAsB1H,MAAM,OAAO,yBAAyB;IANtC;QAOW,gBAAW,GAAY,KAAK,CAAC;QACtC,6FAA6F;QACpF,YAAO,GAAyC,EAAE,CAAC;QAC5D,wEAAwE;QAC/D,qBAAgB,GAA2B,EAAE,CAAC;QAC9C,gCAA2B,GAAW,CAAC,CAAC,CAAC,UAAU;QAElD,2BAAsB,GAAG,IAAI,YAAY,EAA0B,CAAC;QACpE,sBAAiB,GAAG,IAAI,YAAY,EAAU,CAAC;KAqC1D;IAnCC,WAAW,CAAC,OAAsB;QAChC,yEAAyE;QACzE,IAAI,OAAO,CAAC,SAAS,CAAC,IAAI,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,IAAI,CAAC,OAAO,CAAC,MAAM,EAAE;YAC5E,KAAK,MAAM,GAAG,IAAI,IAAI,CAAC,OAAO,EAAE;gBAC9B,IAAI,IAAI,CAAC,gBAAgB,CAAC,GAAG,CAAC,EAAE,CAAC,KAAK,SAAS,EAAE;oBAC/C,IAAI,CAAC,gBAAgB,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC;iBACtC;aACF;SACF;IACH,CAAC;IAED,IAAI,qBAAqB;QACvB,MAAM,IAAI,GAAG,IAAI,CAAC,gBAAgB,EAAE,CAAC;QACrC,OAAO,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC,CAAC,CAAC,CAAC;IACrD,CAAC;IAED,gBAAgB,CAAC,OAAgB;QAC/B,MAAM,IAAI,GAAG,IAAI,CAAC,gBAAgB,EAAE,CAAC;QACrC,KAAK,MAAM,CAAC,IAAI,IAAI,EAAE;YACpB,IAAI,CAAC,gBAAgB,CAAC,CAAC,CAAC,GAAG,OAAO,CAAC;SACpC;QACD,IAAI,CAAC,qBAAqB,EAAE,CAAC;IAC/B,CAAC;IAED,qBAAqB;QACnB,IAAI,CAAC,sBAAsB,CAAC,IAAI,CAAC,EAAE,GAAG,IAAI,CAAC,gBAAgB,EAAE,CAAC,CAAC;IACjE,CAAC;IAED,mBAAmB;QACjB,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,IAAI,CAAC,2BAA2B,CAAC,CAAC;IAChE,CAAC;IAEO,gBAAgB;QACtB,OAAO,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;IACxE,CAAC;;sHA7CU,yBAAyB;0GAAzB,yBAAyB,uVCtBtC,8gEAoCa;2FDdA,yBAAyB;kBANrC,SAAS;+BACE,uBAAuB,mBAGhB,uBAAuB,CAAC,MAAM;8BAGtC,WAAW;sBAAnB,KAAK;gBAEG,OAAO;sBAAf,KAAK;gBAEG,gBAAgB;sBAAxB,KAAK;gBACG,2BAA2B;sBAAnC,KAAK;gBAEI,sBAAsB;sBAA/B,MAAM;gBACG,iBAAiB;sBAA1B,MAAM","sourcesContent":["import { ChangeDetectionStrategy, Component, EventEmitter, Input, OnChanges, Output, SimpleChanges } from '@angular/core';\n\nexport interface ColumnVisibilityConfig {\n  type?: boolean;\n  priority?: boolean;\n  result?: boolean;\n  status?: boolean;\n  labels?: boolean;\n  createdBy?: boolean;\n  createdAt?: boolean;\n  updatedAt?: boolean;\n  lastRun?: boolean;\n  // Allow additional keys\n  [key: string]: any;\n}\n\n@Component({\n  selector: 'cqa-column-visibility',\n  templateUrl: './column-visibility.component.html',\n  styleUrls: [],\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class ColumnVisibilityComponent implements OnChanges {\n  @Input() isStepGroup: boolean = false;\n  // Dynamic columns (preferred). Each item defines the id used as key and the label to render.\n  @Input() columns: Array<{ id: string; label: string }> = [];\n  // Start with an empty visibility map; keys will be added from 'columns'\n  @Input() columnVisibility: ColumnVisibilityConfig = {};\n  @Input() selectedAutoRefreshInterval: number = 0; // 0 = Off\n\n  @Output() columnVisibilityChange = new EventEmitter<ColumnVisibilityConfig>();\n  @Output() autoRefreshChange = new EventEmitter<number>();\n\n  ngOnChanges(changes: SimpleChanges): void {\n    // When dynamic columns change, ensure we have keys in the visibility map\n    if (changes['columns'] && Array.isArray(this.columns) && this.columns.length) {\n      for (const col of this.columns) {\n        if (this.columnVisibility[col.id] === undefined) {\n          this.columnVisibility[col.id] = true;\n        }\n      }\n    }\n  }\n\n  get areAllColumnsSelected(): boolean {\n    const keys = this.getTogglableKeys();\n    return keys.every(k => !!this.columnVisibility[k]);\n  }\n\n  toggleAllColumns(checked: boolean): void {\n    const keys = this.getTogglableKeys();\n    for (const k of keys) {\n      this.columnVisibility[k] = checked;\n    }\n    this.saveColumnPreferences();\n  }\n\n  saveColumnPreferences(): void {\n    this.columnVisibilityChange.emit({ ...this.columnVisibility });\n  }\n\n  onAutoRefreshChange(): void {\n    this.autoRefreshChange.emit(this.selectedAutoRefreshInterval);\n  }\n\n  private getTogglableKeys(): string[] {\n    return Array.isArray(this.columns) ? this.columns.map(c => c.id) : [];\n  }\n}\n\n\n","<div id=\"cqa-ui-root\">\n  <cqa-button variant=\"grey-solid\" icon=\"settings\" [matMenuTriggerFor]=\"settingsMenu\" aria-label=\"Settings\">\n  </cqa-button>\n\n  <mat-menu #settingsMenu=\"matMenu\" class=\"table-settings-menu\">\n    <div class=\"settings-menu-content cqa-p-[17px]\" (click)=\"$event.stopPropagation()\">\n      <div class=\"settings-section cqa-mb-3\">\n        <h4 class=\"settings-title cqa-font-bold cqa-text-[14px] cqa-leading-[20px] cqa-mb-2\">Show Columns</h4>\n        <div class=\"settings-options cqa-flex cqa-flex-col cqa-gap-2 cqa-text-[14px] cqa-leading-[20px]\">\n          <mat-checkbox [checked]=\"areAllColumnsSelected\" (change)=\"toggleAllColumns($event.checked)\"\n            class=\"select-all-checkbox\">\n            {{ areAllColumnsSelected ? 'Unselect All' : 'Select All' }}\n          </mat-checkbox>\n          <!-- Dynamic column list -->\n          <ng-container *ngIf=\"columns?.length\">\n            <mat-checkbox *ngFor=\"let col of columns\" [(ngModel)]=\"columnVisibility[col.id]\"\n              (change)=\"saveColumnPreferences()\">\n              {{ col.label }}\n            </mat-checkbox>\n          </ng-container>\n        </div>\n      </div>\n\n      <div class=\"settings-section\">\n        <h4 class=\"settings-title cqa-font-bold cqa-text-[14px] cqa-leading-[20px] cqa-mb-2\">Auto refresh every</h4>\n        <div class=\"refresh-options\">\n          <mat-radio-group [(ngModel)]=\"selectedAutoRefreshInterval\" (change)=\"onAutoRefreshChange()\"\n            class=\"cqa-flex cqa-flex-col cqa-gap-2 cqa-text-[14px] cqa-leading-[20px]\">\n            <label><mat-radio-button [value]=\"10000\">10 Seconds</mat-radio-button></label>\n            <label><mat-radio-button [value]=\"20000\">20 Seconds</mat-radio-button></label>\n            <label><mat-radio-button [value]=\"30000\">30 Seconds</mat-radio-button></label>\n            <label><mat-radio-button [value]=\"0\">Off</mat-radio-button></label>\n          </mat-radio-group>\n        </div>\n      </div>\n    </div>\n  </mat-menu>"]}