@cqa-lib/cqa-ui 1.1.4 → 1.1.5
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/compare-runs/compare-runs.component.mjs +3 -6
- package/esm2020/lib/configuration-card/configuration-card.component.mjs +3 -3
- package/esm2020/lib/failed-step-card/failed-step-card.component.mjs +77 -0
- package/esm2020/lib/iterations-loop/iterations-loop.component.mjs +174 -0
- package/esm2020/lib/ui-kit.module.mjs +15 -5
- package/esm2020/public-api.mjs +3 -1
- package/fesm2015/cqa-lib-cqa-ui.mjs +267 -12
- package/fesm2015/cqa-lib-cqa-ui.mjs.map +1 -1
- package/fesm2020/cqa-lib-cqa-ui.mjs +259 -12
- package/fesm2020/cqa-lib-cqa-ui.mjs.map +1 -1
- package/lib/compare-runs/compare-runs.component.d.ts +7 -10
- package/lib/failed-step-card/failed-step-card.component.d.ts +41 -0
- package/lib/iterations-loop/iterations-loop.component.d.ts +39 -0
- package/lib/ui-kit.module.d.ts +18 -16
- package/package.json +1 -1
- package/public-api.d.ts +2 -0
- package/styles.css +1 -1
|
@@ -0,0 +1,77 @@
|
|
|
1
|
+
import { Component, Input, Output, EventEmitter } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
import * as i1 from "../button/button.component";
|
|
4
|
+
import * as i2 from "@angular/common";
|
|
5
|
+
export class FailedStepCardComponent {
|
|
6
|
+
constructor() {
|
|
7
|
+
this.jumpToStep = new EventEmitter();
|
|
8
|
+
this.openInVideo = new EventEmitter();
|
|
9
|
+
this.showExpectedMore = false;
|
|
10
|
+
this.showActualMore = false;
|
|
11
|
+
}
|
|
12
|
+
get headerTitle() {
|
|
13
|
+
if (this.failedStepData?.stepTitle) {
|
|
14
|
+
return `Failed at Step ${this.failedStepData.failed_step_index}: ${this.failedStepData.stepTitle}`;
|
|
15
|
+
}
|
|
16
|
+
return `Failed at Step ${this.failedStepData?.failed_step_index || ''}`;
|
|
17
|
+
}
|
|
18
|
+
get errorText() {
|
|
19
|
+
return this.failedStepData?.errorMessage || this.failedStepData?.reason || 'An error occurred';
|
|
20
|
+
}
|
|
21
|
+
get videoTimestamp() {
|
|
22
|
+
return this.failedStepData?.timestamp || '00:00';
|
|
23
|
+
}
|
|
24
|
+
get durationText() {
|
|
25
|
+
return this.failedStepData?.duration || '0s';
|
|
26
|
+
}
|
|
27
|
+
get expectedResult() {
|
|
28
|
+
return this.failedStepData?.expected_result || '';
|
|
29
|
+
}
|
|
30
|
+
get actualResult() {
|
|
31
|
+
return this.failedStepData?.actual_result || '';
|
|
32
|
+
}
|
|
33
|
+
get suggestions() {
|
|
34
|
+
return this.failedStepData?.suggestions || '';
|
|
35
|
+
}
|
|
36
|
+
get hasSuggestions() {
|
|
37
|
+
return !!this.failedStepData?.suggestions && this.failedStepData.suggestions.trim().length > 0;
|
|
38
|
+
}
|
|
39
|
+
toggleExpectedMore() {
|
|
40
|
+
this.showExpectedMore = !this.showExpectedMore;
|
|
41
|
+
}
|
|
42
|
+
toggleActualMore() {
|
|
43
|
+
this.showActualMore = !this.showActualMore;
|
|
44
|
+
}
|
|
45
|
+
onJumpToStep() {
|
|
46
|
+
this.jumpToStep.emit(this.failedStepData);
|
|
47
|
+
}
|
|
48
|
+
onOpenInVideo() {
|
|
49
|
+
this.openInVideo.emit(this.failedStepData);
|
|
50
|
+
}
|
|
51
|
+
shouldShowViewMore(text, maxLength = 100) {
|
|
52
|
+
return !!(text && text.length > maxLength);
|
|
53
|
+
}
|
|
54
|
+
getTruncatedText(text, maxLength = 100) {
|
|
55
|
+
if (!text)
|
|
56
|
+
return '';
|
|
57
|
+
return text.length > maxLength ? text.substring(0, maxLength) + '...' : text;
|
|
58
|
+
}
|
|
59
|
+
getFormattedSuggestions() {
|
|
60
|
+
if (!this.suggestions)
|
|
61
|
+
return [];
|
|
62
|
+
return this.suggestions.split('\n').filter(s => s.trim().length > 0);
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
FailedStepCardComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: FailedStepCardComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
66
|
+
FailedStepCardComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.4.0", type: FailedStepCardComponent, selector: "cqa-failed-step-card", inputs: { failedStepData: "failedStepData" }, outputs: { jumpToStep: "jumpToStep", openInVideo: "openInVideo" }, ngImport: i0, template: "<div class=\"cqa-ui-root\" style=\"display: block; width: 100%;\">\n <div class=\"cqa-bg-[#FEF2F2] cqa-p-[17px] cqa-rounded-lg cqa-overflow-hidden cqa-flex cqa-flex-col cqa-gap-3\" style=\"border: 1px solid #FECACA;\">\n <div>\n <h3 class=\"cqa-text-sm cqa-leading-[18px] cqa-text-[#111827] cqa-mb-1\">{{ headerTitle }}</h3>\n <div class=\"cqa-flex cqa-flex-wrap cqa-items-center cqa-gap-3 cqa-text-xs\">\n <span class=\"cqa-text-[12px] cqa-text-[#B91C1C]\">Error: {{ errorText }}</span>\n <span class=\"cqa-text-[#636363]\">\u2022</span>\n <span class=\"cqa-text-[#636363]\">Video timestamp: {{ videoTimestamp }}</span>\n <span class=\"cqa-text-[#636363]\">\u2022</span>\n <span class=\"cqa-text-[#636363]\">Duration: {{ durationText }}</span>\n </div>\n </div>\n\n <div class=\"cqa-grid cqa-grid-cols-2 cqa-gap-0 cqa-rounded-[4px] cqa-overflow-hidden\" style=\"border: 1px solid #E5E7EB\">\n <div class=\"cqa-bg-white cqa-px-2 cqa-py-1 md:cqa-border-r cqa-flex cqa-flex-col\" style=\"border-right: 1px solid #E5E7EB\">\n <div class=\"cqa-flex cqa-flex-col cqa-gap-1\">\n <span class=\"cqa-text-[10px] cqa-font-semibold cqa-text-[#9CA3AF] cqa-uppercase cqa-tracking-wide\">EXPECTED</span>\n <div class=\"cqa-text-[10px] cqa-text-[#0B0B0B] cqa-leading-relaxed\">\n <ng-container *ngIf=\"!showExpectedMore && shouldShowViewMore(expectedResult)\">\n {{ getTruncatedText(expectedResult) }}\n </ng-container>\n <ng-container *ngIf=\"showExpectedMore || !shouldShowViewMore(expectedResult)\">\n {{ expectedResult }}\n </ng-container>\n </div>\n </div>\n <div *ngIf=\"shouldShowViewMore(expectedResult)\" class=\"cqa-ml-auto cqa-mt-auto cqa-pt-1\">\n <cqa-button\n variant=\"text\"\n btnSize=\"sm\"\n icon=\"chevron_right\"\n iconPosition=\"end\"\n [text]=\"showExpectedMore ? 'View Less' : 'View More'\"\n [inlineStyles]=\"showExpectedMore ? 'transition: transform 0.2s ease;' : 'transition: transform 0.2s ease;'\"\n (clicked)=\"toggleExpectedMore()\">\n </cqa-button>\n </div>\n </div>\n\n <div class=\"cqa-bg-[#FFF9F9] cqa-px-2 cqa-py-1 cqa-flex cqa-flex-col\">\n <div class=\"cqa-flex cqa-flex-col cqa-gap-1\">\n <span class=\"cqa-text-[10px] cqa-font-semibold cqa-text-[#9CA3AF] cqa-uppercase cqa-tracking-wide\">ACTUAL</span>\n <div class=\"cqa-text-[10px] cqa-text-[#C10007] cqa-leading-relaxed cqa-font-medium\">\n <ng-container *ngIf=\"!showActualMore && shouldShowViewMore(actualResult)\">\n {{ getTruncatedText(actualResult) }}\n </ng-container>\n <ng-container *ngIf=\"showActualMore || !shouldShowViewMore(actualResult)\">\n {{ actualResult }}\n </ng-container>\n </div>\n </div>\n <div *ngIf=\"shouldShowViewMore(actualResult)\" class=\"cqa-ml-auto cqa-mt-auto cqa-pt-1\">\n <cqa-button\n variant=\"text\"\n btnSize=\"sm\"\n icon=\"chevron_right\"\n iconPosition=\"end\"\n [text]=\"showActualMore ? 'View Less' : 'View More'\"\n [inlineStyles]=\"showActualMore ? 'transition: transform 0.2s ease;' : 'transition: transform 0.2s ease;'\"\n (clicked)=\"toggleActualMore()\">\n </cqa-button>\n </div>\n </div>\n </div>\n\n <div class=\"cqa-border-t cqa-border-[#E4E4E4] cqa-flex cqa-flex-wrap cqa-items-center cqa-justify-end cqa-gap-2\">\n <cqa-button\n variant=\"outlined\"\n icon=\"play_arrow\"\n iconLibrary=\"mat\"\n [text]=\"'Jump to step'\"\n btnSize=\"lg\"\n (clicked)=\"onJumpToStep()\">\n </cqa-button>\n <cqa-button\n variant=\"outlined\"\n icon=\"videocam\"\n iconLibrary=\"mat\"\n [text]=\"'Open In Video'\"\n btnSize=\"lg\"\n (clicked)=\"onOpenInVideo()\">\n </cqa-button>\n </div>\n </div>\n</div>\n\n", components: [{ type: i1.ButtonComponent, selector: "cqa-button", inputs: ["variant", "btnSize", "disabled", "icon", "iconPosition", "fullWidth", "iconColor", "type", "text", "customClass", "inlineStyles", "tooltip", "tooltipPosition"], outputs: ["clicked"] }], directives: [{ type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] });
|
|
67
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: FailedStepCardComponent, decorators: [{
|
|
68
|
+
type: Component,
|
|
69
|
+
args: [{ selector: 'cqa-failed-step-card', template: "<div class=\"cqa-ui-root\" style=\"display: block; width: 100%;\">\n <div class=\"cqa-bg-[#FEF2F2] cqa-p-[17px] cqa-rounded-lg cqa-overflow-hidden cqa-flex cqa-flex-col cqa-gap-3\" style=\"border: 1px solid #FECACA;\">\n <div>\n <h3 class=\"cqa-text-sm cqa-leading-[18px] cqa-text-[#111827] cqa-mb-1\">{{ headerTitle }}</h3>\n <div class=\"cqa-flex cqa-flex-wrap cqa-items-center cqa-gap-3 cqa-text-xs\">\n <span class=\"cqa-text-[12px] cqa-text-[#B91C1C]\">Error: {{ errorText }}</span>\n <span class=\"cqa-text-[#636363]\">\u2022</span>\n <span class=\"cqa-text-[#636363]\">Video timestamp: {{ videoTimestamp }}</span>\n <span class=\"cqa-text-[#636363]\">\u2022</span>\n <span class=\"cqa-text-[#636363]\">Duration: {{ durationText }}</span>\n </div>\n </div>\n\n <div class=\"cqa-grid cqa-grid-cols-2 cqa-gap-0 cqa-rounded-[4px] cqa-overflow-hidden\" style=\"border: 1px solid #E5E7EB\">\n <div class=\"cqa-bg-white cqa-px-2 cqa-py-1 md:cqa-border-r cqa-flex cqa-flex-col\" style=\"border-right: 1px solid #E5E7EB\">\n <div class=\"cqa-flex cqa-flex-col cqa-gap-1\">\n <span class=\"cqa-text-[10px] cqa-font-semibold cqa-text-[#9CA3AF] cqa-uppercase cqa-tracking-wide\">EXPECTED</span>\n <div class=\"cqa-text-[10px] cqa-text-[#0B0B0B] cqa-leading-relaxed\">\n <ng-container *ngIf=\"!showExpectedMore && shouldShowViewMore(expectedResult)\">\n {{ getTruncatedText(expectedResult) }}\n </ng-container>\n <ng-container *ngIf=\"showExpectedMore || !shouldShowViewMore(expectedResult)\">\n {{ expectedResult }}\n </ng-container>\n </div>\n </div>\n <div *ngIf=\"shouldShowViewMore(expectedResult)\" class=\"cqa-ml-auto cqa-mt-auto cqa-pt-1\">\n <cqa-button\n variant=\"text\"\n btnSize=\"sm\"\n icon=\"chevron_right\"\n iconPosition=\"end\"\n [text]=\"showExpectedMore ? 'View Less' : 'View More'\"\n [inlineStyles]=\"showExpectedMore ? 'transition: transform 0.2s ease;' : 'transition: transform 0.2s ease;'\"\n (clicked)=\"toggleExpectedMore()\">\n </cqa-button>\n </div>\n </div>\n\n <div class=\"cqa-bg-[#FFF9F9] cqa-px-2 cqa-py-1 cqa-flex cqa-flex-col\">\n <div class=\"cqa-flex cqa-flex-col cqa-gap-1\">\n <span class=\"cqa-text-[10px] cqa-font-semibold cqa-text-[#9CA3AF] cqa-uppercase cqa-tracking-wide\">ACTUAL</span>\n <div class=\"cqa-text-[10px] cqa-text-[#C10007] cqa-leading-relaxed cqa-font-medium\">\n <ng-container *ngIf=\"!showActualMore && shouldShowViewMore(actualResult)\">\n {{ getTruncatedText(actualResult) }}\n </ng-container>\n <ng-container *ngIf=\"showActualMore || !shouldShowViewMore(actualResult)\">\n {{ actualResult }}\n </ng-container>\n </div>\n </div>\n <div *ngIf=\"shouldShowViewMore(actualResult)\" class=\"cqa-ml-auto cqa-mt-auto cqa-pt-1\">\n <cqa-button\n variant=\"text\"\n btnSize=\"sm\"\n icon=\"chevron_right\"\n iconPosition=\"end\"\n [text]=\"showActualMore ? 'View Less' : 'View More'\"\n [inlineStyles]=\"showActualMore ? 'transition: transform 0.2s ease;' : 'transition: transform 0.2s ease;'\"\n (clicked)=\"toggleActualMore()\">\n </cqa-button>\n </div>\n </div>\n </div>\n\n <div class=\"cqa-border-t cqa-border-[#E4E4E4] cqa-flex cqa-flex-wrap cqa-items-center cqa-justify-end cqa-gap-2\">\n <cqa-button\n variant=\"outlined\"\n icon=\"play_arrow\"\n iconLibrary=\"mat\"\n [text]=\"'Jump to step'\"\n btnSize=\"lg\"\n (clicked)=\"onJumpToStep()\">\n </cqa-button>\n <cqa-button\n variant=\"outlined\"\n icon=\"videocam\"\n iconLibrary=\"mat\"\n [text]=\"'Open In Video'\"\n btnSize=\"lg\"\n (clicked)=\"onOpenInVideo()\">\n </cqa-button>\n </div>\n </div>\n</div>\n\n", styles: [] }]
|
|
70
|
+
}], propDecorators: { failedStepData: [{
|
|
71
|
+
type: Input
|
|
72
|
+
}], jumpToStep: [{
|
|
73
|
+
type: Output
|
|
74
|
+
}], openInVideo: [{
|
|
75
|
+
type: Output
|
|
76
|
+
}] } });
|
|
77
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"failed-step-card.component.js","sourceRoot":"","sources":["../../../../../src/lib/failed-step-card/failed-step-card.component.ts","../../../../../src/lib/failed-step-card/failed-step-card.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, Output, EventEmitter } from '@angular/core';\n\nexport interface FailedStepData {\n  expected_result: string;\n  actual_result: string;\n  failed_step_id: string;\n  isTimeouterror: boolean;\n  failed_step_index: string;\n  steps: any[];\n  timestamp: string;\n  duration: string;\n  stepScreenshotUrl: string | null;\n  suggestions: string;\n  reason: string;\n  stepTitle?: string;\n  errorMessage?: string;\n}\n\n@Component({\n  selector: 'cqa-failed-step-card',\n  templateUrl: './failed-step-card.component.html',\n  styleUrls: []\n})\nexport class FailedStepCardComponent {\n  @Input() failedStepData!: FailedStepData;\n  @Output() jumpToStep = new EventEmitter<FailedStepData>();\n  @Output() openInVideo = new EventEmitter<FailedStepData>();\n\n  showExpectedMore = false;\n  showActualMore = false;\n\n  get headerTitle(): string {\n    if (this.failedStepData?.stepTitle) {\n      return `Failed at Step ${this.failedStepData.failed_step_index}: ${this.failedStepData.stepTitle}`;\n    }\n    return `Failed at Step ${this.failedStepData?.failed_step_index || ''}`;\n  }\n\n  get errorText(): string {\n    return this.failedStepData?.errorMessage || this.failedStepData?.reason || 'An error occurred';\n  }\n\n  get videoTimestamp(): string {\n    return this.failedStepData?.timestamp || '00:00';\n  }\n\n  get durationText(): string {\n    return this.failedStepData?.duration || '0s';\n  }\n\n  get expectedResult(): string {\n    return this.failedStepData?.expected_result || '';\n  }\n\n  get actualResult(): string {\n    return this.failedStepData?.actual_result || '';\n  }\n\n  get suggestions(): string {\n    return this.failedStepData?.suggestions || '';\n  }\n\n  get hasSuggestions(): boolean {\n    return !!this.failedStepData?.suggestions && this.failedStepData.suggestions.trim().length > 0;\n  }\n\n  toggleExpectedMore(): void {\n    this.showExpectedMore = !this.showExpectedMore;\n  }\n\n  toggleActualMore(): void {\n    this.showActualMore = !this.showActualMore;\n  }\n\n  onJumpToStep(): void {\n    this.jumpToStep.emit(this.failedStepData);\n  }\n\n  onOpenInVideo(): void {\n    this.openInVideo.emit(this.failedStepData);\n  }\n\n  shouldShowViewMore(text: string, maxLength: number = 100): boolean {\n    return !!(text && text.length > maxLength);\n  }\n\n  getTruncatedText(text: string, maxLength: number = 100): string {\n    if (!text) return '';\n    return text.length > maxLength ? text.substring(0, maxLength) + '...' : text;\n  }\n\n  getFormattedSuggestions(): string[] {\n    if (!this.suggestions) return [];\n    return this.suggestions.split('\\n').filter(s => s.trim().length > 0);\n  }\n}\n\n","<div class=\"cqa-ui-root\" style=\"display: block; width: 100%;\">\n  <div class=\"cqa-bg-[#FEF2F2] cqa-p-[17px] cqa-rounded-lg cqa-overflow-hidden cqa-flex cqa-flex-col cqa-gap-3\" style=\"border: 1px solid #FECACA;\">\n    <div>\n      <h3 class=\"cqa-text-sm cqa-leading-[18px] cqa-text-[#111827] cqa-mb-1\">{{ headerTitle }}</h3>\n      <div class=\"cqa-flex cqa-flex-wrap cqa-items-center cqa-gap-3 cqa-text-xs\">\n        <span class=\"cqa-text-[12px] cqa-text-[#B91C1C]\">Error: {{ errorText }}</span>\n        <span class=\"cqa-text-[#636363]\">•</span>\n        <span class=\"cqa-text-[#636363]\">Video timestamp: {{ videoTimestamp }}</span>\n        <span class=\"cqa-text-[#636363]\">•</span>\n        <span class=\"cqa-text-[#636363]\">Duration: {{ durationText }}</span>\n      </div>\n    </div>\n\n    <div class=\"cqa-grid cqa-grid-cols-2 cqa-gap-0 cqa-rounded-[4px] cqa-overflow-hidden\" style=\"border: 1px solid #E5E7EB\">\n      <div class=\"cqa-bg-white cqa-px-2 cqa-py-1 md:cqa-border-r cqa-flex cqa-flex-col\" style=\"border-right: 1px solid #E5E7EB\">\n        <div class=\"cqa-flex cqa-flex-col cqa-gap-1\">\n          <span class=\"cqa-text-[10px] cqa-font-semibold cqa-text-[#9CA3AF] cqa-uppercase cqa-tracking-wide\">EXPECTED</span>\n          <div class=\"cqa-text-[10px] cqa-text-[#0B0B0B] cqa-leading-relaxed\">\n            <ng-container *ngIf=\"!showExpectedMore && shouldShowViewMore(expectedResult)\">\n              {{ getTruncatedText(expectedResult) }}\n            </ng-container>\n            <ng-container *ngIf=\"showExpectedMore || !shouldShowViewMore(expectedResult)\">\n              {{ expectedResult }}\n            </ng-container>\n          </div>\n        </div>\n        <div *ngIf=\"shouldShowViewMore(expectedResult)\" class=\"cqa-ml-auto cqa-mt-auto cqa-pt-1\">\n          <cqa-button\n            variant=\"text\"\n            btnSize=\"sm\"\n            icon=\"chevron_right\"\n            iconPosition=\"end\"\n            [text]=\"showExpectedMore ? 'View Less' : 'View More'\"\n            [inlineStyles]=\"showExpectedMore ? 'transition: transform 0.2s ease;' : 'transition: transform 0.2s ease;'\"\n            (clicked)=\"toggleExpectedMore()\">\n          </cqa-button>\n        </div>\n      </div>\n\n      <div class=\"cqa-bg-[#FFF9F9] cqa-px-2 cqa-py-1 cqa-flex cqa-flex-col\">\n        <div class=\"cqa-flex cqa-flex-col cqa-gap-1\">\n          <span class=\"cqa-text-[10px] cqa-font-semibold cqa-text-[#9CA3AF] cqa-uppercase cqa-tracking-wide\">ACTUAL</span>\n          <div class=\"cqa-text-[10px] cqa-text-[#C10007] cqa-leading-relaxed cqa-font-medium\">\n            <ng-container *ngIf=\"!showActualMore && shouldShowViewMore(actualResult)\">\n              {{ getTruncatedText(actualResult) }}\n            </ng-container>\n            <ng-container *ngIf=\"showActualMore || !shouldShowViewMore(actualResult)\">\n              {{ actualResult }}\n            </ng-container>\n          </div>\n        </div>\n        <div *ngIf=\"shouldShowViewMore(actualResult)\" class=\"cqa-ml-auto cqa-mt-auto cqa-pt-1\">\n          <cqa-button\n            variant=\"text\"\n            btnSize=\"sm\"\n            icon=\"chevron_right\"\n            iconPosition=\"end\"\n            [text]=\"showActualMore ? 'View Less' : 'View More'\"\n            [inlineStyles]=\"showActualMore ? 'transition: transform 0.2s ease;' : 'transition: transform 0.2s ease;'\"\n            (clicked)=\"toggleActualMore()\">\n          </cqa-button>\n        </div>\n      </div>\n    </div>\n\n    <div class=\"cqa-border-t cqa-border-[#E4E4E4] cqa-flex cqa-flex-wrap cqa-items-center cqa-justify-end cqa-gap-2\">\n      <cqa-button\n        variant=\"outlined\"\n        icon=\"play_arrow\"\n        iconLibrary=\"mat\"\n        [text]=\"'Jump to step'\"\n        btnSize=\"lg\"\n        (clicked)=\"onJumpToStep()\">\n      </cqa-button>\n      <cqa-button\n        variant=\"outlined\"\n        icon=\"videocam\"\n        iconLibrary=\"mat\"\n        [text]=\"'Open In Video'\"\n        btnSize=\"lg\"\n        (clicked)=\"onOpenInVideo()\">\n      </cqa-button>\n    </div>\n  </div>\n</div>\n\n"]}
|
|
@@ -0,0 +1,174 @@
|
|
|
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 "../templates/table-template.component";
|
|
5
|
+
import * as i2 from "@angular/common";
|
|
6
|
+
export class IterationsLoopComponent {
|
|
7
|
+
constructor() {
|
|
8
|
+
this.iterations = [];
|
|
9
|
+
this.isTableDataLoading = false;
|
|
10
|
+
this.tableColumns = [];
|
|
11
|
+
this.pageIndex = 0;
|
|
12
|
+
this.pageSize = 5;
|
|
13
|
+
this.emptyStateConfig = {
|
|
14
|
+
title: 'No Iterations',
|
|
15
|
+
description: 'There are no iterations to display for this loop.',
|
|
16
|
+
imageUrl: EMPTY_STATE_IMAGES.DASHBOARD,
|
|
17
|
+
actions: []
|
|
18
|
+
};
|
|
19
|
+
}
|
|
20
|
+
ngOnInit() {
|
|
21
|
+
this.setupTableColumns();
|
|
22
|
+
}
|
|
23
|
+
ngOnChanges(changes) {
|
|
24
|
+
if (changes['iterations']) {
|
|
25
|
+
this.pageIndex = 0;
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
setupTableColumns() {
|
|
29
|
+
this.tableColumns = [
|
|
30
|
+
{
|
|
31
|
+
fieldId: 'index',
|
|
32
|
+
fieldName: '#',
|
|
33
|
+
fieldValue: 'index',
|
|
34
|
+
isShow: true,
|
|
35
|
+
weight: 0.5,
|
|
36
|
+
render: (row) => {
|
|
37
|
+
return `<span class="cqa-text-[16px] cqa-text-[#0A0A0A] cqa-font-regular">${row.index}</span>`;
|
|
38
|
+
}
|
|
39
|
+
},
|
|
40
|
+
{
|
|
41
|
+
fieldId: 'datasetId',
|
|
42
|
+
fieldName: 'Dataset ID',
|
|
43
|
+
fieldValue: 'datasetId',
|
|
44
|
+
isShow: true,
|
|
45
|
+
weight: 1.5,
|
|
46
|
+
render: (row) => {
|
|
47
|
+
return `<span class="cqa-text-sm cqa-text-[#0A0A0A] cqa-font-regular">${row.datasetId}</span>`;
|
|
48
|
+
}
|
|
49
|
+
},
|
|
50
|
+
{
|
|
51
|
+
fieldId: 'variables',
|
|
52
|
+
fieldName: 'Variables',
|
|
53
|
+
isShow: true,
|
|
54
|
+
weight: 2,
|
|
55
|
+
render: (row) => {
|
|
56
|
+
const variableEntries = Object.entries(row.variables || {});
|
|
57
|
+
const variablesHtml = variableEntries.map(([key, value], index) => {
|
|
58
|
+
return `<div class="cqa-flex cqa-items-center cqa-gap-0.5 ${index === variableEntries.length - 1 ? 'cqa-mb-0' : 'cqa-mb-1'}">
|
|
59
|
+
<span class="cqa-px-1 cqa-text-[12px] cqa-text-[#4A5565] cqa-bg-[#F3F4F6] cqa-rounded-[4px]">${key}:</span>
|
|
60
|
+
<span class="cqa-text-sm cqa-text-[#4A5565] cqa-font-medium">${value}</span>
|
|
61
|
+
</div>`;
|
|
62
|
+
}).join('');
|
|
63
|
+
return `<div class="cqa-flex cqa-flex-col">${variablesHtml}</div>`;
|
|
64
|
+
}
|
|
65
|
+
},
|
|
66
|
+
{
|
|
67
|
+
fieldId: 'status',
|
|
68
|
+
fieldName: 'Status',
|
|
69
|
+
fieldValue: 'status',
|
|
70
|
+
isShow: true,
|
|
71
|
+
weight: 1,
|
|
72
|
+
render: (row) => {
|
|
73
|
+
return this.renderStatusIcon(row.status);
|
|
74
|
+
}
|
|
75
|
+
},
|
|
76
|
+
{
|
|
77
|
+
fieldId: 'duration',
|
|
78
|
+
fieldName: 'Duration',
|
|
79
|
+
isShow: true,
|
|
80
|
+
weight: 1,
|
|
81
|
+
render: (row) => {
|
|
82
|
+
return `
|
|
83
|
+
<div class="cqa-flex cqa-items-center cqa-gap-1">
|
|
84
|
+
<svg width="14" height="14" viewBox="0 0 14 14" fill="none" xmlns="http://www.w3.org/2000/svg">
|
|
85
|
+
<path d="M7.00002 12.8337C10.2217 12.8337 12.8334 10.222 12.8334 7.00033C12.8334 3.77866 10.2217 1.16699 7.00002 1.16699C3.77836 1.16699 1.16669 3.77866 1.16669 7.00033C1.16669 10.222 3.77836 12.8337 7.00002 12.8337Z" stroke="#636363" stroke-width="1.16667" stroke-linecap="round" stroke-linejoin="round"/>
|
|
86
|
+
<path d="M7 3.5V7L9.33333 8.16667" stroke="#636363" stroke-width="1.16667" stroke-linecap="round" stroke-linejoin="round"/>
|
|
87
|
+
</svg>
|
|
88
|
+
<span class="cqa-text-xs cqa-text-[#4A5565]">${this.formatDuration(row.duration)}</span>
|
|
89
|
+
</div>
|
|
90
|
+
`;
|
|
91
|
+
}
|
|
92
|
+
}
|
|
93
|
+
];
|
|
94
|
+
}
|
|
95
|
+
renderStatusIcon(status) {
|
|
96
|
+
const upperStatus = status.toUpperCase();
|
|
97
|
+
if (upperStatus === 'PASS') {
|
|
98
|
+
return `
|
|
99
|
+
<div class="cqa-flex cqa-items-center cqa-gap-1.5">
|
|
100
|
+
<svg xmlns="http://www.w3.org/2000/svg" width="16" height="16" viewBox="0 0 16 16" fill="none">
|
|
101
|
+
<circle cx="8" cy="8" r="7" stroke="#008236" stroke-width="1.5" fill="none"/>
|
|
102
|
+
<path d="M5.5 8L7 9.5L10.5 6" stroke="#008236" stroke-width="1.5" stroke-linecap="round" stroke-linejoin="round"/>
|
|
103
|
+
</svg>
|
|
104
|
+
<span class="cqa-rounded-[4px] cqa-leading-4 cqa-px-2 cqa-py-0.5 cqa-bg-[#DCFCE7] cqa-text-xs cqa-text-[#008236]">Pass</span>
|
|
105
|
+
</div>
|
|
106
|
+
`;
|
|
107
|
+
}
|
|
108
|
+
else if (upperStatus === 'FAIL') {
|
|
109
|
+
return `
|
|
110
|
+
<div class="cqa-flex cqa-items-center cqa-gap-1.5">
|
|
111
|
+
<svg xmlns="http://www.w3.org/2000/svg" width="16" height="16" viewBox="0 0 16 16" fill="none">
|
|
112
|
+
<circle cx="8" cy="8" r="7" stroke="#C10007" stroke-width="1.5" fill="none"/>
|
|
113
|
+
<path d="M10 6L6 10M6 6L10 10" stroke="#C10007" stroke-width="1.5" stroke-linecap="round" stroke-linejoin="round"/>
|
|
114
|
+
</svg>
|
|
115
|
+
<span class="cqa-rounded-[4px] cqa-leading-4 cqa-px-2 cqa-py-0.5 cqa-bg-[#FFE2E2] cqa-text-xs cqa-text-[#C10007]">Fail</span>
|
|
116
|
+
</div>
|
|
117
|
+
`;
|
|
118
|
+
}
|
|
119
|
+
else if (upperStatus === 'IN_PROGRESS') {
|
|
120
|
+
return `
|
|
121
|
+
<div class="cqa-flex cqa-items-center cqa-gap-1.5">
|
|
122
|
+
<svg xmlns="http://www.w3.org/2000/svg" width="16" height="16" viewBox="0 0 16 16" fill="none">
|
|
123
|
+
<circle cx="8" cy="8" r="7" stroke="#3B82F6" stroke-width="1.5" fill="none"/>
|
|
124
|
+
</svg>
|
|
125
|
+
<span class="cqa-rounded-[4px] cqa-leading-4 cqa-px-2 cqa-py-0.5 cqa-bg-[#EFF6FF] cqa-text-xs cqa-text-[#3B82F6]">In Progress</span>
|
|
126
|
+
</div>
|
|
127
|
+
`;
|
|
128
|
+
}
|
|
129
|
+
else {
|
|
130
|
+
return `<span class="cqa-rounded-[4px] cqa-leading-4 cqa-px-2 cqa-py-0.5 cqa-text-xs cqa-text-[#9CA3AF]">—</span>`;
|
|
131
|
+
}
|
|
132
|
+
}
|
|
133
|
+
formatDuration(milliseconds) {
|
|
134
|
+
const seconds = milliseconds / 1000;
|
|
135
|
+
if (seconds < 60) {
|
|
136
|
+
return `${seconds.toFixed(1)}s`;
|
|
137
|
+
}
|
|
138
|
+
const minutes = Math.floor(seconds / 60);
|
|
139
|
+
const remainingSeconds = Math.floor(seconds % 60);
|
|
140
|
+
return `${minutes}m ${remainingSeconds}s`;
|
|
141
|
+
}
|
|
142
|
+
onPageChange(event) {
|
|
143
|
+
this.pageIndex = event.pageIndex;
|
|
144
|
+
this.pageSize = event.pageSize;
|
|
145
|
+
}
|
|
146
|
+
get isEmptyState() {
|
|
147
|
+
return !this.iterations || this.iterations.length === 0;
|
|
148
|
+
}
|
|
149
|
+
get computedSummary() {
|
|
150
|
+
if (this.summary) {
|
|
151
|
+
return this.summary;
|
|
152
|
+
}
|
|
153
|
+
const passed = this.iterations.filter(i => i.status === 'PASS').length;
|
|
154
|
+
const failed = this.iterations.filter(i => i.status === 'FAIL').length;
|
|
155
|
+
return {
|
|
156
|
+
totalIterations: this.iterations.length,
|
|
157
|
+
passed,
|
|
158
|
+
failed
|
|
159
|
+
};
|
|
160
|
+
}
|
|
161
|
+
}
|
|
162
|
+
IterationsLoopComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: IterationsLoopComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
163
|
+
IterationsLoopComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.4.0", type: IterationsLoopComponent, selector: "cqa-iterations-loop", inputs: { iterations: "iterations", summary: "summary", isTableDataLoading: "isTableDataLoading" }, usesOnChanges: true, ngImport: i0, template: "<div class=\"cqa-ui-root\" style=\"display: block; width: 100%;\">\n <div class=\"cqa-flex cqa-flex-col\">\n <div class=\"cqa-bg-white\">\n <cqa-table-template\n [columns]=\"tableColumns\"\n [data]=\"iterations\"\n [pageIndex]=\"pageIndex\"\n [pageSize]=\"pageSize\"\n [isEmptyState]=\"isEmptyState\"\n [emptyStateConfig]=\"emptyStateConfig\"\n [isTableDataLoading]=\"isTableDataLoading\"\n [showSearchBar]=\"false\"\n [showFilterButton]=\"false\"\n [showSettingsButton]=\"false\"\n [showAutoRefreshButton]=\"false\"\n [showOtherButton]=\"false\"\n [showFilterPanel]=\"false\"\n [serverSidePagination]=\"false\"\n (pageChange)=\"onPageChange($event)\">\n </cqa-table-template>\n </div>\n\n <div *ngIf=\"!isEmptyState\" class=\"cqa-p-[17px] cqa-mt-6 cqa-bg-[#FBFCFF] cqa-rounded-[5px]\" style=\"border: 1px solid #E5E5E5;\">\n <h4 class=\"cqa-text-[16px] cqa-text-[#111827] cqa-mb-3\">Summary</h4>\n <div class=\"cqa-grid cqa-grid-cols-3 cqa-gap-4\">\n <div class=\"cqa-flex cqa-flex-col\">\n <span class=\"cqa-text-sm cqa-text-[#4A5565] cqa-mb-1\">Total Iterations</span>\n <span class=\"cqa-text-[22px] cqa-leading-[28px] cqa-font-semibold cqa-text-[#0B0B0B]\">{{ computedSummary.totalIterations }}</span>\n </div>\n <div class=\"cqa-flex cqa-flex-col\">\n <span class=\"cqa-text-sm cqa-text-[#4A5565] cqa-mb-1\">Passed</span>\n <span class=\"cqa-text-[22px] cqa-leading-[28px] cqa-font-semibold cqa-text-[#00C950]\">{{ computedSummary.passed }}</span>\n </div>\n <div class=\"cqa-flex cqa-flex-col\">\n <span class=\"cqa-text-sm cqa-text-[#4A5565] cqa-mb-1\">Failed</span>\n <span class=\"cqa-text-[22px] cqa-leading-[28px] cqa-font-semibold cqa-text-[#FB2C36]\">{{ computedSummary.failed }}</span>\n </div>\n </div>\n </div>\n </div>\n</div>\n\n", components: [{ type: i1.TableTemplateComponent, selector: "cqa-table-template", inputs: ["searchPlaceholder", "searchValue", "showClear", "showSearchBar", "filterConfig", "showFilterPanel", "showFilterButton", "otherButtonLabel", "otherButtonVariant", "showOtherButton", "showActionButton", "showSettingsButton", "showAutoRefreshButton", "data", "isEmptyState", "emptyStateConfig", "actions", "chips", "filterApplied", "columns", "selectedAutoRefreshInterval", "pageIndex", "pageSize", "serverSidePagination", "totalElements", "isTableLoading", "isTableDataLoading"], outputs: ["onSearchChange", "onApplyFilterClick", "onResetFilterClick", "onClearAll", "removeChip", "pageChange", "onReload", "onAutoRefreshClick"] }], directives: [{ type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] });
|
|
164
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: IterationsLoopComponent, decorators: [{
|
|
165
|
+
type: Component,
|
|
166
|
+
args: [{ selector: 'cqa-iterations-loop', template: "<div class=\"cqa-ui-root\" style=\"display: block; width: 100%;\">\n <div class=\"cqa-flex cqa-flex-col\">\n <div class=\"cqa-bg-white\">\n <cqa-table-template\n [columns]=\"tableColumns\"\n [data]=\"iterations\"\n [pageIndex]=\"pageIndex\"\n [pageSize]=\"pageSize\"\n [isEmptyState]=\"isEmptyState\"\n [emptyStateConfig]=\"emptyStateConfig\"\n [isTableDataLoading]=\"isTableDataLoading\"\n [showSearchBar]=\"false\"\n [showFilterButton]=\"false\"\n [showSettingsButton]=\"false\"\n [showAutoRefreshButton]=\"false\"\n [showOtherButton]=\"false\"\n [showFilterPanel]=\"false\"\n [serverSidePagination]=\"false\"\n (pageChange)=\"onPageChange($event)\">\n </cqa-table-template>\n </div>\n\n <div *ngIf=\"!isEmptyState\" class=\"cqa-p-[17px] cqa-mt-6 cqa-bg-[#FBFCFF] cqa-rounded-[5px]\" style=\"border: 1px solid #E5E5E5;\">\n <h4 class=\"cqa-text-[16px] cqa-text-[#111827] cqa-mb-3\">Summary</h4>\n <div class=\"cqa-grid cqa-grid-cols-3 cqa-gap-4\">\n <div class=\"cqa-flex cqa-flex-col\">\n <span class=\"cqa-text-sm cqa-text-[#4A5565] cqa-mb-1\">Total Iterations</span>\n <span class=\"cqa-text-[22px] cqa-leading-[28px] cqa-font-semibold cqa-text-[#0B0B0B]\">{{ computedSummary.totalIterations }}</span>\n </div>\n <div class=\"cqa-flex cqa-flex-col\">\n <span class=\"cqa-text-sm cqa-text-[#4A5565] cqa-mb-1\">Passed</span>\n <span class=\"cqa-text-[22px] cqa-leading-[28px] cqa-font-semibold cqa-text-[#00C950]\">{{ computedSummary.passed }}</span>\n </div>\n <div class=\"cqa-flex cqa-flex-col\">\n <span class=\"cqa-text-sm cqa-text-[#4A5565] cqa-mb-1\">Failed</span>\n <span class=\"cqa-text-[22px] cqa-leading-[28px] cqa-font-semibold cqa-text-[#FB2C36]\">{{ computedSummary.failed }}</span>\n </div>\n </div>\n </div>\n </div>\n</div>\n\n", styles: [] }]
|
|
167
|
+
}], propDecorators: { iterations: [{
|
|
168
|
+
type: Input
|
|
169
|
+
}], summary: [{
|
|
170
|
+
type: Input
|
|
171
|
+
}], isTableDataLoading: [{
|
|
172
|
+
type: Input
|
|
173
|
+
}] } });
|
|
174
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"iterations-loop.component.js","sourceRoot":"","sources":["../../../../../src/lib/iterations-loop/iterations-loop.component.ts","../../../../../src/lib/iterations-loop/iterations-loop.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnInit, OnChanges, SimpleChanges } from '@angular/core';\nimport { DynamicTableColumn } from '../table/dynamic-table/dynamic-table.component';\nimport { EmptyStateConfig } from '../empty-state/empty-state-config.interface';\nimport { EMPTY_STATE_IMAGES } from '../assets/images/image-assets.constants';\n\nexport interface IterationData {\n  index: number;\n  datasetId: string;\n  variables: Record<string, any>;\n  status: 'PASS' | 'FAIL' | 'IN_PROGRESS' | 'ABORTED';\n  duration: number;\n  [key: string]: any;\n}\n\nexport interface IterationSummary {\n  totalIterations: number;\n  passed: number;\n  failed: number;\n}\n\n@Component({\n  selector: 'cqa-iterations-loop',\n  templateUrl: './iterations-loop.component.html',\n  styleUrls: []\n})\nexport class IterationsLoopComponent implements OnInit, OnChanges {\n  @Input() iterations: IterationData[] = [];\n  @Input() summary?: IterationSummary;\n  @Input() isTableDataLoading: boolean = false;\n\n  tableColumns: DynamicTableColumn[] = [];\n  pageIndex: number = 0;\n  pageSize: number = 5;\n\n  emptyStateConfig: EmptyStateConfig = {\n    title: 'No Iterations',\n    description: 'There are no iterations to display for this loop.',\n    imageUrl: EMPTY_STATE_IMAGES.DASHBOARD,\n    actions: []\n  };\n\n  ngOnInit(): void {\n    this.setupTableColumns();\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes['iterations']) {\n      this.pageIndex = 0;\n    }\n  }\n\n  private setupTableColumns(): void {\n    this.tableColumns = [\n      {\n        fieldId: 'index',\n        fieldName: '#',\n        fieldValue: 'index',\n        isShow: true,\n        weight: 0.5,\n        render: (row: IterationData) => {\n          return `<span class=\"cqa-text-[16px] cqa-text-[#0A0A0A] cqa-font-regular\">${row.index}</span>`;\n        }\n      },\n      {\n        fieldId: 'datasetId',\n        fieldName: 'Dataset ID',\n        fieldValue: 'datasetId',\n        isShow: true,\n        weight: 1.5,\n        render: (row: IterationData) => {\n          return `<span class=\"cqa-text-sm cqa-text-[#0A0A0A] cqa-font-regular\">${row.datasetId}</span>`;\n        }\n      },\n      {\n        fieldId: 'variables',\n        fieldName: 'Variables',\n        isShow: true,\n        weight: 2,\n        render: (row: IterationData) => {\n          const variableEntries = Object.entries(row.variables || {});\n          const variablesHtml = variableEntries.map(([key, value], index) => {\n            return `<div class=\"cqa-flex cqa-items-center cqa-gap-0.5 ${index === variableEntries.length - 1 ? 'cqa-mb-0' : 'cqa-mb-1'}\">\n              <span class=\"cqa-px-1 cqa-text-[12px] cqa-text-[#4A5565] cqa-bg-[#F3F4F6] cqa-rounded-[4px]\">${key}:</span>\n              <span class=\"cqa-text-sm cqa-text-[#4A5565] cqa-font-medium\">${value}</span>\n            </div>`;\n          }).join('');\n          return `<div class=\"cqa-flex cqa-flex-col\">${variablesHtml}</div>`;\n        }\n      },\n      {\n        fieldId: 'status',\n        fieldName: 'Status',\n        fieldValue: 'status',\n        isShow: true,\n        weight: 1,\n        render: (row: IterationData) => {\n          return this.renderStatusIcon(row.status);\n        }\n      },\n      {\n        fieldId: 'duration',\n        fieldName: 'Duration',\n        isShow: true,\n        weight: 1,\n        render: (row: IterationData) => {\n          return `\n            <div class=\"cqa-flex cqa-items-center cqa-gap-1\">\n              <svg width=\"14\" height=\"14\" viewBox=\"0 0 14 14\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n                <path d=\"M7.00002 12.8337C10.2217 12.8337 12.8334 10.222 12.8334 7.00033C12.8334 3.77866 10.2217 1.16699 7.00002 1.16699C3.77836 1.16699 1.16669 3.77866 1.16669 7.00033C1.16669 10.222 3.77836 12.8337 7.00002 12.8337Z\" stroke=\"#636363\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n                <path d=\"M7 3.5V7L9.33333 8.16667\" stroke=\"#636363\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n              </svg>\n              <span class=\"cqa-text-xs cqa-text-[#4A5565]\">${this.formatDuration(row.duration)}</span>\n            </div>\n          `;\n        }\n      }\n    ];\n  }\n\n  private renderStatusIcon(status: string): string {\n    const upperStatus = status.toUpperCase();\n    if (upperStatus === 'PASS') {\n      return `\n        <div class=\"cqa-flex cqa-items-center cqa-gap-1.5\">\n          <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\">\n            <circle cx=\"8\" cy=\"8\" r=\"7\" stroke=\"#008236\" stroke-width=\"1.5\" fill=\"none\"/>\n            <path d=\"M5.5 8L7 9.5L10.5 6\" stroke=\"#008236\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n          </svg>\n          <span class=\"cqa-rounded-[4px] cqa-leading-4 cqa-px-2 cqa-py-0.5 cqa-bg-[#DCFCE7] cqa-text-xs cqa-text-[#008236]\">Pass</span>\n        </div>\n      `;\n    } else if (upperStatus === 'FAIL') {\n      return `\n        <div class=\"cqa-flex cqa-items-center cqa-gap-1.5\">\n          <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\">\n            <circle cx=\"8\" cy=\"8\" r=\"7\" stroke=\"#C10007\" stroke-width=\"1.5\" fill=\"none\"/>\n            <path d=\"M10 6L6 10M6 6L10 10\" stroke=\"#C10007\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n          </svg>\n          <span class=\"cqa-rounded-[4px] cqa-leading-4 cqa-px-2 cqa-py-0.5 cqa-bg-[#FFE2E2] cqa-text-xs cqa-text-[#C10007]\">Fail</span>\n        </div>\n      `;\n    } else if (upperStatus === 'IN_PROGRESS') {\n      return `\n        <div class=\"cqa-flex cqa-items-center cqa-gap-1.5\">\n          <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\">\n            <circle cx=\"8\" cy=\"8\" r=\"7\" stroke=\"#3B82F6\" stroke-width=\"1.5\" fill=\"none\"/>\n          </svg>\n          <span class=\"cqa-rounded-[4px] cqa-leading-4 cqa-px-2 cqa-py-0.5 cqa-bg-[#EFF6FF] cqa-text-xs cqa-text-[#3B82F6]\">In Progress</span>\n        </div>\n      `;\n    } else {\n      return `<span class=\"cqa-rounded-[4px] cqa-leading-4 cqa-px-2 cqa-py-0.5 cqa-text-xs cqa-text-[#9CA3AF]\">—</span>`;\n    }\n  }\n\n  private formatDuration(milliseconds: number): string {\n    const seconds = milliseconds / 1000;\n    if (seconds < 60) {\n      return `${seconds.toFixed(1)}s`;\n    }\n    const minutes = Math.floor(seconds / 60);\n    const remainingSeconds = Math.floor(seconds % 60);\n    return `${minutes}m ${remainingSeconds}s`;\n  }\n\n  onPageChange(event: { pageIndex: number; pageSize: number }): void {\n    this.pageIndex = event.pageIndex;\n    this.pageSize = event.pageSize;\n  }\n\n  get isEmptyState(): boolean {\n    return !this.iterations || this.iterations.length === 0;\n  }\n\n  get computedSummary(): IterationSummary {\n    if (this.summary) {\n      return this.summary;\n    }\n    \n    const passed = this.iterations.filter(i => i.status === 'PASS').length;\n    const failed = this.iterations.filter(i => i.status === 'FAIL').length;\n    \n    return {\n      totalIterations: this.iterations.length,\n      passed,\n      failed\n    };\n  }\n}\n\n","<div class=\"cqa-ui-root\" style=\"display: block; width: 100%;\">\n  <div class=\"cqa-flex cqa-flex-col\">\n    <div class=\"cqa-bg-white\">\n      <cqa-table-template\n        [columns]=\"tableColumns\"\n        [data]=\"iterations\"\n        [pageIndex]=\"pageIndex\"\n        [pageSize]=\"pageSize\"\n        [isEmptyState]=\"isEmptyState\"\n        [emptyStateConfig]=\"emptyStateConfig\"\n        [isTableDataLoading]=\"isTableDataLoading\"\n        [showSearchBar]=\"false\"\n        [showFilterButton]=\"false\"\n        [showSettingsButton]=\"false\"\n        [showAutoRefreshButton]=\"false\"\n        [showOtherButton]=\"false\"\n        [showFilterPanel]=\"false\"\n        [serverSidePagination]=\"false\"\n        (pageChange)=\"onPageChange($event)\">\n      </cqa-table-template>\n    </div>\n\n    <div *ngIf=\"!isEmptyState\" class=\"cqa-p-[17px] cqa-mt-6 cqa-bg-[#FBFCFF] cqa-rounded-[5px]\" style=\"border: 1px solid #E5E5E5;\">\n      <h4 class=\"cqa-text-[16px] cqa-text-[#111827] cqa-mb-3\">Summary</h4>\n      <div class=\"cqa-grid cqa-grid-cols-3 cqa-gap-4\">\n        <div class=\"cqa-flex cqa-flex-col\">\n          <span class=\"cqa-text-sm cqa-text-[#4A5565] cqa-mb-1\">Total Iterations</span>\n          <span class=\"cqa-text-[22px] cqa-leading-[28px] cqa-font-semibold cqa-text-[#0B0B0B]\">{{ computedSummary.totalIterations }}</span>\n        </div>\n        <div class=\"cqa-flex cqa-flex-col\">\n          <span class=\"cqa-text-sm cqa-text-[#4A5565] cqa-mb-1\">Passed</span>\n          <span class=\"cqa-text-[22px] cqa-leading-[28px] cqa-font-semibold cqa-text-[#00C950]\">{{ computedSummary.passed }}</span>\n        </div>\n        <div class=\"cqa-flex cqa-flex-col\">\n          <span class=\"cqa-text-sm cqa-text-[#4A5565] cqa-mb-1\">Failed</span>\n          <span class=\"cqa-text-[22px] cqa-leading-[28px] cqa-font-semibold cqa-text-[#FB2C36]\">{{ computedSummary.failed }}</span>\n        </div>\n      </div>\n    </div>\n  </div>\n</div>\n\n"]}
|
|
@@ -58,6 +58,8 @@ import { RunHistoryCardComponent } from './run-history-card/run-history-card.com
|
|
|
58
58
|
import { ViewImageModalComponent } from './view-image-modal/view-image-modal.component';
|
|
59
59
|
import { ConfigurationCardComponent } from './configuration-card/configuration-card.component';
|
|
60
60
|
import { CompareRunsComponent } from './compare-runs/compare-runs.component';
|
|
61
|
+
import { IterationsLoopComponent } from './iterations-loop/iterations-loop.component';
|
|
62
|
+
import { FailedStepCardComponent } from './failed-step-card/failed-step-card.component';
|
|
61
63
|
import * as i0 from "@angular/core";
|
|
62
64
|
import * as i1 from "@angular/material/icon";
|
|
63
65
|
export class UiKitModule {
|
|
@@ -107,7 +109,9 @@ UiKitModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "1
|
|
|
107
109
|
RunHistoryCardComponent,
|
|
108
110
|
ViewImageModalComponent,
|
|
109
111
|
ConfigurationCardComponent,
|
|
110
|
-
CompareRunsComponent
|
|
112
|
+
CompareRunsComponent,
|
|
113
|
+
IterationsLoopComponent,
|
|
114
|
+
FailedStepCardComponent], imports: [CommonModule,
|
|
111
115
|
FormsModule,
|
|
112
116
|
ReactiveFormsModule,
|
|
113
117
|
MatIconModule,
|
|
@@ -163,7 +167,9 @@ UiKitModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "1
|
|
|
163
167
|
RunHistoryCardComponent,
|
|
164
168
|
ViewImageModalComponent,
|
|
165
169
|
ConfigurationCardComponent,
|
|
166
|
-
CompareRunsComponent
|
|
170
|
+
CompareRunsComponent,
|
|
171
|
+
IterationsLoopComponent,
|
|
172
|
+
FailedStepCardComponent] });
|
|
167
173
|
UiKitModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: UiKitModule, providers: [
|
|
168
174
|
{ provide: OverlayContainer, useClass: TailwindOverlayContainer }
|
|
169
175
|
], imports: [[
|
|
@@ -230,7 +236,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImpor
|
|
|
230
236
|
RunHistoryCardComponent,
|
|
231
237
|
ViewImageModalComponent,
|
|
232
238
|
ConfigurationCardComponent,
|
|
233
|
-
CompareRunsComponent
|
|
239
|
+
CompareRunsComponent,
|
|
240
|
+
IterationsLoopComponent,
|
|
241
|
+
FailedStepCardComponent
|
|
234
242
|
],
|
|
235
243
|
imports: [
|
|
236
244
|
CommonModule,
|
|
@@ -292,11 +300,13 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImpor
|
|
|
292
300
|
RunHistoryCardComponent,
|
|
293
301
|
ViewImageModalComponent,
|
|
294
302
|
ConfigurationCardComponent,
|
|
295
|
-
CompareRunsComponent
|
|
303
|
+
CompareRunsComponent,
|
|
304
|
+
IterationsLoopComponent,
|
|
305
|
+
FailedStepCardComponent
|
|
296
306
|
],
|
|
297
307
|
providers: [
|
|
298
308
|
{ provide: OverlayContainer, useClass: TailwindOverlayContainer }
|
|
299
309
|
]
|
|
300
310
|
}]
|
|
301
311
|
}], ctorParameters: function () { return [{ type: i1.MatIconRegistry }]; } });
|
|
302
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ui-kit.module.js","sourceRoot":"","sources":["../../../../src/lib/ui-kit.module.ts"],"names":[],"mappings":"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","sourcesContent":["import { NgModule } from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { FormsModule } from '@angular/forms';\nimport { MatIconModule } from '@angular/material/icon';\nimport { MatIconRegistry } from '@angular/material/icon';\nimport { MatMenuModule } from '@angular/material/menu';\nimport { MatButtonModule } from '@angular/material/button';\nimport { MatFormFieldModule } from '@angular/material/form-field';\nimport { MatSelectModule } from '@angular/material/select';\nimport { MatOptionModule } from '@angular/material/core';\nimport { MatCheckboxModule } from '@angular/material/checkbox';\nimport { MatRadioModule } from '@angular/material/radio';\nimport { MatDatepickerModule } from '@angular/material/datepicker';\nimport { MatNativeDateModule } from '@angular/material/core';\nimport { MatProgressSpinnerModule } from '@angular/material/progress-spinner';\nimport { MatTooltipModule } from '@angular/material/tooltip';\nimport { OverlayModule, OverlayContainer } from '@angular/cdk/overlay';\nimport { PortalModule } from '@angular/cdk/portal';\nimport { ReactiveFormsModule } from '@angular/forms';\nimport { ButtonComponent } from './button/button.component';\nimport { SearchBarComponent } from './search-bar/search-bar.component';\nimport { SegmentControlComponent } from './segment-control/segment-control.component';\nimport { DialogComponent } from './dialog/dialog.component';\nimport { DynamicTableComponent } from './table/dynamic-table/dynamic-table.component';\nimport { DynamicCellTemplateDirective, DynamicHeaderTemplateDirective } from './table/dynamic-table/dynamic-cell.directive';\nimport { DynamicCellContainerDirective } from './table/dynamic-table/dynamic-cell-container.directive';\nimport { PaginationComponent } from './pagination/pagination.component';\nimport { ActionMenuButtonComponent } from './action-menu/action-menu.component';\nimport { OtherButtonComponent } from './other-button/other-button.component';\nimport { DynamicFilterComponent } from './filters/dynamic-filter/dynamic-filter.component';\nimport { DaterangepickerDirective } from './filters/daterangepicker/daterangepicker.directive';\nimport { DaterangepickerComponent } from './filters/daterangepicker/daterangepicker.component';\nimport { ColumnVisibilityComponent } from './column-visibility/column-visibility.component';\nimport { TableActionToolbarComponent } from './table-action-toolbar/table-action-toolbar.component';\nimport { MetricsCardComponent } from './dashboards/metrics-card/metrics-card.component';\nimport { MetricsBlockComponent } from './dashboards/metrics-card/metrics-block.component';\nimport { ChartCardComponent } from './dashboards/chart-card/chart-card.component';\nimport { ProgressTextCardComponent } from './dashboards/progress-text-card/progress-text-card.component';\nimport { DashboardHeaderComponent } from './dashboards/dashboard-header/dashboard-header.component';\nimport { CoverageModuleCardComponent } from './dashboards/coverage-module-card/coverage-module-card.component';\nimport { TestDistributionCardComponent } from './dashboards/test-distribution-card/test-distribution-card.component';\nimport { FailedTestCasesCardComponent } from './dashboards/failed-test-cases-card/failed-test-cases-card.component';\nimport { DynamicSelectFieldComponent } from './dynamic-select/dynamic-select-field.component';\nimport { SelectedFiltersComponent } from './selected-filters/selected-filters.component';\nimport { InsightCardComponent } from './dashboards/insight-card/insight-card.component';\nimport { BadgeComponent } from './badge/badge.component';\nimport { DropdownButtonComponent } from './dropdown-button/dropdown-button.component';\nimport { HeatErrorMapCellComponent } from './dashboards/heat-error-map-cell/heat-error-map-cell.component';\nimport { EmptyStateComponent } from './empty-state/empty-state.component';\nimport { TableTemplateComponent } from './templates/table-template.component';\nimport { TailwindOverlayContainer } from './utils/tw-overlay-container';\nimport { FullTableLoaderComponent } from './full-table-loader/full-table-loader.component';\nimport { TableDataLoaderComponent } from './table-data-loader/table-data-loader.component';\nimport { SimulatorComponent } from './simulator/simulator.component';\nimport { ConsoleAlertComponent } from './console-alert/console-alert.component';\nimport { AiDebugAlertComponent } from './ai-debug-alert/ai-debug-alert.component';\nimport { NetworkRequestComponent } from './network-request/network-request.component';\nimport { RunHistoryCardComponent } from './run-history-card/run-history-card.component';\nimport { ViewImageModalComponent } from './view-image-modal/view-image-modal.component';\nimport { ConfigurationCardComponent } from './configuration-card/configuration-card.component';\nimport { CompareRunsComponent } from './compare-runs/compare-runs.component';\n\n@NgModule({\n  declarations: [\n    ButtonComponent,\n    SearchBarComponent,\n    SegmentControlComponent,\n    DialogComponent,\n    DynamicTableComponent,\n    DynamicCellTemplateDirective,\n    DynamicHeaderTemplateDirective,\n    DynamicCellContainerDirective,\n    PaginationComponent,\n    ActionMenuButtonComponent,\n    OtherButtonComponent,\n    DynamicFilterComponent,\n    DaterangepickerDirective,\n    DaterangepickerComponent,\n    ColumnVisibilityComponent,\n    TableActionToolbarComponent,\n    MetricsCardComponent,\n    MetricsBlockComponent,\n    ChartCardComponent,\n    ProgressTextCardComponent,\n    DashboardHeaderComponent,\n    CoverageModuleCardComponent,\n    TestDistributionCardComponent,\n    FailedTestCasesCardComponent,\n    DynamicSelectFieldComponent,\n    SelectedFiltersComponent,\n    InsightCardComponent,\n    BadgeComponent,\n    DropdownButtonComponent,\n    HeatErrorMapCellComponent,\n    EmptyStateComponent,\n    TableTemplateComponent,\n    FullTableLoaderComponent,\n    TableDataLoaderComponent,\n    SimulatorComponent,\n    ConsoleAlertComponent,\n    AiDebugAlertComponent,\n    NetworkRequestComponent,\n    RunHistoryCardComponent,\n    ViewImageModalComponent,\n    ConfigurationCardComponent,\n    CompareRunsComponent\n  ],\n  imports: [\n    CommonModule,\n    FormsModule,\n    ReactiveFormsModule,\n    MatIconModule,\n    MatMenuModule,\n    MatButtonModule,\n    MatFormFieldModule,\n    MatSelectModule,\n    MatOptionModule,\n    MatCheckboxModule,\n    MatRadioModule,\n    MatDatepickerModule,\n    MatNativeDateModule,\n    MatProgressSpinnerModule,\n    MatTooltipModule,\n    OverlayModule,\n    PortalModule\n  ],\n  exports: [\n    ButtonComponent,\n    SearchBarComponent,\n    SegmentControlComponent,\n    DialogComponent,\n    DynamicTableComponent,\n    DynamicCellTemplateDirective,\n    DynamicHeaderTemplateDirective,\n    DynamicCellContainerDirective,\n    PaginationComponent,\n    ActionMenuButtonComponent,\n    OtherButtonComponent,\n    DynamicFilterComponent,\n    DaterangepickerDirective,\n    DaterangepickerComponent,\n    ColumnVisibilityComponent,\n    TableActionToolbarComponent,\n    MetricsCardComponent,\n    ChartCardComponent,\n    ProgressTextCardComponent,\n    DashboardHeaderComponent,\n    CoverageModuleCardComponent,\n    TestDistributionCardComponent,\n    FailedTestCasesCardComponent,\n    DynamicSelectFieldComponent,\n    SelectedFiltersComponent,\n    InsightCardComponent,\n    BadgeComponent,\n    DropdownButtonComponent,\n    HeatErrorMapCellComponent,\n    EmptyStateComponent,\n    TableTemplateComponent,\n    FullTableLoaderComponent,\n    TableDataLoaderComponent,\n    SimulatorComponent,\n    ConsoleAlertComponent,\n    AiDebugAlertComponent,\n    NetworkRequestComponent,\n    RunHistoryCardComponent,\n    ViewImageModalComponent,\n    ConfigurationCardComponent,\n    CompareRunsComponent\n  ],\n  providers: [\n    { provide: OverlayContainer, useClass: TailwindOverlayContainer }\n  ]\n})\nexport class UiKitModule {\n  constructor(iconRegistry: MatIconRegistry) {\n    iconRegistry.registerFontClassAlias('material-symbols-outlined', 'material-symbols-outlined');\n  }\n}\n\n"]}
|
|
312
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ui-kit.module.js","sourceRoot":"","sources":["../../../../src/lib/ui-kit.module.ts"],"names":[],"mappings":"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","sourcesContent":["import { NgModule } from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { FormsModule } from '@angular/forms';\nimport { MatIconModule } from '@angular/material/icon';\nimport { MatIconRegistry } from '@angular/material/icon';\nimport { MatMenuModule } from '@angular/material/menu';\nimport { MatButtonModule } from '@angular/material/button';\nimport { MatFormFieldModule } from '@angular/material/form-field';\nimport { MatSelectModule } from '@angular/material/select';\nimport { MatOptionModule } from '@angular/material/core';\nimport { MatCheckboxModule } from '@angular/material/checkbox';\nimport { MatRadioModule } from '@angular/material/radio';\nimport { MatDatepickerModule } from '@angular/material/datepicker';\nimport { MatNativeDateModule } from '@angular/material/core';\nimport { MatProgressSpinnerModule } from '@angular/material/progress-spinner';\nimport { MatTooltipModule } from '@angular/material/tooltip';\nimport { OverlayModule, OverlayContainer } from '@angular/cdk/overlay';\nimport { PortalModule } from '@angular/cdk/portal';\nimport { ReactiveFormsModule } from '@angular/forms';\nimport { ButtonComponent } from './button/button.component';\nimport { SearchBarComponent } from './search-bar/search-bar.component';\nimport { SegmentControlComponent } from './segment-control/segment-control.component';\nimport { DialogComponent } from './dialog/dialog.component';\nimport { DynamicTableComponent } from './table/dynamic-table/dynamic-table.component';\nimport { DynamicCellTemplateDirective, DynamicHeaderTemplateDirective } from './table/dynamic-table/dynamic-cell.directive';\nimport { DynamicCellContainerDirective } from './table/dynamic-table/dynamic-cell-container.directive';\nimport { PaginationComponent } from './pagination/pagination.component';\nimport { ActionMenuButtonComponent } from './action-menu/action-menu.component';\nimport { OtherButtonComponent } from './other-button/other-button.component';\nimport { DynamicFilterComponent } from './filters/dynamic-filter/dynamic-filter.component';\nimport { DaterangepickerDirective } from './filters/daterangepicker/daterangepicker.directive';\nimport { DaterangepickerComponent } from './filters/daterangepicker/daterangepicker.component';\nimport { ColumnVisibilityComponent } from './column-visibility/column-visibility.component';\nimport { TableActionToolbarComponent } from './table-action-toolbar/table-action-toolbar.component';\nimport { MetricsCardComponent } from './dashboards/metrics-card/metrics-card.component';\nimport { MetricsBlockComponent } from './dashboards/metrics-card/metrics-block.component';\nimport { ChartCardComponent } from './dashboards/chart-card/chart-card.component';\nimport { ProgressTextCardComponent } from './dashboards/progress-text-card/progress-text-card.component';\nimport { DashboardHeaderComponent } from './dashboards/dashboard-header/dashboard-header.component';\nimport { CoverageModuleCardComponent } from './dashboards/coverage-module-card/coverage-module-card.component';\nimport { TestDistributionCardComponent } from './dashboards/test-distribution-card/test-distribution-card.component';\nimport { FailedTestCasesCardComponent } from './dashboards/failed-test-cases-card/failed-test-cases-card.component';\nimport { DynamicSelectFieldComponent } from './dynamic-select/dynamic-select-field.component';\nimport { SelectedFiltersComponent } from './selected-filters/selected-filters.component';\nimport { InsightCardComponent } from './dashboards/insight-card/insight-card.component';\nimport { BadgeComponent } from './badge/badge.component';\nimport { DropdownButtonComponent } from './dropdown-button/dropdown-button.component';\nimport { HeatErrorMapCellComponent } from './dashboards/heat-error-map-cell/heat-error-map-cell.component';\nimport { EmptyStateComponent } from './empty-state/empty-state.component';\nimport { TableTemplateComponent } from './templates/table-template.component';\nimport { TailwindOverlayContainer } from './utils/tw-overlay-container';\nimport { FullTableLoaderComponent } from './full-table-loader/full-table-loader.component';\nimport { TableDataLoaderComponent } from './table-data-loader/table-data-loader.component';\nimport { SimulatorComponent } from './simulator/simulator.component';\nimport { ConsoleAlertComponent } from './console-alert/console-alert.component';\nimport { AiDebugAlertComponent } from './ai-debug-alert/ai-debug-alert.component';\nimport { NetworkRequestComponent } from './network-request/network-request.component';\nimport { RunHistoryCardComponent } from './run-history-card/run-history-card.component';\nimport { ViewImageModalComponent } from './view-image-modal/view-image-modal.component';\nimport { ConfigurationCardComponent } from './configuration-card/configuration-card.component';\nimport { CompareRunsComponent } from './compare-runs/compare-runs.component';\nimport { IterationsLoopComponent } from './iterations-loop/iterations-loop.component';\nimport { FailedStepCardComponent } from './failed-step-card/failed-step-card.component';\n\n@NgModule({\n  declarations: [\n    ButtonComponent,\n    SearchBarComponent,\n    SegmentControlComponent,\n    DialogComponent,\n    DynamicTableComponent,\n    DynamicCellTemplateDirective,\n    DynamicHeaderTemplateDirective,\n    DynamicCellContainerDirective,\n    PaginationComponent,\n    ActionMenuButtonComponent,\n    OtherButtonComponent,\n    DynamicFilterComponent,\n    DaterangepickerDirective,\n    DaterangepickerComponent,\n    ColumnVisibilityComponent,\n    TableActionToolbarComponent,\n    MetricsCardComponent,\n    MetricsBlockComponent,\n    ChartCardComponent,\n    ProgressTextCardComponent,\n    DashboardHeaderComponent,\n    CoverageModuleCardComponent,\n    TestDistributionCardComponent,\n    FailedTestCasesCardComponent,\n    DynamicSelectFieldComponent,\n    SelectedFiltersComponent,\n    InsightCardComponent,\n    BadgeComponent,\n    DropdownButtonComponent,\n    HeatErrorMapCellComponent,\n    EmptyStateComponent,\n    TableTemplateComponent,\n    FullTableLoaderComponent,\n    TableDataLoaderComponent,\n    SimulatorComponent,\n    ConsoleAlertComponent,\n    AiDebugAlertComponent,\n    NetworkRequestComponent,\n    RunHistoryCardComponent,\n    ViewImageModalComponent,\n    ConfigurationCardComponent,\n    CompareRunsComponent,\n    IterationsLoopComponent,\n    FailedStepCardComponent\n  ],\n  imports: [\n    CommonModule,\n    FormsModule,\n    ReactiveFormsModule,\n    MatIconModule,\n    MatMenuModule,\n    MatButtonModule,\n    MatFormFieldModule,\n    MatSelectModule,\n    MatOptionModule,\n    MatCheckboxModule,\n    MatRadioModule,\n    MatDatepickerModule,\n    MatNativeDateModule,\n    MatProgressSpinnerModule,\n    MatTooltipModule,\n    OverlayModule,\n    PortalModule\n  ],\n  exports: [\n    ButtonComponent,\n    SearchBarComponent,\n    SegmentControlComponent,\n    DialogComponent,\n    DynamicTableComponent,\n    DynamicCellTemplateDirective,\n    DynamicHeaderTemplateDirective,\n    DynamicCellContainerDirective,\n    PaginationComponent,\n    ActionMenuButtonComponent,\n    OtherButtonComponent,\n    DynamicFilterComponent,\n    DaterangepickerDirective,\n    DaterangepickerComponent,\n    ColumnVisibilityComponent,\n    TableActionToolbarComponent,\n    MetricsCardComponent,\n    ChartCardComponent,\n    ProgressTextCardComponent,\n    DashboardHeaderComponent,\n    CoverageModuleCardComponent,\n    TestDistributionCardComponent,\n    FailedTestCasesCardComponent,\n    DynamicSelectFieldComponent,\n    SelectedFiltersComponent,\n    InsightCardComponent,\n    BadgeComponent,\n    DropdownButtonComponent,\n    HeatErrorMapCellComponent,\n    EmptyStateComponent,\n    TableTemplateComponent,\n    FullTableLoaderComponent,\n    TableDataLoaderComponent,\n    SimulatorComponent,\n    ConsoleAlertComponent,\n    AiDebugAlertComponent,\n    NetworkRequestComponent,\n    RunHistoryCardComponent,\n    ViewImageModalComponent,\n    ConfigurationCardComponent,\n    CompareRunsComponent,\n    IterationsLoopComponent,\n    FailedStepCardComponent\n  ],\n  providers: [\n    { provide: OverlayContainer, useClass: TailwindOverlayContainer }\n  ]\n})\nexport class UiKitModule {\n  constructor(iconRegistry: MatIconRegistry) {\n    iconRegistry.registerFontClassAlias('material-symbols-outlined', 'material-symbols-outlined');\n  }\n}\n\n"]}
|
package/esm2020/public-api.mjs
CHANGED
|
@@ -49,4 +49,6 @@ export * from './lib/run-history-card/run-history-card.component';
|
|
|
49
49
|
export * from './lib/view-image-modal/view-image-modal.component';
|
|
50
50
|
export * from './lib/configuration-card/configuration-card.component';
|
|
51
51
|
export * from './lib/compare-runs/compare-runs.component';
|
|
52
|
-
|
|
52
|
+
export * from './lib/iterations-loop/iterations-loop.component';
|
|
53
|
+
export * from './lib/failed-step-card/failed-step-card.component';
|
|
54
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9wdWJsaWMtYXBpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMscUJBQXFCLENBQUM7QUFDcEMsY0FBYywrQkFBK0IsQ0FBQztBQUM5QyxjQUFjLHVDQUF1QyxDQUFDO0FBQ3RELGNBQWMsaURBQWlELENBQUM7QUFDaEUsY0FBYywrQkFBK0IsQ0FBQztBQUM5QyxjQUFjLDZCQUE2QixDQUFDO0FBQzVDLGNBQWMsNEJBQTRCLENBQUM7QUFDM0MsY0FBYyw0QkFBNEIsQ0FBQztBQUMzQyxjQUFjLHlCQUF5QixDQUFDO0FBQ3hDLGNBQWMsbURBQW1ELENBQUM7QUFDbEUsY0FBYyxrREFBa0QsQ0FBQztBQUNqRSxjQUFjLDREQUE0RCxDQUFDO0FBQzNFLGNBQWMsNkRBQTZELENBQUM7QUFDNUUsY0FBYyx1Q0FBdUMsQ0FBQztBQUN0RCxjQUFjLHlDQUF5QyxDQUFDO0FBQ3hELGNBQWMsMkNBQTJDLENBQUM7QUFDMUQsY0FBYyx1REFBdUQsQ0FBQztBQUN0RSxjQUFjLHlEQUF5RCxDQUFDO0FBQ3hFLGNBQWMseURBQXlELENBQUM7QUFDeEUsY0FBYyxxREFBcUQsQ0FBQztBQUNwRSxjQUFjLDJEQUEyRCxDQUFDO0FBQzFFLGNBQWMsc0RBQXNELENBQUM7QUFDckUsY0FBYyxrREFBa0QsQ0FBQztBQUNqRSxjQUFjLGtFQUFrRSxDQUFDO0FBQ2pGLGNBQWMsOERBQThELENBQUM7QUFDN0UsY0FBYyxzRUFBc0UsQ0FBQztBQUNyRixjQUFjLDBFQUEwRSxDQUFDO0FBQ3pGLGNBQWMsMEVBQTBFLENBQUM7QUFDekYsY0FBYyxxREFBcUQsQ0FBQztBQUNwRSxjQUFjLG1EQUFtRCxDQUFDO0FBQ2xFLGNBQWMsc0RBQXNELENBQUM7QUFDckUsY0FBYyw2QkFBNkIsQ0FBQztBQUM1QyxjQUFjLGlEQUFpRCxDQUFDO0FBQ2hFLGNBQWMsb0VBQW9FLENBQUM7QUFDbkYsY0FBYyx5Q0FBeUMsQ0FBQztBQUN4RCxjQUFjLGlEQUFpRCxDQUFDO0FBQ2hFLGNBQWMsZ0RBQWdELENBQUM7QUFDL0QsY0FBYywwQ0FBMEMsQ0FBQztBQUN6RCxjQUFjLDRDQUE0QyxDQUFDO0FBQzNELGNBQWMsa0NBQWtDLENBQUM7QUFDakQsY0FBYyxxREFBcUQsQ0FBQztBQUNwRSxjQUFjLHFEQUFxRCxDQUFDO0FBQ3BFLGNBQWMsa0NBQWtDLENBQUM7QUFDakQsY0FBYyxxQ0FBcUMsQ0FBQztBQUNwRCxjQUFjLDZDQUE2QyxDQUFDO0FBQzVELGNBQWMsK0NBQStDLENBQUM7QUFDOUQsY0FBYyxpREFBaUQsQ0FBQztBQUNoRSxjQUFjLG1EQUFtRCxDQUFDO0FBQ2xFLGNBQWMsbURBQW1ELENBQUM7QUFDbEUsY0FBYyx1REFBdUQsQ0FBQztBQUN0RSxjQUFjLDJDQUEyQyxDQUFDO0FBQzFELGNBQWMsaURBQWlELENBQUM7QUFDaEUsY0FBYyxtREFBbUQsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vbGliL3VpLWtpdC5tb2R1bGUnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvYnV0dG9uL2J1dHRvbi5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvc2VhcmNoLWJhci9zZWFyY2gtYmFyLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9zZWdtZW50LWNvbnRyb2wvc2VnbWVudC1jb250cm9sLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9kaWFsb2cvZGlhbG9nLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9kaWFsb2cvZGlhbG9nLnNlcnZpY2UnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZGlhbG9nL2RpYWxvZy5tb2RlbHMnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZGlhbG9nL2RpYWxvZy50b2tlbnMnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZGlhbG9nL2RpYWxvZy1yZWYnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvdGFibGUvZHluYW1pYy10YWJsZS9keW5hbWljLXRhYmxlLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi90YWJsZS9keW5hbWljLXRhYmxlL2R5bmFtaWMtY2VsbC5kaXJlY3RpdmUnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvdGFibGUvZHluYW1pYy10YWJsZS9keW5hbWljLWNlbGwtY29udGFpbmVyLmRpcmVjdGl2ZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi90YWJsZS9keW5hbWljLXRhYmxlL2NvbXBvbmVudC1yZW5kZXItY29uZmlnLmludGVyZmFjZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9wYWdpbmF0aW9uL3BhZ2luYXRpb24uY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2FjdGlvbi1tZW51L2FjdGlvbi1tZW51LmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9vdGhlci1idXR0b24vb3RoZXItYnV0dG9uLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9maWx0ZXJzL2R5bmFtaWMtZmlsdGVyL2R5bmFtaWMtZmlsdGVyLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9maWx0ZXJzL2RhdGVyYW5nZXBpY2tlci9kYXRlcmFuZ2VwaWNrZXIuZGlyZWN0aXZlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2ZpbHRlcnMvZGF0ZXJhbmdlcGlja2VyL2RhdGVyYW5nZXBpY2tlci5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29sdW1uLXZpc2liaWxpdHkvY29sdW1uLXZpc2liaWxpdHkuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3RhYmxlLWFjdGlvbi10b29sYmFyL3RhYmxlLWFjdGlvbi10b29sYmFyLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9kYXNoYm9hcmRzL21ldHJpY3MtY2FyZC9tZXRyaWNzLWNhcmQuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2Rhc2hib2FyZHMvY2hhcnQtY2FyZC9jaGFydC1jYXJkLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9kYXNoYm9hcmRzL3Byb2dyZXNzLXRleHQtY2FyZC9wcm9ncmVzcy10ZXh0LWNhcmQuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2Rhc2hib2FyZHMvZGFzaGJvYXJkLWhlYWRlci9kYXNoYm9hcmQtaGVhZGVyLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9kYXNoYm9hcmRzL2NvdmVyYWdlLW1vZHVsZS1jYXJkL2NvdmVyYWdlLW1vZHVsZS1jYXJkLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9kYXNoYm9hcmRzL3Rlc3QtZGlzdHJpYnV0aW9uLWNhcmQvdGVzdC1kaXN0cmlidXRpb24tY2FyZC5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZGFzaGJvYXJkcy9mYWlsZWQtdGVzdC1jYXNlcy1jYXJkL2ZhaWxlZC10ZXN0LWNhc2VzLWNhcmQuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2R5bmFtaWMtc2VsZWN0L2R5bmFtaWMtc2VsZWN0LWZpZWxkLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9zZWxlY3RlZC1maWx0ZXJzL3NlbGVjdGVkLWZpbHRlcnMuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2Rhc2hib2FyZHMvaW5zaWdodC1jYXJkL2luc2lnaHQtY2FyZC5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvYmFkZ2UvYmFkZ2UuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2Ryb3Bkb3duLWJ1dHRvbi9kcm9wZG93bi1idXR0b24uY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2Rhc2hib2FyZHMvaGVhdC1lcnJvci1tYXAtY2VsbC9oZWF0LWVycm9yLW1hcC1jZWxsLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9lbXB0eS1zdGF0ZS9lbXB0eS1zdGF0ZS5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZW1wdHktc3RhdGUvZW1wdHktc3RhdGUtcHJlc2V0cy5jb25zdGFudHMnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZW1wdHktc3RhdGUvZW1wdHktc3RhdGUtY29uZmlnLmludGVyZmFjZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi90ZW1wbGF0ZXMvdGFibGUtdGVtcGxhdGUuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2Fzc2V0cy9pbWFnZXMvaW1hZ2UtYXNzZXRzLmNvbnN0YW50cyc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi91dGlscy9tZXRhZGF0YS1jb2xvcnMudXRpbCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9mdWxsLXRhYmxlLWxvYWRlci9mdWxsLXRhYmxlLWxvYWRlci5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvdGFibGUtZGF0YS1sb2FkZXIvdGFibGUtZGF0YS1sb2FkZXIuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3V0aWxzL3R3LW92ZXJsYXktY29udGFpbmVyJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3NpbXVsYXRvci9zaW11bGF0b3IuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbnNvbGUtYWxlcnQvY29uc29sZS1hbGVydC5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvYWktZGVidWctYWxlcnQvYWktZGVidWctYWxlcnQuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL25ldHdvcmstcmVxdWVzdC9uZXR3b3JrLXJlcXVlc3QuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3J1bi1oaXN0b3J5LWNhcmQvcnVuLWhpc3RvcnktY2FyZC5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvdmlldy1pbWFnZS1tb2RhbC92aWV3LWltYWdlLW1vZGFsLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb25maWd1cmF0aW9uLWNhcmQvY29uZmlndXJhdGlvbi1jYXJkLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wYXJlLXJ1bnMvY29tcGFyZS1ydW5zLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9pdGVyYXRpb25zLWxvb3AvaXRlcmF0aW9ucy1sb29wLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9mYWlsZWQtc3RlcC1jYXJkL2ZhaWxlZC1zdGVwLWNhcmQuY29tcG9uZW50JztcbiJdfQ==
|