@cqa-lib/cqa-ui 1.1.5 → 1.1.7
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/badge/badge.component.mjs +19 -5
- package/esm2020/lib/compare-runs/compare-runs.component.mjs +5 -4
- package/esm2020/lib/custom-input/custom-input.component.mjs +137 -0
- package/esm2020/lib/failed-step-card/failed-step-card.component.mjs +4 -36
- package/esm2020/lib/run-history-card/run-history-card.component.mjs +5 -4
- package/esm2020/lib/table/dynamic-table/dynamic-table.component.mjs +3 -3
- package/esm2020/lib/ui-kit.module.mjs +10 -5
- package/esm2020/public-api.mjs +2 -1
- package/fesm2015/cqa-lib-cqa-ui.mjs +173 -47
- package/fesm2015/cqa-lib-cqa-ui.mjs.map +1 -1
- package/fesm2020/cqa-lib-cqa-ui.mjs +171 -47
- package/fesm2020/cqa-lib-cqa-ui.mjs.map +1 -1
- package/lib/badge/badge.component.d.ts +1 -1
- package/lib/compare-runs/compare-runs.component.d.ts +2 -0
- package/lib/custom-input/custom-input.component.d.ts +39 -0
- package/lib/failed-step-card/failed-step-card.component.d.ts +1 -12
- package/lib/table/dynamic-table/dynamic-table.component.d.ts +1 -0
- package/lib/ui-kit.module.d.ts +17 -16
- package/package.json +1 -1
- package/public-api.d.ts +1 -0
- package/styles.css +1 -1
|
@@ -0,0 +1,137 @@
|
|
|
1
|
+
import { Component, EventEmitter, Input, Output } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
import * as i1 from "@angular/common";
|
|
4
|
+
export class CustomInputComponent {
|
|
5
|
+
constructor() {
|
|
6
|
+
this.label = '';
|
|
7
|
+
this.type = 'text';
|
|
8
|
+
this.placeholder = '';
|
|
9
|
+
this.value = '';
|
|
10
|
+
this.disabled = false;
|
|
11
|
+
this.errors = [];
|
|
12
|
+
this.required = false;
|
|
13
|
+
this.ariaLabel = '';
|
|
14
|
+
this.size = 'md';
|
|
15
|
+
this.fullWidth = false;
|
|
16
|
+
this.showCharCount = false;
|
|
17
|
+
this.valueChange = new EventEmitter();
|
|
18
|
+
this.blurred = new EventEmitter();
|
|
19
|
+
this.focused = new EventEmitter();
|
|
20
|
+
this.enterPressed = new EventEmitter();
|
|
21
|
+
this.inputValue = '';
|
|
22
|
+
this.isFocused = false;
|
|
23
|
+
}
|
|
24
|
+
ngOnChanges(changes) {
|
|
25
|
+
if (changes['value'] && changes['value'].currentValue !== undefined) {
|
|
26
|
+
let newValue = changes['value'].currentValue ?? '';
|
|
27
|
+
if (this.maxLength && newValue.length > this.maxLength) {
|
|
28
|
+
newValue = newValue.substring(0, this.maxLength);
|
|
29
|
+
}
|
|
30
|
+
if (newValue !== this.inputValue) {
|
|
31
|
+
this.inputValue = newValue;
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
get hasError() {
|
|
36
|
+
return this.errors && this.errors.length > 0;
|
|
37
|
+
}
|
|
38
|
+
get inputSizeClasses() {
|
|
39
|
+
switch (this.size) {
|
|
40
|
+
case 'sm':
|
|
41
|
+
return 'cqa-px-3 cqa-py-2 cqa-text-xs';
|
|
42
|
+
case 'md':
|
|
43
|
+
return 'cqa-px-4 cqa-py-2.5 cqa-text-sm';
|
|
44
|
+
case 'lg':
|
|
45
|
+
return 'cqa-px-5 cqa-py-3 cqa-text-base';
|
|
46
|
+
default:
|
|
47
|
+
return 'cqa-px-4 cqa-py-2.5 cqa-text-sm';
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
get labelSizeClasses() {
|
|
51
|
+
switch (this.size) {
|
|
52
|
+
case 'sm':
|
|
53
|
+
return 'cqa-text-xs cqa-mb-1';
|
|
54
|
+
case 'md':
|
|
55
|
+
return 'cqa-text-sm cqa-mb-1.5';
|
|
56
|
+
case 'lg':
|
|
57
|
+
return 'cqa-text-base cqa-mb-2';
|
|
58
|
+
default:
|
|
59
|
+
return 'cqa-text-sm cqa-mb-1.5';
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
onInput(event) {
|
|
63
|
+
const target = event.target;
|
|
64
|
+
let nextValue = target?.value ?? '';
|
|
65
|
+
if (this.showCharCount && this.maxLength && nextValue.length > this.maxLength) {
|
|
66
|
+
nextValue = nextValue.substring(0, this.maxLength);
|
|
67
|
+
if (target) {
|
|
68
|
+
target.value = nextValue;
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
this.inputValue = nextValue;
|
|
72
|
+
this.valueChange.emit(this.inputValue);
|
|
73
|
+
}
|
|
74
|
+
onFocus(event) {
|
|
75
|
+
this.isFocused = true;
|
|
76
|
+
this.focused.emit(event);
|
|
77
|
+
}
|
|
78
|
+
onBlur(event) {
|
|
79
|
+
this.isFocused = false;
|
|
80
|
+
this.blurred.emit(event);
|
|
81
|
+
}
|
|
82
|
+
onKeyDown(event) {
|
|
83
|
+
if (event.key === 'Enter') {
|
|
84
|
+
event.preventDefault();
|
|
85
|
+
this.enterPressed.emit(this.inputValue.trim());
|
|
86
|
+
}
|
|
87
|
+
}
|
|
88
|
+
get inputStyles() {
|
|
89
|
+
return this.inputInlineStyle || '';
|
|
90
|
+
}
|
|
91
|
+
get labelStyles() {
|
|
92
|
+
return this.labelInlineStyle || '';
|
|
93
|
+
}
|
|
94
|
+
}
|
|
95
|
+
CustomInputComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: CustomInputComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
96
|
+
CustomInputComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.4.0", type: CustomInputComponent, selector: "cqa-custom-input", inputs: { label: "label", type: "type", placeholder: "placeholder", value: "value", disabled: "disabled", errors: "errors", required: "required", ariaLabel: "ariaLabel", size: "size", fullWidth: "fullWidth", maxLength: "maxLength", showCharCount: "showCharCount", inputInlineStyle: "inputInlineStyle", labelInlineStyle: "labelInlineStyle" }, outputs: { valueChange: "valueChange", blurred: "blurred", focused: "focused", enterPressed: "enterPressed" }, host: { classAttribute: "cqa-ui-root" }, usesOnChanges: true, ngImport: i0, template: "<div class=\"cqa-ui-root\" [style.display]=\"'block'\" [style.width]=\"fullWidth ? '100%' : 'auto'\">\n <div class=\"cqa-flex cqa-flex-col\" [style.width]=\"fullWidth ? '100%' : 'auto'\">\n <label \n *ngIf=\"label\"\n class=\"cqa-font-medium cqa-text-[#374151]\"\n [ngClass]=\"labelSizeClasses\"\n [style]=\"labelStyles\">\n {{ label }}\n <span *ngIf=\"required\" class=\"cqa-text-[#EF4444] cqa-ml-0.5\">*</span>\n </label>\n\n <div class=\"cqa-relative\" [style.width]=\"fullWidth ? '100%' : 'auto'\">\n <input\n [type]=\"type\"\n class=\"cqa-w-full !cqa-border !cqa-border-solid !cqa-border-gray-200 cqa-rounded-md cqa-bg-white cqa-font-['SF_Pro_Text'] cqa-font-normal cqa-leading-normal cqa-tracking-normal cqa-text-[#0A0A0A] placeholder:cqa-text-[#9CA3AF] cqa-transition-all cqa-duration-200 cqa-outline-none\"\n [ngClass]=\"{\n 'cqa-border-[#D1D5DB] focus:cqa-border-[#3B82F6] focus:cqa-ring-1 focus:cqa-ring-[#3B82F6]': !hasError,\n 'cqa-border-[#EF4444] focus:cqa-border-[#EF4444] focus:cqa-ring-1 focus:cqa-ring-[#EF4444]': hasError,\n 'cqa-bg-[#F9FAFB] cqa-cursor-not-allowed cqa-text-[#9CA3AF]': disabled,\n 'cqa-outline-none': true\n }\"\n [ngClass]=\"inputSizeClasses\"\n [style]=\"inputStyles\"\n [placeholder]=\"placeholder\"\n [value]=\"inputValue\"\n (input)=\"onInput($event)\"\n (focus)=\"onFocus($event)\"\n (blur)=\"onBlur($event)\"\n (keydown)=\"onKeyDown($event)\"\n [disabled]=\"disabled\"\n [attr.aria-label]=\"ariaLabel || label\"\n [attr.aria-invalid]=\"hasError\"\n [attr.aria-required]=\"required\"\n autocomplete=\"off\"\n />\n </div>\n\n <div *ngIf=\"showCharCount && maxLength\" class=\"cqa-flex cqa-justify-end cqa-mt-1\">\n <span class=\"cqa-text-xs cqa-text-[#6B7280]\">\n {{ inputValue.length }}/{{ maxLength }}\n </span>\n </div>\n\n <div *ngIf=\"hasError\" class=\"cqa-flex cqa-flex-col cqa-gap-1 cqa-mt-1.5\">\n <div *ngFor=\"let error of errors\" class=\"cqa-flex cqa-items-start cqa-gap-1.5\">\n <svg \n xmlns=\"http://www.w3.org/2000/svg\" \n width=\"14\" \n height=\"14\" \n viewBox=\"0 0 14 14\" \n fill=\"none\"\n class=\"cqa-flex-shrink-0 cqa-mt-0.5\">\n <path d=\"M7 1.75C4.1 1.75 1.75 4.1 1.75 7C1.75 9.9 4.1 12.25 7 12.25C9.9 12.25 12.25 9.9 12.25 7C12.25 4.1 9.9 1.75 7 1.75ZM7 9.625C6.65625 9.625 6.375 9.34375 6.375 9V7C6.375 6.65625 6.65625 6.375 7 6.375C7.34375 6.375 7.625 6.65625 7.625 7V9C7.625 9.34375 7.34375 9.625 7 9.625ZM7.625 5.25H6.375V4H7.625V5.25Z\" fill=\"#EF4444\"/>\n </svg>\n <span class=\"cqa-text-xs cqa-text-[#EF4444] cqa-font-medium cqa-leading-[18px]\">\n {{ error }}\n </span>\n </div>\n </div>\n </div>\n</div>\n\n", directives: [{ type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }] });
|
|
97
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: CustomInputComponent, decorators: [{
|
|
98
|
+
type: Component,
|
|
99
|
+
args: [{ selector: 'cqa-custom-input', host: { class: 'cqa-ui-root' }, template: "<div class=\"cqa-ui-root\" [style.display]=\"'block'\" [style.width]=\"fullWidth ? '100%' : 'auto'\">\n <div class=\"cqa-flex cqa-flex-col\" [style.width]=\"fullWidth ? '100%' : 'auto'\">\n <label \n *ngIf=\"label\"\n class=\"cqa-font-medium cqa-text-[#374151]\"\n [ngClass]=\"labelSizeClasses\"\n [style]=\"labelStyles\">\n {{ label }}\n <span *ngIf=\"required\" class=\"cqa-text-[#EF4444] cqa-ml-0.5\">*</span>\n </label>\n\n <div class=\"cqa-relative\" [style.width]=\"fullWidth ? '100%' : 'auto'\">\n <input\n [type]=\"type\"\n class=\"cqa-w-full !cqa-border !cqa-border-solid !cqa-border-gray-200 cqa-rounded-md cqa-bg-white cqa-font-['SF_Pro_Text'] cqa-font-normal cqa-leading-normal cqa-tracking-normal cqa-text-[#0A0A0A] placeholder:cqa-text-[#9CA3AF] cqa-transition-all cqa-duration-200 cqa-outline-none\"\n [ngClass]=\"{\n 'cqa-border-[#D1D5DB] focus:cqa-border-[#3B82F6] focus:cqa-ring-1 focus:cqa-ring-[#3B82F6]': !hasError,\n 'cqa-border-[#EF4444] focus:cqa-border-[#EF4444] focus:cqa-ring-1 focus:cqa-ring-[#EF4444]': hasError,\n 'cqa-bg-[#F9FAFB] cqa-cursor-not-allowed cqa-text-[#9CA3AF]': disabled,\n 'cqa-outline-none': true\n }\"\n [ngClass]=\"inputSizeClasses\"\n [style]=\"inputStyles\"\n [placeholder]=\"placeholder\"\n [value]=\"inputValue\"\n (input)=\"onInput($event)\"\n (focus)=\"onFocus($event)\"\n (blur)=\"onBlur($event)\"\n (keydown)=\"onKeyDown($event)\"\n [disabled]=\"disabled\"\n [attr.aria-label]=\"ariaLabel || label\"\n [attr.aria-invalid]=\"hasError\"\n [attr.aria-required]=\"required\"\n autocomplete=\"off\"\n />\n </div>\n\n <div *ngIf=\"showCharCount && maxLength\" class=\"cqa-flex cqa-justify-end cqa-mt-1\">\n <span class=\"cqa-text-xs cqa-text-[#6B7280]\">\n {{ inputValue.length }}/{{ maxLength }}\n </span>\n </div>\n\n <div *ngIf=\"hasError\" class=\"cqa-flex cqa-flex-col cqa-gap-1 cqa-mt-1.5\">\n <div *ngFor=\"let error of errors\" class=\"cqa-flex cqa-items-start cqa-gap-1.5\">\n <svg \n xmlns=\"http://www.w3.org/2000/svg\" \n width=\"14\" \n height=\"14\" \n viewBox=\"0 0 14 14\" \n fill=\"none\"\n class=\"cqa-flex-shrink-0 cqa-mt-0.5\">\n <path d=\"M7 1.75C4.1 1.75 1.75 4.1 1.75 7C1.75 9.9 4.1 12.25 7 12.25C9.9 12.25 12.25 9.9 12.25 7C12.25 4.1 9.9 1.75 7 1.75ZM7 9.625C6.65625 9.625 6.375 9.34375 6.375 9V7C6.375 6.65625 6.65625 6.375 7 6.375C7.34375 6.375 7.625 6.65625 7.625 7V9C7.625 9.34375 7.34375 9.625 7 9.625ZM7.625 5.25H6.375V4H7.625V5.25Z\" fill=\"#EF4444\"/>\n </svg>\n <span class=\"cqa-text-xs cqa-text-[#EF4444] cqa-font-medium cqa-leading-[18px]\">\n {{ error }}\n </span>\n </div>\n </div>\n </div>\n</div>\n\n", styles: [] }]
|
|
100
|
+
}], propDecorators: { label: [{
|
|
101
|
+
type: Input
|
|
102
|
+
}], type: [{
|
|
103
|
+
type: Input
|
|
104
|
+
}], placeholder: [{
|
|
105
|
+
type: Input
|
|
106
|
+
}], value: [{
|
|
107
|
+
type: Input
|
|
108
|
+
}], disabled: [{
|
|
109
|
+
type: Input
|
|
110
|
+
}], errors: [{
|
|
111
|
+
type: Input
|
|
112
|
+
}], required: [{
|
|
113
|
+
type: Input
|
|
114
|
+
}], ariaLabel: [{
|
|
115
|
+
type: Input
|
|
116
|
+
}], size: [{
|
|
117
|
+
type: Input
|
|
118
|
+
}], fullWidth: [{
|
|
119
|
+
type: Input
|
|
120
|
+
}], maxLength: [{
|
|
121
|
+
type: Input
|
|
122
|
+
}], showCharCount: [{
|
|
123
|
+
type: Input
|
|
124
|
+
}], inputInlineStyle: [{
|
|
125
|
+
type: Input
|
|
126
|
+
}], labelInlineStyle: [{
|
|
127
|
+
type: Input
|
|
128
|
+
}], valueChange: [{
|
|
129
|
+
type: Output
|
|
130
|
+
}], blurred: [{
|
|
131
|
+
type: Output
|
|
132
|
+
}], focused: [{
|
|
133
|
+
type: Output
|
|
134
|
+
}], enterPressed: [{
|
|
135
|
+
type: Output
|
|
136
|
+
}] } });
|
|
137
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"custom-input.component.js","sourceRoot":"","sources":["../../../../../src/lib/custom-input/custom-input.component.ts","../../../../../src/lib/custom-input/custom-input.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnChanges, Output, SimpleChanges } from '@angular/core';\n\ntype InputType = 'text' | 'password' | 'email' | 'number' | 'tel' | 'url';\ntype InputSize = 'sm' | 'md' | 'lg';\n\n@Component({\n  selector: 'cqa-custom-input',\n  templateUrl: './custom-input.component.html',\n  styleUrls: [],\n  host: { class: 'cqa-ui-root' }\n})\nexport class CustomInputComponent implements OnChanges {\n\n  @Input() label = '';\n\n  @Input() type: InputType = 'text';\n\n  @Input() placeholder = '';\n\n  @Input() value = '';\n\n  @Input() disabled = false;\n\n  @Input() errors: string[] = [];\n\n  @Input() required = false;\n\n  @Input() ariaLabel = '';\n\n  @Input() size: InputSize = 'md';\n\n  @Input() fullWidth = false;\n\n  @Input() maxLength?: number;\n\n  @Input() showCharCount = false;\n\n  @Input() inputInlineStyle?: string;\n\n  @Input() labelInlineStyle?: string;\n\n  @Output() valueChange = new EventEmitter<string>();\n\n  @Output() blurred = new EventEmitter<FocusEvent>();\n\n  @Output() focused = new EventEmitter<FocusEvent>();\n\n  @Output() enterPressed = new EventEmitter<string>();\n\n  inputValue = '';\n  isFocused = false;\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes['value'] && changes['value'].currentValue !== undefined) {\n      let newValue = changes['value'].currentValue ?? '';\n      \n      if (this.maxLength && newValue.length > this.maxLength) {\n        newValue = newValue.substring(0, this.maxLength);\n      }\n      \n      if (newValue !== this.inputValue) {\n        this.inputValue = newValue;\n      }\n    }\n  }\n\n  get hasError(): boolean {\n    return this.errors && this.errors.length > 0;\n  }\n\n  get inputSizeClasses(): string {\n    switch (this.size) {\n      case 'sm':\n        return 'cqa-px-3 cqa-py-2 cqa-text-xs';\n      case 'md':\n        return 'cqa-px-4 cqa-py-2.5 cqa-text-sm';\n      case 'lg':\n        return 'cqa-px-5 cqa-py-3 cqa-text-base';\n      default:\n        return 'cqa-px-4 cqa-py-2.5 cqa-text-sm';\n    }\n  }\n\n  get labelSizeClasses(): string {\n    switch (this.size) {\n      case 'sm':\n        return 'cqa-text-xs cqa-mb-1';\n      case 'md':\n        return 'cqa-text-sm cqa-mb-1.5';\n      case 'lg':\n        return 'cqa-text-base cqa-mb-2';\n      default:\n        return 'cqa-text-sm cqa-mb-1.5';\n    }\n  }\n\n  onInput(event: Event): void {\n    const target = event.target as HTMLInputElement | null;\n    let nextValue = target?.value ?? '';\n    \n    if (this.showCharCount && this.maxLength && nextValue.length > this.maxLength) {\n      nextValue = nextValue.substring(0, this.maxLength);\n      if (target) {\n        target.value = nextValue;\n      }\n    }\n    \n    this.inputValue = nextValue;\n    this.valueChange.emit(this.inputValue);\n  }\n\n  onFocus(event: FocusEvent): void {\n    this.isFocused = true;\n    this.focused.emit(event);\n  }\n\n  onBlur(event: FocusEvent): void {\n    this.isFocused = false;\n    this.blurred.emit(event);\n  }\n\n  onKeyDown(event: KeyboardEvent): void {\n    if (event.key === 'Enter') {\n      event.preventDefault();\n      this.enterPressed.emit(this.inputValue.trim());\n    }\n  }\n\n  get inputStyles(): string {\n    return this.inputInlineStyle || '';\n  }\n\n  get labelStyles(): string {\n    return this.labelInlineStyle || '';\n  }\n}\n\n","<div class=\"cqa-ui-root\" [style.display]=\"'block'\" [style.width]=\"fullWidth ? '100%' : 'auto'\">\n  <div class=\"cqa-flex cqa-flex-col\" [style.width]=\"fullWidth ? '100%' : 'auto'\">\n    <label \n      *ngIf=\"label\"\n      class=\"cqa-font-medium cqa-text-[#374151]\"\n      [ngClass]=\"labelSizeClasses\"\n      [style]=\"labelStyles\">\n      {{ label }}\n      <span *ngIf=\"required\" class=\"cqa-text-[#EF4444] cqa-ml-0.5\">*</span>\n    </label>\n\n    <div class=\"cqa-relative\" [style.width]=\"fullWidth ? '100%' : 'auto'\">\n      <input\n        [type]=\"type\"\n        class=\"cqa-w-full !cqa-border !cqa-border-solid !cqa-border-gray-200 cqa-rounded-md cqa-bg-white cqa-font-['SF_Pro_Text'] cqa-font-normal cqa-leading-normal cqa-tracking-normal cqa-text-[#0A0A0A] placeholder:cqa-text-[#9CA3AF] cqa-transition-all cqa-duration-200 cqa-outline-none\"\n        [ngClass]=\"{\n          'cqa-border-[#D1D5DB] focus:cqa-border-[#3B82F6] focus:cqa-ring-1 focus:cqa-ring-[#3B82F6]': !hasError,\n          'cqa-border-[#EF4444] focus:cqa-border-[#EF4444] focus:cqa-ring-1 focus:cqa-ring-[#EF4444]': hasError,\n          'cqa-bg-[#F9FAFB] cqa-cursor-not-allowed cqa-text-[#9CA3AF]': disabled,\n          'cqa-outline-none': true\n        }\"\n        [ngClass]=\"inputSizeClasses\"\n        [style]=\"inputStyles\"\n        [placeholder]=\"placeholder\"\n        [value]=\"inputValue\"\n        (input)=\"onInput($event)\"\n        (focus)=\"onFocus($event)\"\n        (blur)=\"onBlur($event)\"\n        (keydown)=\"onKeyDown($event)\"\n        [disabled]=\"disabled\"\n        [attr.aria-label]=\"ariaLabel || label\"\n        [attr.aria-invalid]=\"hasError\"\n        [attr.aria-required]=\"required\"\n        autocomplete=\"off\"\n      />\n    </div>\n\n    <div *ngIf=\"showCharCount && maxLength\" class=\"cqa-flex cqa-justify-end cqa-mt-1\">\n      <span class=\"cqa-text-xs cqa-text-[#6B7280]\">\n        {{ inputValue.length }}/{{ maxLength }}\n      </span>\n    </div>\n\n    <div *ngIf=\"hasError\" class=\"cqa-flex cqa-flex-col cqa-gap-1 cqa-mt-1.5\">\n      <div *ngFor=\"let error of errors\" class=\"cqa-flex cqa-items-start cqa-gap-1.5\">\n        <svg \n          xmlns=\"http://www.w3.org/2000/svg\" \n          width=\"14\" \n          height=\"14\" \n          viewBox=\"0 0 14 14\" \n          fill=\"none\"\n          class=\"cqa-flex-shrink-0 cqa-mt-0.5\">\n          <path d=\"M7 1.75C4.1 1.75 1.75 4.1 1.75 7C1.75 9.9 4.1 12.25 7 12.25C9.9 12.25 12.25 9.9 12.25 7C12.25 4.1 9.9 1.75 7 1.75ZM7 9.625C6.65625 9.625 6.375 9.34375 6.375 9V7C6.375 6.65625 6.65625 6.375 7 6.375C7.34375 6.375 7.625 6.65625 7.625 7V9C7.625 9.34375 7.34375 9.625 7 9.625ZM7.625 5.25H6.375V4H7.625V5.25Z\" fill=\"#EF4444\"/>\n        </svg>\n        <span class=\"cqa-text-xs cqa-text-[#EF4444] cqa-font-medium cqa-leading-[18px]\">\n          {{ error }}\n        </span>\n      </div>\n    </div>\n  </div>\n</div>\n\n"]}
|
|
@@ -1,14 +1,6 @@
|
|
|
1
|
-
import { Component, Input
|
|
1
|
+
import { Component, Input } from '@angular/core';
|
|
2
2
|
import * as i0 from "@angular/core";
|
|
3
|
-
import * as i1 from "../button/button.component";
|
|
4
|
-
import * as i2 from "@angular/common";
|
|
5
3
|
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
4
|
get headerTitle() {
|
|
13
5
|
if (this.failedStepData?.stepTitle) {
|
|
14
6
|
return `Failed at Step ${this.failedStepData.failed_step_index}: ${this.failedStepData.stepTitle}`;
|
|
@@ -36,26 +28,6 @@ export class FailedStepCardComponent {
|
|
|
36
28
|
get hasSuggestions() {
|
|
37
29
|
return !!this.failedStepData?.suggestions && this.failedStepData.suggestions.trim().length > 0;
|
|
38
30
|
}
|
|
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
31
|
getFormattedSuggestions() {
|
|
60
32
|
if (!this.suggestions)
|
|
61
33
|
return [];
|
|
@@ -63,15 +35,11 @@ export class FailedStepCardComponent {
|
|
|
63
35
|
}
|
|
64
36
|
}
|
|
65
37
|
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" },
|
|
38
|
+
FailedStepCardComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.4.0", type: FailedStepCardComponent, selector: "cqa-failed-step-card", inputs: { failedStepData: "failedStepData" }, 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 cqa-h-[114px]\" 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 cqa-h-[91px] cqa-max-h-[91px] cqa-overflow-y-auto cqa-font-medium\">\n {{ expectedResult }}\n </div>\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-h-[91px] cqa-max-h-[91px] cqa-overflow-y-auto cqa-font-medium\">\n {{ actualResult }}\n </div>\n </div>\n </div>\n </div>\n </div>\n</div>\n\n" });
|
|
67
39
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: FailedStepCardComponent, decorators: [{
|
|
68
40
|
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
|
|
41
|
+
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 cqa-h-[114px]\" 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 cqa-h-[91px] cqa-max-h-[91px] cqa-overflow-y-auto cqa-font-medium\">\n {{ expectedResult }}\n </div>\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-h-[91px] cqa-max-h-[91px] cqa-overflow-y-auto cqa-font-medium\">\n {{ actualResult }}\n </div>\n </div>\n </div>\n </div>\n </div>\n</div>\n\n", styles: [] }]
|
|
70
42
|
}], propDecorators: { failedStepData: [{
|
|
71
43
|
type: Input
|
|
72
|
-
}], jumpToStep: [{
|
|
73
|
-
type: Output
|
|
74
|
-
}], openInVideo: [{
|
|
75
|
-
type: Output
|
|
76
44
|
}] } });
|
|
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"]}
|
|
45
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmFpbGVkLXN0ZXAtY2FyZC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9zcmMvbGliL2ZhaWxlZC1zdGVwLWNhcmQvZmFpbGVkLXN0ZXAtY2FyZC5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi9zcmMvbGliL2ZhaWxlZC1zdGVwLWNhcmQvZmFpbGVkLXN0ZXAtY2FyZC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBd0IsTUFBTSxlQUFlLENBQUM7O0FBdUJ2RSxNQUFNLE9BQU8sdUJBQXVCO0lBR2xDLElBQUksV0FBVztRQUNiLElBQUksSUFBSSxDQUFDLGNBQWMsRUFBRSxTQUFTLEVBQUU7WUFDbEMsT0FBTyxrQkFBa0IsSUFBSSxDQUFDLGNBQWMsQ0FBQyxpQkFBaUIsS0FBSyxJQUFJLENBQUMsY0FBYyxDQUFDLFNBQVMsRUFBRSxDQUFDO1NBQ3BHO1FBQ0QsT0FBTyxrQkFBa0IsSUFBSSxDQUFDLGNBQWMsRUFBRSxpQkFBaUIsSUFBSSxFQUFFLEVBQUUsQ0FBQztJQUMxRSxDQUFDO0lBRUQsSUFBSSxTQUFTO1FBQ1gsT0FBTyxJQUFJLENBQUMsY0FBYyxFQUFFLFlBQVksSUFBSSxJQUFJLENBQUMsY0FBYyxFQUFFLE1BQU0sSUFBSSxtQkFBbUIsQ0FBQztJQUNqRyxDQUFDO0lBRUQsSUFBSSxjQUFjO1FBQ2hCLE9BQU8sSUFBSSxDQUFDLGNBQWMsRUFBRSxTQUFTLElBQUksT0FBTyxDQUFDO0lBQ25ELENBQUM7SUFFRCxJQUFJLFlBQVk7UUFDZCxPQUFPLElBQUksQ0FBQyxjQUFjLEVBQUUsUUFBUSxJQUFJLElBQUksQ0FBQztJQUMvQyxDQUFDO0lBRUQsSUFBSSxjQUFjO1FBQ2hCLE9BQU8sSUFBSSxDQUFDLGNBQWMsRUFBRSxlQUFlLElBQUksRUFBRSxDQUFDO0lBQ3BELENBQUM7SUFFRCxJQUFJLFlBQVk7UUFDZCxPQUFPLElBQUksQ0FBQyxjQUFjLEVBQUUsYUFBYSxJQUFJLEVBQUUsQ0FBQztJQUNsRCxDQUFDO0lBRUQsSUFBSSxXQUFXO1FBQ2IsT0FBTyxJQUFJLENBQUMsY0FBYyxFQUFFLFdBQVcsSUFBSSxFQUFFLENBQUM7SUFDaEQsQ0FBQztJQUVELElBQUksY0FBYztRQUNoQixPQUFPLENBQUMsQ0FBQyxJQUFJLENBQUMsY0FBYyxFQUFFLFdBQVcsSUFBSSxJQUFJLENBQUMsY0FBYyxDQUFDLFdBQVcsQ0FBQyxJQUFJLEVBQUUsQ0FBQyxNQUFNLEdBQUcsQ0FBQyxDQUFDO0lBQ2pHLENBQUM7SUFFRCx1QkFBdUI7UUFDckIsSUFBSSxDQUFDLElBQUksQ0FBQyxXQUFXO1lBQUUsT0FBTyxFQUFFLENBQUM7UUFDakMsT0FBTyxJQUFJLENBQUMsV0FBVyxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUMsSUFBSSxFQUFFLENBQUMsTUFBTSxHQUFHLENBQUMsQ0FBQyxDQUFDO0lBQ3ZFLENBQUM7O29IQXpDVSx1QkFBdUI7d0dBQXZCLHVCQUF1QiwwR0N2QnBDLDYvREFtQ0E7MkZEWmEsdUJBQXVCO2tCQUxuQyxTQUFTOytCQUNFLHNCQUFzQjs4QkFLdkIsY0FBYztzQkFBdEIsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgSW5wdXQsIE91dHB1dCwgRXZlbnRFbWl0dGVyIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgRmFpbGVkU3RlcERhdGEge1xuICBleHBlY3RlZF9yZXN1bHQ6IHN0cmluZztcbiAgYWN0dWFsX3Jlc3VsdDogc3RyaW5nO1xuICBmYWlsZWRfc3RlcF9pZDogc3RyaW5nO1xuICBpc1RpbWVvdXRlcnJvcjogYm9vbGVhbjtcbiAgZmFpbGVkX3N0ZXBfaW5kZXg6IHN0cmluZztcbiAgc3RlcHM6IGFueVtdO1xuICB0aW1lc3RhbXA6IHN0cmluZztcbiAgZHVyYXRpb246IHN0cmluZztcbiAgc3RlcFNjcmVlbnNob3RVcmw6IHN0cmluZyB8IG51bGw7XG4gIHN1Z2dlc3Rpb25zOiBzdHJpbmc7XG4gIHJlYXNvbjogc3RyaW5nO1xuICBzdGVwVGl0bGU/OiBzdHJpbmc7XG4gIGVycm9yTWVzc2FnZT86IHN0cmluZztcbn1cblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnY3FhLWZhaWxlZC1zdGVwLWNhcmQnLFxuICB0ZW1wbGF0ZVVybDogJy4vZmFpbGVkLXN0ZXAtY2FyZC5jb21wb25lbnQuaHRtbCcsXG4gIHN0eWxlVXJsczogW11cbn0pXG5leHBvcnQgY2xhc3MgRmFpbGVkU3RlcENhcmRDb21wb25lbnQge1xuICBASW5wdXQoKSBmYWlsZWRTdGVwRGF0YSE6IEZhaWxlZFN0ZXBEYXRhO1xuXG4gIGdldCBoZWFkZXJUaXRsZSgpOiBzdHJpbmcge1xuICAgIGlmICh0aGlzLmZhaWxlZFN0ZXBEYXRhPy5zdGVwVGl0bGUpIHtcbiAgICAgIHJldHVybiBgRmFpbGVkIGF0IFN0ZXAgJHt0aGlzLmZhaWxlZFN0ZXBEYXRhLmZhaWxlZF9zdGVwX2luZGV4fTogJHt0aGlzLmZhaWxlZFN0ZXBEYXRhLnN0ZXBUaXRsZX1gO1xuICAgIH1cbiAgICByZXR1cm4gYEZhaWxlZCBhdCBTdGVwICR7dGhpcy5mYWlsZWRTdGVwRGF0YT8uZmFpbGVkX3N0ZXBfaW5kZXggfHwgJyd9YDtcbiAgfVxuXG4gIGdldCBlcnJvclRleHQoKTogc3RyaW5nIHtcbiAgICByZXR1cm4gdGhpcy5mYWlsZWRTdGVwRGF0YT8uZXJyb3JNZXNzYWdlIHx8IHRoaXMuZmFpbGVkU3RlcERhdGE/LnJlYXNvbiB8fCAnQW4gZXJyb3Igb2NjdXJyZWQnO1xuICB9XG5cbiAgZ2V0IHZpZGVvVGltZXN0YW1wKCk6IHN0cmluZyB7XG4gICAgcmV0dXJuIHRoaXMuZmFpbGVkU3RlcERhdGE/LnRpbWVzdGFtcCB8fCAnMDA6MDAnO1xuICB9XG5cbiAgZ2V0IGR1cmF0aW9uVGV4dCgpOiBzdHJpbmcge1xuICAgIHJldHVybiB0aGlzLmZhaWxlZFN0ZXBEYXRhPy5kdXJhdGlvbiB8fCAnMHMnO1xuICB9XG5cbiAgZ2V0IGV4cGVjdGVkUmVzdWx0KCk6IHN0cmluZyB7XG4gICAgcmV0dXJuIHRoaXMuZmFpbGVkU3RlcERhdGE/LmV4cGVjdGVkX3Jlc3VsdCB8fCAnJztcbiAgfVxuXG4gIGdldCBhY3R1YWxSZXN1bHQoKTogc3RyaW5nIHtcbiAgICByZXR1cm4gdGhpcy5mYWlsZWRTdGVwRGF0YT8uYWN0dWFsX3Jlc3VsdCB8fCAnJztcbiAgfVxuXG4gIGdldCBzdWdnZXN0aW9ucygpOiBzdHJpbmcge1xuICAgIHJldHVybiB0aGlzLmZhaWxlZFN0ZXBEYXRhPy5zdWdnZXN0aW9ucyB8fCAnJztcbiAgfVxuXG4gIGdldCBoYXNTdWdnZXN0aW9ucygpOiBib29sZWFuIHtcbiAgICByZXR1cm4gISF0aGlzLmZhaWxlZFN0ZXBEYXRhPy5zdWdnZXN0aW9ucyAmJiB0aGlzLmZhaWxlZFN0ZXBEYXRhLnN1Z2dlc3Rpb25zLnRyaW0oKS5sZW5ndGggPiAwO1xuICB9XG5cbiAgZ2V0Rm9ybWF0dGVkU3VnZ2VzdGlvbnMoKTogc3RyaW5nW10ge1xuICAgIGlmICghdGhpcy5zdWdnZXN0aW9ucykgcmV0dXJuIFtdO1xuICAgIHJldHVybiB0aGlzLnN1Z2dlc3Rpb25zLnNwbGl0KCdcXG4nKS5maWx0ZXIocyA9PiBzLnRyaW0oKS5sZW5ndGggPiAwKTtcbiAgfVxufVxuXG4iLCI8ZGl2IGNsYXNzPVwiY3FhLXVpLXJvb3RcIiBzdHlsZT1cImRpc3BsYXk6IGJsb2NrOyB3aWR0aDogMTAwJTtcIj5cbiAgPGRpdiBjbGFzcz1cImNxYS1iZy1bI0ZFRjJGMl0gY3FhLXAtWzE3cHhdIGNxYS1yb3VuZGVkLWxnIGNxYS1vdmVyZmxvdy1oaWRkZW4gY3FhLWZsZXggY3FhLWZsZXgtY29sIGNxYS1nYXAtM1wiIHN0eWxlPVwiYm9yZGVyOiAxcHggc29saWQgI0ZFQ0FDQTtcIj5cbiAgICA8ZGl2PlxuICAgICAgPGgzIGNsYXNzPVwiY3FhLXRleHQtc20gY3FhLWxlYWRpbmctWzE4cHhdIGNxYS10ZXh0LVsjMTExODI3XSBjcWEtbWItMVwiPnt7IGhlYWRlclRpdGxlIH19PC9oMz5cbiAgICAgIDxkaXYgY2xhc3M9XCJjcWEtZmxleCBjcWEtZmxleC13cmFwIGNxYS1pdGVtcy1jZW50ZXIgY3FhLWdhcC0zIGNxYS10ZXh0LXhzXCI+XG4gICAgICAgIDxzcGFuIGNsYXNzPVwiY3FhLXRleHQtWzEycHhdIGNxYS10ZXh0LVsjQjkxQzFDXVwiPkVycm9yOiB7eyBlcnJvclRleHQgfX08L3NwYW4+XG4gICAgICAgIDxzcGFuIGNsYXNzPVwiY3FhLXRleHQtWyM2MzYzNjNdXCI+4oCiPC9zcGFuPlxuICAgICAgICA8c3BhbiBjbGFzcz1cImNxYS10ZXh0LVsjNjM2MzYzXVwiPlZpZGVvIHRpbWVzdGFtcDoge3sgdmlkZW9UaW1lc3RhbXAgfX08L3NwYW4+XG4gICAgICAgIDxzcGFuIGNsYXNzPVwiY3FhLXRleHQtWyM2MzYzNjNdXCI+4oCiPC9zcGFuPlxuICAgICAgICA8c3BhbiBjbGFzcz1cImNxYS10ZXh0LVsjNjM2MzYzXVwiPkR1cmF0aW9uOiB7eyBkdXJhdGlvblRleHQgfX08L3NwYW4+XG4gICAgICA8L2Rpdj5cbiAgICA8L2Rpdj5cblxuICAgIDxkaXYgY2xhc3M9XCJjcWEtZ3JpZCBjcWEtZ3JpZC1jb2xzLTIgY3FhLWdhcC0wIGNxYS1yb3VuZGVkLVs0cHhdIGNxYS1vdmVyZmxvdy1oaWRkZW5cIiBzdHlsZT1cImJvcmRlcjogMXB4IHNvbGlkICNFNUU3RUJcIj5cbiAgICAgIDxkaXYgY2xhc3M9XCJjcWEtYmctd2hpdGUgY3FhLXB4LTIgY3FhLXB5LTEgbWQ6Y3FhLWJvcmRlci1yIGNxYS1mbGV4IGNxYS1mbGV4LWNvbCBjcWEtaC1bMTE0cHhdXCIgc3R5bGU9XCJib3JkZXItcmlnaHQ6IDFweCBzb2xpZCAjRTVFN0VCXCI+XG4gICAgICAgIDxkaXYgY2xhc3M9XCJjcWEtZmxleCBjcWEtZmxleC1jb2wgY3FhLWdhcC0xXCI+XG4gICAgICAgICAgPHNwYW4gY2xhc3M9XCJjcWEtdGV4dC1bMTBweF0gY3FhLWZvbnQtc2VtaWJvbGQgY3FhLXRleHQtWyM5Q0EzQUZdIGNxYS11cHBlcmNhc2UgY3FhLXRyYWNraW5nLXdpZGVcIj5FWFBFQ1RFRDwvc3Bhbj5cbiAgICAgICAgICA8ZGl2IGNsYXNzPVwiY3FhLXRleHQtWzEwcHhdIGNxYS10ZXh0LVsjMEIwQjBCXSBjcWEtbGVhZGluZy1yZWxheGVkIGNxYS1oLVs5MXB4XSBjcWEtbWF4LWgtWzkxcHhdIGNxYS1vdmVyZmxvdy15LWF1dG8gY3FhLWZvbnQtbWVkaXVtXCI+XG4gICAgICAgICAgICB7eyBleHBlY3RlZFJlc3VsdCB9fVxuICAgICAgICAgIDwvZGl2PlxuICAgICAgICA8L2Rpdj5cbiAgICAgIDwvZGl2PlxuXG4gICAgICA8ZGl2IGNsYXNzPVwiY3FhLWJnLVsjRkZGOUY5XSBjcWEtcHgtMiBjcWEtcHktMSBjcWEtZmxleCBjcWEtZmxleC1jb2xcIj5cbiAgICAgICAgPGRpdiBjbGFzcz1cImNxYS1mbGV4IGNxYS1mbGV4LWNvbCBjcWEtZ2FwLTFcIj5cbiAgICAgICAgICA8c3BhbiBjbGFzcz1cImNxYS10ZXh0LVsxMHB4XSBjcWEtZm9udC1zZW1pYm9sZCBjcWEtdGV4dC1bIzlDQTNBRl0gY3FhLXVwcGVyY2FzZSBjcWEtdHJhY2tpbmctd2lkZVwiPkFDVFVBTDwvc3Bhbj5cbiAgICAgICAgICA8ZGl2IGNsYXNzPVwiY3FhLXRleHQtWzEwcHhdIGNxYS10ZXh0LVsjQzEwMDA3XSBjcWEtbGVhZGluZy1yZWxheGVkIGNxYS1oLVs5MXB4XSBjcWEtbWF4LWgtWzkxcHhdIGNxYS1vdmVyZmxvdy15LWF1dG8gY3FhLWZvbnQtbWVkaXVtXCI+XG4gICAgICAgICAgICB7eyBhY3R1YWxSZXN1bHQgfX1cbiAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgPC9kaXY+XG4gICAgICAgIDwvZGl2PlxuICAgIDwvZGl2PlxuICA8L2Rpdj5cbjwvZGl2PlxuXG4iXX0=
|
|
@@ -132,7 +132,8 @@ export class RunHistoryCardComponent {
|
|
|
132
132
|
'background-color': '#ecedfe',
|
|
133
133
|
'padding': this.isSmall ? '2px 6px' : '2px 8px',
|
|
134
134
|
'border-radius': this.isSmall ? '5px' : '4px',
|
|
135
|
-
'font-size': this.isSmall ? '8px' : '10px'
|
|
135
|
+
'font-size': this.isSmall ? '8px' : '10px',
|
|
136
|
+
'line-height': this.isSmall ? '12px' : '15px'
|
|
136
137
|
};
|
|
137
138
|
}
|
|
138
139
|
get cardPadding() {
|
|
@@ -143,10 +144,10 @@ export class RunHistoryCardComponent {
|
|
|
143
144
|
}
|
|
144
145
|
}
|
|
145
146
|
RunHistoryCardComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: RunHistoryCardComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
146
|
-
RunHistoryCardComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.4.0", type: RunHistoryCardComponent, selector: "cqa-run-history-card", inputs: { id: "id", status: "status", type: "type", timestamp: "timestamp", duration: "duration", runLabel: "runLabel", errorMessage: "errorMessage", size: "size", durationTooltip: "durationTooltip" }, ngImport: i0, template: "<div class=\"cqa-ui-root\" style=\"display: block; width: 100%; height: 100%; min-width: 180px;\">\n <div class=\"cqa-bg-white cqa-rounded-lg cqa-shadow-sm cqa-flex cqa-flex-col\" [ngStyle]=\"{\n padding: cardPadding,\n border: '1px solid #E4E4E4',\n 'border-left-color': statusColor,\n 'border-left-width': borderLeftWidth\n }\">\n\n <!-- Header: Run ID and Status Badge -->\n <div class=\"cqa-flex cqa-items-start cqa-justify-between cqa-gap-2 cqa-flex-wrap\" [ngClass]=\"{\n 'cqa-mb-[10px]': isSmall,\n 'cqa-mb-2': !isSmall\n }\">\n <div class=\"cqa-flex cqa-items-center\" [ngClass]=\"{ 'cqa-gap-[6px]': isSmall, 'cqa-gap-2': !isSmall }\">\n <span [ngStyle]=\"statusIconContainerStyles\">\n <mat-icon [ngStyle]=\"statusIconStyles\">\n {{ statusIcon }}\n </mat-icon>\n </span>\n <span class=\"cqa-font-semibold cqa-text-[#3f43ee]\" [ngClass]=\"{\n 'cqa-text-xs': isSmall,\n 'cqa-text-sm': !isSmall\n }\">\n #{{ id }}\n </span>\n </div>\n\n <!-- Status Badge -->\n <span class=\"cqa-inline-flex cqa-items-center cqa-justify-center cqa-rounded-md cqa-font-medium cqa-text-white cqa-px-2\"\n [ngClass]=\"{\n 'cqa-py-[2px] cqa-text-[10px]': isSmall,\n 'cqa-py-1 cqa-text-xs': !isSmall\n }\" [ngStyle]=\"statusBadgeStyles\">\n {{ statusLabel }}\n </span>\n </div>\n\n <!-- Type and Timestamp -->\n <div class=\"cqa-flex cqa-items-center cqa-text-[#636363]\" [ngClass]=\"{\n 'cqa-gap-1': isSmall,\n 'cqa-gap-[6px]': !isSmall,\n 'cqa-mb-2': isSmall,\n 'cqa-mb-[6px]': !isSmall\n }\">\n <mat-icon [ngClass]=\"{\n 'cqa-text-[12px] cqa-w-3 cqa-h-3': isSmall,\n 'cqa-text-[14px] cqa-w-[14px] cqa-h-[14px]': !isSmall }\">\n {{ typeIcon }}\n </mat-icon>\n <span [ngClass]=\"{ 'cqa-text-[10px]': isSmall, 'cqa-text-xs': !isSmall }\">\n {{ typeLabel }}\n </span>\n </div>\n\n <!-- Timestamp -->\n <div class=\"cqa-font-normal cqa-text-[#0B0B0B]\" [ngClass]=\"{\n 'cqa-text-sm': !isSmall,\n 'cqa-text-[11px]': isSmall,\n 'cqa-mb-2': isSmall,\n 'cqa-mb-[6px]': !isSmall\n }\">\n {{ timestamp }}\n </div>\n\n <!-- Duration and Run Label -->\n <div class=\"cqa-flex cqa-items-center cqa-justify-between cqa-gap-2\">\n <div class=\"cqa-flex cqa-items-center cqa-text-[#636363]\" [ngClass]=\"{\n 'cqa-gap-1': isSmall,\n 'cqa-gap-[6px]': !isSmall\n }\" [title]=\"durationTooltip\">\n <mat-icon [ngClass]=\"{\n 'cqa-text-[12px] cqa-w-3 cqa-h-3': isSmall,\n 'cqa-text-[14px] cqa-w-[14px] cqa-h-[14px]': !isSmall }\" style=\"flex-shrink: 0;\">\n schedule\n </mat-icon>\n <span [ngClass]=\"{\n 'cqa-text-[8px]': isSmall,\n 'cqa-text-[10px]': !isSmall\n }\">\n {{ duration }}\n </span>\n </div>\n\n <span *ngIf=\"runLabel\" class=\"cqa-text-[#3F43EE] cqa-rounded-md cqa-whitespace-nowrap\"\n [ngStyle]=\"runLabelStyles\"\n [ngClass]=\"{ 'cqa-font-medium': !isSmall }\">\n {{ runLabel }}\n </span>\n </div>\n\n <!-- Error Message (only for failed status and normal size) -->\n <div *ngIf=\"errorMessage && status === 'failed' && !isSmall\" class=\"cqa-mt-2 cqa-pt-2\"\n style=\"border-top: 1px solid #E4E4E4;\">\n <p class=\"cqa-text-[10px] cqa-text-[#E7000B]\">\n {{ errorMessage }}\n </p>\n </div>\n </div>\n</div>", components: [{ type: i1.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }], directives: [{ type: i2.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] });
|
|
147
|
+
RunHistoryCardComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.4.0", type: RunHistoryCardComponent, selector: "cqa-run-history-card", inputs: { id: "id", status: "status", type: "type", timestamp: "timestamp", duration: "duration", runLabel: "runLabel", errorMessage: "errorMessage", size: "size", durationTooltip: "durationTooltip" }, ngImport: i0, template: "<div class=\"cqa-ui-root\" style=\"display: block; width: 100%; height: 100%; min-width: 180px;\">\n <div class=\"cqa-bg-white cqa-rounded-lg cqa-shadow-sm cqa-flex cqa-flex-col\" [ngStyle]=\"{\n padding: cardPadding,\n border: '1px solid #E4E4E4',\n 'border-left-color': statusColor,\n 'border-left-width': borderLeftWidth\n }\">\n\n <!-- Header: Run ID and Status Badge -->\n <div class=\"cqa-flex cqa-items-start cqa-justify-between cqa-gap-2 cqa-flex-wrap\" [ngClass]=\"{\n 'cqa-mb-[10px]': isSmall,\n 'cqa-mb-2': !isSmall\n }\">\n <div class=\"cqa-flex cqa-items-center\" [ngClass]=\"{ 'cqa-gap-[6px]': isSmall, 'cqa-gap-2': !isSmall }\">\n <span [ngStyle]=\"statusIconContainerStyles\">\n <mat-icon [ngStyle]=\"statusIconStyles\">\n {{ statusIcon }}\n </mat-icon>\n </span>\n <span class=\"cqa-font-semibold cqa-text-[#3f43ee]\" [ngClass]=\"{\n 'cqa-text-xs': isSmall,\n 'cqa-text-sm': !isSmall\n }\">\n #{{ id }}\n </span>\n </div>\n\n <!-- Status Badge -->\n <span class=\"cqa-inline-flex cqa-items-center cqa-justify-center cqa-rounded-md cqa-font-medium cqa-text-white cqa-px-2\"\n [ngClass]=\"{\n 'cqa-py-[2px] cqa-text-[10px]': isSmall,\n 'cqa-py-1 cqa-text-xs': !isSmall\n }\" [ngStyle]=\"statusBadgeStyles\">\n {{ statusLabel }}\n </span>\n </div>\n\n <!-- Type and Timestamp -->\n <div class=\"cqa-flex cqa-items-center cqa-text-[#636363]\" [ngClass]=\"{\n 'cqa-gap-1': isSmall,\n 'cqa-gap-[6px]': !isSmall,\n 'cqa-mb-2': isSmall,\n 'cqa-mb-[6px]': !isSmall\n }\">\n <mat-icon [ngClass]=\"{\n 'cqa-text-[12px] cqa-w-3 cqa-h-3': isSmall,\n 'cqa-text-[14px] cqa-w-[14px] cqa-h-[14px]': !isSmall }\">\n {{ typeIcon }}\n </mat-icon>\n <span [ngClass]=\"{ 'cqa-text-[10px]': isSmall, 'cqa-text-xs': !isSmall }\">\n {{ typeLabel }}\n </span>\n </div>\n\n <!-- Timestamp -->\n <div class=\"cqa-font-normal cqa-text-[#0B0B0B] cqa-leading-normal\" [ngClass]=\"{\n 'cqa-text-sm': !isSmall,\n 'cqa-text-[11px]': isSmall,\n 'cqa-mb-2': isSmall,\n 'cqa-mb-[6px]': !isSmall\n }\">\n {{ timestamp }}\n </div>\n\n <!-- Duration and Run Label -->\n <div class=\"cqa-flex cqa-items-center cqa-justify-between cqa-gap-2\">\n <div class=\"cqa-flex cqa-items-center cqa-text-[#636363]\" [ngClass]=\"{\n 'cqa-gap-1': isSmall,\n 'cqa-gap-[6px]': !isSmall\n }\" [title]=\"durationTooltip\">\n <mat-icon [ngClass]=\"{\n 'cqa-text-[12px] cqa-w-3 cqa-h-3': isSmall,\n 'cqa-text-[14px] cqa-w-[14px] cqa-h-[14px]': !isSmall }\" style=\"flex-shrink: 0;\">\n schedule\n </mat-icon>\n <span [ngClass]=\"{\n 'cqa-text-[8px]': isSmall,\n 'cqa-text-[10px]': !isSmall\n }\">\n {{ duration }}\n </span>\n </div>\n\n <span *ngIf=\"runLabel\" class=\"cqa-text-[#3F43EE] cqa-rounded-md cqa-whitespace-nowrap\"\n [ngStyle]=\"runLabelStyles\"\n [ngClass]=\"{ 'cqa-font-medium': !isSmall }\">\n {{ runLabel }}\n </span>\n </div>\n\n <!-- Error Message (only for failed status and normal size) -->\n <div *ngIf=\"errorMessage && status === 'failed' && !isSmall\" class=\"cqa-mt-2 cqa-pt-2\"\n style=\"border-top: 1px solid #E4E4E4;\">\n <p class=\"cqa-text-[10px] cqa-text-[#E7000B]\">\n {{ errorMessage }}\n </p>\n </div>\n </div>\n</div>", components: [{ type: i1.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }], directives: [{ type: i2.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] });
|
|
147
148
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: RunHistoryCardComponent, decorators: [{
|
|
148
149
|
type: Component,
|
|
149
|
-
args: [{ selector: 'cqa-run-history-card', template: "<div class=\"cqa-ui-root\" style=\"display: block; width: 100%; height: 100%; min-width: 180px;\">\n <div class=\"cqa-bg-white cqa-rounded-lg cqa-shadow-sm cqa-flex cqa-flex-col\" [ngStyle]=\"{\n padding: cardPadding,\n border: '1px solid #E4E4E4',\n 'border-left-color': statusColor,\n 'border-left-width': borderLeftWidth\n }\">\n\n <!-- Header: Run ID and Status Badge -->\n <div class=\"cqa-flex cqa-items-start cqa-justify-between cqa-gap-2 cqa-flex-wrap\" [ngClass]=\"{\n 'cqa-mb-[10px]': isSmall,\n 'cqa-mb-2': !isSmall\n }\">\n <div class=\"cqa-flex cqa-items-center\" [ngClass]=\"{ 'cqa-gap-[6px]': isSmall, 'cqa-gap-2': !isSmall }\">\n <span [ngStyle]=\"statusIconContainerStyles\">\n <mat-icon [ngStyle]=\"statusIconStyles\">\n {{ statusIcon }}\n </mat-icon>\n </span>\n <span class=\"cqa-font-semibold cqa-text-[#3f43ee]\" [ngClass]=\"{\n 'cqa-text-xs': isSmall,\n 'cqa-text-sm': !isSmall\n }\">\n #{{ id }}\n </span>\n </div>\n\n <!-- Status Badge -->\n <span class=\"cqa-inline-flex cqa-items-center cqa-justify-center cqa-rounded-md cqa-font-medium cqa-text-white cqa-px-2\"\n [ngClass]=\"{\n 'cqa-py-[2px] cqa-text-[10px]': isSmall,\n 'cqa-py-1 cqa-text-xs': !isSmall\n }\" [ngStyle]=\"statusBadgeStyles\">\n {{ statusLabel }}\n </span>\n </div>\n\n <!-- Type and Timestamp -->\n <div class=\"cqa-flex cqa-items-center cqa-text-[#636363]\" [ngClass]=\"{\n 'cqa-gap-1': isSmall,\n 'cqa-gap-[6px]': !isSmall,\n 'cqa-mb-2': isSmall,\n 'cqa-mb-[6px]': !isSmall\n }\">\n <mat-icon [ngClass]=\"{\n 'cqa-text-[12px] cqa-w-3 cqa-h-3': isSmall,\n 'cqa-text-[14px] cqa-w-[14px] cqa-h-[14px]': !isSmall }\">\n {{ typeIcon }}\n </mat-icon>\n <span [ngClass]=\"{ 'cqa-text-[10px]': isSmall, 'cqa-text-xs': !isSmall }\">\n {{ typeLabel }}\n </span>\n </div>\n\n <!-- Timestamp -->\n <div class=\"cqa-font-normal cqa-text-[#0B0B0B]\" [ngClass]=\"{\n 'cqa-text-sm': !isSmall,\n 'cqa-text-[11px]': isSmall,\n 'cqa-mb-2': isSmall,\n 'cqa-mb-[6px]': !isSmall\n }\">\n {{ timestamp }}\n </div>\n\n <!-- Duration and Run Label -->\n <div class=\"cqa-flex cqa-items-center cqa-justify-between cqa-gap-2\">\n <div class=\"cqa-flex cqa-items-center cqa-text-[#636363]\" [ngClass]=\"{\n 'cqa-gap-1': isSmall,\n 'cqa-gap-[6px]': !isSmall\n }\" [title]=\"durationTooltip\">\n <mat-icon [ngClass]=\"{\n 'cqa-text-[12px] cqa-w-3 cqa-h-3': isSmall,\n 'cqa-text-[14px] cqa-w-[14px] cqa-h-[14px]': !isSmall }\" style=\"flex-shrink: 0;\">\n schedule\n </mat-icon>\n <span [ngClass]=\"{\n 'cqa-text-[8px]': isSmall,\n 'cqa-text-[10px]': !isSmall\n }\">\n {{ duration }}\n </span>\n </div>\n\n <span *ngIf=\"runLabel\" class=\"cqa-text-[#3F43EE] cqa-rounded-md cqa-whitespace-nowrap\"\n [ngStyle]=\"runLabelStyles\"\n [ngClass]=\"{ 'cqa-font-medium': !isSmall }\">\n {{ runLabel }}\n </span>\n </div>\n\n <!-- Error Message (only for failed status and normal size) -->\n <div *ngIf=\"errorMessage && status === 'failed' && !isSmall\" class=\"cqa-mt-2 cqa-pt-2\"\n style=\"border-top: 1px solid #E4E4E4;\">\n <p class=\"cqa-text-[10px] cqa-text-[#E7000B]\">\n {{ errorMessage }}\n </p>\n </div>\n </div>\n</div>", styles: [] }]
|
|
150
|
+
args: [{ selector: 'cqa-run-history-card', template: "<div class=\"cqa-ui-root\" style=\"display: block; width: 100%; height: 100%; min-width: 180px;\">\n <div class=\"cqa-bg-white cqa-rounded-lg cqa-shadow-sm cqa-flex cqa-flex-col\" [ngStyle]=\"{\n padding: cardPadding,\n border: '1px solid #E4E4E4',\n 'border-left-color': statusColor,\n 'border-left-width': borderLeftWidth\n }\">\n\n <!-- Header: Run ID and Status Badge -->\n <div class=\"cqa-flex cqa-items-start cqa-justify-between cqa-gap-2 cqa-flex-wrap\" [ngClass]=\"{\n 'cqa-mb-[10px]': isSmall,\n 'cqa-mb-2': !isSmall\n }\">\n <div class=\"cqa-flex cqa-items-center\" [ngClass]=\"{ 'cqa-gap-[6px]': isSmall, 'cqa-gap-2': !isSmall }\">\n <span [ngStyle]=\"statusIconContainerStyles\">\n <mat-icon [ngStyle]=\"statusIconStyles\">\n {{ statusIcon }}\n </mat-icon>\n </span>\n <span class=\"cqa-font-semibold cqa-text-[#3f43ee]\" [ngClass]=\"{\n 'cqa-text-xs': isSmall,\n 'cqa-text-sm': !isSmall\n }\">\n #{{ id }}\n </span>\n </div>\n\n <!-- Status Badge -->\n <span class=\"cqa-inline-flex cqa-items-center cqa-justify-center cqa-rounded-md cqa-font-medium cqa-text-white cqa-px-2\"\n [ngClass]=\"{\n 'cqa-py-[2px] cqa-text-[10px]': isSmall,\n 'cqa-py-1 cqa-text-xs': !isSmall\n }\" [ngStyle]=\"statusBadgeStyles\">\n {{ statusLabel }}\n </span>\n </div>\n\n <!-- Type and Timestamp -->\n <div class=\"cqa-flex cqa-items-center cqa-text-[#636363]\" [ngClass]=\"{\n 'cqa-gap-1': isSmall,\n 'cqa-gap-[6px]': !isSmall,\n 'cqa-mb-2': isSmall,\n 'cqa-mb-[6px]': !isSmall\n }\">\n <mat-icon [ngClass]=\"{\n 'cqa-text-[12px] cqa-w-3 cqa-h-3': isSmall,\n 'cqa-text-[14px] cqa-w-[14px] cqa-h-[14px]': !isSmall }\">\n {{ typeIcon }}\n </mat-icon>\n <span [ngClass]=\"{ 'cqa-text-[10px]': isSmall, 'cqa-text-xs': !isSmall }\">\n {{ typeLabel }}\n </span>\n </div>\n\n <!-- Timestamp -->\n <div class=\"cqa-font-normal cqa-text-[#0B0B0B] cqa-leading-normal\" [ngClass]=\"{\n 'cqa-text-sm': !isSmall,\n 'cqa-text-[11px]': isSmall,\n 'cqa-mb-2': isSmall,\n 'cqa-mb-[6px]': !isSmall\n }\">\n {{ timestamp }}\n </div>\n\n <!-- Duration and Run Label -->\n <div class=\"cqa-flex cqa-items-center cqa-justify-between cqa-gap-2\">\n <div class=\"cqa-flex cqa-items-center cqa-text-[#636363]\" [ngClass]=\"{\n 'cqa-gap-1': isSmall,\n 'cqa-gap-[6px]': !isSmall\n }\" [title]=\"durationTooltip\">\n <mat-icon [ngClass]=\"{\n 'cqa-text-[12px] cqa-w-3 cqa-h-3': isSmall,\n 'cqa-text-[14px] cqa-w-[14px] cqa-h-[14px]': !isSmall }\" style=\"flex-shrink: 0;\">\n schedule\n </mat-icon>\n <span [ngClass]=\"{\n 'cqa-text-[8px]': isSmall,\n 'cqa-text-[10px]': !isSmall\n }\">\n {{ duration }}\n </span>\n </div>\n\n <span *ngIf=\"runLabel\" class=\"cqa-text-[#3F43EE] cqa-rounded-md cqa-whitespace-nowrap\"\n [ngStyle]=\"runLabelStyles\"\n [ngClass]=\"{ 'cqa-font-medium': !isSmall }\">\n {{ runLabel }}\n </span>\n </div>\n\n <!-- Error Message (only for failed status and normal size) -->\n <div *ngIf=\"errorMessage && status === 'failed' && !isSmall\" class=\"cqa-mt-2 cqa-pt-2\"\n style=\"border-top: 1px solid #E4E4E4;\">\n <p class=\"cqa-text-[10px] cqa-text-[#E7000B]\">\n {{ errorMessage }}\n </p>\n </div>\n </div>\n</div>", styles: [] }]
|
|
150
151
|
}], propDecorators: { id: [{
|
|
151
152
|
type: Input
|
|
152
153
|
}], status: [{
|
|
@@ -166,4 +167,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImpor
|
|
|
166
167
|
}], durationTooltip: [{
|
|
167
168
|
type: Input
|
|
168
169
|
}] } });
|
|
169
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"run-history-card.component.js","sourceRoot":"","sources":["../../../../../src/lib/run-history-card/run-history-card.component.ts","../../../../../src/lib/run-history-card/run-history-card.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input } from \"@angular/core\";\n\nexport type RunStatus = 'passed' | 'failed' | 'aborted' | 'running' | 'stopped' | 'queued' | 'not-executed' | 'unknown';\nexport type RunType = 'automated' | 'manual';\nexport type CardSize = 'normal' | 'small';\n\n@Component({\n  selector: 'cqa-run-history-card',\n  templateUrl: './run-history-card.component.html',\n  styleUrls: []\n})\nexport class RunHistoryCardComponent {\n  @Input() id!: number;\n  @Input() status!: RunStatus;\n  @Input() type!: RunType;\n  @Input() timestamp!: string;\n  @Input() duration!: string;\n  @Input() runLabel?: string;\n  @Input() errorMessage?: string;\n  @Input() size: CardSize = 'normal';\n  @Input() durationTooltip?: string;\n\n  get statusLabel(): string {\n    switch (this.status) {\n      case 'passed':\n        return 'Passed';\n      case 'failed':\n        return 'Failed';\n      case 'aborted':\n        return 'Aborted';\n      case 'running':\n        return 'Running';\n      case 'stopped':\n        return 'Stopped';\n      case 'queued':\n        return 'Queued';\n      case 'not-executed':\n        return 'Not Executed';\n      case 'unknown':\n        return 'Unknown';\n      default:\n        return '';\n    }\n  }\n\n  get statusColor(): string {\n    switch (this.status) {\n      case 'passed':\n        return '#00C950';\n      case 'failed':\n        return '#FB2C36';\n      case 'aborted':\n        return '#F97316';\n      case 'running':\n        return '#3B82F6';\n      case 'stopped':\n        return '#EF4444';\n      case 'queued':\n        return '#8B5CF6';\n      case 'not-executed':\n        return '#6B7280';\n      case 'unknown':\n        return '#9CA3AF';\n      default:\n        return '#6B7280';\n    }\n  }\n\n  get statusIconBgColor(): string {\n    switch (this.status) {\n        case 'passed':\n            return '#DCFCE7';\n        case 'failed':\n            return '#ffe2e2';\n        case 'aborted':\n            return '#FFEDD5'; \n        case 'running':\n            return '#DBEAFE';\n        case 'stopped':\n            return '#FEE2E2';\n        case 'queued':\n            return '#EDE9FE';\n        case 'not-executed':\n            return '#F3F4F6';\n        case 'unknown':\n            return '#F3F4F6';\n        default:\n            return '#E5E7EB';\n    }\n  }\n\n  get statusIcon(): string {\n    switch (this.status) {\n      case 'passed':\n        return 'check';\n      case 'failed':\n        return 'close';\n      case 'aborted':\n        return 'warning';\n      case 'running':\n        return 'schedule';\n      case 'stopped':\n        return 'stop';\n      case 'queued':\n        return 'hourglass_empty';\n      case 'not-executed':\n        return 'remove_circle_outline';\n      case 'unknown':\n        return 'help_outline';\n      default:\n        return 'help_outline';\n    }\n  }\n\n  get typeIcon(): string {\n    return this.type === 'automated' ? 'settings' : 'person';\n  }\n\n  get typeLabel(): string {\n    return this.type === 'automated' ? 'Automated' : 'Manual';\n  }\n\n  get isSmall(): boolean {\n    return this.size === 'small';\n  }\n\n  get statusIconContainerStyles(): { [key: string]: string } {\n    return {\n      'background-color': this.statusIconBgColor,\n      'width': this.isSmall ? '16px' : '20px',\n      'height': this.isSmall ? '16px' : '20px',\n      'border-radius': '4px',\n      'display': 'inline-flex',\n      'align-items': 'center',\n      'justify-content': 'center'\n    };\n  }\n\n  get statusIconStyles(): { [key: string]: string } {\n    return {\n      'color': this.statusColor,\n      'font-size': this.isSmall ? '10px' : '12px',\n      'width': this.isSmall ? '10px' : '12px',\n      'height': this.isSmall ? '10px' : '12px'\n    };\n  }\n\n  get statusBadgeStyles(): { [key: string]: string } {\n    return {\n      'background-color': this.statusColor\n    };\n  }\n\n  get runLabelStyles(): { [key: string]: string } {\n    return {\n      'background-color': '#ecedfe',\n      'padding': this.isSmall ? '2px 6px' : '2px 8px',\n      'border-radius': this.isSmall ? '5px' : '4px',\n      'font-size' : this.isSmall ? '8px' : '10px'\n    };\n  }\n\n  get cardPadding(): string {\n    return this.isSmall ? '10px' : '12px';\n  }\n\n  get borderLeftWidth(): string {\n    return this.isSmall ? '3px' : '4px';\n  }\n\n}","<div class=\"cqa-ui-root\" style=\"display: block; width: 100%; height: 100%; min-width: 180px;\">\n  <div class=\"cqa-bg-white cqa-rounded-lg cqa-shadow-sm cqa-flex cqa-flex-col\" [ngStyle]=\"{\n      padding: cardPadding,\n      border: '1px solid #E4E4E4',\n      'border-left-color': statusColor,\n      'border-left-width': borderLeftWidth\n    }\">\n\n    <!-- Header: Run ID and Status Badge -->\n    <div class=\"cqa-flex cqa-items-start cqa-justify-between cqa-gap-2 cqa-flex-wrap\" [ngClass]=\"{\n        'cqa-mb-[10px]': isSmall,\n        'cqa-mb-2': !isSmall\n      }\">\n      <div class=\"cqa-flex cqa-items-center\" [ngClass]=\"{ 'cqa-gap-[6px]': isSmall, 'cqa-gap-2': !isSmall }\">\n        <span [ngStyle]=\"statusIconContainerStyles\">\n          <mat-icon [ngStyle]=\"statusIconStyles\">\n            {{ statusIcon }}\n          </mat-icon>\n        </span>\n        <span class=\"cqa-font-semibold cqa-text-[#3f43ee]\" [ngClass]=\"{\n            'cqa-text-xs': isSmall,\n            'cqa-text-sm': !isSmall\n          }\">\n          #{{ id }}\n        </span>\n      </div>\n\n      <!-- Status Badge -->\n      <span class=\"cqa-inline-flex cqa-items-center cqa-justify-center cqa-rounded-md cqa-font-medium cqa-text-white cqa-px-2\"\n        [ngClass]=\"{\n          'cqa-py-[2px] cqa-text-[10px]': isSmall,\n          'cqa-py-1 cqa-text-xs': !isSmall\n        }\" [ngStyle]=\"statusBadgeStyles\">\n        {{ statusLabel }}\n      </span>\n    </div>\n\n    <!-- Type and Timestamp -->\n    <div class=\"cqa-flex cqa-items-center cqa-text-[#636363]\" [ngClass]=\"{\n          'cqa-gap-1': isSmall,\n          'cqa-gap-[6px]': !isSmall,\n          'cqa-mb-2': isSmall,\n          'cqa-mb-[6px]': !isSmall\n        }\">\n      <mat-icon [ngClass]=\"{\n        'cqa-text-[12px] cqa-w-3 cqa-h-3': isSmall,\n        'cqa-text-[14px] cqa-w-[14px] cqa-h-[14px]': !isSmall }\">\n        {{ typeIcon }}\n      </mat-icon>\n      <span [ngClass]=\"{ 'cqa-text-[10px]': isSmall, 'cqa-text-xs': !isSmall }\">\n        {{ typeLabel }}\n      </span>\n    </div>\n\n    <!-- Timestamp -->\n    <div class=\"cqa-font-normal cqa-text-[#0B0B0B]\" [ngClass]=\"{\n        'cqa-text-sm': !isSmall,\n        'cqa-text-[11px]': isSmall,\n        'cqa-mb-2': isSmall,\n        'cqa-mb-[6px]': !isSmall\n      }\">\n      {{ timestamp }}\n    </div>\n\n    <!-- Duration and Run Label -->\n    <div class=\"cqa-flex cqa-items-center cqa-justify-between cqa-gap-2\">\n      <div class=\"cqa-flex cqa-items-center cqa-text-[#636363]\" [ngClass]=\"{\n        'cqa-gap-1': isSmall,\n        'cqa-gap-[6px]': !isSmall\n      }\" [title]=\"durationTooltip\">\n        <mat-icon [ngClass]=\"{\n          'cqa-text-[12px] cqa-w-3 cqa-h-3': isSmall,\n          'cqa-text-[14px] cqa-w-[14px] cqa-h-[14px]': !isSmall }\" style=\"flex-shrink: 0;\">\n          schedule\n        </mat-icon>\n        <span [ngClass]=\"{\n          'cqa-text-[8px]': isSmall,\n          'cqa-text-[10px]': !isSmall\n        }\">\n          {{ duration }}\n        </span>\n      </div>\n\n      <span *ngIf=\"runLabel\" class=\"cqa-text-[#3F43EE] cqa-rounded-md cqa-whitespace-nowrap\"\n        [ngStyle]=\"runLabelStyles\"\n        [ngClass]=\"{ 'cqa-font-medium': !isSmall }\">\n        {{ runLabel }}\n      </span>\n    </div>\n\n    <!-- Error Message (only for failed status and normal size) -->\n    <div *ngIf=\"errorMessage && status === 'failed' && !isSmall\" class=\"cqa-mt-2 cqa-pt-2\"\n      style=\"border-top: 1px solid #E4E4E4;\">\n      <p class=\"cqa-text-[10px] cqa-text-[#E7000B]\">\n        {{ errorMessage }}\n      </p>\n    </div>\n  </div>\n</div>"]}
|
|
170
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"run-history-card.component.js","sourceRoot":"","sources":["../../../../../src/lib/run-history-card/run-history-card.component.ts","../../../../../src/lib/run-history-card/run-history-card.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input } from \"@angular/core\";\n\nexport type RunStatus = 'passed' | 'failed' | 'aborted' | 'running' | 'stopped' | 'queued' | 'not-executed' | 'unknown';\nexport type RunType = 'automated' | 'manual';\nexport type CardSize = 'normal' | 'small';\n\n@Component({\n  selector: 'cqa-run-history-card',\n  templateUrl: './run-history-card.component.html',\n  styleUrls: []\n})\nexport class RunHistoryCardComponent {\n  @Input() id!: number;\n  @Input() status!: RunStatus;\n  @Input() type!: RunType;\n  @Input() timestamp!: string;\n  @Input() duration!: string;\n  @Input() runLabel?: string;\n  @Input() errorMessage?: string;\n  @Input() size: CardSize = 'normal';\n  @Input() durationTooltip?: string;\n\n  get statusLabel(): string {\n    switch (this.status) {\n      case 'passed':\n        return 'Passed';\n      case 'failed':\n        return 'Failed';\n      case 'aborted':\n        return 'Aborted';\n      case 'running':\n        return 'Running';\n      case 'stopped':\n        return 'Stopped';\n      case 'queued':\n        return 'Queued';\n      case 'not-executed':\n        return 'Not Executed';\n      case 'unknown':\n        return 'Unknown';\n      default:\n        return '';\n    }\n  }\n\n  get statusColor(): string {\n    switch (this.status) {\n      case 'passed':\n        return '#00C950';\n      case 'failed':\n        return '#FB2C36';\n      case 'aborted':\n        return '#F97316';\n      case 'running':\n        return '#3B82F6';\n      case 'stopped':\n        return '#EF4444';\n      case 'queued':\n        return '#8B5CF6';\n      case 'not-executed':\n        return '#6B7280';\n      case 'unknown':\n        return '#9CA3AF';\n      default:\n        return '#6B7280';\n    }\n  }\n\n  get statusIconBgColor(): string {\n    switch (this.status) {\n        case 'passed':\n            return '#DCFCE7';\n        case 'failed':\n            return '#ffe2e2';\n        case 'aborted':\n            return '#FFEDD5'; \n        case 'running':\n            return '#DBEAFE';\n        case 'stopped':\n            return '#FEE2E2';\n        case 'queued':\n            return '#EDE9FE';\n        case 'not-executed':\n            return '#F3F4F6';\n        case 'unknown':\n            return '#F3F4F6';\n        default:\n            return '#E5E7EB';\n    }\n  }\n\n  get statusIcon(): string {\n    switch (this.status) {\n      case 'passed':\n        return 'check';\n      case 'failed':\n        return 'close';\n      case 'aborted':\n        return 'warning';\n      case 'running':\n        return 'schedule';\n      case 'stopped':\n        return 'stop';\n      case 'queued':\n        return 'hourglass_empty';\n      case 'not-executed':\n        return 'remove_circle_outline';\n      case 'unknown':\n        return 'help_outline';\n      default:\n        return 'help_outline';\n    }\n  }\n\n  get typeIcon(): string {\n    return this.type === 'automated' ? 'settings' : 'person';\n  }\n\n  get typeLabel(): string {\n    return this.type === 'automated' ? 'Automated' : 'Manual';\n  }\n\n  get isSmall(): boolean {\n    return this.size === 'small';\n  }\n\n  get statusIconContainerStyles(): { [key: string]: string } {\n    return {\n      'background-color': this.statusIconBgColor,\n      'width': this.isSmall ? '16px' : '20px',\n      'height': this.isSmall ? '16px' : '20px',\n      'border-radius': '4px',\n      'display': 'inline-flex',\n      'align-items': 'center',\n      'justify-content': 'center'\n    };\n  }\n\n  get statusIconStyles(): { [key: string]: string } {\n    return {\n      'color': this.statusColor,\n      'font-size': this.isSmall ? '10px' : '12px',\n      'width': this.isSmall ? '10px' : '12px',\n      'height': this.isSmall ? '10px' : '12px'\n    };\n  }\n\n  get statusBadgeStyles(): { [key: string]: string } {\n    return {\n      'background-color': this.statusColor\n    };\n  }\n\n  get runLabelStyles(): { [key: string]: string } {\n    return {\n      'background-color': '#ecedfe',\n      'padding': this.isSmall ? '2px 6px' : '2px 8px',\n      'border-radius': this.isSmall ? '5px' : '4px',\n      'font-size' : this.isSmall ? '8px' : '10px',\n      'line-height': this.isSmall ? '12px' : '15px'\n    };\n  }\n\n  get cardPadding(): string {\n    return this.isSmall ? '10px' : '12px';\n  }\n\n  get borderLeftWidth(): string {\n    return this.isSmall ? '3px' : '4px';\n  }\n\n}","<div class=\"cqa-ui-root\" style=\"display: block; width: 100%; height: 100%; min-width: 180px;\">\n  <div class=\"cqa-bg-white cqa-rounded-lg cqa-shadow-sm cqa-flex cqa-flex-col\" [ngStyle]=\"{\n      padding: cardPadding,\n      border: '1px solid #E4E4E4',\n      'border-left-color': statusColor,\n      'border-left-width': borderLeftWidth\n    }\">\n\n    <!-- Header: Run ID and Status Badge -->\n    <div class=\"cqa-flex cqa-items-start cqa-justify-between cqa-gap-2 cqa-flex-wrap\" [ngClass]=\"{\n        'cqa-mb-[10px]': isSmall,\n        'cqa-mb-2': !isSmall\n      }\">\n      <div class=\"cqa-flex cqa-items-center\" [ngClass]=\"{ 'cqa-gap-[6px]': isSmall, 'cqa-gap-2': !isSmall }\">\n        <span [ngStyle]=\"statusIconContainerStyles\">\n          <mat-icon [ngStyle]=\"statusIconStyles\">\n            {{ statusIcon }}\n          </mat-icon>\n        </span>\n        <span class=\"cqa-font-semibold cqa-text-[#3f43ee]\" [ngClass]=\"{\n            'cqa-text-xs': isSmall,\n            'cqa-text-sm': !isSmall\n          }\">\n          #{{ id }}\n        </span>\n      </div>\n\n      <!-- Status Badge -->\n      <span class=\"cqa-inline-flex cqa-items-center cqa-justify-center cqa-rounded-md cqa-font-medium cqa-text-white cqa-px-2\"\n        [ngClass]=\"{\n          'cqa-py-[2px] cqa-text-[10px]': isSmall,\n          'cqa-py-1 cqa-text-xs': !isSmall\n        }\" [ngStyle]=\"statusBadgeStyles\">\n        {{ statusLabel }}\n      </span>\n    </div>\n\n    <!-- Type and Timestamp -->\n    <div class=\"cqa-flex cqa-items-center cqa-text-[#636363]\" [ngClass]=\"{\n          'cqa-gap-1': isSmall,\n          'cqa-gap-[6px]': !isSmall,\n          'cqa-mb-2': isSmall,\n          'cqa-mb-[6px]': !isSmall\n        }\">\n      <mat-icon [ngClass]=\"{\n        'cqa-text-[12px] cqa-w-3 cqa-h-3': isSmall,\n        'cqa-text-[14px] cqa-w-[14px] cqa-h-[14px]': !isSmall }\">\n        {{ typeIcon }}\n      </mat-icon>\n      <span [ngClass]=\"{ 'cqa-text-[10px]': isSmall, 'cqa-text-xs': !isSmall }\">\n        {{ typeLabel }}\n      </span>\n    </div>\n\n    <!-- Timestamp -->\n    <div class=\"cqa-font-normal cqa-text-[#0B0B0B] cqa-leading-normal\" [ngClass]=\"{\n        'cqa-text-sm': !isSmall,\n        'cqa-text-[11px]': isSmall,\n        'cqa-mb-2': isSmall,\n        'cqa-mb-[6px]': !isSmall\n      }\">\n      {{ timestamp }}\n    </div>\n\n    <!-- Duration and Run Label -->\n    <div class=\"cqa-flex cqa-items-center cqa-justify-between cqa-gap-2\">\n      <div class=\"cqa-flex cqa-items-center cqa-text-[#636363]\" [ngClass]=\"{\n        'cqa-gap-1': isSmall,\n        'cqa-gap-[6px]': !isSmall\n      }\" [title]=\"durationTooltip\">\n        <mat-icon [ngClass]=\"{\n          'cqa-text-[12px] cqa-w-3 cqa-h-3': isSmall,\n          'cqa-text-[14px] cqa-w-[14px] cqa-h-[14px]': !isSmall }\" style=\"flex-shrink: 0;\">\n          schedule\n        </mat-icon>\n        <span [ngClass]=\"{\n          'cqa-text-[8px]': isSmall,\n          'cqa-text-[10px]': !isSmall\n        }\">\n          {{ duration }}\n        </span>\n      </div>\n\n      <span *ngIf=\"runLabel\" class=\"cqa-text-[#3F43EE] cqa-rounded-md cqa-whitespace-nowrap\"\n        [ngStyle]=\"runLabelStyles\"\n        [ngClass]=\"{ 'cqa-font-medium': !isSmall }\">\n        {{ runLabel }}\n      </span>\n    </div>\n\n    <!-- Error Message (only for failed status and normal size) -->\n    <div *ngIf=\"errorMessage && status === 'failed' && !isSmall\" class=\"cqa-mt-2 cqa-pt-2\"\n      style=\"border-top: 1px solid #E4E4E4;\">\n      <p class=\"cqa-text-[10px] cqa-text-[#E7000B]\">\n        {{ errorMessage }}\n      </p>\n    </div>\n  </div>\n</div>"]}
|