@cqa-lib/cqa-ui 1.1.124 → 1.1.125
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.
|
@@ -93,4 +93,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImpor
|
|
|
93
93
|
}], closeModal: [{
|
|
94
94
|
type: Output
|
|
95
95
|
}] } });
|
|
96
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"execution-result-modal.component.js","sourceRoot":"","sources":["../../../../../src/lib/execution-result-modal/execution-result-modal.component.ts","../../../../../src/lib/execution-result-modal/execution-result-modal.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,KAAK,EAAE,MAAM,EAAE,YAAY,EAAE,MAAM,eAAe,CAAC;;;;AA6BvE,MAAM,OAAO,6BAA6B;IAL1C;QAMW,WAAM,GAAY,KAAK,CAAC;QACxB,WAAM,GAAoB,QAAQ,CAAC;QACnC,UAAK,GAAW,EAAE,CAAC;QACnB,eAAU,GAAW,CAAC,CAAC;QACvB,mBAAc,GAAW,CAAC,CAAC;QAC3B,cAAS,GAAW,EAAE,CAAC;QACvB,YAAO,GAAW,EAAE,CAAC;QACrB,aAAQ,GAAW,EAAE,CAAC;QAEtB,YAAO,GAA4B,EAAE,CAAC;QACtC,gBAAW,GAAiB,EAAE,CAAC;QAE9B,gBAAW,GAAG,IAAI,YAAY,EAAU,CAAC;QACzC,eAAU,GAAG,IAAI,YAAY,EAAQ,CAAC;KAoDhD;IAlDA,IAAI,oBAAoB;QACtB,QAAQ,IAAI,CAAC,MAAM,EAAE;YACnB,KAAK,QAAQ;gBACX,OAAO,oBAAoB,CAAC;YAC9B,KAAK,QAAQ;gBACX,OAAO,oBAAoB,CAAC;YAC9B,KAAK,SAAS;gBACZ,OAAO,oBAAoB,CAAC;YAC9B;gBACE,OAAO,iBAAiB,CAAC;SAC5B;IACH,CAAC;IAED,IAAI,gBAAgB;QAClB,QAAQ,IAAI,CAAC,MAAM,EAAE;YACnB,KAAK,QAAQ;gBACX,OAAO,SAAS,CAAC;YACnB,KAAK,QAAQ;gBACX,OAAO,SAAS,CAAC;YACnB,KAAK,SAAS;gBACZ,OAAO,SAAS,CAAC;YACnB;gBACE,OAAO,SAAS,CAAC;SACpB;IACH,CAAC;IAED,IAAI,2BAA2B;QAC7B,OAAO,IAAI,CAAC,MAAM,KAAK,SAAS,IAAI,CAAC,CAAC,IAAI,CAAC,iBAAiB,CAAC;IAC/D,CAAC;IAED,IAAI,qBAAqB;QACvB,OAAO,IAAI,CAAC,MAAM,KAAK,QAAQ,IAAI,IAAI,CAAC,WAAW,IAAI,IAAI,CAAC,WAAW,CAAC,MAAM,GAAG,CAAC,CAAC;IACrF,CAAC;IAED,eAAe,CAAC,KAAiB;QAC/B,MAAM,MAAM,GAAG,KAAK,CAAC,MAAqB,CAAC;QAC3C,MAAM,aAAa,GAAG,KAAK,CAAC,aAA4B,CAAC;QAEzD,IAAI,MAAM,KAAK,aAAa,IAAI,MAAM,CAAC,SAAS,CAAC,QAAQ,CAAC,gBAAgB,CAAC,EAAE;YAC3E,IAAI,CAAC,OAAO,EAAE,CAAC;SAChB;IACH,CAAC;IAED,aAAa,CAAC,MAA6B;QACzC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;IACvC,CAAC;IAED,OAAO;QACL,IAAI,CAAC,UAAU,CAAC,IAAI,EAAE,CAAC;IACzB,CAAC;;0HAjEU,6BAA6B;8GAA7B,6BAA6B,2ZC7B1C,wuQAgIA;2FDnGa,6BAA6B;kBALzC,SAAS;+BACE,4BAA4B;8BAK7B,MAAM;sBAAd,KAAK;gBACG,MAAM;sBAAd,KAAK;gBACG,KAAK;sBAAb,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBACG,cAAc;sBAAtB,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,iBAAiB;sBAAzB,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBAEI,WAAW;sBAApB,MAAM;gBACG,UAAU;sBAAnB,MAAM","sourcesContent":["import { Component, Input, Output, EventEmitter } from '@angular/core';\nimport { ButtonVariant } from '../button/button.component';\n\nexport type ExecutionStatus = 'passed' | 'failed' | 'aborted';\n\nexport interface ExecutionResultButton {\n  label: string;\n  variant: ButtonVariant;\n  icon?: string;\n  action: string;\n  btnSize?: 'sm' | 'md' | 'lg';\n  fullWidth?: boolean;\n}\n\nexport interface FailedStep {\n  failedStep: number;\n  stepTitle?: string;\n  error?: string;\n  timestamp?: string;\n  suggestions?: string;\n  actual?: string;\n  expected?: string;\n}\n\n@Component({\n  selector: 'cqa-execution-result-modal',\n  templateUrl: './execution-result-modal.component.html',\n  styleUrls: []\n})\nexport class ExecutionResultModalComponent {\n  @Input() isOpen: boolean = false;\n  @Input() status: ExecutionStatus = 'passed';\n  @Input() title: string = '';\n  @Input() totalSteps: number = 0;\n  @Input() completedSteps: number = 0;\n  @Input() totalTime: string = '';\n  @Input() appTime: string = '';\n  @Input() toolTime: string = '';\n  @Input() lastCompletedStep?: string;\n  @Input() buttons: ExecutionResultButton[] = [];\n  @Input() failedSteps: FailedStep[] = [];\n\n  @Output() buttonClick = new EventEmitter<string>();\n  @Output() closeModal = new EventEmitter<void>();\n\n  get stepsBackgroundClass(): string {\n    switch (this.status) {\n      case 'passed':\n        return 'cqa-bg-[#0DBD7D1A]';\n      case 'failed':\n        return 'cqa-bg-[#EE3F3F1A]';\n      case 'aborted':\n        return 'cqa-bg-[#FBBF241A]';\n      default:\n        return 'cqa-bg-gray-100';\n    }\n  }\n\n  get stepsBorderClass(): string {\n    switch (this.status) {\n      case 'passed':\n        return '#BBF7D0';\n      case 'failed':\n        return '#FECACA';\n      case 'aborted':\n        return '#FDE68A';\n      default:\n        return '#E5E7EB';\n    }\n  }\n\n  get shouldShowLastCompletedStep(): boolean {\n    return this.status === 'aborted' && !!this.lastCompletedStep;\n  }\n\n  get shouldShowFailedSteps(): boolean {\n    return this.status === 'failed' && this.failedSteps && this.failedSteps.length > 0;\n  }\n\n  onBackdropClick(event: MouseEvent): void {\n    const target = event.target as HTMLElement;\n    const currentTarget = event.currentTarget as HTMLElement;\n    \n    if (target === currentTarget || target.classList.contains('modal-backdrop')) {\n      this.onClose();\n    }\n  }\n\n  onButtonClick(button: ExecutionResultButton): void {\n    this.buttonClick.emit(button.action);\n  }\n\n  onClose(): void {\n    this.closeModal.emit();\n  }\n }\n \n","<div \n  *ngIf=\"isOpen\"\n  class=\"modal-backdrop cqa-fixed cqa-inset-0 cqa-bg-black cqa-bg-opacity-50 cqa-z-50 cqa-flex cqa-items-center cqa-justify-center cqa-p-4\"\n  (click)=\"onBackdropClick($event)\">\n  <div \n    class=\"cqa-rounded-lg cqa-bg-white cqa-shadow-xl cqa-w-full cqa-max-w-[500px] cqa-overflow-hidden cqa-p-6 cqa-flex cqa-flex-col cqa-gap-2\"\n    style=\"box-shadow: 0px 8px 8px -4px #10182808;\"\n    (click)=\"$event.stopPropagation()\">\n      \n      <div class=\"cqa-flex cqa-flex-col cqa-items-center\">\n          <div *ngIf=\"status === 'passed'\">\n            <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"93\" height=\"93\" viewBox=\"0 0 93 93\" fill=\"none\">\n              <rect x=\"4\" y=\"4\" width=\"85\" height=\"85\" rx=\"42.5\" fill=\"#AEE9D4\"/>\n              <rect x=\"4\" y=\"4\" width=\"85\" height=\"85\" rx=\"42.5\" stroke=\"#CFF2E5\" stroke-width=\"8\"/>\n              <path d=\"M75.25 43.8549V46.4999C75.2465 52.6996 73.2389 58.732 69.5268 63.6976C65.8147 68.6632 60.5969 72.2957 54.6517 74.0536C48.7064 75.8114 42.3521 75.6003 36.5366 73.4518C30.7211 71.3033 25.7559 67.3324 22.3815 62.1314C19.0071 56.9305 17.4044 50.778 17.8123 44.5918C18.2202 38.4055 20.617 32.5168 24.6451 27.8039C28.6731 23.0911 34.1168 19.8066 40.164 18.4403C46.2113 17.074 52.5383 17.6991 58.2013 20.2224M75.25 23.4999L46.5 52.2786L37.875 43.6536\" stroke=\"#0DBD7D\" stroke-width=\"4\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n            </svg>\n          </div>\n  \n          <div *ngIf=\"status === 'failed'\">\n            <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"93\" height=\"93\" viewBox=\"0 0 93 93\" fill=\"none\">\n              <rect x=\"4\" y=\"4\" width=\"85\" height=\"85\" rx=\"42.5\" fill=\"#F9BFBF\"/>\n              <rect x=\"4\" y=\"4\" width=\"85\" height=\"85\" rx=\"42.5\" stroke=\"#FCD9D9\" stroke-width=\"8\"/>\n              <path d=\"M55.125 37.875L37.875 55.125M37.875 37.875L55.125 55.125M75.25 46.5C75.25 62.3782 62.3782 75.25 46.5 75.25C30.6218 75.25 17.75 62.3782 17.75 46.5C17.75 30.6218 30.6218 17.75 46.5 17.75C62.3782 17.75 75.25 30.6218 75.25 46.5Z\" stroke=\"#EE3F3F\" stroke-width=\"4\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n              </svg>\n          </div>\n  \n          <div *ngIf=\"status === 'aborted'\">\n            <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"93\" height=\"93\" viewBox=\"0 0 93 93\" fill=\"none\">\n              <rect x=\"4\" y=\"4\" width=\"85\" height=\"85\" rx=\"42.5\" fill=\"#FEECBD\"/>\n              <rect x=\"4\" y=\"4\" width=\"85\" height=\"85\" rx=\"42.5\" stroke=\"#FFF9E9\" stroke-width=\"8\"/>\n              <path d=\"M46.5 17.75C30.63 17.75 17.75 30.63 17.75 46.5C17.75 62.37 30.63 75.25 46.5 75.25C62.37 75.25 75.25 62.37 75.25 46.5C75.25 30.63 62.37 17.75 46.5 17.75ZM46.5 69.5C33.7925 69.5 23.5 59.2075 23.5 46.5C23.5 33.7925 33.7925 23.5 46.5 23.5C59.2075 23.5 69.5 33.7925 69.5 46.5C69.5 59.2075 59.2075 69.5 46.5 69.5ZM58 58H35V35H58V58Z\" fill=\"#FBBF24\"/>\n              </svg>\n          </div>\n  \n        <h2 class=\"cqa-text-[22px] cqa-font-semibold cqa-text-[#0B0B0C] cqa-mt-[20px] cqa-leading-[28px]\">\n          {{ title }}\n        </h2>\n      </div>\n  \n      <div class=\"cqa-rounded-lg cqa-border cqa-p-[17px] cqa-my-4\"\n           [ngClass]=\"stepsBackgroundClass\" style=\"border: 1px solid;\" [style.border-color]=\"stepsBorderClass\">\n        <div class=\"cqa-grid sm:cqa-flex sm:cqa-justify-between sm:cqa-items-center cqa-grid-cols-2 sm:cqa-grid-cols-4 cqa-gap-4 sm:cqa-gap-2\">\n          <div class=\"cqa-flex cqa-flex-col\" *ngIf=\"totalSteps\">\n            <span class=\"cqa-text-xs cqa-text-[#4A5565] cqa-mb-1\">Total Steps</span>\n            <span class=\"cqa-text-[18px] cqa-font-medium cqa-text-[#101828]\">\n              {{ completedSteps }} / {{ totalSteps }}\n            </span>\n          </div>\n  \n          <div class=\"cqa-flex cqa-flex-col\" *ngIf=\"totalTime\">\n            <span class=\"cqa-text-xs cqa-text-[#4A5565] cqa-mb-1\">Total Time</span>\n            <span class=\"cqa-text-[18px] cqa-font-medium cqa-text-[#101828]\">\n              {{ totalTime }}\n            </span>\n          </div>\n  \n          <div class=\"cqa-flex cqa-flex-col\" *ngIf=\"appTime\">\n            <span class=\"cqa-text-xs cqa-text-[#4A5565] cqa-mb-1\">App Time</span>\n            <span class=\"cqa-text-[18px] cqa-font-medium cqa-text-[#101828]\">\n              {{ appTime }}\n            </span>\n          </div>\n  \n          <div class=\"cqa-flex cqa-flex-col\" *ngIf=\"toolTime\">\n            <span class=\"cqa-text-xs cqa-text-[#4A5565] cqa-mb-1\">Tool Time</span>\n            <span class=\"cqa-text-[18px] cqa-font-medium cqa-text-[#101828]\">\n              {{ toolTime }}\n            </span>\n          </div>\n        </div>\n      </div>\n  \n      <div *ngIf=\"shouldShowLastCompletedStep\" class=\"cqa-my-4 cqa-p-[17px] cqa-rounded-[10px] cqa-h-[200px] cqa-overflow-y-auto\" style=\"border: 1px solid #E5E7EB; scrollbar-width: thin;\">\n        <div class=\"cqa-text-[12px] cqa-text-[#364153] cqa-mb-1 cqa-leading-[18px]\">\n          Last completed step:\n        </div>\n        <div class=\"cqa-text-[12px] cqa-font-semibold cqa-text-[#101828] cqa-leading-[18px]\" style=\"word-break: break-word;\">\n          <span [innerHTML]=\"lastCompletedStep\"></span>\n        </div>\n      </div>\n\n      <div *ngIf=\"shouldShowFailedSteps\" class=\"cqa-my-4 cqa-max-h-[300px] cqa-overflow-y-auto\" style=\"scrollbar-width: thin;\">\n        <div class=\"cqa-flex cqa-flex-col cqa-gap-3\">\n          <div \n            *ngFor=\"let failedStep of failedSteps\" \n            class=\"cqa-rounded-lg cqa-p-[17px] cqa-bg-[#FEF2F2]\"\n            style=\"border: 1px solid #FECACA;\">\n            <div *ngIf=\"failedStep?.failedStep\" class=\"cqa-text-sm cqa-font-semibold cqa-text-[#111827] cqa-mb-2 cqa-leading-[18px]\">\n              Failed at Step {{ failedStep.failedStep }}<span *ngIf=\"failedStep.stepTitle\">: {{ failedStep.stepTitle }}</span>\n            </div>\n            <div *ngIf=\"failedStep.error\" class=\"cqa-text-[12px] cqa-text-[#B91C1C] cqa-mb-1 cqa-whitespace-normal cqa-break-anywhere\" style=\"word-break: break-word;\">\n              <span class=\"cqa-font-bold\">Error:</span> {{ failedStep.error }}\n            </div>\n            <div *ngIf=\"failedStep.actual\" class=\"cqa-text-[12px] cqa-text-[#B91C1C] cqa-mb-1 cqa-whitespace-normal cqa-break-anywhere\" style=\"word-break: break-word;\">\n              <span class=\"cqa-font-bold\">Actual:</span> {{ failedStep.actual }}\n            </div>\n            <div *ngIf=\"failedStep.expected\" class=\"cqa-text-[12px] cqa-text-[#B91C1C] cqa-mb-2 cqa-whitespace-normal cqa-break-anywhere\" style=\"word-break: break-word;\">\n              <span class=\"cqa-font-bold\">Expected:</span> {{ failedStep.expected }}\n            </div>\n            <div *ngIf=\"failedStep.suggestions\" class=\"cqa-text-[12px] cqa-text-[#B91C1C] cqa-mb-1 cqa-whitespace-normal cqa-break-anywhere\" style=\"word-break: break-word;\">\n              <span class=\"cqa-font-bold\">Suggestions:</span> {{ failedStep.suggestions }}\n            </div>\n            <div *ngIf=\"failedStep.timestamp\" class=\"cqa-flex cqa-items-center cqa-gap-1 cqa-text-[12px] cqa-text-[#636363]\">\n              <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"12\" height=\"12\" viewBox=\"0 0 12 12\" fill=\"none\">\n                <path d=\"M6 1V6L9 7.5\" stroke=\"#636363\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n                <circle cx=\"6\" cy=\"6\" r=\"5\" stroke=\"#636363\" stroke-width=\"1.5\"/>\n              </svg>\n              <span>View screenshot at {{ failedStep.timestamp }}</span>\n            </div>\n          </div>\n        </div>\n      </div>\n  \n      <div class=\"cqa-flex cqa-flex-col cqa-gap-[20px]\">\n        <ng-container *ngFor=\"let button of buttons; let i = index\">\n          <cqa-button\n            [variant]=\"button.variant\"\n            [text]=\"button.label\"\n            [icon]=\"button.icon\"\n            [btnSize]=\"button.btnSize || 'lg'\"\n            [fullWidth]=\"button.fullWidth !== undefined ? button.fullWidth : true\"\n            (clicked)=\"onButtonClick(button)\">\n          </cqa-button>\n        </ng-container>\n      </div>\n    </div>\n  </div>\n\n"]}
|
|
96
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"execution-result-modal.component.js","sourceRoot":"","sources":["../../../../../src/lib/execution-result-modal/execution-result-modal.component.ts","../../../../../src/lib/execution-result-modal/execution-result-modal.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,KAAK,EAAE,MAAM,EAAE,YAAY,EAAE,MAAM,eAAe,CAAC;;;;AA6BvE,MAAM,OAAO,6BAA6B;IAL1C;QAMW,WAAM,GAAY,KAAK,CAAC;QACxB,WAAM,GAAoB,QAAQ,CAAC;QACnC,UAAK,GAAW,EAAE,CAAC;QACnB,eAAU,GAAW,CAAC,CAAC;QACvB,mBAAc,GAAW,CAAC,CAAC;QAC3B,cAAS,GAAW,EAAE,CAAC;QACvB,YAAO,GAAW,EAAE,CAAC;QACrB,aAAQ,GAAW,EAAE,CAAC;QAEtB,YAAO,GAA4B,EAAE,CAAC;QACtC,gBAAW,GAAiB,EAAE,CAAC;QAE9B,gBAAW,GAAG,IAAI,YAAY,EAAU,CAAC;QACzC,eAAU,GAAG,IAAI,YAAY,EAAQ,CAAC;KAoDhD;IAlDA,IAAI,oBAAoB;QACtB,QAAQ,IAAI,CAAC,MAAM,EAAE;YACnB,KAAK,QAAQ;gBACX,OAAO,oBAAoB,CAAC;YAC9B,KAAK,QAAQ;gBACX,OAAO,oBAAoB,CAAC;YAC9B,KAAK,SAAS;gBACZ,OAAO,oBAAoB,CAAC;YAC9B;gBACE,OAAO,iBAAiB,CAAC;SAC5B;IACH,CAAC;IAED,IAAI,gBAAgB;QAClB,QAAQ,IAAI,CAAC,MAAM,EAAE;YACnB,KAAK,QAAQ;gBACX,OAAO,SAAS,CAAC;YACnB,KAAK,QAAQ;gBACX,OAAO,SAAS,CAAC;YACnB,KAAK,SAAS;gBACZ,OAAO,SAAS,CAAC;YACnB;gBACE,OAAO,SAAS,CAAC;SACpB;IACH,CAAC;IAED,IAAI,2BAA2B;QAC7B,OAAO,IAAI,CAAC,MAAM,KAAK,SAAS,IAAI,CAAC,CAAC,IAAI,CAAC,iBAAiB,CAAC;IAC/D,CAAC;IAED,IAAI,qBAAqB;QACvB,OAAO,IAAI,CAAC,MAAM,KAAK,QAAQ,IAAI,IAAI,CAAC,WAAW,IAAI,IAAI,CAAC,WAAW,CAAC,MAAM,GAAG,CAAC,CAAC;IACrF,CAAC;IAED,eAAe,CAAC,KAAiB;QAC/B,MAAM,MAAM,GAAG,KAAK,CAAC,MAAqB,CAAC;QAC3C,MAAM,aAAa,GAAG,KAAK,CAAC,aAA4B,CAAC;QAEzD,IAAI,MAAM,KAAK,aAAa,IAAI,MAAM,CAAC,SAAS,CAAC,QAAQ,CAAC,gBAAgB,CAAC,EAAE;YAC3E,IAAI,CAAC,OAAO,EAAE,CAAC;SAChB;IACH,CAAC;IAED,aAAa,CAAC,MAA6B;QACzC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;IACvC,CAAC;IAED,OAAO;QACL,IAAI,CAAC,UAAU,CAAC,IAAI,EAAE,CAAC;IACzB,CAAC;;0HAjEU,6BAA6B;8GAA7B,6BAA6B,2ZC7B1C,wuQAgIA;2FDnGa,6BAA6B;kBALzC,SAAS;+BACE,4BAA4B;8BAK7B,MAAM;sBAAd,KAAK;gBACG,MAAM;sBAAd,KAAK;gBACG,KAAK;sBAAb,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBACG,cAAc;sBAAtB,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,iBAAiB;sBAAzB,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBAEI,WAAW;sBAApB,MAAM;gBACG,UAAU;sBAAnB,MAAM","sourcesContent":["import { Component, Input, Output, EventEmitter } from '@angular/core';\nimport { ButtonVariant } from '../button/button.component';\n\nexport type ExecutionStatus = 'passed' | 'failed' | 'aborted' | 'error';\n\nexport interface ExecutionResultButton {\n  label: string;\n  variant: ButtonVariant;\n  icon?: string;\n  action: string;\n  btnSize?: 'sm' | 'md' | 'lg';\n  fullWidth?: boolean;\n}\n\nexport interface FailedStep {\n  failedStep: number;\n  stepTitle?: string;\n  error?: string;\n  timestamp?: string;\n  suggestions?: string;\n  actual?: string;\n  expected?: string;\n}\n\n@Component({\n  selector: 'cqa-execution-result-modal',\n  templateUrl: './execution-result-modal.component.html',\n  styleUrls: []\n})\nexport class ExecutionResultModalComponent {\n  @Input() isOpen: boolean = false;\n  @Input() status: ExecutionStatus = 'passed';\n  @Input() title: string = '';\n  @Input() totalSteps: number = 0;\n  @Input() completedSteps: number = 0;\n  @Input() totalTime: string = '';\n  @Input() appTime: string = '';\n  @Input() toolTime: string = '';\n  @Input() lastCompletedStep?: string;\n  @Input() buttons: ExecutionResultButton[] = [];\n  @Input() failedSteps: FailedStep[] = [];\n\n  @Output() buttonClick = new EventEmitter<string>();\n  @Output() closeModal = new EventEmitter<void>();\n\n  get stepsBackgroundClass(): string {\n    switch (this.status) {\n      case 'passed':\n        return 'cqa-bg-[#0DBD7D1A]';\n      case 'failed':\n        return 'cqa-bg-[#EE3F3F1A]';\n      case 'aborted':\n        return 'cqa-bg-[#FBBF241A]';\n      default:\n        return 'cqa-bg-gray-100';\n    }\n  }\n\n  get stepsBorderClass(): string {\n    switch (this.status) {\n      case 'passed':\n        return '#BBF7D0';\n      case 'failed':\n        return '#FECACA';\n      case 'aborted':\n        return '#FDE68A';\n      default:\n        return '#E5E7EB';\n    }\n  }\n\n  get shouldShowLastCompletedStep(): boolean {\n    return this.status === 'aborted' && !!this.lastCompletedStep;\n  }\n\n  get shouldShowFailedSteps(): boolean {\n    return this.status === 'failed' && this.failedSteps && this.failedSteps.length > 0;\n  }\n\n  onBackdropClick(event: MouseEvent): void {\n    const target = event.target as HTMLElement;\n    const currentTarget = event.currentTarget as HTMLElement;\n    \n    if (target === currentTarget || target.classList.contains('modal-backdrop')) {\n      this.onClose();\n    }\n  }\n\n  onButtonClick(button: ExecutionResultButton): void {\n    this.buttonClick.emit(button.action);\n  }\n\n  onClose(): void {\n    this.closeModal.emit();\n  }\n }\n \n","<div \n  *ngIf=\"isOpen\"\n  class=\"modal-backdrop cqa-fixed cqa-inset-0 cqa-bg-black cqa-bg-opacity-50 cqa-z-50 cqa-flex cqa-items-center cqa-justify-center cqa-p-4\"\n  (click)=\"onBackdropClick($event)\">\n  <div \n    class=\"cqa-rounded-lg cqa-bg-white cqa-shadow-xl cqa-w-full cqa-max-w-[500px] cqa-overflow-hidden cqa-p-6 cqa-flex cqa-flex-col cqa-gap-2\"\n    style=\"box-shadow: 0px 8px 8px -4px #10182808;\"\n    (click)=\"$event.stopPropagation()\">\n      \n      <div class=\"cqa-flex cqa-flex-col cqa-items-center\">\n          <div *ngIf=\"status === 'passed'\">\n            <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"93\" height=\"93\" viewBox=\"0 0 93 93\" fill=\"none\">\n              <rect x=\"4\" y=\"4\" width=\"85\" height=\"85\" rx=\"42.5\" fill=\"#AEE9D4\"/>\n              <rect x=\"4\" y=\"4\" width=\"85\" height=\"85\" rx=\"42.5\" stroke=\"#CFF2E5\" stroke-width=\"8\"/>\n              <path d=\"M75.25 43.8549V46.4999C75.2465 52.6996 73.2389 58.732 69.5268 63.6976C65.8147 68.6632 60.5969 72.2957 54.6517 74.0536C48.7064 75.8114 42.3521 75.6003 36.5366 73.4518C30.7211 71.3033 25.7559 67.3324 22.3815 62.1314C19.0071 56.9305 17.4044 50.778 17.8123 44.5918C18.2202 38.4055 20.617 32.5168 24.6451 27.8039C28.6731 23.0911 34.1168 19.8066 40.164 18.4403C46.2113 17.074 52.5383 17.6991 58.2013 20.2224M75.25 23.4999L46.5 52.2786L37.875 43.6536\" stroke=\"#0DBD7D\" stroke-width=\"4\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n            </svg>\n          </div>\n  \n          <div *ngIf=\"status === 'failed'\">\n            <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"93\" height=\"93\" viewBox=\"0 0 93 93\" fill=\"none\">\n              <rect x=\"4\" y=\"4\" width=\"85\" height=\"85\" rx=\"42.5\" fill=\"#F9BFBF\"/>\n              <rect x=\"4\" y=\"4\" width=\"85\" height=\"85\" rx=\"42.5\" stroke=\"#FCD9D9\" stroke-width=\"8\"/>\n              <path d=\"M55.125 37.875L37.875 55.125M37.875 37.875L55.125 55.125M75.25 46.5C75.25 62.3782 62.3782 75.25 46.5 75.25C30.6218 75.25 17.75 62.3782 17.75 46.5C17.75 30.6218 30.6218 17.75 46.5 17.75C62.3782 17.75 75.25 30.6218 75.25 46.5Z\" stroke=\"#EE3F3F\" stroke-width=\"4\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n              </svg>\n          </div>\n  \n          <div *ngIf=\"status === 'aborted'\">\n            <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"93\" height=\"93\" viewBox=\"0 0 93 93\" fill=\"none\">\n              <rect x=\"4\" y=\"4\" width=\"85\" height=\"85\" rx=\"42.5\" fill=\"#FEECBD\"/>\n              <rect x=\"4\" y=\"4\" width=\"85\" height=\"85\" rx=\"42.5\" stroke=\"#FFF9E9\" stroke-width=\"8\"/>\n              <path d=\"M46.5 17.75C30.63 17.75 17.75 30.63 17.75 46.5C17.75 62.37 30.63 75.25 46.5 75.25C62.37 75.25 75.25 62.37 75.25 46.5C75.25 30.63 62.37 17.75 46.5 17.75ZM46.5 69.5C33.7925 69.5 23.5 59.2075 23.5 46.5C23.5 33.7925 33.7925 23.5 46.5 23.5C59.2075 23.5 69.5 33.7925 69.5 46.5C69.5 59.2075 59.2075 69.5 46.5 69.5ZM58 58H35V35H58V58Z\" fill=\"#FBBF24\"/>\n              </svg>\n          </div>\n  \n        <h2 class=\"cqa-text-[22px] cqa-font-semibold cqa-text-[#0B0B0C] cqa-mt-[20px] cqa-leading-[28px]\">\n          {{ title }}\n        </h2>\n      </div>\n  \n      <div class=\"cqa-rounded-lg cqa-border cqa-p-[17px] cqa-my-4\"\n           [ngClass]=\"stepsBackgroundClass\" style=\"border: 1px solid;\" [style.border-color]=\"stepsBorderClass\">\n        <div class=\"cqa-grid sm:cqa-flex sm:cqa-justify-between sm:cqa-items-center cqa-grid-cols-2 sm:cqa-grid-cols-4 cqa-gap-4 sm:cqa-gap-2\">\n          <div class=\"cqa-flex cqa-flex-col\" *ngIf=\"totalSteps\">\n            <span class=\"cqa-text-xs cqa-text-[#4A5565] cqa-mb-1\">Total Steps</span>\n            <span class=\"cqa-text-[18px] cqa-font-medium cqa-text-[#101828]\">\n              {{ completedSteps }} / {{ totalSteps }}\n            </span>\n          </div>\n  \n          <div class=\"cqa-flex cqa-flex-col\" *ngIf=\"totalTime\">\n            <span class=\"cqa-text-xs cqa-text-[#4A5565] cqa-mb-1\">Total Time</span>\n            <span class=\"cqa-text-[18px] cqa-font-medium cqa-text-[#101828]\">\n              {{ totalTime }}\n            </span>\n          </div>\n  \n          <div class=\"cqa-flex cqa-flex-col\" *ngIf=\"appTime\">\n            <span class=\"cqa-text-xs cqa-text-[#4A5565] cqa-mb-1\">App Time</span>\n            <span class=\"cqa-text-[18px] cqa-font-medium cqa-text-[#101828]\">\n              {{ appTime }}\n            </span>\n          </div>\n  \n          <div class=\"cqa-flex cqa-flex-col\" *ngIf=\"toolTime\">\n            <span class=\"cqa-text-xs cqa-text-[#4A5565] cqa-mb-1\">Tool Time</span>\n            <span class=\"cqa-text-[18px] cqa-font-medium cqa-text-[#101828]\">\n              {{ toolTime }}\n            </span>\n          </div>\n        </div>\n      </div>\n  \n      <div *ngIf=\"shouldShowLastCompletedStep\" class=\"cqa-my-4 cqa-p-[17px] cqa-rounded-[10px] cqa-h-[200px] cqa-overflow-y-auto\" style=\"border: 1px solid #E5E7EB; scrollbar-width: thin;\">\n        <div class=\"cqa-text-[12px] cqa-text-[#364153] cqa-mb-1 cqa-leading-[18px]\">\n          Last completed step:\n        </div>\n        <div class=\"cqa-text-[12px] cqa-font-semibold cqa-text-[#101828] cqa-leading-[18px]\" style=\"word-break: break-word;\">\n          <span [innerHTML]=\"lastCompletedStep\"></span>\n        </div>\n      </div>\n\n      <div *ngIf=\"shouldShowFailedSteps\" class=\"cqa-my-4 cqa-max-h-[300px] cqa-overflow-y-auto\" style=\"scrollbar-width: thin;\">\n        <div class=\"cqa-flex cqa-flex-col cqa-gap-3\">\n          <div \n            *ngFor=\"let failedStep of failedSteps\" \n            class=\"cqa-rounded-lg cqa-p-[17px] cqa-bg-[#FEF2F2]\"\n            style=\"border: 1px solid #FECACA;\">\n            <div *ngIf=\"failedStep?.failedStep\" class=\"cqa-text-sm cqa-font-semibold cqa-text-[#111827] cqa-mb-2 cqa-leading-[18px]\">\n              Failed at Step {{ failedStep.failedStep }}<span *ngIf=\"failedStep.stepTitle\">: {{ failedStep.stepTitle }}</span>\n            </div>\n            <div *ngIf=\"failedStep.error\" class=\"cqa-text-[12px] cqa-text-[#B91C1C] cqa-mb-1 cqa-whitespace-normal cqa-break-anywhere\" style=\"word-break: break-word;\">\n              <span class=\"cqa-font-bold\">Error:</span> {{ failedStep.error }}\n            </div>\n            <div *ngIf=\"failedStep.actual\" class=\"cqa-text-[12px] cqa-text-[#B91C1C] cqa-mb-1 cqa-whitespace-normal cqa-break-anywhere\" style=\"word-break: break-word;\">\n              <span class=\"cqa-font-bold\">Actual:</span> {{ failedStep.actual }}\n            </div>\n            <div *ngIf=\"failedStep.expected\" class=\"cqa-text-[12px] cqa-text-[#B91C1C] cqa-mb-2 cqa-whitespace-normal cqa-break-anywhere\" style=\"word-break: break-word;\">\n              <span class=\"cqa-font-bold\">Expected:</span> {{ failedStep.expected }}\n            </div>\n            <div *ngIf=\"failedStep.suggestions\" class=\"cqa-text-[12px] cqa-text-[#B91C1C] cqa-mb-1 cqa-whitespace-normal cqa-break-anywhere\" style=\"word-break: break-word;\">\n              <span class=\"cqa-font-bold\">Suggestions:</span> {{ failedStep.suggestions }}\n            </div>\n            <div *ngIf=\"failedStep.timestamp\" class=\"cqa-flex cqa-items-center cqa-gap-1 cqa-text-[12px] cqa-text-[#636363]\">\n              <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"12\" height=\"12\" viewBox=\"0 0 12 12\" fill=\"none\">\n                <path d=\"M6 1V6L9 7.5\" stroke=\"#636363\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n                <circle cx=\"6\" cy=\"6\" r=\"5\" stroke=\"#636363\" stroke-width=\"1.5\"/>\n              </svg>\n              <span>View screenshot at {{ failedStep.timestamp }}</span>\n            </div>\n          </div>\n        </div>\n      </div>\n  \n      <div class=\"cqa-flex cqa-flex-col cqa-gap-[20px]\">\n        <ng-container *ngFor=\"let button of buttons; let i = index\">\n          <cqa-button\n            [variant]=\"button.variant\"\n            [text]=\"button.label\"\n            [icon]=\"button.icon\"\n            [btnSize]=\"button.btnSize || 'lg'\"\n            [fullWidth]=\"button.fullWidth !== undefined ? button.fullWidth : true\"\n            (clicked)=\"onButtonClick(button)\">\n          </cqa-button>\n        </ng-container>\n      </div>\n    </div>\n  </div>\n\n"]}
|