@cqa-lib/cqa-ui 0.1.2 → 1.0.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2020/lib/action-menu/action-menu.component.mjs +42 -0
- package/esm2020/lib/assets/images/image-assets.constants.mjs +28 -0
- package/esm2020/lib/badge/badge.component.mjs +141 -0
- package/esm2020/lib/button/button.component.mjs +42 -67
- package/esm2020/lib/column-visibility/column-visibility.component.mjs +69 -0
- package/esm2020/lib/dashboards/chart-card/chart-card.component.mjs +22 -0
- package/esm2020/lib/dashboards/coverage-module-card/coverage-module-card.component.mjs +105 -0
- package/esm2020/lib/dashboards/dashboard-header/dashboard-header.component.mjs +82 -0
- package/esm2020/lib/dashboards/failed-test-cases-card/failed-test-cases-card.component.mjs +59 -0
- package/esm2020/lib/dashboards/heat-error-map-cell/heat-error-map-cell.component.mjs +45 -0
- package/esm2020/lib/dashboards/insight-card/insight-card.component.mjs +201 -0
- package/esm2020/lib/dashboards/metrics-card/metrics-block.component.mjs +41 -0
- package/esm2020/lib/dashboards/metrics-card/metrics-card-item.interface.mjs +2 -0
- package/esm2020/lib/dashboards/metrics-card/metrics-card.component.mjs +62 -0
- package/esm2020/lib/dashboards/progress-text-card/progress-text-card.component.mjs +46 -0
- package/esm2020/lib/dashboards/test-distribution-card/test-distribution-card.component.mjs +35 -0
- package/esm2020/lib/dialog/dialog.component.mjs +4 -4
- package/esm2020/lib/dropdown-button/dropdown-button.component.mjs +189 -0
- package/esm2020/lib/dynamic-select/dynamic-select-field.component.mjs +160 -0
- package/esm2020/lib/empty-state/empty-state.component.mjs +37 -0
- package/esm2020/lib/filters/dynamic-filter/dynamic-filter.component.mjs +239 -0
- package/esm2020/lib/full-table-loader/full-table-loader.component.mjs +16 -0
- package/esm2020/lib/inline-sort/inline-sort.component.mjs +58 -0
- package/esm2020/lib/other-button/other-button.component.mjs +76 -0
- package/esm2020/lib/pagination/pagination.component.mjs +102 -0
- package/esm2020/lib/search-bar/search-bar.component.mjs +3 -3
- package/esm2020/lib/segment-control/segment-control.component.mjs +3 -3
- package/esm2020/lib/selected-filters/selected-filters.component.mjs +27 -0
- package/esm2020/lib/table/dynamic-table/dynamic-cell.directive.mjs +35 -0
- package/esm2020/lib/table/dynamic-table/dynamic-table.component.mjs +258 -0
- package/esm2020/lib/table-action-toolbar/table-action-toolbar.component.mjs +52 -0
- package/esm2020/lib/table-data-loader/table-data-loader.component.mjs +19 -0
- package/esm2020/lib/templates/table-template.component.mjs +365 -0
- package/esm2020/lib/ui-kit.module.mjs +196 -17
- package/esm2020/lib/utils/metadata-colors.util.mjs +100 -0
- package/esm2020/lib/utils/tw-overlay-container.mjs +22 -0
- package/esm2020/public-api.mjs +29 -1
- package/fesm2015/cqa-lib-cqa-ui.mjs +2899 -133
- package/fesm2015/cqa-lib-cqa-ui.mjs.map +1 -1
- package/fesm2020/cqa-lib-cqa-ui.mjs +2867 -133
- package/fesm2020/cqa-lib-cqa-ui.mjs.map +1 -1
- package/lib/action-menu/action-menu.component.d.ts +17 -0
- package/lib/assets/images/image-assets.constants.d.ts +20 -0
- package/lib/badge/badge.component.d.ts +25 -0
- package/lib/button/button.component.d.ts +6 -5
- package/lib/column-visibility/column-visibility.component.d.ts +33 -0
- package/lib/dashboards/chart-card/chart-card.component.d.ts +8 -0
- package/lib/dashboards/coverage-module-card/coverage-module-card.component.d.ts +44 -0
- package/lib/dashboards/dashboard-header/dashboard-header.component.d.ts +30 -0
- package/lib/dashboards/failed-test-cases-card/failed-test-cases-card.component.d.ts +28 -0
- package/lib/dashboards/heat-error-map-cell/heat-error-map-cell.component.d.ts +14 -0
- package/lib/dashboards/insight-card/insight-card.component.d.ts +73 -0
- package/lib/dashboards/metrics-card/metrics-block.component.d.ts +12 -0
- package/lib/dashboards/metrics-card/metrics-card-item.interface.d.ts +12 -0
- package/lib/dashboards/metrics-card/metrics-card.component.d.ts +17 -0
- package/lib/dashboards/progress-text-card/progress-text-card.component.d.ts +13 -0
- package/lib/dashboards/test-distribution-card/test-distribution-card.component.d.ts +29 -0
- package/lib/dropdown-button/dropdown-button.component.d.ts +32 -0
- package/lib/dynamic-select/dynamic-select-field.component.d.ts +43 -0
- package/lib/empty-state/empty-state.component.d.ts +20 -0
- package/lib/filters/dynamic-filter/dynamic-filter.component.d.ts +56 -0
- package/lib/full-table-loader/full-table-loader.component.d.ts +6 -0
- package/lib/inline-sort/inline-sort.component.d.ts +12 -0
- package/lib/other-button/other-button.component.d.ts +37 -0
- package/lib/pagination/pagination.component.d.ts +37 -0
- package/lib/selected-filters/selected-filters.component.d.ts +17 -0
- package/lib/table/dynamic-table/dynamic-cell.directive.d.ts +16 -0
- package/lib/table/dynamic-table/dynamic-table.component.d.ts +72 -0
- package/lib/table-action-toolbar/table-action-toolbar.component.d.ts +34 -0
- package/lib/table-data-loader/table-data-loader.component.d.ts +7 -0
- package/lib/templates/table-template.component.d.ts +90 -0
- package/lib/ui-kit.module.d.ts +43 -6
- package/lib/utils/metadata-colors.util.d.ts +50 -0
- package/lib/utils/tw-overlay-container.d.ts +12 -0
- package/package.json +1 -1
- package/public-api.d.ts +28 -0
- package/src/assets/fonts/SFUIText-Bold/SF-UI-Text-Bold.eot +0 -0
- package/src/assets/fonts/SFUIText-Bold/SF-UI-Text-Bold.otf +0 -0
- package/src/assets/fonts/SFUIText-Bold/SF-UI-Text-Bold.svg +14730 -0
- package/src/assets/fonts/SFUIText-Bold/SF-UI-Text-Bold.ttf +0 -0
- package/src/assets/fonts/SFUIText-Bold/SF-UI-Text-Bold.woff +0 -0
- package/src/assets/fonts/SFUIText-Bold/SF-UI-Text-Bold.woff2 +0 -0
- package/src/assets/fonts/SFUIText-Light/SF-UI-Text-Light.eot +0 -0
- package/src/assets/fonts/SFUIText-Light/SF-UI-Text-Light.otf +0 -0
- package/src/assets/fonts/SFUIText-Light/SF-UI-Text-Light.svg +21333 -0
- package/src/assets/fonts/SFUIText-Light/SF-UI-Text-Light.ttf +0 -0
- package/src/assets/fonts/SFUIText-Light/SF-UI-Text-Light.woff +0 -0
- package/src/assets/fonts/SFUIText-Light/SF-UI-Text-Light.woff2 +0 -0
- package/src/assets/fonts/SFUIText-Medium/SF-UI-Text-Medium.eot +0 -0
- package/src/assets/fonts/SFUIText-Medium/SF-UI-Text-Medium.otf +0 -0
- package/src/assets/fonts/SFUIText-Medium/SF-UI-Text-Medium.svg +14584 -0
- package/src/assets/fonts/SFUIText-Medium/SF-UI-Text-Medium.ttf +0 -0
- package/src/assets/fonts/SFUIText-Medium/SF-UI-Text-Medium.woff +0 -0
- package/src/assets/fonts/SFUIText-Medium/SF-UI-Text-Medium.woff2 +0 -0
- package/src/assets/fonts/SFUIText-Regular/SF-UI-Text-Regular.eot +0 -0
- package/src/assets/fonts/SFUIText-Regular/SF-UI-Text-Regular.otf +0 -0
- package/src/assets/fonts/SFUIText-Regular/SF-UI-Text-Regular.svg +17870 -0
- package/src/assets/fonts/SFUIText-Regular/SF-UI-Text-Regular.ttf +0 -0
- package/src/assets/fonts/SFUIText-Regular/SF-UI-Text-Regular.woff +0 -0
- package/src/assets/fonts/SFUIText-Regular/SF-UI-Text-Regular.woff2 +0 -0
- package/src/assets/fonts/SFUIText-Semibold/SF-UI-Text-Semibold.eot +0 -0
- package/src/assets/fonts/SFUIText-Semibold/SF-UI-Text-Semibold.otf +0 -0
- package/src/assets/fonts/SFUIText-Semibold/SF-UI-Text-Semibold.svg +14732 -0
- package/src/assets/fonts/SFUIText-Semibold/SF-UI-Text-Semibold.ttf +0 -0
- package/src/assets/fonts/SFUIText-Semibold/SF-UI-Text-Semibold.woff +0 -0
- package/src/assets/fonts/SFUIText-Semibold/SF-UI-Text-Semibold.woff2 +0 -0
- package/src/lib/assets/images/.gitkeep +0 -0
- package/src/lib/assets/images/DashboardIcon.png +0 -0
- package/src/lib/assets/images/FilesIcon.png +0 -0
- package/src/lib/assets/images/README.md +66 -0
- package/src/lib/assets/images/ReportsIcon.png +0 -0
- package/src/lib/assets/images/SearchIcon.png +0 -0
- package/src/lib/assets/images/StepsIcon.png +0 -0
- package/src/lib/assets/images/TestCaseIcon.png +0 -0
- package/src/lib/assets/images/analytics-chart-icon.svg +11 -0
- package/src/lib/assets/images/checklist-add-icon.svg +10 -0
- package/src/lib/assets/images/document-gear-icon.svg +9 -0
- package/src/lib/assets/images/empty-state-default-icon.svg +8 -0
- package/src/lib/assets/images/image-assets.constants.ts +38 -0
- package/src/lib/assets/images/search-debug-icon.svg +8 -0
- package/src/lib/assets/images/test-case-icon.svg +9 -0
- package/src/lib/assets/images/upload-folder-icon.svg +7 -0
- package/src/lib/utils/metadata-colors.constants.js +33 -0
- package/storybook-static/assets/images/README.md +66 -0
- package/styles.css +1 -1
|
@@ -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-[#FCD9D9]', 'cqa-text-[#9F2A2A]'].join(' ');
|
|
24
|
+
case 'warning':
|
|
25
|
+
return [...baseClasses, 'cqa-bg-[#FFF9E9]', 'cqa-text-[#7E6012]'].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-[#FCD9D9]', 'cqa-text-[#9F2A2A]'].join(' ');\n        case 'warning':\n          return [...baseClasses, 'cqa-bg-[#FFF9E9]', 'cqa-text-[#7E6012]'].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"]}
|
|
@@ -7,6 +7,7 @@ export class ButtonComponent {
|
|
|
7
7
|
this.variant = 'filled';
|
|
8
8
|
this.disabled = false;
|
|
9
9
|
this.iconPosition = 'start';
|
|
10
|
+
this.fullWidth = false;
|
|
10
11
|
this.type = 'button';
|
|
11
12
|
this.clicked = new EventEmitter();
|
|
12
13
|
// Internal state tracking
|
|
@@ -19,74 +20,26 @@ export class ButtonComponent {
|
|
|
19
20
|
}
|
|
20
21
|
get buttonClasses() {
|
|
21
22
|
const baseClasses = [
|
|
22
|
-
'cqa-flex',
|
|
23
|
-
'cqa-flex-col',
|
|
24
|
-
'cqa-justify-center',
|
|
23
|
+
'cqa-inline-flex',
|
|
25
24
|
'cqa-items-center',
|
|
26
|
-
'cqa-p-0',
|
|
27
|
-
'cqa-gap-2',
|
|
28
|
-
'cqa-rounded-lg',
|
|
29
|
-
'cqa-cursor-pointer',
|
|
30
|
-
'cqa-font-inter',
|
|
31
|
-
'cqa-font-semibold',
|
|
32
|
-
'cqa-text-sm',
|
|
33
|
-
'cqa-leading-[14px]',
|
|
34
|
-
'cqa-transition-all',
|
|
35
|
-
'cqa-duration-200',
|
|
36
|
-
'cqa-outline-none'
|
|
37
|
-
];
|
|
38
|
-
if (this.disabled) {
|
|
39
|
-
baseClasses.push('cqa-cursor-not-allowed');
|
|
40
|
-
}
|
|
41
|
-
// Add variant and state specific classes
|
|
42
|
-
const variantClasses = this.getVariantClasses();
|
|
43
|
-
return [...baseClasses, ...variantClasses].join(' ');
|
|
44
|
-
}
|
|
45
|
-
get stateLayerClasses() {
|
|
46
|
-
const classes = [
|
|
47
|
-
'cqa-flex',
|
|
48
|
-
'cqa-flex-row',
|
|
49
25
|
'cqa-justify-center',
|
|
50
|
-
'cqa-items-center',
|
|
51
26
|
'cqa-gap-2',
|
|
52
|
-
'cqa-w-full',
|
|
53
|
-
'cqa-h-full',
|
|
54
27
|
'cqa-py-[10px]',
|
|
55
|
-
'cqa-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
const classes = [
|
|
61
|
-
'cqa-flex',
|
|
62
|
-
'cqa-items-center',
|
|
63
|
-
'cqa-text-center',
|
|
64
|
-
'cqa-font-inter',
|
|
65
|
-
'cqa-font-semibold',
|
|
66
|
-
'cqa-text-sm',
|
|
67
|
-
'cqa-leading-[14px]',
|
|
68
|
-
'cqa-flex-none',
|
|
69
|
-
this.textClass,
|
|
28
|
+
'cqa-rounded-[8px]',
|
|
29
|
+
'cqa-text-[12.3px]',
|
|
30
|
+
'cqa-leading-[17.5px]',
|
|
31
|
+
'cqa-font-medium',
|
|
32
|
+
'cqa-border',
|
|
70
33
|
];
|
|
71
34
|
if (this.disabled) {
|
|
72
|
-
|
|
35
|
+
baseClasses.push('cqa-cursor-not-allowed');
|
|
73
36
|
}
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
get iconClasses() {
|
|
77
|
-
const classes = [
|
|
78
|
-
'cqa-flex',
|
|
79
|
-
'cqa-items-center',
|
|
80
|
-
'cqa-justify-center',
|
|
81
|
-
'cqa-w-[14px]',
|
|
82
|
-
'cqa-h-[14px]',
|
|
83
|
-
'cqa-shrink-0',
|
|
84
|
-
'cqa-flex-none'
|
|
85
|
-
];
|
|
86
|
-
if (this.disabled) {
|
|
87
|
-
classes.push('cqa-opacity-[0.38]');
|
|
37
|
+
if (this.fullWidth) {
|
|
38
|
+
baseClasses.push('cqa-w-full');
|
|
88
39
|
}
|
|
89
|
-
|
|
40
|
+
// Add variant and state specific classes
|
|
41
|
+
const variantClasses = this.getVariantClasses();
|
|
42
|
+
return [...baseClasses, ...variantClasses, ...(this.customClass ? [this.customClass] : [])].join(' ');
|
|
90
43
|
}
|
|
91
44
|
getVariantClasses() {
|
|
92
45
|
const classes = [];
|
|
@@ -95,9 +48,21 @@ export class ButtonComponent {
|
|
|
95
48
|
classes.push('cqa-bg-primary-muted');
|
|
96
49
|
}
|
|
97
50
|
else {
|
|
98
|
-
classes.push('cqa-bg-primary');
|
|
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');
|
|
99
64
|
if (this.isHovered) {
|
|
100
|
-
classes.push('cqa-
|
|
65
|
+
classes.push('cqa-bg-grey-200');
|
|
101
66
|
}
|
|
102
67
|
}
|
|
103
68
|
}
|
|
@@ -119,10 +84,10 @@ export class ButtonComponent {
|
|
|
119
84
|
}
|
|
120
85
|
else if (this.variant === 'text') {
|
|
121
86
|
if (this.disabled) {
|
|
122
|
-
classes.push('cqa-bg-transparent');
|
|
87
|
+
classes.push('cqa-bg-transparent', 'cqa-border-none');
|
|
123
88
|
}
|
|
124
89
|
else {
|
|
125
|
-
classes.push('cqa-bg-transparent');
|
|
90
|
+
classes.push('cqa-bg-transparent', 'cqa-border-none');
|
|
126
91
|
if (this.isHovered || this.isFocused || this.isPressed) {
|
|
127
92
|
classes.push('cqa-bg-primary-surface');
|
|
128
93
|
}
|
|
@@ -172,6 +137,8 @@ export class ButtonComponent {
|
|
|
172
137
|
switch (this.variant) {
|
|
173
138
|
case 'filled':
|
|
174
139
|
return 'cqa-text-surface-default';
|
|
140
|
+
case 'grey-solid':
|
|
141
|
+
return 'cqa-text-black-100';
|
|
175
142
|
case 'outlined':
|
|
176
143
|
if (this.isFocused || this.isHovered || this.isPressed) {
|
|
177
144
|
return 'cqa-text-primary-hover';
|
|
@@ -219,10 +186,10 @@ export class ButtonComponent {
|
|
|
219
186
|
}
|
|
220
187
|
}
|
|
221
188
|
ButtonComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: ButtonComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
222
|
-
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", type: "type" }, 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\"
|
|
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"] }] });
|
|
223
190
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: ButtonComponent, decorators: [{
|
|
224
191
|
type: Component,
|
|
225
|
-
args: [{ selector: 'cqa-button', template: "<div id=\"cqa-ui-root\"
|
|
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: [] }]
|
|
226
193
|
}], propDecorators: { variant: [{
|
|
227
194
|
type: Input
|
|
228
195
|
}], disabled: [{
|
|
@@ -231,8 +198,16 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImpor
|
|
|
231
198
|
type: Input
|
|
232
199
|
}], iconPosition: [{
|
|
233
200
|
type: Input
|
|
201
|
+
}], fullWidth: [{
|
|
202
|
+
type: Input
|
|
203
|
+
}], iconColor: [{
|
|
204
|
+
type: Input
|
|
234
205
|
}], type: [{
|
|
235
206
|
type: Input
|
|
207
|
+
}], text: [{
|
|
208
|
+
type: Input
|
|
209
|
+
}], customClass: [{
|
|
210
|
+
type: Input
|
|
236
211
|
}], clicked: [{
|
|
237
212
|
type: Output
|
|
238
213
|
}], onMouseEnter: [{
|
|
@@ -254,4 +229,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImpor
|
|
|
254
229
|
type: HostListener,
|
|
255
230
|
args: ['blur']
|
|
256
231
|
}] } });
|
|
257
|
-
//# 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';\n\n@Component({\n  selector: 'cqa-button',\n  templateUrl: './button.component.html',\n  styleUrls: []\n})\nexport class ButtonComponent {\n\n  @Input() variant: ButtonVariant = 'filled';\n  @Input() disabled: boolean = false;\n  @Input() icon?: string;\n  @Input() iconPosition: 'start' | 'end' = 'start';\n  @Input() type: 'button' | 'submit' | 'reset' = 'button';\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-flex',\n      'cqa-flex-col',\n      'cqa-justify-center',\n      'cqa-items-center',\n      'cqa-p-0',\n      'cqa-gap-2',\n      'cqa-rounded-lg',\n      'cqa-cursor-pointer',\n      'cqa-font-inter',\n      'cqa-font-semibold',\n      'cqa-text-sm',\n      'cqa-leading-[14px]',\n      'cqa-transition-all',\n      'cqa-duration-200',\n      'cqa-outline-none'\n    ];\n\n    if (this.disabled) {\n      baseClasses.push('cqa-cursor-not-allowed');\n    }\n\n    // Add variant and state specific classes\n    const variantClasses = this.getVariantClasses();\n    \n    return [...baseClasses, ...variantClasses].join(' ');\n  }\n\n  get stateLayerClasses(): string {\n    const classes = [\n      'cqa-flex',\n      'cqa-flex-row',\n      'cqa-justify-center',\n      'cqa-items-center',\n      'cqa-gap-2',\n      'cqa-w-full',\n      'cqa-h-full',\n      'cqa-py-[10px]',\n      'cqa-px-6',\n    ];\n\n    return classes.join(' ');\n  }\n\n  get labelClasses(): string {\n    const classes = [\n      'cqa-flex',\n      'cqa-items-center',\n      'cqa-text-center',\n      'cqa-font-inter',\n      'cqa-font-semibold',\n      'cqa-text-sm',\n      'cqa-leading-[14px]',\n      'cqa-flex-none',\n      this.textClass,\n    ];\n\n    if (this.disabled) {\n      classes.push('cqa-opacity-[0.38]');\n    }\n\n    return classes.join(' ');\n  }\n\n  get iconClasses(): string {\n    const classes = [\n      'cqa-flex',\n      'cqa-items-center',\n      'cqa-justify-center',\n      'cqa-w-[14px]',\n      'cqa-h-[14px]',\n      'cqa-shrink-0',\n      'cqa-flex-none'\n    ];\n    if (this.disabled) {\n      classes.push('cqa-opacity-[0.38]');\n    }\n    return classes.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');\n        if (this.isHovered) {\n          classes.push('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 === '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');\n      } else {\n        classes.push('cqa-bg-transparent');\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 '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\" style=\"display: inline-block; width: auto;\">\n  <button\n    [type]=\"type\"\n    [disabled]=\"disabled\"\n    [attr.aria-disabled]=\"disabled\"\n    [class]=\"buttonClasses\"\n    (click)=\"onClick($event)\"\n  >\n    <span [class]=\"stateLayerClasses\">\n      <span *ngIf=\"icon && iconPosition === 'start'\" [class]=\"iconClasses\" [ngClass]=\"textClass\">\n        <mat-icon class=\"cqa-text-[18px] cqa-leading-[18px] cqa-w-[18px] cqa-h-[18px]\">\n          {{ icon }}\n        </mat-icon>\n      </span>\n      <span [class]=\"labelClasses\" [ngClass]=\"textClass\">\n        <ng-content></ng-content>\n      </span>\n      <span *ngIf=\"icon && iconPosition === 'end'\" [class]=\"iconClasses\" [ngClass]=\"textClass\">\n        <mat-icon class=\"cqa-text-[18px] cqa-leading-[18px] cqa-w-[18px] cqa-h-[18px]\">\n          {{ icon }}\n        </mat-icon>\n      </span>\n    </span>\n  </button>\n</div>\n\n"]}
|
|
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>"]}
|