@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.
- 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 +232 -0
- 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 +104 -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 +60 -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 +127 -0
- 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/{dist/cqa-ui/esm2020 → esm2020}/lib/search-bar/search-bar.component.mjs +3 -3
- package/{dist/cqa-ui/esm2020 → 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 +248 -0
- 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 +38 -0
- package/fesm2015/cqa-lib-cqa-ui.mjs +3661 -0
- package/fesm2015/cqa-lib-cqa-ui.mjs.map +1 -0
- package/fesm2020/cqa-lib-cqa-ui.mjs +3615 -0
- package/fesm2020/cqa-lib-cqa-ui.mjs.map +1 -0
- 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/{dist/cqa-ui/lib → 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 +52 -0
- package/lib/utils/metadata-colors.util.d.ts +50 -0
- package/lib/utils/tw-overlay-container.d.ts +12 -0
- package/package.json +23 -49
- package/public-api.d.ts +37 -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 -0
- package/dist/cqa-ui/README.md +0 -226
- package/dist/cqa-ui/esm2020/lib/button/button.component.mjs +0 -257
- package/dist/cqa-ui/esm2020/lib/dialog/dialog.component.mjs +0 -127
- package/dist/cqa-ui/esm2020/lib/ui-kit.module.mjs +0 -69
- package/dist/cqa-ui/esm2020/public-api.mjs +0 -10
- package/dist/cqa-ui/fesm2015/cqa-lib-cqa-ui.mjs +0 -895
- package/dist/cqa-ui/fesm2015/cqa-lib-cqa-ui.mjs.map +0 -1
- package/dist/cqa-ui/fesm2020/cqa-lib-cqa-ui.mjs +0 -881
- package/dist/cqa-ui/fesm2020/cqa-lib-cqa-ui.mjs.map +0 -1
- package/dist/cqa-ui/lib/ui-kit.module.d.ts +0 -15
- package/dist/cqa-ui/package.json +0 -56
- package/dist/cqa-ui/public-api.d.ts +0 -9
- package/dist/cqa-ui/styles.css +0 -1
- /package/{dist/cqa-ui/cqa-lib-cqa-ui.d.ts → cqa-lib-cqa-ui.d.ts} +0 -0
- /package/{dist/cqa-ui/esm2020 → esm2020}/cqa-lib-cqa-ui.mjs +0 -0
- /package/{dist/cqa-ui/esm2020 → esm2020}/lib/dialog/dialog-ref.mjs +0 -0
- /package/{dist/cqa-ui/esm2020 → esm2020}/lib/dialog/dialog.models.mjs +0 -0
- /package/{dist/cqa-ui/esm2020 → esm2020}/lib/dialog/dialog.service.mjs +0 -0
- /package/{dist/cqa-ui/esm2020 → esm2020}/lib/dialog/dialog.tokens.mjs +0 -0
- /package/{dist/cqa-ui/lib → lib}/dialog/dialog-ref.d.ts +0 -0
- /package/{dist/cqa-ui/lib → lib}/dialog/dialog.component.d.ts +0 -0
- /package/{dist/cqa-ui/lib → lib}/dialog/dialog.models.d.ts +0 -0
- /package/{dist/cqa-ui/lib → lib}/dialog/dialog.service.d.ts +0 -0
- /package/{dist/cqa-ui/lib → lib}/dialog/dialog.tokens.d.ts +0 -0
- /package/{dist/cqa-ui/lib → lib}/search-bar/search-bar.component.d.ts +0 -0
- /package/{dist/cqa-ui/lib → lib}/segment-control/segment-control.component.d.ts +0 -0
|
@@ -0,0 +1,365 @@
|
|
|
1
|
+
import { Component, Input, } from '@angular/core';
|
|
2
|
+
import { EMPTY_STATE_IMAGES } from '../assets/images/image-assets.constants';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "../search-bar/search-bar.component";
|
|
5
|
+
import * as i2 from "../button/button.component";
|
|
6
|
+
import * as i3 from "../column-visibility/column-visibility.component";
|
|
7
|
+
import * as i4 from "../selected-filters/selected-filters.component";
|
|
8
|
+
import * as i5 from "../filters/dynamic-filter/dynamic-filter.component";
|
|
9
|
+
import * as i6 from "../table/dynamic-table/dynamic-table.component";
|
|
10
|
+
import * as i7 from "../action-menu/action-menu.component";
|
|
11
|
+
import * as i8 from "../empty-state/empty-state.component";
|
|
12
|
+
import * as i9 from "../pagination/pagination.component";
|
|
13
|
+
import * as i10 from "../table-action-toolbar/table-action-toolbar.component";
|
|
14
|
+
import * as i11 from "@angular/common";
|
|
15
|
+
import * as i12 from "../table/dynamic-table/dynamic-cell.directive";
|
|
16
|
+
export class TableTemplateComponent {
|
|
17
|
+
constructor() {
|
|
18
|
+
// Search bar inputs
|
|
19
|
+
this.searchPlaceholder = 'Search components';
|
|
20
|
+
this.searchValue = '';
|
|
21
|
+
this.showClear = true;
|
|
22
|
+
this.showSearchBar = true;
|
|
23
|
+
// Filter inputs
|
|
24
|
+
this.filterConfig = [];
|
|
25
|
+
this.showFilterPanel = false;
|
|
26
|
+
this.showFilterButton = true;
|
|
27
|
+
// Other button input
|
|
28
|
+
this.otherButtonLabel = 'Other Button';
|
|
29
|
+
this.otherButtonVariant = 'filled';
|
|
30
|
+
this.showOtherButton = true;
|
|
31
|
+
// Action menu button (three-dot menu in table rows)
|
|
32
|
+
this.showActionButton = true;
|
|
33
|
+
// Settings and refresh buttons
|
|
34
|
+
this.showSettingsButton = true;
|
|
35
|
+
this.showAutoRefreshButton = true;
|
|
36
|
+
// Data input
|
|
37
|
+
this.data = [];
|
|
38
|
+
// Empty state inputs
|
|
39
|
+
this.isEmptyState = false;
|
|
40
|
+
this.emptyStateConfig = {
|
|
41
|
+
title: 'No Data Available Yet',
|
|
42
|
+
description: 'Run or upload your first test to see your analytics and trends here. Watch your quality metrics come to life with real-time insights.',
|
|
43
|
+
imageUrl: EMPTY_STATE_IMAGES.DASHBOARD,
|
|
44
|
+
actions: [{ label: 'Run Test Suite', variant: 'filled' }],
|
|
45
|
+
};
|
|
46
|
+
// Action bar inputs
|
|
47
|
+
this.actions = [
|
|
48
|
+
{
|
|
49
|
+
id: 'delete',
|
|
50
|
+
label: 'Delete',
|
|
51
|
+
icon: 'delete',
|
|
52
|
+
tooltip: 'Delete selected',
|
|
53
|
+
onClick: (context) => {
|
|
54
|
+
console.log('Delete action clicked:', context);
|
|
55
|
+
}
|
|
56
|
+
},
|
|
57
|
+
{
|
|
58
|
+
id: 'edit',
|
|
59
|
+
label: 'Edit',
|
|
60
|
+
icon: 'edit',
|
|
61
|
+
tooltip: 'Edit selected',
|
|
62
|
+
onClick: (context) => {
|
|
63
|
+
console.log('Edit action clicked:', context);
|
|
64
|
+
}
|
|
65
|
+
},
|
|
66
|
+
{
|
|
67
|
+
id: 'add-tag',
|
|
68
|
+
label: 'Add Tag',
|
|
69
|
+
icon: 'local_offer',
|
|
70
|
+
tooltip: 'Add tags',
|
|
71
|
+
onClick: (context) => {
|
|
72
|
+
console.log('Add tag action clicked:', context);
|
|
73
|
+
}
|
|
74
|
+
},
|
|
75
|
+
{
|
|
76
|
+
id: 'remove-tag',
|
|
77
|
+
label: 'Remove Tag',
|
|
78
|
+
icon: 'label_off',
|
|
79
|
+
tooltip: 'Remove tags',
|
|
80
|
+
onClick: (context) => {
|
|
81
|
+
console.log('Remove tag action clicked:', context);
|
|
82
|
+
}
|
|
83
|
+
},
|
|
84
|
+
];
|
|
85
|
+
// Chips inputs
|
|
86
|
+
this.chips = [];
|
|
87
|
+
this.filterApplied = false;
|
|
88
|
+
// Table inputs
|
|
89
|
+
this.columns = [];
|
|
90
|
+
this.selectedAutoRefreshInterval = 0;
|
|
91
|
+
this.pageIndex = 0;
|
|
92
|
+
this.pageSize = 10;
|
|
93
|
+
// Backward-compatibility flag; if provided, dynamic table will use it when specific flags are undefined
|
|
94
|
+
// Internal state for column visibility
|
|
95
|
+
this._columnVisibility = {};
|
|
96
|
+
this._cachedVisibilityColumns = [];
|
|
97
|
+
this.filteredRows = [];
|
|
98
|
+
this.pagedRows = [];
|
|
99
|
+
}
|
|
100
|
+
// Derived columns with visibility applied. Avoid mutating @Input() columns so parent bindings aren't overridden.
|
|
101
|
+
get computedColumns() {
|
|
102
|
+
const visibility = this._columnVisibility || {};
|
|
103
|
+
const source = this.columns || [];
|
|
104
|
+
return source.map(col => {
|
|
105
|
+
if (['checkbox', 'actions'].includes(col.fieldId)) {
|
|
106
|
+
return col;
|
|
107
|
+
}
|
|
108
|
+
const show = visibility[col.fieldId];
|
|
109
|
+
return { ...col, isShow: show !== false };
|
|
110
|
+
});
|
|
111
|
+
}
|
|
112
|
+
// Auto-generated visibility columns from columns input (excludes default columns and checkbox/actions)
|
|
113
|
+
// Cached to avoid creating new arrays on every change detection cycle
|
|
114
|
+
get visibilityColumns() {
|
|
115
|
+
return this._cachedVisibilityColumns;
|
|
116
|
+
}
|
|
117
|
+
// Internal column visibility state
|
|
118
|
+
get columnVisibility() {
|
|
119
|
+
return this._columnVisibility;
|
|
120
|
+
}
|
|
121
|
+
ngOnInit() {
|
|
122
|
+
this.initializeComponent();
|
|
123
|
+
}
|
|
124
|
+
ngOnChanges(changes) {
|
|
125
|
+
if (changes['data'] || changes['isEmptyState']) {
|
|
126
|
+
this.initializeComponent();
|
|
127
|
+
}
|
|
128
|
+
if (changes['columns']) {
|
|
129
|
+
this.initializeColumnVisibility();
|
|
130
|
+
}
|
|
131
|
+
}
|
|
132
|
+
initializeComponent() {
|
|
133
|
+
if (this.isEmptyState) {
|
|
134
|
+
this.filteredRows = [];
|
|
135
|
+
this.pagedRows = [];
|
|
136
|
+
return;
|
|
137
|
+
}
|
|
138
|
+
this.filteredRows = [...this.data];
|
|
139
|
+
this.applyPagination();
|
|
140
|
+
this.initializeColumnVisibility();
|
|
141
|
+
}
|
|
142
|
+
initializeColumnVisibility() {
|
|
143
|
+
// Cache visibility columns to avoid creating new arrays on every change detection
|
|
144
|
+
this._cachedVisibilityColumns = this.mapVisibilityColumns();
|
|
145
|
+
// Initialize visibility state for all visibility columns (default to true)
|
|
146
|
+
for (const col of this._cachedVisibilityColumns) {
|
|
147
|
+
if (this._columnVisibility[col.id] === undefined) {
|
|
148
|
+
this._columnVisibility[col.id] = true;
|
|
149
|
+
}
|
|
150
|
+
}
|
|
151
|
+
}
|
|
152
|
+
get anyRowSelected() {
|
|
153
|
+
return !!(this.pagedRows && this.pagedRows.some(r => !!r.isSelected));
|
|
154
|
+
}
|
|
155
|
+
get currentSelectedItems() {
|
|
156
|
+
return (this.pagedRows || []).filter(r => !!r.isSelected);
|
|
157
|
+
}
|
|
158
|
+
actionClick(data) {
|
|
159
|
+
console.log('action toolbar', data);
|
|
160
|
+
}
|
|
161
|
+
view(id) {
|
|
162
|
+
console.log('View', id);
|
|
163
|
+
}
|
|
164
|
+
edit(row) {
|
|
165
|
+
console.log('Edit', row);
|
|
166
|
+
}
|
|
167
|
+
delete(row) {
|
|
168
|
+
console.log('Delete', row);
|
|
169
|
+
}
|
|
170
|
+
onRowCheckboxChange(event, row) {
|
|
171
|
+
const input = event.target;
|
|
172
|
+
const checked = !!input?.checked;
|
|
173
|
+
row.isSelected = checked;
|
|
174
|
+
}
|
|
175
|
+
toggleFilter() {
|
|
176
|
+
this.showFilterPanel = !this.showFilterPanel;
|
|
177
|
+
}
|
|
178
|
+
onColumnVisibilityChange(cfg) {
|
|
179
|
+
this._columnVisibility = { ...cfg };
|
|
180
|
+
// Do not mutate this.columns; computedColumns getter will reflect changes
|
|
181
|
+
}
|
|
182
|
+
onAutoRefreshChange(intervalMs) {
|
|
183
|
+
this.selectedAutoRefreshInterval = intervalMs;
|
|
184
|
+
console.log('Auto refresh interval', intervalMs);
|
|
185
|
+
}
|
|
186
|
+
valueChange(value) {
|
|
187
|
+
console.log('Value changed', value);
|
|
188
|
+
}
|
|
189
|
+
search(value) {
|
|
190
|
+
console.log('Search', value);
|
|
191
|
+
}
|
|
192
|
+
cleared() {
|
|
193
|
+
console.log('Cleared');
|
|
194
|
+
}
|
|
195
|
+
resultBadgeClass(result) {
|
|
196
|
+
const value = (result || '').toUpperCase();
|
|
197
|
+
if (value === 'SUCCESS')
|
|
198
|
+
return 'cqa-bg-green-100 cqa-text-green-700';
|
|
199
|
+
if (value === 'FAILURE' || value === 'ABORTED')
|
|
200
|
+
return 'cqa-bg-red-100 cqa-text-red-700';
|
|
201
|
+
if (value === 'QUEUED' || value === 'NOT_EXECUTED' || value === 'STOPPED')
|
|
202
|
+
return 'cqa-bg-gray-100 cqa-text-gray-700';
|
|
203
|
+
return 'cqa-bg-gray-100 cqa-text-gray-700';
|
|
204
|
+
}
|
|
205
|
+
onEmptyAction(action) {
|
|
206
|
+
if (action?.label === 'Show filters') {
|
|
207
|
+
this.toggleFilter();
|
|
208
|
+
}
|
|
209
|
+
}
|
|
210
|
+
onFiltersChanged(current) {
|
|
211
|
+
this.filteredRows = this.data.filter(r => this.passFilters(current, r));
|
|
212
|
+
this.pageIndex = 0;
|
|
213
|
+
this.applyPagination();
|
|
214
|
+
const chips = [];
|
|
215
|
+
if (current) {
|
|
216
|
+
for (const key of Object.keys(current)) {
|
|
217
|
+
const value = current[key];
|
|
218
|
+
if (value == null || value === '' || (Array.isArray(value) && value.length === 0))
|
|
219
|
+
continue;
|
|
220
|
+
let text = '';
|
|
221
|
+
if (Array.isArray(value)) {
|
|
222
|
+
text = value.map((v) => (v?.name ?? v?.label ?? v?.value ?? v)).join(', ');
|
|
223
|
+
}
|
|
224
|
+
else if (typeof value === 'object') {
|
|
225
|
+
if ('start' in value || 'end' in value) {
|
|
226
|
+
const s = value.start ? new Date(value.start).toLocaleDateString() : '';
|
|
227
|
+
const e = value.end ? new Date(value.end).toLocaleDateString() : '';
|
|
228
|
+
text = [s, e].filter(Boolean).join(' - ');
|
|
229
|
+
}
|
|
230
|
+
else {
|
|
231
|
+
text = (value?.name ?? value?.label ?? value?.value ?? JSON.stringify(value));
|
|
232
|
+
}
|
|
233
|
+
}
|
|
234
|
+
else {
|
|
235
|
+
text = String(value);
|
|
236
|
+
}
|
|
237
|
+
chips.push({ key, text, fullText: text, hasMore: text.length > 30 });
|
|
238
|
+
}
|
|
239
|
+
}
|
|
240
|
+
this.chips = chips;
|
|
241
|
+
this.filterApplied = this.chips.length > 0;
|
|
242
|
+
}
|
|
243
|
+
onFiltersApplied(_) {
|
|
244
|
+
// handled in onFiltersChanged for this demo
|
|
245
|
+
}
|
|
246
|
+
onPaginate(e) {
|
|
247
|
+
this.pageIndex = e.pageIndex;
|
|
248
|
+
this.pageSize = e.pageSize;
|
|
249
|
+
this.applyPagination();
|
|
250
|
+
}
|
|
251
|
+
onPageSizeChange(size) {
|
|
252
|
+
this.pageSize = size;
|
|
253
|
+
this.pageIndex = 0;
|
|
254
|
+
this.applyPagination();
|
|
255
|
+
}
|
|
256
|
+
onRemoveChip(chip) {
|
|
257
|
+
this.chips = this.chips.filter(c => c !== chip);
|
|
258
|
+
this.filterApplied = this.chips.length > 0;
|
|
259
|
+
}
|
|
260
|
+
onClearAllChips() {
|
|
261
|
+
this.chips = [];
|
|
262
|
+
this.filterApplied = false;
|
|
263
|
+
}
|
|
264
|
+
applyPagination() {
|
|
265
|
+
const start = this.pageIndex * this.pageSize;
|
|
266
|
+
const end = start + this.pageSize;
|
|
267
|
+
this.pagedRows = this.filteredRows.slice(start, end);
|
|
268
|
+
}
|
|
269
|
+
mapVisibilityColumns() {
|
|
270
|
+
return (this.columns || [])
|
|
271
|
+
.filter(c => c.isDefault === false)
|
|
272
|
+
.map(c => ({ id: c.fieldId, label: c.fieldName || c.fieldId }));
|
|
273
|
+
}
|
|
274
|
+
normalizeDate(d) {
|
|
275
|
+
if (!d)
|
|
276
|
+
return null;
|
|
277
|
+
const ts = Date.parse(d);
|
|
278
|
+
return isNaN(ts) ? null : ts;
|
|
279
|
+
}
|
|
280
|
+
passFilters(filters, row) {
|
|
281
|
+
if (!filters)
|
|
282
|
+
return true;
|
|
283
|
+
if (filters.status && Array.isArray(filters.status) && filters.status.length) {
|
|
284
|
+
if (!filters.status.includes(row.status))
|
|
285
|
+
return false;
|
|
286
|
+
}
|
|
287
|
+
if (filters.priority && Array.isArray(filters.priority) && filters.priority.length) {
|
|
288
|
+
if (!filters.priority.includes(row.priorityName))
|
|
289
|
+
return false;
|
|
290
|
+
}
|
|
291
|
+
if (filters.testType && Array.isArray(filters.testType) && filters.testType.length) {
|
|
292
|
+
if (!filters.testType.includes(row.testType))
|
|
293
|
+
return false;
|
|
294
|
+
}
|
|
295
|
+
if (filters.created_date && (filters.created_date.start || filters.created_date.end)) {
|
|
296
|
+
const startTs = this.normalizeDate(filters.created_date.start);
|
|
297
|
+
const endTs = this.normalizeDate(filters.created_date.end);
|
|
298
|
+
const rowTs = this.normalizeDate(row.createdAt);
|
|
299
|
+
if (rowTs != null) {
|
|
300
|
+
if (startTs != null && rowTs < startTs)
|
|
301
|
+
return false;
|
|
302
|
+
if (endTs != null && rowTs > endTs)
|
|
303
|
+
return false;
|
|
304
|
+
}
|
|
305
|
+
}
|
|
306
|
+
return true;
|
|
307
|
+
}
|
|
308
|
+
}
|
|
309
|
+
TableTemplateComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: TableTemplateComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
310
|
+
TableTemplateComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.4.0", type: TableTemplateComponent, selector: "cqa-table-template", inputs: { searchPlaceholder: "searchPlaceholder", searchValue: "searchValue", showClear: "showClear", showSearchBar: "showSearchBar", filterConfig: "filterConfig", showFilterPanel: "showFilterPanel", showFilterButton: "showFilterButton", otherButtonLabel: "otherButtonLabel", otherButtonVariant: "otherButtonVariant", showOtherButton: "showOtherButton", showActionButton: "showActionButton", showSettingsButton: "showSettingsButton", showAutoRefreshButton: "showAutoRefreshButton", data: "data", isEmptyState: "isEmptyState", emptyStateConfig: "emptyStateConfig", actions: "actions", chips: "chips", filterApplied: "filterApplied", columns: "columns", selectedAutoRefreshInterval: "selectedAutoRefreshInterval", pageIndex: "pageIndex", pageSize: "pageSize", isTableLoading: "isTableLoading", isTableDataLoading: "isTableDataLoading" }, usesOnChanges: true, ngImport: i0, template: "<div id=\"cqa-ui-root\">\n <div class=\"cqa-w-full cqa-flex cqa-flex-col cqa-relative\">\n <div class=\"cqa-w-full cqa-flex cqa-items-center cqa-justify-between cqa-gap-3 cqa-flex-wrap cqa-mb-3\">\n <cqa-search-bar\n *ngIf=\"showSearchBar\"\n [placeholder]=\"searchPlaceholder\"\n [value]=\"searchValue\"\n [showClear]=\"showClear\"\n (valueChange)=\"valueChange($event)\"\n (search)=\"search($event)\"\n (cleared)=\"cleared()\"\n ></cqa-search-bar>\n <div class=\"cqa-flex cqa-items-center cqa-gap-2 cqa-flex-wrap\">\n <cqa-button\n *ngIf=\"showFilterButton\"\n variant=\"grey-solid\"\n icon=\"add\"\n [text]=\"'Filter'\"\n (clicked)=\"toggleFilter()\"\n >\n <span>Filter</span>\n </cqa-button>\n <cqa-column-visibility\n *ngIf=\"showSettingsButton\"\n [columns]=\"visibilityColumns\"\n [columnVisibility]=\"columnVisibility\"\n [selectedAutoRefreshInterval]=\"selectedAutoRefreshInterval\"\n (columnVisibilityChange)=\"onColumnVisibilityChange($event)\"\n (autoRefreshChange)=\"onAutoRefreshChange($event)\"\n ></cqa-column-visibility>\n <cqa-button *ngIf=\"showAutoRefreshButton\" variant=\"grey-solid\" icon=\"refresh\"></cqa-button>\n <cqa-button *ngIf=\"showOtherButton\" [variant]=\"otherButtonVariant\" [text]=\"otherButtonLabel\"></cqa-button>\n </div>\n </div>\n\n <cqa-selected-filters \n *ngIf=\"showFilterPanel\"\n [filterApplied]=\"filterApplied\"\n [chips]=\"chips\"\n (removeChip)=\"onRemoveChip($event)\"\n (clearAll)=\"onClearAllChips()\"\n >\n </cqa-selected-filters>\n\n <cqa-dynamic-filter\n *ngIf=\"showFilterPanel\"\n [config]=\"filterConfig\"\n [showFilterPanel]=\"showFilterPanel\"\n (filtersChanged)=\"onFiltersChanged($event)\"\n (filtersApplied)=\"onFiltersApplied($event)\"\n >\n </cqa-dynamic-filter>\n\n <div class=\"cqa-rounded-[7px] cqa-overflow-hidden cqa-border-t cqa-border-l cqa-border-r cqa-border-grey-200 cqa-relative\">\n <ng-container *ngIf=\"!isEmptyState && pagedRows && pagedRows.length > 0; else storyEmptyTpl\">\n <app-dynamic-table\n [columns]=\"computedColumns\"\n [data]=\"pagedRows\"\n [isTableLoading]=\"isTableLoading\"\n [isTableDataLoading]=\"isTableDataLoading\">\n <ng-template dynamicCell=\"checkbox\" let-row=\"row\">\n <div class=\"custom-checkbox\">\n <input\n type=\"checkbox\"\n class=\"hidden-checkbox\"\n [attr.id]=\"'row-checkbox-' + row.id\"\n [checked]=\"row.isSelected\"\n aria-label=\"Select row\"\n (change)=\"onRowCheckboxChange($event, row)\" />\n <label\n class=\"custom-checkbox-label\"\n [attr.for]=\"'row-checkbox-' + row.id\">\n </label>\n </div>\n </ng-template>\n\n <ng-template dynamicCell=\"testCases\" let-row=\"row\" let-value=\"value\">\n <div class=\"cqa-flex cqa-flex-col cqa-gap-1 cqa-text-[12.3px] cqa-leading-[17.5px] cqa-font-medium\">\n <div class=\"cqa-text-[#3F43EE] cqa-truncate\">\n #{{ row.id }}\n </div>\n <div class=\"cqa-text-[#0A0A0A]\">{{ value }}</div>\n </div>\n </ng-template>\n\n <ng-template dynamicCell=\"type\" let-row=\"row\" let-value=\"value\">\n <div class=\"cqa-text-xs cqa-text-[#111827] cqa-truncate\">{{ value }}</div>\n </ng-template>\n\n <ng-template dynamicCell=\"priority\" let-row=\"row\" let-value=\"value\">\n <span\n class=\"cqa-inline-flex cqa-items-center cqa-px-2 cqa-py-0.5 cqa-rounded cqa-text-xs\"\n [ngClass]=\"{\n 'cqa-bg-red-100 cqa-text-red-700': value === 'Critical' || value === 'Major',\n 'cqa-bg-yellow-100 cqa-text-yellow-700': value === 'Medium',\n 'cqa-bg-blue-100 cqa-text-blue-700': value === 'Minor',\n 'cqa-bg-gray-100 cqa-text-gray-700': !value || value === 'Not Set'\n }\"\n >{{ value || 'Not Set' }}</span\n >\n </ng-template>\n\n <ng-template dynamicCell=\"result\" let-row=\"row\" let-value=\"value\">\n <span class=\"cqa-inline-flex cqa-items-center cqa-px-2 cqa-py-0.5 cqa-rounded cqa-text-xs\" [ngClass]=\"resultBadgeClass(value)\">\n {{ value || 'NOT_EXECUTED' }}\n </span>\n </ng-template>\n\n <ng-template dynamicCell=\"status\" let-row=\"row\" let-value=\"value\">\n <span class=\"cqa-text-xs\">{{ value }}</span>\n </ng-template>\n\n <ng-template dynamicCell=\"labels\" let-row=\"row\" let-value=\"value\">\n <div class=\"cqa-flex cqa-flex-wrap cqa-gap-1\">\n <span *ngFor=\"let tag of (row.tags || []) | slice: 0:3\" class=\"cqa-px-2 cqa-py-0.5 cqa-rounded cqa-bg-gray-100 cqa-text-gray-700 cqa-text-xs\">\n {{ tag }}\n </span>\n <span *ngIf=\"(row.tags?.length || 0) > 3\" class=\"cqa-px-2 cqa-py-0.5 cqa-rounded cqa-bg-gray-100 cqa-text-gray-700 cqa-text-xs\">\n +{{ (row.tags?.length || 0) - 3 }} more\n </span>\n </div>\n </ng-template>\n\n <ng-template dynamicCell=\"createdBy\" let-row=\"row\" let-value=\"value\">\n <span class=\"cqa-text-xs\">{{ value }}</span>\n </ng-template>\n\n <ng-template dynamicCell=\"createdAt\" let-row=\"row\" let-value=\"value\">\n <span class=\"cqa-text-xs cqa-text-gray-700\">{{ value | date: 'medium' }}</span>\n </ng-template>\n\n <ng-template dynamicCell=\"updatedAt\" let-row=\"row\" let-value=\"value\">\n <span class=\"cqa-text-xs cqa-text-gray-700\">{{ value | date: 'medium' }}</span>\n </ng-template>\n\n <ng-template dynamicCell=\"lastRun\" let-row=\"row\">\n <div class=\"cqa-flex cqa-flex-col\">\n <span class=\"cqa-text-xs cqa-text-[#111827]\">{{ row.lastRun?.startTime | date: 'medium' }}</span>\n </div>\n </ng-template>\n\n <ng-template dynamicCell=\"actions\" let-row=\"row\">\n <div class=\"cqa-flex cqa-items-center cqa-gap-2\" *ngIf=\"showActionButton\">\n <cqa-action-menu-button\n [row]=\"row\"\n (view)=\"view($event)\"\n (edit)=\"edit($event)\"\n (delete)=\"delete($event)\"\n ></cqa-action-menu-button>\n </div>\n </ng-template>\n\n <ng-template #emptyTableTpl>\n <div class=\"cqa-flex cqa-flex-col cqa-items-center cqa-justify-center cqa-py-8\">\n <img src=\"/assets/illustrations/empty-state.svg\" alt=\"No data\" class=\"cqa-w-32 cqa-h-32 cqa-mb-4\" />\n <h3 class=\"cqa-text-lg cqa-font-semibold cqa-mb-2\">No test cases</h3>\n <p class=\"cqa-text-sm cqa-text-neutral-500 cqa-mb-4\">Try adjusting filters or create a new test case.</p>\n <cqa-button variant=\"filled\" (clicked)=\"toggleFilter()\">Show Filters</cqa-button>\n </div>\n </ng-template>\n </app-dynamic-table>\n </ng-container>\n\n <ng-template #storyEmptyTpl>\n <div class=\"cqa-p-6 cqa-flex cqa-flex-col cqa-items-center cqa-justify-center\">\n <cqa-empty-state\n *ngIf=\"isEmptyState\"\n [title]=\"emptyStateConfig.title\"\n [description]=\"emptyStateConfig.description\"\n [imageUrl]=\"emptyStateConfig.imageUrl\"\n [actions]=\"emptyStateConfig.actions\"\n (actionClick)=\"onEmptyAction($event)\"\n >\n </cqa-empty-state>\n </div>\n </ng-template>\n\n </div>\n\n <cqa-pagination\n [totalElements]=\"filteredRows.length\"\n [pageIndex]=\"pageIndex\"\n [pageSize]=\"pageSize\"\n [pageItemCount]=\"pagedRows.length\"\n (paginate)=\"onPaginate($event)\"\n (pageSizeChange)=\"onPageSizeChange($event)\"\n >\n </cqa-pagination>\n\n <div *ngIf=\"anyRowSelected\" class=\"cqa-absolute cqa-bottom-[18.75px] cqa-left-[50%] cqa-translate-x-[-50%] cqa-w-full lg:cqa-max-w-[68%] cqa-sm:max-w-[75%] cqa-max-w-[90%] cqa-z-[1]\" >\n <cqa-table-action-toolbar\n [selectedItems]=\"currentSelectedItems\"\n [actions]=\"actions\"\n (actionClick)=\"actionClick($event)\"\n ></cqa-table-action-toolbar>\n </div>\n \n </div>\n</div>\n\n", components: [{ type: i1.SearchBarComponent, selector: "cqa-search-bar", inputs: ["placeholder", "value", "disabled", "showClear", "ariaLabel", "autoFocus", "size", "fullWidth"], outputs: ["valueChange", "search", "cleared"] }, { type: i2.ButtonComponent, selector: "cqa-button", inputs: ["variant", "disabled", "icon", "iconPosition", "fullWidth", "iconColor", "type", "text", "customClass"], outputs: ["clicked"] }, { type: i3.ColumnVisibilityComponent, selector: "cqa-column-visibility", inputs: ["isStepGroup", "columns", "columnVisibility", "selectedAutoRefreshInterval"], outputs: ["columnVisibilityChange", "autoRefreshChange"] }, { type: i4.SelectedFiltersComponent, selector: "cqa-selected-filters", inputs: ["filterApplied", "chips"], outputs: ["removeChip", "clearAll"] }, { type: i5.DynamicFilterComponent, selector: "cqa-dynamic-filter", inputs: ["config", "model", "showFilterPanel"], outputs: ["filtersApplied", "filtersChanged", "resetAction"] }, { type: i6.DynamicTableComponent, selector: "app-dynamic-table", inputs: ["data", "columns", "emptyState", "gridTemplateColumns", "screenWidth", "enableSelectAll", "enableLocalSort", "isTableLoading", "isTableDataLoading"], outputs: ["sortChange"] }, { type: i7.ActionMenuButtonComponent, selector: "cqa-action-menu-button", inputs: ["row"], outputs: ["view", "edit", "delete"] }, { type: i8.EmptyStateComponent, selector: "cqa-empty-state", inputs: ["imageUrl", "title", "description", "actions"], outputs: ["actionClick"] }, { type: i9.PaginationComponent, selector: "cqa-pagination", inputs: ["totalElements", "totalPages", "pageIndex", "pageSize", "pageItemCount", "pageSizeOptions"], outputs: ["pageIndexChange", "pageSizeChange", "paginate"] }, { type: i10.TableActionToolbarComponent, selector: "cqa-table-action-toolbar", inputs: ["selectedItems", "actions"], outputs: ["actionClick"] }], directives: [{ type: i11.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i12.DynamicCellTemplateDirective, selector: "ng-template[dynamicCell]", inputs: ["dynamicCell"] }, { type: i11.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i11.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }], pipes: { "slice": i11.SlicePipe, "date": i11.DatePipe } });
|
|
311
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: TableTemplateComponent, decorators: [{
|
|
312
|
+
type: Component,
|
|
313
|
+
args: [{ selector: 'cqa-table-template', template: "<div id=\"cqa-ui-root\">\n <div class=\"cqa-w-full cqa-flex cqa-flex-col cqa-relative\">\n <div class=\"cqa-w-full cqa-flex cqa-items-center cqa-justify-between cqa-gap-3 cqa-flex-wrap cqa-mb-3\">\n <cqa-search-bar\n *ngIf=\"showSearchBar\"\n [placeholder]=\"searchPlaceholder\"\n [value]=\"searchValue\"\n [showClear]=\"showClear\"\n (valueChange)=\"valueChange($event)\"\n (search)=\"search($event)\"\n (cleared)=\"cleared()\"\n ></cqa-search-bar>\n <div class=\"cqa-flex cqa-items-center cqa-gap-2 cqa-flex-wrap\">\n <cqa-button\n *ngIf=\"showFilterButton\"\n variant=\"grey-solid\"\n icon=\"add\"\n [text]=\"'Filter'\"\n (clicked)=\"toggleFilter()\"\n >\n <span>Filter</span>\n </cqa-button>\n <cqa-column-visibility\n *ngIf=\"showSettingsButton\"\n [columns]=\"visibilityColumns\"\n [columnVisibility]=\"columnVisibility\"\n [selectedAutoRefreshInterval]=\"selectedAutoRefreshInterval\"\n (columnVisibilityChange)=\"onColumnVisibilityChange($event)\"\n (autoRefreshChange)=\"onAutoRefreshChange($event)\"\n ></cqa-column-visibility>\n <cqa-button *ngIf=\"showAutoRefreshButton\" variant=\"grey-solid\" icon=\"refresh\"></cqa-button>\n <cqa-button *ngIf=\"showOtherButton\" [variant]=\"otherButtonVariant\" [text]=\"otherButtonLabel\"></cqa-button>\n </div>\n </div>\n\n <cqa-selected-filters \n *ngIf=\"showFilterPanel\"\n [filterApplied]=\"filterApplied\"\n [chips]=\"chips\"\n (removeChip)=\"onRemoveChip($event)\"\n (clearAll)=\"onClearAllChips()\"\n >\n </cqa-selected-filters>\n\n <cqa-dynamic-filter\n *ngIf=\"showFilterPanel\"\n [config]=\"filterConfig\"\n [showFilterPanel]=\"showFilterPanel\"\n (filtersChanged)=\"onFiltersChanged($event)\"\n (filtersApplied)=\"onFiltersApplied($event)\"\n >\n </cqa-dynamic-filter>\n\n <div class=\"cqa-rounded-[7px] cqa-overflow-hidden cqa-border-t cqa-border-l cqa-border-r cqa-border-grey-200 cqa-relative\">\n <ng-container *ngIf=\"!isEmptyState && pagedRows && pagedRows.length > 0; else storyEmptyTpl\">\n <app-dynamic-table\n [columns]=\"computedColumns\"\n [data]=\"pagedRows\"\n [isTableLoading]=\"isTableLoading\"\n [isTableDataLoading]=\"isTableDataLoading\">\n <ng-template dynamicCell=\"checkbox\" let-row=\"row\">\n <div class=\"custom-checkbox\">\n <input\n type=\"checkbox\"\n class=\"hidden-checkbox\"\n [attr.id]=\"'row-checkbox-' + row.id\"\n [checked]=\"row.isSelected\"\n aria-label=\"Select row\"\n (change)=\"onRowCheckboxChange($event, row)\" />\n <label\n class=\"custom-checkbox-label\"\n [attr.for]=\"'row-checkbox-' + row.id\">\n </label>\n </div>\n </ng-template>\n\n <ng-template dynamicCell=\"testCases\" let-row=\"row\" let-value=\"value\">\n <div class=\"cqa-flex cqa-flex-col cqa-gap-1 cqa-text-[12.3px] cqa-leading-[17.5px] cqa-font-medium\">\n <div class=\"cqa-text-[#3F43EE] cqa-truncate\">\n #{{ row.id }}\n </div>\n <div class=\"cqa-text-[#0A0A0A]\">{{ value }}</div>\n </div>\n </ng-template>\n\n <ng-template dynamicCell=\"type\" let-row=\"row\" let-value=\"value\">\n <div class=\"cqa-text-xs cqa-text-[#111827] cqa-truncate\">{{ value }}</div>\n </ng-template>\n\n <ng-template dynamicCell=\"priority\" let-row=\"row\" let-value=\"value\">\n <span\n class=\"cqa-inline-flex cqa-items-center cqa-px-2 cqa-py-0.5 cqa-rounded cqa-text-xs\"\n [ngClass]=\"{\n 'cqa-bg-red-100 cqa-text-red-700': value === 'Critical' || value === 'Major',\n 'cqa-bg-yellow-100 cqa-text-yellow-700': value === 'Medium',\n 'cqa-bg-blue-100 cqa-text-blue-700': value === 'Minor',\n 'cqa-bg-gray-100 cqa-text-gray-700': !value || value === 'Not Set'\n }\"\n >{{ value || 'Not Set' }}</span\n >\n </ng-template>\n\n <ng-template dynamicCell=\"result\" let-row=\"row\" let-value=\"value\">\n <span class=\"cqa-inline-flex cqa-items-center cqa-px-2 cqa-py-0.5 cqa-rounded cqa-text-xs\" [ngClass]=\"resultBadgeClass(value)\">\n {{ value || 'NOT_EXECUTED' }}\n </span>\n </ng-template>\n\n <ng-template dynamicCell=\"status\" let-row=\"row\" let-value=\"value\">\n <span class=\"cqa-text-xs\">{{ value }}</span>\n </ng-template>\n\n <ng-template dynamicCell=\"labels\" let-row=\"row\" let-value=\"value\">\n <div class=\"cqa-flex cqa-flex-wrap cqa-gap-1\">\n <span *ngFor=\"let tag of (row.tags || []) | slice: 0:3\" class=\"cqa-px-2 cqa-py-0.5 cqa-rounded cqa-bg-gray-100 cqa-text-gray-700 cqa-text-xs\">\n {{ tag }}\n </span>\n <span *ngIf=\"(row.tags?.length || 0) > 3\" class=\"cqa-px-2 cqa-py-0.5 cqa-rounded cqa-bg-gray-100 cqa-text-gray-700 cqa-text-xs\">\n +{{ (row.tags?.length || 0) - 3 }} more\n </span>\n </div>\n </ng-template>\n\n <ng-template dynamicCell=\"createdBy\" let-row=\"row\" let-value=\"value\">\n <span class=\"cqa-text-xs\">{{ value }}</span>\n </ng-template>\n\n <ng-template dynamicCell=\"createdAt\" let-row=\"row\" let-value=\"value\">\n <span class=\"cqa-text-xs cqa-text-gray-700\">{{ value | date: 'medium' }}</span>\n </ng-template>\n\n <ng-template dynamicCell=\"updatedAt\" let-row=\"row\" let-value=\"value\">\n <span class=\"cqa-text-xs cqa-text-gray-700\">{{ value | date: 'medium' }}</span>\n </ng-template>\n\n <ng-template dynamicCell=\"lastRun\" let-row=\"row\">\n <div class=\"cqa-flex cqa-flex-col\">\n <span class=\"cqa-text-xs cqa-text-[#111827]\">{{ row.lastRun?.startTime | date: 'medium' }}</span>\n </div>\n </ng-template>\n\n <ng-template dynamicCell=\"actions\" let-row=\"row\">\n <div class=\"cqa-flex cqa-items-center cqa-gap-2\" *ngIf=\"showActionButton\">\n <cqa-action-menu-button\n [row]=\"row\"\n (view)=\"view($event)\"\n (edit)=\"edit($event)\"\n (delete)=\"delete($event)\"\n ></cqa-action-menu-button>\n </div>\n </ng-template>\n\n <ng-template #emptyTableTpl>\n <div class=\"cqa-flex cqa-flex-col cqa-items-center cqa-justify-center cqa-py-8\">\n <img src=\"/assets/illustrations/empty-state.svg\" alt=\"No data\" class=\"cqa-w-32 cqa-h-32 cqa-mb-4\" />\n <h3 class=\"cqa-text-lg cqa-font-semibold cqa-mb-2\">No test cases</h3>\n <p class=\"cqa-text-sm cqa-text-neutral-500 cqa-mb-4\">Try adjusting filters or create a new test case.</p>\n <cqa-button variant=\"filled\" (clicked)=\"toggleFilter()\">Show Filters</cqa-button>\n </div>\n </ng-template>\n </app-dynamic-table>\n </ng-container>\n\n <ng-template #storyEmptyTpl>\n <div class=\"cqa-p-6 cqa-flex cqa-flex-col cqa-items-center cqa-justify-center\">\n <cqa-empty-state\n *ngIf=\"isEmptyState\"\n [title]=\"emptyStateConfig.title\"\n [description]=\"emptyStateConfig.description\"\n [imageUrl]=\"emptyStateConfig.imageUrl\"\n [actions]=\"emptyStateConfig.actions\"\n (actionClick)=\"onEmptyAction($event)\"\n >\n </cqa-empty-state>\n </div>\n </ng-template>\n\n </div>\n\n <cqa-pagination\n [totalElements]=\"filteredRows.length\"\n [pageIndex]=\"pageIndex\"\n [pageSize]=\"pageSize\"\n [pageItemCount]=\"pagedRows.length\"\n (paginate)=\"onPaginate($event)\"\n (pageSizeChange)=\"onPageSizeChange($event)\"\n >\n </cqa-pagination>\n\n <div *ngIf=\"anyRowSelected\" class=\"cqa-absolute cqa-bottom-[18.75px] cqa-left-[50%] cqa-translate-x-[-50%] cqa-w-full lg:cqa-max-w-[68%] cqa-sm:max-w-[75%] cqa-max-w-[90%] cqa-z-[1]\" >\n <cqa-table-action-toolbar\n [selectedItems]=\"currentSelectedItems\"\n [actions]=\"actions\"\n (actionClick)=\"actionClick($event)\"\n ></cqa-table-action-toolbar>\n </div>\n \n </div>\n</div>\n\n", styles: [] }]
|
|
314
|
+
}], propDecorators: { searchPlaceholder: [{
|
|
315
|
+
type: Input
|
|
316
|
+
}], searchValue: [{
|
|
317
|
+
type: Input
|
|
318
|
+
}], showClear: [{
|
|
319
|
+
type: Input
|
|
320
|
+
}], showSearchBar: [{
|
|
321
|
+
type: Input
|
|
322
|
+
}], filterConfig: [{
|
|
323
|
+
type: Input
|
|
324
|
+
}], showFilterPanel: [{
|
|
325
|
+
type: Input
|
|
326
|
+
}], showFilterButton: [{
|
|
327
|
+
type: Input
|
|
328
|
+
}], otherButtonLabel: [{
|
|
329
|
+
type: Input
|
|
330
|
+
}], otherButtonVariant: [{
|
|
331
|
+
type: Input
|
|
332
|
+
}], showOtherButton: [{
|
|
333
|
+
type: Input
|
|
334
|
+
}], showActionButton: [{
|
|
335
|
+
type: Input
|
|
336
|
+
}], showSettingsButton: [{
|
|
337
|
+
type: Input
|
|
338
|
+
}], showAutoRefreshButton: [{
|
|
339
|
+
type: Input
|
|
340
|
+
}], data: [{
|
|
341
|
+
type: Input
|
|
342
|
+
}], isEmptyState: [{
|
|
343
|
+
type: Input
|
|
344
|
+
}], emptyStateConfig: [{
|
|
345
|
+
type: Input
|
|
346
|
+
}], actions: [{
|
|
347
|
+
type: Input
|
|
348
|
+
}], chips: [{
|
|
349
|
+
type: Input
|
|
350
|
+
}], filterApplied: [{
|
|
351
|
+
type: Input
|
|
352
|
+
}], columns: [{
|
|
353
|
+
type: Input
|
|
354
|
+
}], selectedAutoRefreshInterval: [{
|
|
355
|
+
type: Input
|
|
356
|
+
}], pageIndex: [{
|
|
357
|
+
type: Input
|
|
358
|
+
}], pageSize: [{
|
|
359
|
+
type: Input
|
|
360
|
+
}], isTableLoading: [{
|
|
361
|
+
type: Input
|
|
362
|
+
}], isTableDataLoading: [{
|
|
363
|
+
type: Input
|
|
364
|
+
}] } });
|
|
365
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-template.component.js","sourceRoot":"","sources":["../../../../../src/lib/templates/table-template.component.ts","../../../../../src/lib/templates/table-template.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  Input,\n  OnChanges,\n  OnInit,\n  SimpleChanges,\n} from '@angular/core';\nimport { DynamicFilterItem } from '../filters/dynamic-filter/dynamic-filter.component';\nimport { DynamicTableColumn } from '../table/dynamic-table/dynamic-table.component';\nimport { ColumnVisibilityConfig } from '../column-visibility/column-visibility.component';\nimport { TableAction } from '../table-action-toolbar/table-action-toolbar.component';\nimport { EmptyStateAction } from '../empty-state/empty-state.component';\nimport { EMPTY_STATE_IMAGES } from '../assets/images/image-assets.constants';\n\nexport interface EmptyStateConfig {\n  title: string;\n  description: string;\n  imageUrl: string;\n  actions: EmptyStateAction[];\n}\n\n@Component({\n  selector: 'cqa-table-template',\n  templateUrl: './table-template.component.html',\n  styleUrls: [],\n})\nexport class TableTemplateComponent implements OnInit, OnChanges {\n  // Search bar inputs\n  @Input() searchPlaceholder: string = 'Search components';\n  @Input() searchValue: string = '';\n  @Input() showClear: boolean = true;\n  @Input() showSearchBar: boolean = true;\n\n  // Filter inputs\n  @Input() filterConfig: DynamicFilterItem[] = [];\n  @Input() showFilterPanel: boolean = false;\n  @Input() showFilterButton: boolean = true;\n\n  // Other button input\n  @Input() otherButtonLabel: string = 'Other Button';\n  @Input() otherButtonVariant: 'filled' | 'outlined' | 'text' | 'elevated' | 'tonal' | 'grey-solid' = 'filled';\n  @Input() showOtherButton: boolean = true;\n  \n  // Action menu button (three-dot menu in table rows)\n  @Input() showActionButton: boolean = true;\n\n  // Settings and refresh buttons\n  @Input() showSettingsButton: boolean = true;\n  @Input() showAutoRefreshButton: boolean = true;\n\n  // Data input\n  @Input() data: any[] = [];\n\n  // Empty state inputs\n  @Input() isEmptyState: boolean = false;\n  @Input() emptyStateConfig: EmptyStateConfig = {\n    title: 'No Data Available Yet',\n    description: 'Run or upload your first test to see your analytics and trends here. Watch your quality metrics come to life with real-time insights.',\n    imageUrl: EMPTY_STATE_IMAGES.DASHBOARD,\n    actions: [{ label: 'Run Test Suite', variant: 'filled' }],\n  };\n\n  // Action bar inputs\n  @Input() actions: TableAction[] = [\n    { \n      id: 'delete', \n      label: 'Delete', \n      icon: 'delete', \n      tooltip: 'Delete selected',\n      onClick: (context) => {\n        console.log('Delete action clicked:', context);\n      }\n    },\n    { \n      id: 'edit', \n      label: 'Edit', \n      icon: 'edit', \n      tooltip: 'Edit selected',\n      onClick: (context) => {\n        console.log('Edit action clicked:', context);\n      }\n    },\n    { \n      id: 'add-tag', \n      label: 'Add Tag', \n      icon: 'local_offer', \n      tooltip: 'Add tags',\n      onClick: (context) => {\n        console.log('Add tag action clicked:', context);\n      }\n    },\n    { \n      id: 'remove-tag', \n      label: 'Remove Tag', \n      icon: 'label_off', \n      tooltip: 'Remove tags',\n      onClick: (context) => {\n        console.log('Remove tag action clicked:', context);\n      }\n    },\n  ];\n\n  // Chips inputs\n  @Input() chips: Array<{ key?: string; label?: string; text: string; fullText?: string; hasMore?: boolean }> = [];\n  @Input() filterApplied: boolean = false;\n\n  // Table inputs\n  @Input() columns: DynamicTableColumn[] = [];\n  @Input() selectedAutoRefreshInterval: number = 0;\n  @Input() pageIndex: number = 0;\n  @Input() pageSize: number = 10;\n  // Loader controls (passed down to dynamic table)\n  @Input() isTableLoading?: boolean;\n  @Input() isTableDataLoading?: boolean;\n  // Backward-compatibility flag; if provided, dynamic table will use it when specific flags are undefined\n\n  // Internal state for column visibility\n  private _columnVisibility: ColumnVisibilityConfig = {};\n  private _cachedVisibilityColumns: Array<{ id: string; label: string }> = [];\n  filteredRows: any[] = [];\n  pagedRows: any[] = [];\n\n  // Derived columns with visibility applied. Avoid mutating @Input() columns so parent bindings aren't overridden.\n  get computedColumns(): DynamicTableColumn[] {\n    const visibility = this._columnVisibility || {};\n    const source = this.columns || [];\n    return source.map(col => {\n      if (['checkbox', 'actions'].includes(col.fieldId)) {\n        return col;\n      }\n      const show = visibility[col.fieldId];\n      return { ...col, isShow: show !== false };\n    });\n  }\n\n  // Auto-generated visibility columns from columns input (excludes default columns and checkbox/actions)\n  // Cached to avoid creating new arrays on every change detection cycle\n  get visibilityColumns(): Array<{ id: string; label: string }> {\n    return this._cachedVisibilityColumns;\n  }\n\n  // Internal column visibility state\n  get columnVisibility(): ColumnVisibilityConfig {\n    return this._columnVisibility;\n  }\n  ngOnInit(): void {\n    this.initializeComponent();\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes['data'] || changes['isEmptyState']) {\n      this.initializeComponent();\n    }\n    if (changes['columns']) {\n      this.initializeColumnVisibility();\n    }\n  }\n\n  private initializeComponent(): void {\n    if (this.isEmptyState) {\n      this.filteredRows = [];\n      this.pagedRows = [];\n      return;\n    }\n\n    this.filteredRows = [...this.data];\n    this.applyPagination();\n    this.initializeColumnVisibility();\n  }\n\n  private initializeColumnVisibility(): void {\n    // Cache visibility columns to avoid creating new arrays on every change detection\n    this._cachedVisibilityColumns = this.mapVisibilityColumns();\n    // Initialize visibility state for all visibility columns (default to true)\n    for (const col of this._cachedVisibilityColumns) {\n      if (this._columnVisibility[col.id] === undefined) {\n        this._columnVisibility[col.id] = true;\n      }\n    }\n  }\n\n  get anyRowSelected(): boolean {\n    return !!(this.pagedRows && this.pagedRows.some(r => !!(r as any).isSelected));\n  }\n\n  get currentSelectedItems(): any[] {\n    return (this.pagedRows || []).filter(r => !!(r as any).isSelected);\n  }\n\n  actionClick(data: any) {\n    console.log('action toolbar', data);\n  }\n\n  view(id: number | string): void {\n    console.log('View', id);\n  }\n\n  edit(row: any): void {\n    console.log('Edit', row);\n  }\n\n  delete(row: any): void {\n    console.log('Delete', row);\n  }\n\n  onRowCheckboxChange(event: Event, row: any): void {\n    const input = event.target as HTMLInputElement | null;\n    const checked = !!input?.checked;\n    row.isSelected = checked;\n  }\n\n  toggleFilter(): void {\n    this.showFilterPanel = !this.showFilterPanel;\n  }\n\n  onColumnVisibilityChange(cfg: ColumnVisibilityConfig): void {\n    this._columnVisibility = { ...cfg };\n    // Do not mutate this.columns; computedColumns getter will reflect changes\n  }\n\n  onAutoRefreshChange(intervalMs: number): void {\n    this.selectedAutoRefreshInterval = intervalMs;\n    console.log('Auto refresh interval', intervalMs);\n  }\n\n  valueChange(value: string): void {\n    console.log('Value changed', value);\n  }\n\n  search(value: string): void {\n    console.log('Search', value);\n  }\n\n  cleared(): void {\n    console.log('Cleared');\n  }\n\n  resultBadgeClass(result?: string | null): string {\n    const value = (result || '').toUpperCase();\n    if (value === 'SUCCESS') return 'cqa-bg-green-100 cqa-text-green-700';\n    if (value === 'FAILURE' || value === 'ABORTED') return 'cqa-bg-red-100 cqa-text-red-700';\n    if (value === 'QUEUED' || value === 'NOT_EXECUTED' || value === 'STOPPED') return 'cqa-bg-gray-100 cqa-text-gray-700';\n    return 'cqa-bg-gray-100 cqa-text-gray-700';\n  }\n\n  onEmptyAction(action: any) {\n    if (action?.label === 'Show filters') {\n      this.toggleFilter();\n    }\n  }\n\n  onFiltersChanged(current: any): void {\n    this.filteredRows = this.data.filter(r => this.passFilters(current, r));\n    this.pageIndex = 0;\n    this.applyPagination();\n    const chips: Array<{ key?: string; label?: string; text: string; fullText?: string; hasMore?: boolean }> = [];\n    if (current) {\n      for (const key of Object.keys(current)) {\n        const value = current[key];\n        if (value == null || value === '' || (Array.isArray(value) && value.length === 0)) continue;\n        let text = '';\n        if (Array.isArray(value)) {\n          text = value.map((v: any) => (v?.name ?? v?.label ?? v?.value ?? v)).join(', ');\n        } else if (typeof value === 'object') {\n          if ('start' in value || 'end' in value) {\n            const s = value.start ? new Date(value.start).toLocaleDateString() : '';\n            const e = value.end ? new Date(value.end).toLocaleDateString() : '';\n            text = [s, e].filter(Boolean).join(' - ');\n          } else {\n            text = (value?.name ?? value?.label ?? value?.value ?? JSON.stringify(value));\n          }\n        } else {\n          text = String(value);\n        }\n        chips.push({ key, text, fullText: text, hasMore: text.length > 30 });\n      }\n    }\n    this.chips = chips;\n    this.filterApplied = this.chips.length > 0;\n  }\n\n  onFiltersApplied(_: any): void {\n    // handled in onFiltersChanged for this demo\n  }\n\n  onPaginate(e: { pageIndex: number; pageSize: number }): void {\n    this.pageIndex = e.pageIndex;\n    this.pageSize = e.pageSize;\n    this.applyPagination();\n  }\n\n  onPageSizeChange(size: number): void {\n    this.pageSize = size;\n    this.pageIndex = 0;\n    this.applyPagination();\n  }\n\n  onRemoveChip(chip: any): void {\n    this.chips = this.chips.filter(c => c !== chip);\n    this.filterApplied = this.chips.length > 0;\n  }\n\n  onClearAllChips(): void {\n    this.chips = [];\n    this.filterApplied = false;\n  }\n\n  private applyPagination(): void {\n    const start = this.pageIndex * this.pageSize;\n    const end = start + this.pageSize;\n    this.pagedRows = this.filteredRows.slice(start, end);\n  }\n\n  private mapVisibilityColumns(): Array<{ id: string; label: string }> {\n    return (this.columns || [])\n      .filter(c => c.isDefault === false)\n      .map(c => ({ id: c.fieldId, label: c.fieldName || c.fieldId }));\n  }\n\n  private normalizeDate(d: any): number | null {\n    if (!d) return null;\n    const ts = Date.parse(d);\n    return isNaN(ts) ? null : ts;\n  }\n\n  private passFilters(filters: any, row: any): boolean {\n    if (!filters) return true;\n    if (filters.status && Array.isArray(filters.status) && filters.status.length) {\n      if (!filters.status.includes(row.status)) return false;\n    }\n    if (filters.priority && Array.isArray(filters.priority) && filters.priority.length) {\n      if (!filters.priority.includes(row.priorityName)) return false;\n    }\n    if (filters.testType && Array.isArray(filters.testType) && filters.testType.length) {\n      if (!filters.testType.includes(row.testType)) return false;\n    }\n    if (filters.created_date && (filters.created_date.start || filters.created_date.end)) {\n      const startTs = this.normalizeDate(filters.created_date.start);\n      const endTs = this.normalizeDate(filters.created_date.end);\n      const rowTs = this.normalizeDate(row.createdAt);\n      if (rowTs != null) {\n        if (startTs != null && rowTs < startTs) return false;\n        if (endTs != null && rowTs > endTs) return false;\n      }\n    }\n    return true;\n  }\n}\n","<div id=\"cqa-ui-root\">\n  <div class=\"cqa-w-full cqa-flex cqa-flex-col cqa-relative\">\n    <div class=\"cqa-w-full cqa-flex cqa-items-center cqa-justify-between cqa-gap-3 cqa-flex-wrap cqa-mb-3\">\n      <cqa-search-bar\n        *ngIf=\"showSearchBar\"\n        [placeholder]=\"searchPlaceholder\"\n        [value]=\"searchValue\"\n        [showClear]=\"showClear\"\n        (valueChange)=\"valueChange($event)\"\n        (search)=\"search($event)\"\n        (cleared)=\"cleared()\"\n      ></cqa-search-bar>\n      <div class=\"cqa-flex cqa-items-center cqa-gap-2 cqa-flex-wrap\">\n        <cqa-button\n          *ngIf=\"showFilterButton\"\n          variant=\"grey-solid\"\n          icon=\"add\"\n          [text]=\"'Filter'\"\n          (clicked)=\"toggleFilter()\"\n        >\n          <span>Filter</span>\n        </cqa-button>\n        <cqa-column-visibility\n          *ngIf=\"showSettingsButton\"\n          [columns]=\"visibilityColumns\"\n          [columnVisibility]=\"columnVisibility\"\n          [selectedAutoRefreshInterval]=\"selectedAutoRefreshInterval\"\n          (columnVisibilityChange)=\"onColumnVisibilityChange($event)\"\n          (autoRefreshChange)=\"onAutoRefreshChange($event)\"\n        ></cqa-column-visibility>\n        <cqa-button *ngIf=\"showAutoRefreshButton\" variant=\"grey-solid\" icon=\"refresh\"></cqa-button>\n        <cqa-button *ngIf=\"showOtherButton\" [variant]=\"otherButtonVariant\" [text]=\"otherButtonLabel\"></cqa-button>\n      </div>\n    </div>\n\n    <cqa-selected-filters \n      *ngIf=\"showFilterPanel\"\n      [filterApplied]=\"filterApplied\"\n      [chips]=\"chips\"\n      (removeChip)=\"onRemoveChip($event)\"\n      (clearAll)=\"onClearAllChips()\"\n    >\n    </cqa-selected-filters>\n\n    <cqa-dynamic-filter\n      *ngIf=\"showFilterPanel\"\n      [config]=\"filterConfig\"\n      [showFilterPanel]=\"showFilterPanel\"\n      (filtersChanged)=\"onFiltersChanged($event)\"\n      (filtersApplied)=\"onFiltersApplied($event)\"\n    >\n    </cqa-dynamic-filter>\n\n    <div class=\"cqa-rounded-[7px] cqa-overflow-hidden cqa-border-t cqa-border-l cqa-border-r cqa-border-grey-200 cqa-relative\">\n      <ng-container *ngIf=\"!isEmptyState && pagedRows && pagedRows.length > 0; else storyEmptyTpl\">\n        <app-dynamic-table\n          [columns]=\"computedColumns\"\n          [data]=\"pagedRows\"\n          [isTableLoading]=\"isTableLoading\"\n          [isTableDataLoading]=\"isTableDataLoading\">\n          <ng-template dynamicCell=\"checkbox\" let-row=\"row\">\n            <div class=\"custom-checkbox\">\n              <input\n                type=\"checkbox\"\n                class=\"hidden-checkbox\"\n                [attr.id]=\"'row-checkbox-' + row.id\"\n                [checked]=\"row.isSelected\"\n                aria-label=\"Select row\"\n                (change)=\"onRowCheckboxChange($event, row)\" />\n              <label\n                class=\"custom-checkbox-label\"\n                [attr.for]=\"'row-checkbox-' + row.id\">\n              </label>\n            </div>\n          </ng-template>\n\n          <ng-template dynamicCell=\"testCases\" let-row=\"row\" let-value=\"value\">\n            <div class=\"cqa-flex cqa-flex-col cqa-gap-1 cqa-text-[12.3px] cqa-leading-[17.5px] cqa-font-medium\">\n              <div class=\"cqa-text-[#3F43EE] cqa-truncate\">\n                #{{ row.id }}\n              </div>\n              <div class=\"cqa-text-[#0A0A0A]\">{{ value }}</div>\n            </div>\n          </ng-template>\n\n          <ng-template dynamicCell=\"type\" let-row=\"row\" let-value=\"value\">\n            <div class=\"cqa-text-xs cqa-text-[#111827] cqa-truncate\">{{ value }}</div>\n          </ng-template>\n\n          <ng-template dynamicCell=\"priority\" let-row=\"row\" let-value=\"value\">\n            <span\n              class=\"cqa-inline-flex cqa-items-center cqa-px-2 cqa-py-0.5 cqa-rounded cqa-text-xs\"\n              [ngClass]=\"{\n                'cqa-bg-red-100 cqa-text-red-700': value === 'Critical' || value === 'Major',\n                'cqa-bg-yellow-100 cqa-text-yellow-700': value === 'Medium',\n                'cqa-bg-blue-100 cqa-text-blue-700': value === 'Minor',\n                'cqa-bg-gray-100 cqa-text-gray-700': !value || value === 'Not Set'\n              }\"\n              >{{ value || 'Not Set' }}</span\n            >\n          </ng-template>\n\n          <ng-template dynamicCell=\"result\" let-row=\"row\" let-value=\"value\">\n            <span class=\"cqa-inline-flex cqa-items-center cqa-px-2 cqa-py-0.5 cqa-rounded cqa-text-xs\" [ngClass]=\"resultBadgeClass(value)\">\n              {{ value || 'NOT_EXECUTED' }}\n            </span>\n          </ng-template>\n\n          <ng-template dynamicCell=\"status\" let-row=\"row\" let-value=\"value\">\n            <span class=\"cqa-text-xs\">{{ value }}</span>\n          </ng-template>\n\n          <ng-template dynamicCell=\"labels\" let-row=\"row\" let-value=\"value\">\n            <div class=\"cqa-flex cqa-flex-wrap cqa-gap-1\">\n              <span *ngFor=\"let tag of (row.tags || []) | slice: 0:3\" class=\"cqa-px-2 cqa-py-0.5 cqa-rounded cqa-bg-gray-100 cqa-text-gray-700 cqa-text-xs\">\n                {{ tag }}\n              </span>\n              <span *ngIf=\"(row.tags?.length || 0) > 3\" class=\"cqa-px-2 cqa-py-0.5 cqa-rounded cqa-bg-gray-100 cqa-text-gray-700 cqa-text-xs\">\n                +{{ (row.tags?.length || 0) - 3 }} more\n              </span>\n            </div>\n          </ng-template>\n\n          <ng-template dynamicCell=\"createdBy\" let-row=\"row\" let-value=\"value\">\n            <span class=\"cqa-text-xs\">{{ value }}</span>\n          </ng-template>\n\n          <ng-template dynamicCell=\"createdAt\" let-row=\"row\" let-value=\"value\">\n            <span class=\"cqa-text-xs cqa-text-gray-700\">{{ value | date: 'medium' }}</span>\n          </ng-template>\n\n          <ng-template dynamicCell=\"updatedAt\" let-row=\"row\" let-value=\"value\">\n            <span class=\"cqa-text-xs cqa-text-gray-700\">{{ value | date: 'medium' }}</span>\n          </ng-template>\n\n          <ng-template dynamicCell=\"lastRun\" let-row=\"row\">\n            <div class=\"cqa-flex cqa-flex-col\">\n              <span class=\"cqa-text-xs cqa-text-[#111827]\">{{ row.lastRun?.startTime | date: 'medium' }}</span>\n            </div>\n          </ng-template>\n\n          <ng-template dynamicCell=\"actions\" let-row=\"row\">\n            <div class=\"cqa-flex cqa-items-center cqa-gap-2\" *ngIf=\"showActionButton\">\n              <cqa-action-menu-button\n                [row]=\"row\"\n                (view)=\"view($event)\"\n                (edit)=\"edit($event)\"\n                (delete)=\"delete($event)\"\n              ></cqa-action-menu-button>\n            </div>\n          </ng-template>\n\n          <ng-template #emptyTableTpl>\n            <div class=\"cqa-flex cqa-flex-col cqa-items-center cqa-justify-center cqa-py-8\">\n              <img src=\"/assets/illustrations/empty-state.svg\" alt=\"No data\" class=\"cqa-w-32 cqa-h-32 cqa-mb-4\" />\n              <h3 class=\"cqa-text-lg cqa-font-semibold cqa-mb-2\">No test cases</h3>\n              <p class=\"cqa-text-sm cqa-text-neutral-500 cqa-mb-4\">Try adjusting filters or create a new test case.</p>\n              <cqa-button variant=\"filled\" (clicked)=\"toggleFilter()\">Show Filters</cqa-button>\n            </div>\n          </ng-template>\n        </app-dynamic-table>\n      </ng-container>\n\n      <ng-template #storyEmptyTpl>\n        <div class=\"cqa-p-6 cqa-flex cqa-flex-col cqa-items-center cqa-justify-center\">\n          <cqa-empty-state\n            *ngIf=\"isEmptyState\"\n            [title]=\"emptyStateConfig.title\"\n            [description]=\"emptyStateConfig.description\"\n            [imageUrl]=\"emptyStateConfig.imageUrl\"\n            [actions]=\"emptyStateConfig.actions\"\n            (actionClick)=\"onEmptyAction($event)\"\n          >\n          </cqa-empty-state>\n        </div>\n      </ng-template>\n\n    </div>\n\n    <cqa-pagination\n      [totalElements]=\"filteredRows.length\"\n      [pageIndex]=\"pageIndex\"\n      [pageSize]=\"pageSize\"\n      [pageItemCount]=\"pagedRows.length\"\n      (paginate)=\"onPaginate($event)\"\n      (pageSizeChange)=\"onPageSizeChange($event)\"\n    >\n    </cqa-pagination>\n\n    <div *ngIf=\"anyRowSelected\" class=\"cqa-absolute cqa-bottom-[18.75px] cqa-left-[50%] cqa-translate-x-[-50%] cqa-w-full lg:cqa-max-w-[68%] cqa-sm:max-w-[75%] cqa-max-w-[90%] cqa-z-[1]\" >\n      <cqa-table-action-toolbar\n        [selectedItems]=\"currentSelectedItems\"\n        [actions]=\"actions\"\n        (actionClick)=\"actionClick($event)\"\n      ></cqa-table-action-toolbar>\n    </div>\n    \n  </div>\n</div>\n\n"]}
|