@cqa-lib/cqa-ui 1.1.90 → 1.1.91
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/execution-screen/ai-agent-step/ai-agent-step.component.mjs +4 -4
- package/esm2020/lib/execution-screen/basic-step/basic-step.component.mjs +1 -2
- package/esm2020/lib/execution-screen/condition-step/condition-step.component.mjs +1 -68
- package/esm2020/lib/execution-screen/visual-comparison/visual-comparison.component.mjs +3 -3
- package/fesm2015/cqa-lib-cqa-ui.mjs +5 -73
- package/fesm2015/cqa-lib-cqa-ui.mjs.map +1 -1
- package/fesm2020/cqa-lib-cqa-ui.mjs +5 -73
- package/fesm2020/cqa-lib-cqa-ui.mjs.map +1 -1
- package/lib/execution-screen/condition-step/condition-step.component.d.ts +0 -16
- package/package.json +1 -1
|
@@ -124,7 +124,6 @@ export class ConditionStepComponent extends BaseStepComponent {
|
|
|
124
124
|
// Filter nested steps based on active branch
|
|
125
125
|
if (changes['nestedSteps'] || changes['activeBranchStepId']) {
|
|
126
126
|
this.config.nestedSteps = this.nestedSteps;
|
|
127
|
-
console.log("Nested steps updated", this.nestedSteps);
|
|
128
127
|
}
|
|
129
128
|
if (changes['branches']) {
|
|
130
129
|
this.config.branches = this.branches;
|
|
@@ -221,10 +220,6 @@ export class ConditionStepComponent extends BaseStepComponent {
|
|
|
221
220
|
const hasNestedSteps = !!(this.config.nestedSteps && this.config.nestedSteps.length > 0);
|
|
222
221
|
return hasBranchSubSteps || hasNestedSteps;
|
|
223
222
|
}
|
|
224
|
-
/**
|
|
225
|
-
* Determine the active branch step ID based on executed branch.
|
|
226
|
-
* Always derives activeBranchStepId from the executed branch (not user selection).
|
|
227
|
-
*/
|
|
228
223
|
determineActiveBranch() {
|
|
229
224
|
if (!this.branches || !Array.isArray(this.branches) || this.branches.length === 0) {
|
|
230
225
|
return;
|
|
@@ -247,74 +242,12 @@ export class ConditionStepComponent extends BaseStepComponent {
|
|
|
247
242
|
}
|
|
248
243
|
}
|
|
249
244
|
}
|
|
250
|
-
/**
|
|
251
|
-
* Filter nested steps to show only children of the active branch step.
|
|
252
|
-
*/
|
|
253
|
-
// private getFilteredNestedSteps(): ExecutionStepConfig[] {
|
|
254
|
-
// // If no active branch is set, determine it
|
|
255
|
-
// if (!this.activeBranchStepId) {
|
|
256
|
-
// this.determineActiveBranch();
|
|
257
|
-
// }
|
|
258
|
-
// // If still no active branch after determination, return all nested steps
|
|
259
|
-
// if (!this.activeBranchStepId) {
|
|
260
|
-
// return this.nestedSteps || [];
|
|
261
|
-
// }
|
|
262
|
-
// if (!this.branches || !Array.isArray(this.branches)) {
|
|
263
|
-
// return this.nestedSteps || [];
|
|
264
|
-
// }
|
|
265
|
-
// const currentConditionBranch = this.branches.find((b: any) => b.branchStepId === this.activeBranchStepId);
|
|
266
|
-
// if (!currentConditionBranch || !currentConditionBranch.branchStep) {
|
|
267
|
-
// console.warn('Branch step not found for active ID:', this.activeBranchStepId);
|
|
268
|
-
// return this.nestedSteps || [];
|
|
269
|
-
// }
|
|
270
|
-
// const ifCondition = currentConditionBranch.branchStep.testStepType === 'CONDITION_IF';
|
|
271
|
-
// console.log('ifCondition selected branch step', ifCondition, currentConditionBranch, currentConditionBranch.branchStep);
|
|
272
|
-
// if (ifCondition) {
|
|
273
|
-
// return currentConditionBranch.branchStep?.children || [];
|
|
274
|
-
// } else {
|
|
275
|
-
// // For ELSE_IF/ELSE branches, return the branch step itself
|
|
276
|
-
// // Ensure it has all required properties for step-renderer
|
|
277
|
-
// const branchStep = currentConditionBranch.branchStep;
|
|
278
|
-
// // Create a properly formatted step object with all required properties
|
|
279
|
-
// const formattedStep: ExecutionStepConfig = {
|
|
280
|
-
// ...branchStep,
|
|
281
|
-
// // Ensure type is set to 'condition' for step-renderer
|
|
282
|
-
// type: branchStep.type,
|
|
283
|
-
// // Ensure id is set (required by BaseStepConfig)
|
|
284
|
-
// id: branchStep.id || '',
|
|
285
|
-
// // Ensure testStepResultId is set (required by BaseStepConfig)
|
|
286
|
-
// testStepResultId: branchStep.testStepResultId || branchStep.id || '',
|
|
287
|
-
// // Ensure stepNumber is set if not present
|
|
288
|
-
// stepNumber: branchStep.stepNumber || '',
|
|
289
|
-
// // Ensure title is set if not present
|
|
290
|
-
// title: branchStep.title || branchStep.action || '',
|
|
291
|
-
// // Ensure status is set if not present
|
|
292
|
-
// status: branchStep.status,
|
|
293
|
-
// // Ensure duration is set if not present
|
|
294
|
-
// duration: branchStep.duration || 0,
|
|
295
|
-
// } as ExecutionStepConfig;
|
|
296
|
-
// // Create a new array reference to ensure change detection triggers
|
|
297
|
-
// return [formattedStep];
|
|
298
|
-
// }
|
|
299
|
-
// }
|
|
300
|
-
/**
|
|
301
|
-
* Branch click handler - DISABLED for manual selection.
|
|
302
|
-
* Branches are now automatically determined by executed status.
|
|
303
|
-
* This method is kept for backward compatibility but does not allow manual selection.
|
|
304
|
-
*/
|
|
305
245
|
onBranchClick(branch) {
|
|
306
246
|
if (!this.isLive) {
|
|
307
247
|
return;
|
|
308
248
|
}
|
|
309
|
-
// Manual branch selection is disabled - branches are determined by executed status only
|
|
310
|
-
// This method is kept for template compatibility but does nothing
|
|
311
|
-
// The active branch is automatically determined from branch.executed in determineActiveBranch()
|
|
312
249
|
this.onBranchClickEvent.emit(branch);
|
|
313
250
|
}
|
|
314
|
-
/**
|
|
315
|
-
* Get CSS classes for branch button based on execution status and active state.
|
|
316
|
-
* For live mode: shows blue border if branch is active but not executed.
|
|
317
|
-
*/
|
|
318
251
|
getBranchClass(branch) {
|
|
319
252
|
// If branch is executed, show green styling
|
|
320
253
|
if (branch.executed) {
|
|
@@ -438,4 +371,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImpor
|
|
|
438
371
|
}], selfHealAction: [{
|
|
439
372
|
type: Output
|
|
440
373
|
}] } });
|
|
441
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"condition-step.component.js","sourceRoot":"","sources":["../../../../../../src/lib/execution-screen/condition-step/condition-step.component.ts","../../../../../../src/lib/execution-screen/condition-step/condition-step.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, OnChanges, Output, SimpleChanges, ChangeDetectorRef } from '@angular/core';\nimport { ConditionStepConfig, ConditionBranch, StepStatus, TimingBreakdown, FailureDetails, SubStep, SelfHealAnalysisData, SelfHealAction, ExecutionStepConfig } from '../execution-step.models';\nimport { BaseStepComponent } from '../base-step.component';\nimport { makeCurrentBaselineEvent, uploadBaselineEvent } from '../visual-comparison/visual-comparison.component';\n\n@Component({\n  selector: 'cqa-condition-step',\n  templateUrl: './condition-step.component.html',\n  styleUrls: [],\n  host: { class: 'cqa-ui-root' }\n})\nexport class ConditionStepComponent extends BaseStepComponent implements OnInit, OnChanges {\n  // Individual inputs\n  @Input() id!: string;\n  @Input() testStepResultId!: string;\n  @Input() stepNumber!: string;\n  @Input() title!: string;\n  @Input() status!: StepStatus;\n  @Input() duration!: number;\n  @Input() timingBreakdown?: TimingBreakdown;\n  @Input() expanded?: boolean;\n  @Input() conditionText!: string;\n  @Input() branches: ConditionBranch[] = [];\n  @Input() failureDetails?: FailureDetails;\n  @Input() reasoning?: string[];\n  @Input() confidence?: string;\n  @Input() selfHealAnalysis?: SelfHealAnalysisData;\n  @Input() isLoading?: boolean;\n  @Input() nestedSteps?: ExecutionStepConfig[] = [];\n  @Input() hasChild?: boolean;\n  @Input() ifChild?: any; // ifChild data from API - if null and hasChild is true, we need to call API\n  @Input() activeBranchStepId?: string | number; // ID of the currently active/selected branch step\n\n  // Handler function to pass down to nested child step groups for recursive expansion\n  @Input() onExpandHandler?: (step: ExecutionStepConfig) => void;\n\n  // Handler functions for condition steps\n  @Input() getConditionBranchesHandler?: (step: ExecutionStepConfig) => ConditionBranch[];\n  @Input() isStepLoadingHandler?: (step: ExecutionStepConfig) => boolean;\n  @Input() isStepExpandedHandler?: (step: ExecutionStepConfig) => boolean;\n  @Input() convertMsToSecondsHandler?: (duration: number) => number;\n  @Input() formatFailureDetailsHandler?: (step: ExecutionStepConfig) => any;\n  @Input() getSelfHealAnalysisHandler?: (step: ExecutionStepConfig) => any;\n  @Input() onMakeCurrentBaselineHandler?: (event: any) => void;\n  @Input() onUploadBaselineHandler?: (event: any) => void;\n  @Input() onAnalyzeHandler?: () => void;\n  @Input() onViewFullLogsHandler?: () => void;\n  @Input() onSelfHealActionHandler?: (event: any) => void;\n  @Input() getSelfHealLoadingStatesHandler?: () => { isLoadingAccept: boolean; isLoadingModifyAccept: boolean };\n  @Input() getLoopIterationsHandler?: (step: ExecutionStepConfig) => any[];\n  @Input() getApiAssertionsHandler?: (step: ExecutionStepConfig) => any[];\n  @Input() formatActionsHandler?: (step: ExecutionStepConfig) => any[];\n  @Input() onViewAllIterationsHandler?: (step: ExecutionStepConfig) => void;\n  @Input() onConditionBranchClickHandler?: (step: any, branch: any) => void;\n\n  @Output() onBranchClickEvent = new EventEmitter<ConditionBranch>();\n  @Output() onExpand = new EventEmitter<void>();\n  @Input() isUploadingBaseline = {};\n  @Input() isMakingCurrentBaseline = {};\n  @Input() isLive: boolean = false;\n  @Output() makeCurrentBaseline = new EventEmitter<makeCurrentBaselineEvent>();\n  @Output() uploadBaseline = new EventEmitter<uploadBaselineEvent>();\n  @Output() analyze = new EventEmitter<void>();\n  @Output() viewFullLogs = new EventEmitter<void>();\n  @Output() selfHealAction = new EventEmitter<{ type: SelfHealAction; healedLocator: string; }>();\n\n  showFailedStepDetails: boolean = false;\n\n  // Config property for base class - built from individual inputs in ngOnInit\n  override config!: ConditionStepConfig;\n\n  constructor(private cdr: ChangeDetectorRef) {\n    super();\n  }\n\n  override ngOnInit(): void {\n    // Always determine active branch from executed branch (for live mode)\n    if (this.isLive) {\n      this.determineActiveBranch();\n    }\n\n    // Filter nested steps based on active branch (derived from executed branch)\n    const stepsToUse = this.nestedSteps || [];\n\n    this.config = {\n      id: this.id,\n      testStepResultId: this.testStepResultId,\n      stepNumber: this.stepNumber,\n      title: this.title,\n      status: this.status,\n      duration: this.duration,\n      type: 'condition',\n      conditionText: this.conditionText,\n      branches: this.branches,\n      timingBreakdown: this.timingBreakdown,\n      expanded: this.expanded,\n      nestedSteps: stepsToUse,\n    } as ConditionStepConfig;\n\n    super.ngOnInit();\n  }\n\n\n  ngOnChanges(changes: SimpleChanges): void {\n    // Only process changes if config has been initialized (ngOnInit has been called)\n    if (!this.config) {\n      return;\n    }\n\n    // Process ifChild if it's provided and branches need to be updated\n    if (changes['ifChild'] && this.ifChild && Array.isArray(this.ifChild) && this.ifChild.length > 0) {\n      // Process ifChild to update branches\n      // This ensures branches reflect the executed condition from ifChild\n      if (this.getConditionBranchesHandler) {\n        // Use handler to get updated branches from ifChild\n        const stepWithIfChild = {\n          ...this.config,\n          ifChild: this.ifChild\n        } as any;\n        const updatedBranches = this.getConditionBranchesHandler(stepWithIfChild);\n        if (updatedBranches && updatedBranches.length > 0) {\n          this.branches = updatedBranches;\n          this.config.branches = updatedBranches.map((branch: any) => ({\n            ...branch,\n            subSteps: branch.subSteps ? [...branch.subSteps] : []\n          }));\n        }\n      }\n    }\n\n    if (this.isLive) {\n      // Update branches if changed - create deep copy to ensure change detection works\n      if (changes['branches'] && this.branches !== undefined) {\n        // Create a deep copy to ensure Angular change detection picks up nested changes\n        this.config.branches = this.branches.map((branch: any) => ({\n          ...branch,\n          subSteps: branch.subSteps ? [...branch.subSteps] : []\n        }));\n      } else if (this.branches !== undefined && this.config.branches !== this.branches) {\n        // Fallback: check if branches changed even if ngOnChanges didn't detect it\n        // This handles cases where nested subSteps were updated\n        const currentSubStepsCount = (this.config.branches || []).reduce((sum: number, b: any) => sum + (b.subSteps?.length || 0), 0);\n        const newSubStepsCount = (this.branches || []).reduce((sum: number, b: any) => sum + (b.subSteps?.length || 0), 0);\n\n        if (currentSubStepsCount !== newSubStepsCount ||\n          this.config.branches !== this.branches) {\n          this.config.branches = this.branches.map((branch: any) => ({\n            ...branch,\n            subSteps: branch.subSteps ? [...branch.subSteps] : []\n          }));\n        }\n      }\n\n      // Update other properties that might change\n      if (changes['status'] && this.status !== undefined) {\n        this.config.status = this.status;\n      }\n\n      if (changes['duration'] && this.duration !== undefined) {\n        this.config.duration = this.duration;\n      }\n\n      if (changes['expanded'] && this.expanded !== undefined) {\n        this.config.expanded = this.expanded;\n        this.isExpanded = this.expanded;\n      }\n\n      if (changes['conditionText'] && this.conditionText !== undefined) {\n        this.config.conditionText = this.conditionText;\n      }\n      // Update active branch if changed - always derive from executed branch\n      if (changes['activeBranchStepId'] || changes['branches']) {\n        // Check if executed branch changed\n        const executedBranchChanged = changes['branches'] && \n          changes['branches'].previousValue && \n          changes['branches'].currentValue &&\n          changes['branches'].previousValue.some((prevBranch: any, index: number) => {\n            const currentBranch = changes['branches'].currentValue[index];\n            return prevBranch?.executed !== currentBranch?.executed;\n          });\n        \n        // Always determine active branch from executed branch\n        this.determineActiveBranch();\n      }\n\n      // Filter nested steps based on active branch\n      if (changes['nestedSteps'] || changes['activeBranchStepId']) {\n        this.config.nestedSteps = this.nestedSteps;\n        console.log(\"Nested steps updated\", this.nestedSteps);\n      }\n\n      if (changes['branches']) {\n        this.config.branches = this.branches;\n      }\n    }\n  }\n\n  override toggle(): void {\n    const wasExpanded = this.isExpanded;\n    super.toggle();\n    if (!wasExpanded && this.isExpanded) {\n      this.onExpand.emit();\n      // Always call children API if hasChild is true (like other step types)\n      // If ifChild exists and has an executed condition (result: \"SUCCESS\"), use that condition's testStepResultId\n      if (this.onExpandHandler && this.config && this.hasChild) {\n        const configWithNested = this.config as ConditionStepConfig;\n\n        // Find the executed condition from ifChild (the one with result: \"SUCCESS\")\n        let executedConditionTestStepResultId = this.testStepResultId; // Default to parent's ID\n        let executedConditionHasChild = this.hasChild;\n\n        if (this.ifChild && Array.isArray(this.ifChild) && this.ifChild.length > 0) {\n          const executedCondition = this.ifChild.find((condition: any) =>\n            condition.result === 'SUCCESS' || condition.result === 'SUCCESS'\n          );\n\n          if (executedCondition && executedCondition.testStepResultId) {\n            // Use the executed condition's testStepResultId and hasChild\n            executedConditionTestStepResultId = executedCondition.testStepResultId;\n            executedConditionHasChild = executedCondition.hasChild || false;\n          }\n        }\n\n        // Create a step config object for the handler\n        const stepConfig = {\n          ...this.config,\n          hasChild: executedConditionHasChild,\n          expanded: true, // Ensure expanded is set\n          testStepType: (this.config as any).testStepType || 'CONDITION_IF',\n          children: configWithNested.nestedSteps || [],\n          testStepResultId: executedConditionTestStepResultId, // Use executed condition's ID for API call\n          id: this.id,\n          ifChild: this.ifChild || null, // Pass ifChild for branch execution determination\n          // Store original parent testStepResultId for tracking states and updating parent structure\n          originalTestStepResultId: this.testStepResultId\n        } as ExecutionStepConfig & { originalTestStepResultId?: string | number };\n        this.onExpandHandler(stepConfig);\n      }\n    }\n\n    // Ensure expanded state is synced with config\n    if (this.config) {\n      this.config.expanded = this.isExpanded;\n    }\n  }\n\n  getExecutedBranch(): ConditionBranch | null {\n    return this.branches.find(branch => branch.executed) || null;\n  }\n\n  getUnexecutedBranches(): ConditionBranch[] {\n    return this.branches?.filter(branch => !branch.executed) || [];\n  }\n\n  getSubStepIndex(subSteps: any[], subStep: any): number {\n    return subSteps.indexOf(subStep) + 1;\n  }\n\n  onViewMoreFailedStepClick(expanded: boolean): void {\n    this.showFailedStepDetails = expanded;\n  }\n\n  getSubStepsForFailedStep(): SubStep[] {\n    const executedBranch = this.getExecutedBranch();\n    return executedBranch?.subSteps || [];\n  }\n\n  onMakeCurrentBaseline(event: makeCurrentBaselineEvent): void {\n    this.makeCurrentBaseline.emit(event);\n  }\n\n  onUploadBaseline(event: uploadBaselineEvent): void {\n    this.uploadBaseline.emit(event);\n  }\n\n  onAnalyze(): void {\n    this.analyze.emit();\n  }\n\n  onViewFullLogs(): void {\n    this.viewFullLogs.emit();\n  }\n\n  onSelfHealAction(event: { type: SelfHealAction; healedLocator: string; }): void {\n    this.selfHealAction.emit(event);\n  }\n\n  get showViewMoreButton(): boolean {\n    return this.isExpanded && Boolean(this.failureDetails) &&\n      (\n        (Boolean(this.failureDetails?.expected || this.failureDetails?.actual)) ||\n        (Boolean(this.failureDetails?.screenshots?.current || this.failureDetails?.screenshots?.baseline || this.failureDetails?.screenshots?.difference)\n          || Boolean(this.failureDetails?.logs?.length)) ||\n        (Boolean(this.failureDetails?.aiFixApplied && (this.failureDetails?.aiFixMessage || this.confidence || this.reasoning?.length)))\n      )\n  }\n\n  toggleHeader(): void {\n    this.toggle();\n    if (!this.isExpanded) {\n      this.showFailedStepDetails = false;\n    }\n  }\n\n  get hasExpandableContent(): boolean {\n    const hasBranchSubSteps = this.config.branches?.some(branch =>\n      branch.subSteps && branch.subSteps.length > 0\n    ) || false;\n    const hasNestedSteps = !!(this.config.nestedSteps && this.config.nestedSteps.length > 0);\n    return hasBranchSubSteps || hasNestedSteps;\n  }\n\n  /**\n   * Determine the active branch step ID based on executed branch.\n   * Always derives activeBranchStepId from the executed branch (not user selection).\n   */\n  private determineActiveBranch(): void {\n    if (!this.branches || !Array.isArray(this.branches) || this.branches.length === 0) {\n      return;\n    }\n\n    // Always find the executed branch and set activeBranchStepId from it\n    const executedBranch = this.branches.find((b: any) => b.executed) as any;\n    if (executedBranch && executedBranch.branchStepId) {\n      // Update activeBranchStepId to match executed branch\n      if (this.activeBranchStepId !== executedBranch.branchStepId) {\n        this.activeBranchStepId = executedBranch.branchStepId;\n        // Update nested steps when executed branch changes\n      }\n      return;\n    }\n\n    // If no branch is executed, default to first branch (IF branch) but don't mark it as executed\n    const firstBranch = this.branches[0] as any;\n    if (firstBranch && firstBranch.branchStepId) {\n      if (this.activeBranchStepId !== firstBranch.branchStepId) {\n        this.activeBranchStepId = firstBranch.branchStepId;\n      }\n    }\n  }\n\n  /**\n   * Filter nested steps to show only children of the active branch step.\n   */\n  // private getFilteredNestedSteps(): ExecutionStepConfig[] {\n  //   // If no active branch is set, determine it\n  //   if (!this.activeBranchStepId) {\n  //     this.determineActiveBranch();\n  //   }\n\n  //   // If still no active branch after determination, return all nested steps\n  //   if (!this.activeBranchStepId) {\n  //     return this.nestedSteps || [];\n  //   }\n\n\n  //   if (!this.branches || !Array.isArray(this.branches)) {\n  //     return this.nestedSteps || [];\n  //   }\n\n  //   const currentConditionBranch = this.branches.find((b: any) => b.branchStepId === this.activeBranchStepId);\n\n  //   if (!currentConditionBranch || !currentConditionBranch.branchStep) {\n  //     console.warn('Branch step not found for active ID:', this.activeBranchStepId);\n  //     return this.nestedSteps || [];\n  //   }\n\n  //   const ifCondition = currentConditionBranch.branchStep.testStepType === 'CONDITION_IF';\n  //   console.log('ifCondition selected branch step', ifCondition, currentConditionBranch, currentConditionBranch.branchStep);\n  //   if (ifCondition) {\n  //     return currentConditionBranch.branchStep?.children || [];\n  //   } else {\n  //     // For ELSE_IF/ELSE branches, return the branch step itself\n  //     // Ensure it has all required properties for step-renderer\n  //     const branchStep = currentConditionBranch.branchStep;\n      \n  //     // Create a properly formatted step object with all required properties\n  //     const formattedStep: ExecutionStepConfig = {\n  //       ...branchStep,\n  //       // Ensure type is set to 'condition' for step-renderer\n  //       type: branchStep.type,\n  //       // Ensure id is set (required by BaseStepConfig)\n  //       id: branchStep.id || '',\n  //       // Ensure testStepResultId is set (required by BaseStepConfig)\n  //       testStepResultId: branchStep.testStepResultId || branchStep.id || '',\n  //       // Ensure stepNumber is set if not present\n  //       stepNumber: branchStep.stepNumber || '',\n  //       // Ensure title is set if not present\n  //       title: branchStep.title || branchStep.action || '',\n  //       // Ensure status is set if not present\n  //       status: branchStep.status,\n  //       // Ensure duration is set if not present\n  //       duration: branchStep.duration || 0,\n  //     } as ExecutionStepConfig;\n      \n  //     // Create a new array reference to ensure change detection triggers\n  //     return [formattedStep];\n  //   }\n  // }\n\n  /**\n   * Branch click handler - DISABLED for manual selection.\n   * Branches are now automatically determined by executed status.\n   * This method is kept for backward compatibility but does not allow manual selection.\n   */\n  onBranchClick(branch: ConditionBranch): void {\n    if (!this.isLive) {\n      return;\n    }\n\n    // Manual branch selection is disabled - branches are determined by executed status only\n    // This method is kept for template compatibility but does nothing\n    // The active branch is automatically determined from branch.executed in determineActiveBranch()\n\n    this.onBranchClickEvent.emit(branch);\n  }\n\n  /**\n   * Get CSS classes for branch button based on execution status and active state.\n   * For live mode: shows blue border if branch is active but not executed.\n   */\n  getBranchClass(branch: any): string {\n    // If branch is executed, show green styling\n    if (branch.executed) {\n      return 'cqa-bg-[#DCFCE7] cqa-text-[#008236] cqa-border cqa-border-solid cqa-border-[#B9F8CF]';\n    }\n\n    // For live mode: if no branches are executed but there's an activeBranchStepId,\n    // show the active branch with blue border\n    if (this.isLive && !this.hasAnyExecutedBranch()) {\n      return 'cqa-bg-[#EFF6FF] cqa-text-[#1E40AF] cqa-border cqa-border-solid cqa-border-[#3B82F6]';\n    }\n\n    // Default: gray styling for unexecuted branches\n    return 'cqa-bg-[#F3F4F6] cqa-text-[#99A1AF] cqa-border cqa-border-solid cqa-border-[#E5E7EB]';\n  }\n\n  /**\n   * Check if any branch is executed.\n   */\n  private hasAnyExecutedBranch(): boolean {\n    if (!this.branches || !Array.isArray(this.branches)) {\n      return false;\n    }\n    return this.branches.some((b: any) => b.executed === true);\n  }\n}\n","<div>\n  <div class=\"cqa-p-2\">\n    <!-- Header -->\n    <div\n      class=\"cqa-flex cqa-items-center cqa-gap-2 cqa-pb-1.5 cqa-cursor-pointer\"\n      (click)=\"toggleHeader()\">\n      \n      <!-- Status Icon -->\n      <div *ngIf=\"status.toLowerCase() === 'success'\" ><svg width=\"12\" height=\"12\" viewBox=\"0 0 12 12\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M10.9005 4.99999C11.1289 6.12064 10.9662 7.28571 10.4395 8.30089C9.91279 9.31608 9.054 10.12 8.00631 10.5787C6.95862 11.0373 5.78536 11.1229 4.6822 10.8212C3.57904 10.5195 2.61265 9.84869 1.94419 8.92071C1.27573 7.99272 0.945611 6.86361 1.00888 5.72169C1.07215 4.57976 1.52499 3.49404 2.29188 2.64558C3.05876 1.79712 4.09334 1.23721 5.22308 1.05922C6.35282 0.881233 7.50944 1.09592 8.50005 1.66749\" stroke=\"#22C55E\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M4.5 5.5L6 7L11 2\" stroke=\"#22C55E\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/></svg></div>\n      <div *ngIf=\"status.toLowerCase() === 'failure' || status.toLowerCase() === 'failed'\"><svg width=\"12\" height=\"12\" viewBox=\"0 0 12 12\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M6 11C8.76142 11 11 8.76142 11 6C11 3.23858 8.76142 1 6 1C3.23858 1 1 3.23858 1 6C1 8.76142 3.23858 11 6 11Z\" stroke=\"#DC2626\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M7.5 4.5L4.5 7.5\" stroke=\"#DC2626\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M4.5 4.5L7.5 7.5\" stroke=\"#DC2626\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/></svg></div>\n      <div *ngIf=\"status.toLowerCase() === 'pending'\"><svg width=\"12\" height=\"12\" viewBox=\"0 0 12 12\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M6 11C8.76142 11 11 8.76142 11 6C11 3.23858 8.76142 1 6 1C3.23858 1 1 3.23858 1 6C1 8.76142 3.23858 11 6 11Z\" stroke=\"#9CA3AF\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M6 3V6L8 7\" stroke=\"#9CA3AF\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/></svg></div>\n      <div *ngIf=\"status.toLowerCase() === 'running'\"><svg class=\"cqa-animate-spin cqa-text-[#3B82F6]\" width=\"12\" height=\"12\" viewBox=\"0 0 12 12\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><circle cx=\"6\" cy=\"6\" r=\"5\" stroke=\"currentColor\" stroke-width=\"1.5\" fill=\"none\" opacity=\"0.25\"/><path d=\"M6 1A5 5 0 0 1 11 6\" stroke=\"currentColor\" stroke-width=\"1.5\" fill=\"none\" stroke-linecap=\"round\"/></svg></div>\n\n      <!-- Condition Icon -->\n      <div><svg width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><rect width=\"16\" height=\"16\" rx=\"4\" fill=\"#FFEDD5\"/><path d=\"M6 5V9\" stroke=\"#FD9A00\" stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M10 7C10.5523 7 11 6.55228 11 6C11 5.44772 10.5523 5 10 5C9.44772 5 9 5.44772 9 6C9 6.55228 9.44772 7 10 7Z\" stroke=\"#FD9A00\" stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M6 11C6.55228 11 7 10.5523 7 10C7 9.44772 6.55228 9 6 9C5.44772 9 5 9.44772 5 10C5 10.5523 5.44772 11 6 11Z\" stroke=\"#FD9A00\" stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M10 7C10 7.79565 9.68393 8.55871 9.12132 9.12132C8.55871 9.68393 7.79565 10 7 10\" stroke=\"#FD9A00\" stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/></svg></div>\n\n      <!-- Step Number and Title -->\n      <div class=\"cqa-flex-1 cqa-flex cqa-items-center cqa-gap-3\">\n        <span class=\"cqa-font-bold cqa-text-[#334155] cqa-text-[11px] cqa-leading-[13px]\">\n          {{ config.stepNumber }}. Condition: <span [innerHTML]=\"config.conditionText\"></span>\n        </span>\n        \n        <!-- Condition Badge -->\n        <span class=\"cqa-px-1.5 cqa-rounded-full cqa-font-medium cqa-text-[#EA580C] cqa-bg-[#FFEDD5] cqa-text-[10px] cqa-leading-[15px]\">\n          CONDITION\n        </span>\n      </div>\n\n      <div class=\"cqa-flex cqa-items-center cqa-gap-1\">\n        <span class=\"cqa-text-[9px] cqa-leading-[11px] cqa-text-[#9CA3AF]\">\n          {{ formatDuration(config.duration) }}\n        </span>\n        <svg *ngIf=\"hasExpandableContent\" [class.cqa-rotate-180]=\"isExpanded\" class=\"cqa-transition-transform\" width=\"14\" height=\"14\" viewBox=\"0 0 14 14\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M3.5 5L7 8.5L10.5 5\" stroke=\"#9CA3AF\" stroke-width=\"0.833333\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/></svg>\n      </div>\n    </div>\n    <!-- Branch Buttons - Read-only, showing executed status only -->\n    <div class=\"cqa-flex cqa-items-center cqa-gap-3 cqa-px-4 cqa-text-[10px] cqa-leading-[15px] cqa-font-medium cqa-text-[#737373] cqa-flex-wrap\">\n      <div\n        *ngFor=\"let branch of config.branches\"\n        class=\"cqa-px-2 cqa-py-1 cqa-rounded cqa-text-[10px] cqa-leading-[15px] cqa-font-medium cqa-flex cqa-items-center cqa-gap-1.5\"\n        [ngClass]=\"getBranchClass(branch)\" (click)=\"onBranchClick(branch)\">\n        <!-- Checkmark icon for executed branch -->\n        <div *ngIf=\"branch.executed\">\n          <svg width=\"12\" height=\"12\" viewBox=\"0 0 12 12\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n            <path d=\"M10 3L4.5 8.5L2 6\" stroke=\"#008236\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n          </svg>\n        </div>\n        <span>{{ branch.type.toUpperCase() }}</span>\n      </div>\n    </div>\n  </div>\n\n  <!-- Expanded Content -->\n  <div *ngIf=\"isExpanded && !isLoading\">\n\n    <!-- Executed Branch Sub-steps -->\n    <div *ngFor=\"let branch of config.branches\">\n      <div *ngIf=\"branch.executed && branch.subSteps\" class=\"cqa-flex cqa-flex-col cqa-gap-1 cqa-pb-1 cqa-ml-9\" style=\"border-bottom: '1px solid #F3F4F6'\">\n        <div\n          *ngFor=\"let subStep of branch.subSteps\"\n          class=\"cqa-flex cqa-items-center cqa-gap-3 cqa-py-[5.5px] cqa-px-3\">\n          \n          <!-- Sub-step Status Icon -->\n          <div *ngIf=\"subStep?.status?.toLowerCase() === 'success' || subStep?.status?.toLowerCase() === 'passed'\" >\n            <svg width=\"12\" height=\"12\" viewBox=\"0 0 12 12\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M10.9005 4.99999C11.1289 6.12064 10.9662 7.28571 10.4395 8.30089C9.91279 9.31608 9.054 10.12 8.00631 10.5787C6.95862 11.0373 5.78536 11.1229 4.6822 10.8212C3.57904 10.5195 2.61265 9.84869 1.94419 8.92071C1.27573 7.99272 0.945611 6.86361 1.00888 5.72169C1.07215 4.57976 1.52499 3.49404 2.29188 2.64558C3.05876 1.79712 4.09334 1.23721 5.22308 1.05922C6.35282 0.881233 7.50944 1.09592 8.50005 1.66749\" stroke=\"#22C55E\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M4.5 5.5L6 7L11 2\" stroke=\"#22C55E\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/></svg>\n          </div>\n          <!-- Failure -->\n          <div *ngIf=\"subStep?.status?.toLowerCase() === 'failure' || subStep?.status?.toLowerCase() === 'failed'\">\n            <svg width=\"12\" height=\"12\" viewBox=\"0 0 12 12\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M6 11C8.76142 11 11 8.76142 11 6C11 3.23858 8.76142 1 6 1C3.23858 1 1 3.23858 1 6C1 8.76142 3.23858 11 6 11Z\" stroke=\"#DC2626\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M7.5 4.5L4.5 7.5\" stroke=\"#DC2626\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M4.5 4.5L7.5 7.5\" stroke=\"#DC2626\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/></svg>\n          </div>\n          <!-- Pending -->\n          <div *ngIf=\"subStep?.status?.toLowerCase() === 'pending'\">\n            <svg width=\"12\" height=\"12\" viewBox=\"0 0 12 12\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M6 11C8.76142 11 11 8.76142 11 6C11 3.23858 8.76142 1 6 1C3.23858 1 1 3.23858 1 6C1 8.76142 3.23858 11 6 11Z\" stroke=\"#9CA3AF\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M6 3V6L8 7\" stroke=\"#9CA3AF\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/></svg>\n          </div>\n          <!-- Running - Show spinner -->\n          <div *ngIf=\"subStep?.status?.toLowerCase() === 'running'\">\n            <svg class=\"cqa-animate-spin cqa-text-[#3B82F6]\" width=\"12\" height=\"12\" viewBox=\"0 0 12 12\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n              <circle cx=\"6\" cy=\"6\" r=\"5\" stroke=\"currentColor\" stroke-width=\"1.5\" fill=\"none\" opacity=\"0.25\"/>\n              <path d=\"M6 1A5 5 0 0 1 11 6\" stroke=\"currentColor\" stroke-width=\"1.5\" fill=\"none\" stroke-linecap=\"round\"/>\n            </svg>\n          </div>\n  \n\n          <!-- Sub-step Description -->\n          <span class=\"cqa-flex-1 cqa-text-[11px] cqa-leading-[13px] cqa-text-[#364153]\">\n            {{ config.stepNumber }}.{{ getSubStepIndex(branch.subSteps, subStep) }}. <span [innerHTML]=\"subStep.description\"></span>\n          </span>\n\n          <!-- Sub-step Duration -->\n          <span class=\"cqa-text-[10px] cqa-leading-[15px] cqa-font-medium cqa-text-metadata-key\">\n            {{ formatDuration(subStep.duration) }}\n          </span>\n        </div>\n      </div>\n    </div>\n\n    <!-- Unexecuted Branch Message -->\n    <div *ngIf=\"getUnexecutedBranches().length > 0 && getUnexecutedBranches().length < 2\" class=\"cqa-ml-9\">\n      <p class=\"cqa-px-3 cqa-py-[10px] cqa-text-[12px] cqa-leading-4 cqa-text-[#737373] cqa-italic\">\n        {{ getUnexecutedBranches()?.[0]?.type?.toUpperCase() }} branch not executed\n      </p>\n    </div>\n\n    <div *ngIf=\"getUnexecutedBranches().length > 1\" class=\"cqa-ml-9\">\n      <p class=\"cqa-px-3 cqa-py-[10px] cqa-text-[12px] cqa-leading-4 cqa-text-[#737373] cqa-italic\">\n        {{ getUnexecutedBranches()?.[0]?.type?.toUpperCase() }} and {{ getUnexecutedBranches()?.[1]?.type?.toUpperCase() }} branches not executed\n      </p>\n    </div>\n\n    <!-- Nested Steps -->\n    <div *ngIf=\"config.nestedSteps && config.nestedSteps.length > 0\" class=\"cqa-ml-9 cqa-pb-1\" style=\"border-bottom: '1px solid #F3F4F6'\">\n      <div class=\"cqa-text-[10px] cqa-leading-[15px] cqa-font-medium cqa-text-[#737373] cqa-py-[2px] cqa-px-3\">Nested steps</div>\n      <div class=\"cqa-flex cqa-flex-col cqa-gap-2 cqa-pl-[18px]\" style=\"border-left: 2px solid #C5C7FA;\">\n        <ng-container *ngFor=\"let step of config.nestedSteps\">\n          <!-- Use step-renderer for all nested steps to avoid circular dependencies -->\n          <!-- The step-renderer will dynamically load the appropriate component and pass handlers -->\n          <cqa-step-renderer \n            [step]=\"step\"\n            [onConditionBranchClickHandler]=\"onConditionBranchClickHandler\"\n            [onExpandHandler]=\"onExpandHandler\"\n            [getConditionBranchesHandler]=\"getConditionBranchesHandler\"\n            [isStepLoadingHandler]=\"isStepLoadingHandler\"\n            [isStepExpandedHandler]=\"isStepExpandedHandler\"\n            [convertMsToSecondsHandler]=\"convertMsToSecondsHandler\"\n            [formatFailureDetailsHandler]=\"formatFailureDetailsHandler\"\n            [getSelfHealAnalysisHandler]=\"getSelfHealAnalysisHandler\"\n            [getLoopIterationsHandler]=\"getLoopIterationsHandler\"\n            [getApiAssertionsHandler]=\"getApiAssertionsHandler\"\n            [formatActionsHandler]=\"formatActionsHandler\"\n            [onViewAllIterationsHandler]=\"onViewAllIterationsHandler\"\n            [onMakeCurrentBaselineHandler]=\"onMakeCurrentBaselineHandler\"\n            [onUploadBaselineHandler]=\"onUploadBaselineHandler\"\n            [onAnalyzeHandler]=\"onAnalyzeHandler\"\n            [onViewFullLogsHandler]=\"onViewFullLogsHandler\"\n            [onSelfHealActionHandler]=\"onSelfHealActionHandler\"\n            [isUploadingBaseline]=\"isUploadingBaseline\"\n            [isMakingCurrentBaseline]=\"isMakingCurrentBaseline\"\n            [selectedIterationId]=\"step?.selectedIterationId || ''\"\n            [isLive]=\"isLive\">\n          </cqa-step-renderer>\n        </ng-container>\n      </div>\n    </div>\n\n      <!-- Self Heal Analysis -->\n    <cqa-self-heal-analysis \n      *ngIf=\"selfHealAnalysis\" \n      [originalLocator]=\"selfHealAnalysis.originalLocator\"\n      [healedLocator]=\"selfHealAnalysis.healedLocator\"\n      [confidence]=\"selfHealAnalysis.confidence\"\n      [healMethod]=\"selfHealAnalysis.healMethod\"\n      [isLoadingAccept]=\"getSelfHealLoadingStatesHandler ? getSelfHealLoadingStatesHandler().isLoadingAccept : false\"\n      [isLoadingModifyAccept]=\"getSelfHealLoadingStatesHandler ? getSelfHealLoadingStatesHandler().isLoadingModifyAccept : false\"\n      (action)=\"onSelfHealAction($event)\">\n    </cqa-self-heal-analysis>\n\n    <!-- Timing Breakdown -->\n    <div *ngIf=\"config.timingBreakdown\" class=\"cqa-flex cqa-items-center cqa-justify-end cqa-gap-5 cqa-pt-1.5 cqa-px-4 cqa-text-[10px] cqa-leading-[15px] cqa-font-medium cqa-text-[#9CA3AF]\">\n      <div class=\"cqa-flex cqa-items-center cqa-gap-2\">\n        <div><svg width=\"12\" height=\"12\" viewBox=\"0 0 12 12\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M6 11C8.76142 11 11 8.76142 11 6C11 3.23858 8.76142 1 6 1C3.23858 1 1 3.23858 1 6C1 8.76142 3.23858 11 6 11Z\" stroke=\"#9CA3AF\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M6 3V6L8 7\" stroke=\"#9CA3AF\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/></svg></div>\n        <span>Timing breakdown</span>\n      </div>\n      <span class=\"cqa-text-dialog-muted cqa-flex cqa-items-center cqa-gap-3\">\n        <div>\n          App <span class=\"cqa-text-gray-700\">{{ formatDuration(config.timingBreakdown.app) }}</span>\n        </div>\n        <div><svg width=\"1\" height=\"11\" viewBox=\"0 0 1 11\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M-3.8147e-06 10.32V-7.15256e-07H0.959996V10.32H-3.8147e-06Z\" fill=\"#E5E7EB\"/></svg></div>\n        <div>\n          Tool <span class=\"cqa-text-gray-700\">{{ formatDuration(config.timingBreakdown.tool) }}</span>\n        </div>\n      </span>\n    </div>\n  </div>\n\n  <!-- View More Failed Step Button - shown when expanded and failure details exist -->\n  <div *ngIf=\"showViewMoreButton && !isLoading\" class=\"cqa-mt-2 cqa-px-4\">\n    <cqa-view-more-failed-step-button\n      [timingBreakdown]=\"timingBreakdown\"\n      [subSteps]=\"getSubStepsForFailedStep()\"\n      [failureDetails]=\"failureDetails\"\n      [isExpanded]=\"showFailedStepDetails\"\n      (viewMoreClick)=\"onViewMoreFailedStepClick($event)\">\n    </cqa-view-more-failed-step-button>\n  </div>\n\n  <!-- Updated Failed Step Component - shown when button is clicked -->\n  <div *ngIf=\"showViewMoreButton && showFailedStepDetails && failureDetails\" class=\"cqa-mt-2 cqa-px-4\">\n    <cqa-updated-failed-step\n      [timingBreakdown]=\"timingBreakdown\"\n      [testStepResultId]=\"testStepResultId\"\n      [expanded]=\"true\"\n      [subSteps]=\"getSubStepsForFailedStep()\"\n      [failureDetails]=\"failureDetails\"\n      [reasoning]=\"reasoning\"\n      [confidence]=\"confidence\"\n      [isUploadingBaseline]=\"isUploadingBaseline\"\n      [isMakingCurrentBaseline]=\"isMakingCurrentBaseline\"\n      [isLive]=\"isLive\"\n      (makeCurrentBaseline)=\"onMakeCurrentBaseline($event)\"\n      (uploadBaseline)=\"onUploadBaseline($event)\"\n      (analyze)=\"onAnalyze()\"\n      (viewFullLogs)=\"onViewFullLogs()\">\n    </cqa-updated-failed-step>\n  </div>\n</div>\n"]}
|
|
374
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"condition-step.component.js","sourceRoot":"","sources":["../../../../../../src/lib/execution-screen/condition-step/condition-step.component.ts","../../../../../../src/lib/execution-screen/condition-step/condition-step.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, OnChanges, Output, SimpleChanges, ChangeDetectorRef } from '@angular/core';\nimport { ConditionStepConfig, ConditionBranch, StepStatus, TimingBreakdown, FailureDetails, SubStep, SelfHealAnalysisData, SelfHealAction, ExecutionStepConfig } from '../execution-step.models';\nimport { BaseStepComponent } from '../base-step.component';\nimport { makeCurrentBaselineEvent, uploadBaselineEvent } from '../visual-comparison/visual-comparison.component';\n\n@Component({\n  selector: 'cqa-condition-step',\n  templateUrl: './condition-step.component.html',\n  styleUrls: [],\n  host: { class: 'cqa-ui-root' }\n})\nexport class ConditionStepComponent extends BaseStepComponent implements OnInit, OnChanges {\n  // Individual inputs\n  @Input() id!: string;\n  @Input() testStepResultId!: string;\n  @Input() stepNumber!: string;\n  @Input() title!: string;\n  @Input() status!: StepStatus;\n  @Input() duration!: number;\n  @Input() timingBreakdown?: TimingBreakdown;\n  @Input() expanded?: boolean;\n  @Input() conditionText!: string;\n  @Input() branches: ConditionBranch[] = [];\n  @Input() failureDetails?: FailureDetails;\n  @Input() reasoning?: string[];\n  @Input() confidence?: string;\n  @Input() selfHealAnalysis?: SelfHealAnalysisData;\n  @Input() isLoading?: boolean;\n  @Input() nestedSteps?: ExecutionStepConfig[] = [];\n  @Input() hasChild?: boolean;\n  @Input() ifChild?: any; // ifChild data from API - if null and hasChild is true, we need to call API\n  @Input() activeBranchStepId?: string | number; // ID of the currently active/selected branch step\n\n  // Handler function to pass down to nested child step groups for recursive expansion\n  @Input() onExpandHandler?: (step: ExecutionStepConfig) => void;\n\n  // Handler functions for condition steps\n  @Input() getConditionBranchesHandler?: (step: ExecutionStepConfig) => ConditionBranch[];\n  @Input() isStepLoadingHandler?: (step: ExecutionStepConfig) => boolean;\n  @Input() isStepExpandedHandler?: (step: ExecutionStepConfig) => boolean;\n  @Input() convertMsToSecondsHandler?: (duration: number) => number;\n  @Input() formatFailureDetailsHandler?: (step: ExecutionStepConfig) => any;\n  @Input() getSelfHealAnalysisHandler?: (step: ExecutionStepConfig) => any;\n  @Input() onMakeCurrentBaselineHandler?: (event: any) => void;\n  @Input() onUploadBaselineHandler?: (event: any) => void;\n  @Input() onAnalyzeHandler?: () => void;\n  @Input() onViewFullLogsHandler?: () => void;\n  @Input() onSelfHealActionHandler?: (event: any) => void;\n  @Input() getSelfHealLoadingStatesHandler?: () => { isLoadingAccept: boolean; isLoadingModifyAccept: boolean };\n  @Input() getLoopIterationsHandler?: (step: ExecutionStepConfig) => any[];\n  @Input() getApiAssertionsHandler?: (step: ExecutionStepConfig) => any[];\n  @Input() formatActionsHandler?: (step: ExecutionStepConfig) => any[];\n  @Input() onViewAllIterationsHandler?: (step: ExecutionStepConfig) => void;\n  @Input() onConditionBranchClickHandler?: (step: any, branch: any) => void;\n\n  @Output() onBranchClickEvent = new EventEmitter<ConditionBranch>();\n  @Output() onExpand = new EventEmitter<void>();\n  @Input() isUploadingBaseline = {};\n  @Input() isMakingCurrentBaseline = {};\n  @Input() isLive: boolean = false;\n  @Output() makeCurrentBaseline = new EventEmitter<makeCurrentBaselineEvent>();\n  @Output() uploadBaseline = new EventEmitter<uploadBaselineEvent>();\n  @Output() analyze = new EventEmitter<void>();\n  @Output() viewFullLogs = new EventEmitter<void>();\n  @Output() selfHealAction = new EventEmitter<{ type: SelfHealAction; healedLocator: string; }>();\n\n  showFailedStepDetails: boolean = false;\n\n  // Config property for base class - built from individual inputs in ngOnInit\n  override config!: ConditionStepConfig;\n\n  constructor(private cdr: ChangeDetectorRef) {\n    super();\n  }\n\n  override ngOnInit(): void {\n    // Always determine active branch from executed branch (for live mode)\n    if (this.isLive) {\n      this.determineActiveBranch();\n    }\n\n    // Filter nested steps based on active branch (derived from executed branch)\n    const stepsToUse = this.nestedSteps || [];\n\n    this.config = {\n      id: this.id,\n      testStepResultId: this.testStepResultId,\n      stepNumber: this.stepNumber,\n      title: this.title,\n      status: this.status,\n      duration: this.duration,\n      type: 'condition',\n      conditionText: this.conditionText,\n      branches: this.branches,\n      timingBreakdown: this.timingBreakdown,\n      expanded: this.expanded,\n      nestedSteps: stepsToUse,\n    } as ConditionStepConfig;\n\n    super.ngOnInit();\n  }\n\n\n  ngOnChanges(changes: SimpleChanges): void {\n    // Only process changes if config has been initialized (ngOnInit has been called)\n    if (!this.config) {\n      return;\n    }\n\n    // Process ifChild if it's provided and branches need to be updated\n    if (changes['ifChild'] && this.ifChild && Array.isArray(this.ifChild) && this.ifChild.length > 0) {\n      // Process ifChild to update branches\n      // This ensures branches reflect the executed condition from ifChild\n      if (this.getConditionBranchesHandler) {\n        // Use handler to get updated branches from ifChild\n        const stepWithIfChild = {\n          ...this.config,\n          ifChild: this.ifChild\n        } as any;\n        const updatedBranches = this.getConditionBranchesHandler(stepWithIfChild);\n        if (updatedBranches && updatedBranches.length > 0) {\n          this.branches = updatedBranches;\n          this.config.branches = updatedBranches.map((branch: any) => ({\n            ...branch,\n            subSteps: branch.subSteps ? [...branch.subSteps] : []\n          }));\n        }\n      }\n    }\n\n    if (this.isLive) {\n      // Update branches if changed - create deep copy to ensure change detection works\n      if (changes['branches'] && this.branches !== undefined) {\n        // Create a deep copy to ensure Angular change detection picks up nested changes\n        this.config.branches = this.branches.map((branch: any) => ({\n          ...branch,\n          subSteps: branch.subSteps ? [...branch.subSteps] : []\n        }));\n      } else if (this.branches !== undefined && this.config.branches !== this.branches) {\n        // Fallback: check if branches changed even if ngOnChanges didn't detect it\n        // This handles cases where nested subSteps were updated\n        const currentSubStepsCount = (this.config.branches || []).reduce((sum: number, b: any) => sum + (b.subSteps?.length || 0), 0);\n        const newSubStepsCount = (this.branches || []).reduce((sum: number, b: any) => sum + (b.subSteps?.length || 0), 0);\n\n        if (currentSubStepsCount !== newSubStepsCount ||\n          this.config.branches !== this.branches) {\n          this.config.branches = this.branches.map((branch: any) => ({\n            ...branch,\n            subSteps: branch.subSteps ? [...branch.subSteps] : []\n          }));\n        }\n      }\n\n      // Update other properties that might change\n      if (changes['status'] && this.status !== undefined) {\n        this.config.status = this.status;\n      }\n\n      if (changes['duration'] && this.duration !== undefined) {\n        this.config.duration = this.duration;\n      }\n\n      if (changes['expanded'] && this.expanded !== undefined) {\n        this.config.expanded = this.expanded;\n        this.isExpanded = this.expanded;\n      }\n\n      if (changes['conditionText'] && this.conditionText !== undefined) {\n        this.config.conditionText = this.conditionText;\n      }\n      // Update active branch if changed - always derive from executed branch\n      if (changes['activeBranchStepId'] || changes['branches']) {\n        // Check if executed branch changed\n        const executedBranchChanged = changes['branches'] && \n          changes['branches'].previousValue && \n          changes['branches'].currentValue &&\n          changes['branches'].previousValue.some((prevBranch: any, index: number) => {\n            const currentBranch = changes['branches'].currentValue[index];\n            return prevBranch?.executed !== currentBranch?.executed;\n          });\n        \n        // Always determine active branch from executed branch\n        this.determineActiveBranch();\n      }\n\n      // Filter nested steps based on active branch\n      if (changes['nestedSteps'] || changes['activeBranchStepId']) {\n        this.config.nestedSteps = this.nestedSteps;\n      }\n\n      if (changes['branches']) {\n        this.config.branches = this.branches;\n      }\n    }\n  }\n\n  override toggle(): void {\n    const wasExpanded = this.isExpanded;\n    super.toggle();\n    if (!wasExpanded && this.isExpanded) {\n      this.onExpand.emit();\n      // Always call children API if hasChild is true (like other step types)\n      // If ifChild exists and has an executed condition (result: \"SUCCESS\"), use that condition's testStepResultId\n      if (this.onExpandHandler && this.config && this.hasChild) {\n        const configWithNested = this.config as ConditionStepConfig;\n\n        // Find the executed condition from ifChild (the one with result: \"SUCCESS\")\n        let executedConditionTestStepResultId = this.testStepResultId; // Default to parent's ID\n        let executedConditionHasChild = this.hasChild;\n\n        if (this.ifChild && Array.isArray(this.ifChild) && this.ifChild.length > 0) {\n          const executedCondition = this.ifChild.find((condition: any) =>\n            condition.result === 'SUCCESS' || condition.result === 'SUCCESS'\n          );\n\n          if (executedCondition && executedCondition.testStepResultId) {\n            // Use the executed condition's testStepResultId and hasChild\n            executedConditionTestStepResultId = executedCondition.testStepResultId;\n            executedConditionHasChild = executedCondition.hasChild || false;\n          }\n        }\n\n        // Create a step config object for the handler\n        const stepConfig = {\n          ...this.config,\n          hasChild: executedConditionHasChild,\n          expanded: true, // Ensure expanded is set\n          testStepType: (this.config as any).testStepType || 'CONDITION_IF',\n          children: configWithNested.nestedSteps || [],\n          testStepResultId: executedConditionTestStepResultId, // Use executed condition's ID for API call\n          id: this.id,\n          ifChild: this.ifChild || null, // Pass ifChild for branch execution determination\n          // Store original parent testStepResultId for tracking states and updating parent structure\n          originalTestStepResultId: this.testStepResultId\n        } as ExecutionStepConfig & { originalTestStepResultId?: string | number };\n        this.onExpandHandler(stepConfig);\n      }\n    }\n\n    // Ensure expanded state is synced with config\n    if (this.config) {\n      this.config.expanded = this.isExpanded;\n    }\n  }\n\n  getExecutedBranch(): ConditionBranch | null {\n    return this.branches.find(branch => branch.executed) || null;\n  }\n\n  getUnexecutedBranches(): ConditionBranch[] {\n    return this.branches?.filter(branch => !branch.executed) || [];\n  }\n\n  getSubStepIndex(subSteps: any[], subStep: any): number {\n    return subSteps.indexOf(subStep) + 1;\n  }\n\n  onViewMoreFailedStepClick(expanded: boolean): void {\n    this.showFailedStepDetails = expanded;\n  }\n\n  getSubStepsForFailedStep(): SubStep[] {\n    const executedBranch = this.getExecutedBranch();\n    return executedBranch?.subSteps || [];\n  }\n\n  onMakeCurrentBaseline(event: makeCurrentBaselineEvent): void {\n    this.makeCurrentBaseline.emit(event);\n  }\n\n  onUploadBaseline(event: uploadBaselineEvent): void {\n    this.uploadBaseline.emit(event);\n  }\n\n  onAnalyze(): void {\n    this.analyze.emit();\n  }\n\n  onViewFullLogs(): void {\n    this.viewFullLogs.emit();\n  }\n\n  onSelfHealAction(event: { type: SelfHealAction; healedLocator: string; }): void {\n    this.selfHealAction.emit(event);\n  }\n\n  get showViewMoreButton(): boolean {\n    return this.isExpanded && Boolean(this.failureDetails) &&\n      (\n        (Boolean(this.failureDetails?.expected || this.failureDetails?.actual)) ||\n        (Boolean(this.failureDetails?.screenshots?.current || this.failureDetails?.screenshots?.baseline || this.failureDetails?.screenshots?.difference)\n          || Boolean(this.failureDetails?.logs?.length)) ||\n        (Boolean(this.failureDetails?.aiFixApplied && (this.failureDetails?.aiFixMessage || this.confidence || this.reasoning?.length)))\n      )\n  }\n\n  toggleHeader(): void {\n    this.toggle();\n    if (!this.isExpanded) {\n      this.showFailedStepDetails = false;\n    }\n  }\n\n  get hasExpandableContent(): boolean {\n    const hasBranchSubSteps = this.config.branches?.some(branch =>\n      branch.subSteps && branch.subSteps.length > 0\n    ) || false;\n    const hasNestedSteps = !!(this.config.nestedSteps && this.config.nestedSteps.length > 0);\n    return hasBranchSubSteps || hasNestedSteps;\n  }\n\n  private determineActiveBranch(): void {\n    if (!this.branches || !Array.isArray(this.branches) || this.branches.length === 0) {\n      return;\n    }\n\n    // Always find the executed branch and set activeBranchStepId from it\n    const executedBranch = this.branches.find((b: any) => b.executed) as any;\n    if (executedBranch && executedBranch.branchStepId) {\n      // Update activeBranchStepId to match executed branch\n      if (this.activeBranchStepId !== executedBranch.branchStepId) {\n        this.activeBranchStepId = executedBranch.branchStepId;\n        // Update nested steps when executed branch changes\n      }\n      return;\n    }\n\n    // If no branch is executed, default to first branch (IF branch) but don't mark it as executed\n    const firstBranch = this.branches[0] as any;\n    if (firstBranch && firstBranch.branchStepId) {\n      if (this.activeBranchStepId !== firstBranch.branchStepId) {\n        this.activeBranchStepId = firstBranch.branchStepId;\n      }\n    }\n  }\n\n  onBranchClick(branch: ConditionBranch): void {\n    if (!this.isLive) {\n      return;\n    }\n\n    this.onBranchClickEvent.emit(branch);\n  }\n\n  getBranchClass(branch: any): string {\n    // If branch is executed, show green styling\n    if (branch.executed) {\n      return 'cqa-bg-[#DCFCE7] cqa-text-[#008236] cqa-border cqa-border-solid cqa-border-[#B9F8CF]';\n    }\n\n    // For live mode: if no branches are executed but there's an activeBranchStepId,\n    // show the active branch with blue border\n    if (this.isLive && !this.hasAnyExecutedBranch()) {\n      return 'cqa-bg-[#EFF6FF] cqa-text-[#1E40AF] cqa-border cqa-border-solid cqa-border-[#3B82F6]';\n    }\n\n    // Default: gray styling for unexecuted branches\n    return 'cqa-bg-[#F3F4F6] cqa-text-[#99A1AF] cqa-border cqa-border-solid cqa-border-[#E5E7EB]';\n  }\n\n  /**\n   * Check if any branch is executed.\n   */\n  private hasAnyExecutedBranch(): boolean {\n    if (!this.branches || !Array.isArray(this.branches)) {\n      return false;\n    }\n    return this.branches.some((b: any) => b.executed === true);\n  }\n}\n","<div>\n  <div class=\"cqa-p-2\">\n    <!-- Header -->\n    <div\n      class=\"cqa-flex cqa-items-center cqa-gap-2 cqa-pb-1.5 cqa-cursor-pointer\"\n      (click)=\"toggleHeader()\">\n      \n      <!-- Status Icon -->\n      <div *ngIf=\"status.toLowerCase() === 'success'\" ><svg width=\"12\" height=\"12\" viewBox=\"0 0 12 12\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M10.9005 4.99999C11.1289 6.12064 10.9662 7.28571 10.4395 8.30089C9.91279 9.31608 9.054 10.12 8.00631 10.5787C6.95862 11.0373 5.78536 11.1229 4.6822 10.8212C3.57904 10.5195 2.61265 9.84869 1.94419 8.92071C1.27573 7.99272 0.945611 6.86361 1.00888 5.72169C1.07215 4.57976 1.52499 3.49404 2.29188 2.64558C3.05876 1.79712 4.09334 1.23721 5.22308 1.05922C6.35282 0.881233 7.50944 1.09592 8.50005 1.66749\" stroke=\"#22C55E\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M4.5 5.5L6 7L11 2\" stroke=\"#22C55E\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/></svg></div>\n      <div *ngIf=\"status.toLowerCase() === 'failure' || status.toLowerCase() === 'failed'\"><svg width=\"12\" height=\"12\" viewBox=\"0 0 12 12\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M6 11C8.76142 11 11 8.76142 11 6C11 3.23858 8.76142 1 6 1C3.23858 1 1 3.23858 1 6C1 8.76142 3.23858 11 6 11Z\" stroke=\"#DC2626\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M7.5 4.5L4.5 7.5\" stroke=\"#DC2626\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M4.5 4.5L7.5 7.5\" stroke=\"#DC2626\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/></svg></div>\n      <div *ngIf=\"status.toLowerCase() === 'pending'\"><svg width=\"12\" height=\"12\" viewBox=\"0 0 12 12\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M6 11C8.76142 11 11 8.76142 11 6C11 3.23858 8.76142 1 6 1C3.23858 1 1 3.23858 1 6C1 8.76142 3.23858 11 6 11Z\" stroke=\"#9CA3AF\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M6 3V6L8 7\" stroke=\"#9CA3AF\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/></svg></div>\n      <div *ngIf=\"status.toLowerCase() === 'running'\"><svg class=\"cqa-animate-spin cqa-text-[#3B82F6]\" width=\"12\" height=\"12\" viewBox=\"0 0 12 12\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><circle cx=\"6\" cy=\"6\" r=\"5\" stroke=\"currentColor\" stroke-width=\"1.5\" fill=\"none\" opacity=\"0.25\"/><path d=\"M6 1A5 5 0 0 1 11 6\" stroke=\"currentColor\" stroke-width=\"1.5\" fill=\"none\" stroke-linecap=\"round\"/></svg></div>\n\n      <!-- Condition Icon -->\n      <div><svg width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><rect width=\"16\" height=\"16\" rx=\"4\" fill=\"#FFEDD5\"/><path d=\"M6 5V9\" stroke=\"#FD9A00\" stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M10 7C10.5523 7 11 6.55228 11 6C11 5.44772 10.5523 5 10 5C9.44772 5 9 5.44772 9 6C9 6.55228 9.44772 7 10 7Z\" stroke=\"#FD9A00\" stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M6 11C6.55228 11 7 10.5523 7 10C7 9.44772 6.55228 9 6 9C5.44772 9 5 9.44772 5 10C5 10.5523 5.44772 11 6 11Z\" stroke=\"#FD9A00\" stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M10 7C10 7.79565 9.68393 8.55871 9.12132 9.12132C8.55871 9.68393 7.79565 10 7 10\" stroke=\"#FD9A00\" stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/></svg></div>\n\n      <!-- Step Number and Title -->\n      <div class=\"cqa-flex-1 cqa-flex cqa-items-center cqa-gap-3\">\n        <span class=\"cqa-font-bold cqa-text-[#334155] cqa-text-[11px] cqa-leading-[13px]\">\n          {{ config.stepNumber }}. Condition: <span [innerHTML]=\"config.conditionText\"></span>\n        </span>\n        \n        <!-- Condition Badge -->\n        <span class=\"cqa-px-1.5 cqa-rounded-full cqa-font-medium cqa-text-[#EA580C] cqa-bg-[#FFEDD5] cqa-text-[10px] cqa-leading-[15px]\">\n          CONDITION\n        </span>\n      </div>\n\n      <div class=\"cqa-flex cqa-items-center cqa-gap-1\">\n        <span class=\"cqa-text-[9px] cqa-leading-[11px] cqa-text-[#9CA3AF]\">\n          {{ formatDuration(config.duration) }}\n        </span>\n        <svg *ngIf=\"hasExpandableContent\" [class.cqa-rotate-180]=\"isExpanded\" class=\"cqa-transition-transform\" width=\"14\" height=\"14\" viewBox=\"0 0 14 14\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M3.5 5L7 8.5L10.5 5\" stroke=\"#9CA3AF\" stroke-width=\"0.833333\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/></svg>\n      </div>\n    </div>\n    <!-- Branch Buttons - Read-only, showing executed status only -->\n    <div class=\"cqa-flex cqa-items-center cqa-gap-3 cqa-px-4 cqa-text-[10px] cqa-leading-[15px] cqa-font-medium cqa-text-[#737373] cqa-flex-wrap\">\n      <div\n        *ngFor=\"let branch of config.branches\"\n        class=\"cqa-px-2 cqa-py-1 cqa-rounded cqa-text-[10px] cqa-leading-[15px] cqa-font-medium cqa-flex cqa-items-center cqa-gap-1.5\"\n        [ngClass]=\"getBranchClass(branch)\" (click)=\"onBranchClick(branch)\">\n        <!-- Checkmark icon for executed branch -->\n        <div *ngIf=\"branch.executed\">\n          <svg width=\"12\" height=\"12\" viewBox=\"0 0 12 12\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n            <path d=\"M10 3L4.5 8.5L2 6\" stroke=\"#008236\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n          </svg>\n        </div>\n        <span>{{ branch.type.toUpperCase() }}</span>\n      </div>\n    </div>\n  </div>\n\n  <!-- Expanded Content -->\n  <div *ngIf=\"isExpanded && !isLoading\">\n\n    <!-- Executed Branch Sub-steps -->\n    <div *ngFor=\"let branch of config.branches\">\n      <div *ngIf=\"branch.executed && branch.subSteps\" class=\"cqa-flex cqa-flex-col cqa-gap-1 cqa-pb-1 cqa-ml-9\" style=\"border-bottom: '1px solid #F3F4F6'\">\n        <div\n          *ngFor=\"let subStep of branch.subSteps\"\n          class=\"cqa-flex cqa-items-center cqa-gap-3 cqa-py-[5.5px] cqa-px-3\">\n          \n          <!-- Sub-step Status Icon -->\n          <div *ngIf=\"subStep?.status?.toLowerCase() === 'success' || subStep?.status?.toLowerCase() === 'passed'\" >\n            <svg width=\"12\" height=\"12\" viewBox=\"0 0 12 12\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M10.9005 4.99999C11.1289 6.12064 10.9662 7.28571 10.4395 8.30089C9.91279 9.31608 9.054 10.12 8.00631 10.5787C6.95862 11.0373 5.78536 11.1229 4.6822 10.8212C3.57904 10.5195 2.61265 9.84869 1.94419 8.92071C1.27573 7.99272 0.945611 6.86361 1.00888 5.72169C1.07215 4.57976 1.52499 3.49404 2.29188 2.64558C3.05876 1.79712 4.09334 1.23721 5.22308 1.05922C6.35282 0.881233 7.50944 1.09592 8.50005 1.66749\" stroke=\"#22C55E\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M4.5 5.5L6 7L11 2\" stroke=\"#22C55E\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/></svg>\n          </div>\n          <!-- Failure -->\n          <div *ngIf=\"subStep?.status?.toLowerCase() === 'failure' || subStep?.status?.toLowerCase() === 'failed'\">\n            <svg width=\"12\" height=\"12\" viewBox=\"0 0 12 12\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M6 11C8.76142 11 11 8.76142 11 6C11 3.23858 8.76142 1 6 1C3.23858 1 1 3.23858 1 6C1 8.76142 3.23858 11 6 11Z\" stroke=\"#DC2626\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M7.5 4.5L4.5 7.5\" stroke=\"#DC2626\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M4.5 4.5L7.5 7.5\" stroke=\"#DC2626\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/></svg>\n          </div>\n          <!-- Pending -->\n          <div *ngIf=\"subStep?.status?.toLowerCase() === 'pending'\">\n            <svg width=\"12\" height=\"12\" viewBox=\"0 0 12 12\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M6 11C8.76142 11 11 8.76142 11 6C11 3.23858 8.76142 1 6 1C3.23858 1 1 3.23858 1 6C1 8.76142 3.23858 11 6 11Z\" stroke=\"#9CA3AF\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M6 3V6L8 7\" stroke=\"#9CA3AF\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/></svg>\n          </div>\n          <!-- Running - Show spinner -->\n          <div *ngIf=\"subStep?.status?.toLowerCase() === 'running'\">\n            <svg class=\"cqa-animate-spin cqa-text-[#3B82F6]\" width=\"12\" height=\"12\" viewBox=\"0 0 12 12\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n              <circle cx=\"6\" cy=\"6\" r=\"5\" stroke=\"currentColor\" stroke-width=\"1.5\" fill=\"none\" opacity=\"0.25\"/>\n              <path d=\"M6 1A5 5 0 0 1 11 6\" stroke=\"currentColor\" stroke-width=\"1.5\" fill=\"none\" stroke-linecap=\"round\"/>\n            </svg>\n          </div>\n  \n\n          <!-- Sub-step Description -->\n          <span class=\"cqa-flex-1 cqa-text-[11px] cqa-leading-[13px] cqa-text-[#364153]\">\n            {{ config.stepNumber }}.{{ getSubStepIndex(branch.subSteps, subStep) }}. <span [innerHTML]=\"subStep.description\"></span>\n          </span>\n\n          <!-- Sub-step Duration -->\n          <span class=\"cqa-text-[10px] cqa-leading-[15px] cqa-font-medium cqa-text-metadata-key\">\n            {{ formatDuration(subStep.duration) }}\n          </span>\n        </div>\n      </div>\n    </div>\n\n    <!-- Unexecuted Branch Message -->\n    <div *ngIf=\"getUnexecutedBranches().length > 0 && getUnexecutedBranches().length < 2\" class=\"cqa-ml-9\">\n      <p class=\"cqa-px-3 cqa-py-[10px] cqa-text-[12px] cqa-leading-4 cqa-text-[#737373] cqa-italic\">\n        {{ getUnexecutedBranches()?.[0]?.type?.toUpperCase() }} branch not executed\n      </p>\n    </div>\n\n    <div *ngIf=\"getUnexecutedBranches().length > 1\" class=\"cqa-ml-9\">\n      <p class=\"cqa-px-3 cqa-py-[10px] cqa-text-[12px] cqa-leading-4 cqa-text-[#737373] cqa-italic\">\n        {{ getUnexecutedBranches()?.[0]?.type?.toUpperCase() }} and {{ getUnexecutedBranches()?.[1]?.type?.toUpperCase() }} branches not executed\n      </p>\n    </div>\n\n    <!-- Nested Steps -->\n    <div *ngIf=\"config.nestedSteps && config.nestedSteps.length > 0\" class=\"cqa-ml-9 cqa-pb-1\" style=\"border-bottom: '1px solid #F3F4F6'\">\n      <div class=\"cqa-text-[10px] cqa-leading-[15px] cqa-font-medium cqa-text-[#737373] cqa-py-[2px] cqa-px-3\">Nested steps</div>\n      <div class=\"cqa-flex cqa-flex-col cqa-gap-2 cqa-pl-[18px]\" style=\"border-left: 2px solid #C5C7FA;\">\n        <ng-container *ngFor=\"let step of config.nestedSteps\">\n          <!-- Use step-renderer for all nested steps to avoid circular dependencies -->\n          <!-- The step-renderer will dynamically load the appropriate component and pass handlers -->\n          <cqa-step-renderer \n            [step]=\"step\"\n            [onConditionBranchClickHandler]=\"onConditionBranchClickHandler\"\n            [onExpandHandler]=\"onExpandHandler\"\n            [getConditionBranchesHandler]=\"getConditionBranchesHandler\"\n            [isStepLoadingHandler]=\"isStepLoadingHandler\"\n            [isStepExpandedHandler]=\"isStepExpandedHandler\"\n            [convertMsToSecondsHandler]=\"convertMsToSecondsHandler\"\n            [formatFailureDetailsHandler]=\"formatFailureDetailsHandler\"\n            [getSelfHealAnalysisHandler]=\"getSelfHealAnalysisHandler\"\n            [getLoopIterationsHandler]=\"getLoopIterationsHandler\"\n            [getApiAssertionsHandler]=\"getApiAssertionsHandler\"\n            [formatActionsHandler]=\"formatActionsHandler\"\n            [onViewAllIterationsHandler]=\"onViewAllIterationsHandler\"\n            [onMakeCurrentBaselineHandler]=\"onMakeCurrentBaselineHandler\"\n            [onUploadBaselineHandler]=\"onUploadBaselineHandler\"\n            [onAnalyzeHandler]=\"onAnalyzeHandler\"\n            [onViewFullLogsHandler]=\"onViewFullLogsHandler\"\n            [onSelfHealActionHandler]=\"onSelfHealActionHandler\"\n            [isUploadingBaseline]=\"isUploadingBaseline\"\n            [isMakingCurrentBaseline]=\"isMakingCurrentBaseline\"\n            [selectedIterationId]=\"step?.selectedIterationId || ''\"\n            [isLive]=\"isLive\">\n          </cqa-step-renderer>\n        </ng-container>\n      </div>\n    </div>\n\n      <!-- Self Heal Analysis -->\n    <cqa-self-heal-analysis \n      *ngIf=\"selfHealAnalysis\" \n      [originalLocator]=\"selfHealAnalysis.originalLocator\"\n      [healedLocator]=\"selfHealAnalysis.healedLocator\"\n      [confidence]=\"selfHealAnalysis.confidence\"\n      [healMethod]=\"selfHealAnalysis.healMethod\"\n      [isLoadingAccept]=\"getSelfHealLoadingStatesHandler ? getSelfHealLoadingStatesHandler().isLoadingAccept : false\"\n      [isLoadingModifyAccept]=\"getSelfHealLoadingStatesHandler ? getSelfHealLoadingStatesHandler().isLoadingModifyAccept : false\"\n      (action)=\"onSelfHealAction($event)\">\n    </cqa-self-heal-analysis>\n\n    <!-- Timing Breakdown -->\n    <div *ngIf=\"config.timingBreakdown\" class=\"cqa-flex cqa-items-center cqa-justify-end cqa-gap-5 cqa-pt-1.5 cqa-px-4 cqa-text-[10px] cqa-leading-[15px] cqa-font-medium cqa-text-[#9CA3AF]\">\n      <div class=\"cqa-flex cqa-items-center cqa-gap-2\">\n        <div><svg width=\"12\" height=\"12\" viewBox=\"0 0 12 12\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M6 11C8.76142 11 11 8.76142 11 6C11 3.23858 8.76142 1 6 1C3.23858 1 1 3.23858 1 6C1 8.76142 3.23858 11 6 11Z\" stroke=\"#9CA3AF\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M6 3V6L8 7\" stroke=\"#9CA3AF\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/></svg></div>\n        <span>Timing breakdown</span>\n      </div>\n      <span class=\"cqa-text-dialog-muted cqa-flex cqa-items-center cqa-gap-3\">\n        <div>\n          App <span class=\"cqa-text-gray-700\">{{ formatDuration(config.timingBreakdown.app) }}</span>\n        </div>\n        <div><svg width=\"1\" height=\"11\" viewBox=\"0 0 1 11\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M-3.8147e-06 10.32V-7.15256e-07H0.959996V10.32H-3.8147e-06Z\" fill=\"#E5E7EB\"/></svg></div>\n        <div>\n          Tool <span class=\"cqa-text-gray-700\">{{ formatDuration(config.timingBreakdown.tool) }}</span>\n        </div>\n      </span>\n    </div>\n  </div>\n\n  <!-- View More Failed Step Button - shown when expanded and failure details exist -->\n  <div *ngIf=\"showViewMoreButton && !isLoading\" class=\"cqa-mt-2 cqa-px-4\">\n    <cqa-view-more-failed-step-button\n      [timingBreakdown]=\"timingBreakdown\"\n      [subSteps]=\"getSubStepsForFailedStep()\"\n      [failureDetails]=\"failureDetails\"\n      [isExpanded]=\"showFailedStepDetails\"\n      (viewMoreClick)=\"onViewMoreFailedStepClick($event)\">\n    </cqa-view-more-failed-step-button>\n  </div>\n\n  <!-- Updated Failed Step Component - shown when button is clicked -->\n  <div *ngIf=\"showViewMoreButton && showFailedStepDetails && failureDetails\" class=\"cqa-mt-2 cqa-px-4\">\n    <cqa-updated-failed-step\n      [timingBreakdown]=\"timingBreakdown\"\n      [testStepResultId]=\"testStepResultId\"\n      [expanded]=\"true\"\n      [subSteps]=\"getSubStepsForFailedStep()\"\n      [failureDetails]=\"failureDetails\"\n      [reasoning]=\"reasoning\"\n      [confidence]=\"confidence\"\n      [isUploadingBaseline]=\"isUploadingBaseline\"\n      [isMakingCurrentBaseline]=\"isMakingCurrentBaseline\"\n      [isLive]=\"isLive\"\n      (makeCurrentBaseline)=\"onMakeCurrentBaseline($event)\"\n      (uploadBaseline)=\"onUploadBaseline($event)\"\n      (analyze)=\"onAnalyze()\"\n      (viewFullLogs)=\"onViewFullLogs()\">\n    </cqa-updated-failed-step>\n  </div>\n</div>\n"]}
|