@cqa-lib/cqa-ui 1.1.78 → 1.1.80

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.
@@ -33,11 +33,15 @@ export class LoopStepComponent extends BaseStepComponent {
33
33
  // Build config from individual inputs
34
34
  // Use nestedSteps if provided, otherwise fall back to empty array
35
35
  const stepsToUse = this.nestedSteps || [];
36
+ // Use action as fallback for title if title is empty
37
+ // Check both instance property and config for action
38
+ const actionValue = this.action || '';
39
+ const stepTitle = (this.title && this.title.trim()) ? this.title : actionValue;
36
40
  this.config = {
37
41
  id: this.id,
38
42
  testStepResultId: this.testStepResultId,
39
43
  stepNumber: this.stepNumber,
40
- title: this.title,
44
+ title: stepTitle,
41
45
  status: this.status,
42
46
  duration: this.duration,
43
47
  type: 'loop',
@@ -135,6 +139,14 @@ export class LoopStepComponent extends BaseStepComponent {
135
139
  }
136
140
  }
137
141
  }
142
+ // Update title if it changes - also check for action in config or instance
143
+ if (changes['title']) {
144
+ const actionValue = this.action || this.config?.action || '';
145
+ const stepTitle = (this.title && this.title.trim()) ? this.title : actionValue;
146
+ if (this.config) {
147
+ this.config.title = stepTitle;
148
+ }
149
+ }
138
150
  // Update config when inputs change
139
151
  if (changes['iterations'] || changes['selectedIterationId'] || changes['nestedSteps']) {
140
152
  if (this.config) {
@@ -617,4 +629,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImpor
617
629
  }], onIterationChange: [{
618
630
  type: Output
619
631
  }] } });
620
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"loop-step.component.js","sourceRoot":"","sources":["../../../../../../src/lib/execution-screen/loop-step/loop-step.component.ts","../../../../../../src/lib/execution-screen/loop-step/loop-step.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, Output, EventEmitter, OnInit, OnChanges, SimpleChanges, ChangeDetectorRef } from '@angular/core';\nimport { LoopStepConfig, LoopIteration, ExecutionStepConfig, StepStatus, TimingBreakdown, FailureDetails, SubStep, SelfHealAnalysisData, SelfHealAction, StepGroupConfig, ConditionBranch } 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-loop-step',\n  templateUrl: './loop-step.component.html',\n  styleUrls: [],\n  host: { class: 'cqa-ui-root' }\n})\nexport class LoopStepComponent 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() loopType?: 'for' | 'while';\n  @Input() iterations!: LoopIteration[];\n  @Input() selectedIterationId?: string;\n  @Input() defaultIteration?: 'first' | 'last' = 'last';\n  @Input() nestedSteps?: ExecutionStepConfig[];\n  @Input() showViewAllIterations?: boolean;\n  @Input() hasChild?: boolean;\n  @Input() isLive: boolean = false;\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() getLoopIterationsHandler?: (step: ExecutionStepConfig) => any[];\n  @Input() getApiAssertionsHandler?: (step: ExecutionStepConfig) => any[];\n  @Input() formatActionsHandler?: (step: ExecutionStepConfig) => any[];\n  @Input() onViewAllIterationsHandler?: (step: ExecutionStepConfig) => void;\n  \n  @Input() failureDetails?: FailureDetails;\n  @Input() reasoning?: string[];\n  @Input() confidence?: string;\n  @Input() isUploadingBaseline = {};\n  @Input() selfHealAnalysis?: SelfHealAnalysisData;\n  @Input() iterationData?: any;\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  // Output event for when the loop step expands\n  @Output() onExpand = new EventEmitter<void>();\n\n  // Output event for when \"View all iterations\" is clicked\n  @Output() onViewAllIterations = new EventEmitter<void>();\n\n  // Output event for when iteration selection changes\n  @Output() onIterationChange = new EventEmitter<string>();\n\n  // Config property for base class - built from individual inputs in ngOnInit\n  override config!: LoopStepConfig;\n\n  selectedIteration: LoopIteration | null = null;\n  private userSelectedIterationId: string | null = null; // Track user's manual selection\n  private previousStatus?: StepStatus;\n  private userManuallyClosed: boolean = false;\n\n  override ngOnInit(): void {\n    // Build config from individual inputs\n    // Use nestedSteps if provided, otherwise fall back to empty array\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: 'loop',\n      loopType: this.loopType,\n      iterations: this.iterations,\n      selectedIterationId: this.selectedIterationId,\n      defaultIteration: this.defaultIteration,\n      nestedSteps: stepsToUse,\n      showViewAllIterations: this.showViewAllIterations,\n      timingBreakdown: this.timingBreakdown,\n      expanded: this.expanded,\n    } as LoopStepConfig;\n\n    super.ngOnInit();\n    \n    // Initialize selection - prioritize selectedIterationId input, then default\n    if (this.selectedIterationId && this.iterations && this.iterations.length > 0) {\n      const found = this.iterations.find(iter => iter.id === this.selectedIterationId);\n      if (found) {\n        this.selectedIteration = found;\n        this.userSelectedIterationId = this.selectedIterationId;\n      } else {\n        this.selectDefaultIteration();\n      }\n    } else if (this.iterations && this.iterations.length > 0) {\n      this.selectDefaultIteration();\n      // If defaultIteration is 'last', also set userSelectedIterationId to the last iteration\n      if (this.defaultIteration === 'last' && this.selectedIteration) {\n        this.userSelectedIterationId = this.selectedIteration.id;\n      }\n    }\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    // Update selection when selectedIterationId input changes\n    if (changes['selectedIterationId'] && this.iterations && this.iterations.length > 0) {\n      const currentValue = changes['selectedIterationId'].currentValue;\n      const previousValue = changes['selectedIterationId'].previousValue;\n      \n      // Always update when selectedIterationId input changes from parent\n      if (currentValue !== previousValue) {\n        if (currentValue) {\n          const found = this.iterations.find(iter => iter.id === currentValue);\n          if (found) {\n            this.selectedIteration = found;\n            // Sync userSelectedIterationId with the input value\n            this.userSelectedIterationId = currentValue;\n          } else {\n            // If not found, select default\n            this.selectDefaultIteration();\n          }\n        } else {\n          // If no value provided, select default\n          this.selectDefaultIteration();\n        }\n      }\n    }\n    // Update selection when iterations array changes\n    if (changes['iterations'] && this.iterations && this.iterations.length > 0) {\n      // If we have a user selection, try to preserve it\n      if (this.userSelectedIterationId) {\n        const found = this.iterations.find(iter => iter.id === this.userSelectedIterationId);\n        if (found) {\n          this.selectedIteration = found;\n        } else {\n          // User selection no longer valid, use selectedIterationId or default\n          if (this.selectedIterationId) {\n            const foundById = this.iterations.find(iter => iter.id === this.selectedIterationId);\n            if (foundById) {\n              this.selectedIteration = foundById;\n            } else {\n              this.selectDefaultIteration();\n            }\n          } else {\n            this.selectDefaultIteration();\n          }\n        }\n      } else if (!this.selectedIteration || !this.iterations.some(iter => iter.id === this.selectedIteration?.id)) {\n        // No user selection, use selectedIterationId or default\n        if (this.selectedIterationId) {\n          const found = this.iterations.find(iter => iter.id === this.selectedIterationId);\n          if (found) {\n            this.selectedIteration = found;\n          } else {\n            this.selectDefaultIteration();\n          }\n        } else {\n          this.selectDefaultIteration();\n        }\n      }\n    }\n    // Update config when inputs change\n    if (changes['iterations'] || changes['selectedIterationId'] || changes['nestedSteps']) {\n      if (this.config) {\n        this.config.iterations = this.iterations;\n        this.config.selectedIterationId = this.selectedIterationId;\n        this.config.nestedSteps = this.nestedSteps || [];\n      }\n    }\n    \n    // Also handle when nestedSteps is passed via children property (for step-renderer compatibility)\n    if (changes['nestedSteps'] && this.nestedSteps) {\n      // Ensure config is updated with nestedSteps\n      if (this.config) {\n        this.config.nestedSteps = this.nestedSteps;\n      }\n    }\n    \n    // If nestedSteps is not provided but children is (from step-renderer), use children\n    if (!this.nestedSteps && (this.config as any).children && Array.isArray((this.config as any).children)) {\n      this.nestedSteps = (this.config as any).children;\n      if (this.config) {\n        this.config.nestedSteps = this.nestedSteps;\n      }\n    }\n\n    if(this.isLive) {\n      // Update subSteps array when new ones are added\n      if (changes['nestedSteps']) {\n        const previousSubStepsCount = changes['nestedSteps'].previousValue?.length || 0;\n        const currentSubStepsCount = (this.nestedSteps || []).length;\n        \n        // Sub-steps are appended externally, so we just update the config\n        if (this.config) {\n          this.config.nestedSteps = this.nestedSteps || [];\n        }\n        \n        // Auto-expand if step is running and new subSteps are added (logs coming in)\n        if (!changes['nestedSteps'].firstChange && \n            this.status === 'running' && \n            currentSubStepsCount > previousSubStepsCount &&\n            this.hasSubSteps && \n            !this.isExpanded && \n            !this.userManuallyClosed) {\n          this.autoExpand();\n        }\n      }\n\n      // Handle status changes - auto-expand when step starts executing\n      if (changes['status'] && !changes['status'].firstChange) {\n        const newStatus = changes['status'].currentValue;\n        const oldStatus = changes['status'].previousValue;\n        \n        // Auto-expand when status changes to 'running' and has subSteps (or will have soon)\n        if (newStatus === 'running' && oldStatus !== 'running' && !this.userManuallyClosed) {\n          // Expand immediately if already has subSteps, or wait for them\n          if (this.hasSubSteps) {\n            this.autoExpand();\n          }\n        }\n        \n        this.previousStatus = newStatus;\n      }\n    }\n  }\n\n  private autoExpand(): void {\n    if (!this.isExpanded && this.hasSubSteps) {\n      this.isExpanded = true;\n      this.userManuallyClosed = false;\n      this.toggleExpanded.emit(true);\n    }\n  }\n\n  get hasSubSteps(): boolean {\n    return this.nestedSteps !== undefined && this.nestedSteps.length > 0;\n  }\n\n  override toggle(): void {\n    const wasExpanded = this.isExpanded;\n    super.toggle();\n    // Emit event when expanding (transitioning from collapsed to expanded)\n    if (!wasExpanded && this.isExpanded) {\n      this.onExpand.emit();\n      // If this step has children (hasChild is true) and onExpandHandler is provided, call it to fetch children\n      if (this.onExpandHandler && this.config && this.hasChild) {\n        // Create a step config object for the handler with hasChild property\n        const stepConfig = {\n          ...this.config,\n          hasChild: true,\n          expanded: true, // Ensure expanded is set\n          testStepType: (this.config as any).testStepType || (this.loopType === 'for' ? 'FOR_LOOP' : 'WHILE_LOOP'),\n          children: this.config.nestedSteps || [],\n          testStepResultId: this.testStepResultId,\n          id: this.id\n        } as ExecutionStepConfig & { hasChild: boolean; testStepType?: string; children?: any[]; expanded?: boolean };\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  selectDefaultIteration(): void {\n    // First, try to use selectedIterationId if provided\n    if (this.selectedIterationId) {\n      const found = this.iterations.find(\n        iter => iter.id === this.selectedIterationId\n      );\n      if (found) {\n        this.selectedIteration = found;\n        return;\n      }\n    }\n    \n    // If user has manually selected something, preserve it\n    if (this.userSelectedIterationId) {\n      const found = this.iterations.find(iter => iter.id === this.userSelectedIterationId);\n      if (found) {\n        this.selectedIteration = found;\n        return;\n      }\n    }\n    \n    // Apply default based on defaultIteration setting\n    if (this.defaultIteration === 'last' && this.iterations.length > 0) {\n      const lastIteration = this.iterations[this.iterations.length - 1];\n      this.selectedIteration = lastIteration;\n      // Set userSelectedIterationId to track the default selection\n      this.userSelectedIterationId = lastIteration.id;\n    } else if (this.iterations.length > 0) {\n      const firstIteration = this.iterations[0];\n      this.selectedIteration = firstIteration;\n      // Set userSelectedIterationId to track the default selection\n      this.userSelectedIterationId = firstIteration.id;\n    }\n  }\n\n  handleIterationChange(iteration: LoopIteration): void {\n    // Store the user's manual selection\n    this.selectedIteration = iteration;\n    this.userSelectedIterationId = iteration.id;\n\n    if (this.isLive) {\n      const index = this.iterations.findIndex(iter => iter.id === iteration.id);\n\n      if (index > -1 && this.iterationData?.[index] && this.nestedSteps) {\n\n        const updatedNestedSteps: ExecutionStepConfig[] =\n          this.nestedSteps.map(step => {\n            const updatedSubSteps = this.iterationData[index][step.id];\n            step.duration = updatedSubSteps.reduce((acc: number, subStep: any) => acc + subStep?.duration || 0, 0);\n\n            if (updatedSubSteps) {\n              return {\n                ...step,\n                subSteps: [...updatedSubSteps]\n              };\n            }\n\n            return { ...step };\n          });\n\n        this.nestedSteps = updatedNestedSteps;\n\n        if (this.config) {\n          this.config = {\n            ...this.config,\n            nestedSteps: updatedNestedSteps\n          };\n        }\n      }\n    }\n    // Emit the event with the iteration ID\n    this.onIterationChange.emit(iteration.id);\n  }\n\n  compareIteration(a: LoopIteration, b: LoopIteration): boolean {\n    return a && b ? a.id === b.id : a === b;\n  }\n\n  getLoopTypeBadges(): string[] {\n    const badges: string[] = ['LOOP'];\n    if (this.loopType === 'for') {\n      badges.push('FOR');\n    } else if (this.loopType === 'while') {\n      badges.push('WHILE');\n    }\n    return badges;\n  }\n\n  getIterationLabel(iteration: LoopIteration): string {\n    return iteration.label;\n  }\n\n  onViewAllIterationsClick(event: Event): void {\n    event.preventDefault();\n    this.onViewAllIterations.emit();\n  }\n\n  onViewMoreFailedStepClick(expanded: boolean): void {\n    this.showFailedStepDetails = expanded;\n  }\n\n  getSubStepsForFailedStep(): SubStep[] {\n    return this.selectedIteration?.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() {\n    this.toggle();\n    if(!this.isExpanded){\n      this.showFailedStepDetails = false;\n    }\n  }\n\n  // Helper method to check if a step is a step-group with hasChild\n  isNestedStepGroupWithChildren(step: ExecutionStepConfig): boolean {\n    return step.type === 'step-group' && !!(step as any).hasChild;\n  }\n\n  // Helper method to get groupName from step config\n  getGroupName(step: ExecutionStepConfig): string {\n    return (step as StepGroupConfig).groupName || '';\n  }\n\n  // Helper method to get steps from step config\n  getSteps(step: ExecutionStepConfig): ExecutionStepConfig[] {\n    const stepGroup = step as StepGroupConfig;\n    return stepGroup.steps || (step as any).children || [];\n  }\n\n  // Helper method to check if a step is a condition step\n  isNestedConditionStep(step: ExecutionStepConfig): boolean {\n    const stepType = (step as any).testStepType || step.type;\n    return stepType === 'CONDITION_IF' || stepType === 'CONDITION_ELSE' || \n           stepType === 'CONDITION_ELSE_IF' || stepType === 'CONDITION_ELSEIF' ||\n           stepType === 'condition';\n  }\n\n  // Helper method to check if a step is a loop step\n  isNestedLoopStep(step: ExecutionStepConfig): boolean {\n    const stepType = (step as any).testStepType || step.type;\n    return stepType === 'FOR_LOOP' || stepType === 'WHILE_LOOP' || stepType === 'loop';\n  }\n\n  // Helper method to get loop type from step config\n  getLoopType(step: ExecutionStepConfig): 'for' | 'while' | undefined {\n    const stepType = (step as any).testStepType || step.type;\n    if (stepType === 'FOR_LOOP' || (step as LoopStepConfig).loopType === 'for') {\n      return 'for';\n    } else if (stepType === 'WHILE_LOOP' || (step as LoopStepConfig).loopType === 'while') {\n      return 'while';\n    }\n    return (step as LoopStepConfig).loopType;\n  }\n\n  // Helper method to get iterations from step config\n  getLoopIterations(step: ExecutionStepConfig): any[] {\n    // Use handler if available, otherwise use config\n    if (this.getLoopIterationsHandler) {\n      return this.getLoopIterationsHandler(step);\n    }\n    const loopStep = step as LoopStepConfig;\n    return loopStep.iterations || [];\n  }\n\n  // Helper method to get nested steps from loop step config\n  getLoopNestedSteps(step: ExecutionStepConfig): ExecutionStepConfig[] {\n    const loopStep = step as LoopStepConfig;\n    return loopStep.nestedSteps || (step as any).children || [];\n  }\n\n  // Helper method to handle nested loop step expansion\n  handleLoopStepExpand(step: ExecutionStepConfig): void {\n    if (this.onExpandHandler) {\n      this.onExpandHandler(step);\n    }\n  }\n\n  // Helper method to handle nested loop step iteration change\n  handleLoopStepIterationChange(step: ExecutionStepConfig, iterationId: string): void {\n    // This would typically be handled by the parent component\n    // For now, we just emit the expand event\n    if (this.onExpandHandler) {\n      this.onExpandHandler(step);\n    }\n  }\n\n  // Helper method to get step title\n  getStepTitle(step: ExecutionStepConfig): string {\n    return (step as any).action || step.title || '';\n  }\n\n  // Helper method to get step status\n  getStepStatus(step: ExecutionStepConfig): StepStatus {\n    const result = (step as any).result;\n    if (result) {\n      const resultLower = result.toLowerCase();\n      if (resultLower === 'success' || resultLower === 'passed') {\n        return 'success';\n      } else if (resultLower === 'failure' || resultLower === 'failed') {\n        return 'failed';\n      } else if (resultLower === 'pending' || resultLower === 'not-executed') {\n        return 'pending';\n      } else if (resultLower === 'running') {\n        return 'running';\n      }\n    }\n    return step.status || 'pending';\n  }\n\n  // Helper method to get step duration\n  getStepDuration(step: ExecutionStepConfig): number {\n    return (step as any).duration || step.duration || 0;\n  }\n\n  // Helper methods for condition step properties\n  getConditionStepDuration(step: ExecutionStepConfig): number {\n    const duration = this.getStepDuration(step);\n    if (this.convertMsToSecondsHandler) {\n      return this.convertMsToSecondsHandler(duration);\n    }\n    return duration;\n  }\n\n  getConditionStepExpanded(step: ExecutionStepConfig): boolean {\n    if (this.isStepExpandedHandler) {\n      return this.isStepExpandedHandler(step);\n    }\n    return step.expanded || false;\n  }\n\n  getConditionStepText(step: ExecutionStepConfig): string {\n    return (step as any).action || step.title || '';\n  }\n\n  getConditionStepBranches(step: ExecutionStepConfig): ConditionBranch[] {\n    if (this.getConditionBranchesHandler) {\n      return this.getConditionBranchesHandler(step);\n    }\n    return [];\n  }\n\n  getConditionStepLoading(step: ExecutionStepConfig): boolean {\n    if (this.isStepLoadingHandler) {\n      return this.isStepLoadingHandler(step);\n    }\n    return false;\n  }\n\n  handleConditionStepExpand(step: ExecutionStepConfig): void {\n    if (this.onExpandHandler) {\n      this.onExpandHandler(step);\n    }\n  }\n\n  getConditionStepFailureDetails(step: ExecutionStepConfig): any {\n    if (this.formatFailureDetailsHandler) {\n      return this.formatFailureDetailsHandler(step);\n    }\n    return undefined;\n  }\n\n  getConditionStepSelfHealAnalysis(step: ExecutionStepConfig): any {\n    if (this.getSelfHealAnalysisHandler) {\n      return this.getSelfHealAnalysisHandler(step);\n    }\n    return undefined;\n  }\n\n  handleConditionStepSelfHealAction(event: any): void {\n    if (this.onSelfHealActionHandler) {\n      this.onSelfHealActionHandler(event);\n    }\n  }\n\n  handleConditionStepMakeBaseline(event: any): void {\n    if (this.onMakeCurrentBaselineHandler) {\n      this.onMakeCurrentBaselineHandler(event);\n    }\n  }\n\n  handleConditionStepUploadBaseline(event: any): void {\n    if (this.onUploadBaselineHandler) {\n      this.onUploadBaselineHandler(event);\n    }\n  }\n\n  handleConditionStepAnalyze(): void {\n    if (this.onAnalyzeHandler) {\n      this.onAnalyzeHandler();\n    }\n  }\n\n  handleConditionStepViewLogs(): void {\n    if (this.onViewFullLogsHandler) {\n      this.onViewFullLogsHandler();\n    }\n  }\n\n  // Helper methods to safely access LoopStepConfig properties\n  getLoopSelectedIterationId(step: ExecutionStepConfig): string | undefined {\n    const loopStep = step as LoopStepConfig;\n    return loopStep.selectedIterationId;\n  }\n\n  getLoopDefaultIteration(step: ExecutionStepConfig): 'first' | 'last' | undefined {\n    const loopStep = step as LoopStepConfig;\n    return loopStep.defaultIteration || 'last';\n  }\n\n  getLoopShowViewAllIterations(step: ExecutionStepConfig): boolean | undefined {\n    const loopStep = step as LoopStepConfig;\n    return loopStep.showViewAllIterations;\n  }\n}\n","<div>\n  <!-- Header -->\n  <div\n    class=\"cqa-flex cqa-items-center cqa-gap-2 cqa-p-2 cqa-cursor-pointer\"\n    (click)=\"toggleHeader()\">\n    \n    <!-- Status Icon -->\n    <div>\n      <!-- Success -->\n      <svg *ngIf=\"status.toLowerCase() === 'success'\" 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      <!-- Failed -->\n      <svg *ngIf=\"status.toLowerCase() === 'failure' || status.toLowerCase() === 'failed'\" 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=\"#EF4444\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M4 4L8 8M8 4L4 8\" stroke=\"#EF4444\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/></svg>\n      <!-- Pending -->\n      <svg *ngIf=\"status.toLowerCase() === 'pending'\" 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      <!-- Running -->\n      <svg *ngIf=\"status.toLowerCase() === 'running'\" 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=\"#3B82F6\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M6 3V6L8 7\" stroke=\"#3B82F6\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/></svg>\n    </div>\n\n    <!-- Loop 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=\"#EBECFD\"/><path d=\"M9.66663 4.66666L11 5.99999L9.66663 7.33332\" stroke=\"#3F43EE\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M5 7.66667V7.33333C5 6.97971 5.14048 6.64057 5.39052 6.39052C5.64057 6.14048 5.97971 6 6.33333 6H11\" stroke=\"#3F43EE\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M6.33333 11.3333L5 9.99999L6.33333 8.66666\" stroke=\"#3F43EE\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M11 8.33334V8.66668C11 9.0203 10.8595 9.35944 10.6095 9.60949C10.3594 9.85953 10.0203 10 9.66667 10H5\" stroke=\"#3F43EE\" 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 }}. <span [innerHTML]=\"config.title\"></span>\n      </span>\n      \n      <!-- Loop Type Badges -->\n      <span *ngFor=\"let badge of getLoopTypeBadges()\" \n        class=\"cqa-px-1.5 cqa-rounded-full cqa-font-medium cqa-text-primary cqa-bg-[#EBECFD] cqa-text-[10px] cqa-leading-[15px]\">\n        {{ badge }}\n      </span>\n    </div>\n\n    <div class=\"cqa-flex cqa-items-center cqa-gap-1\">\n      <span class=\"cqa-text-[10px] cqa-leading-[15px] cqa-font-medium cqa-text-[#9CA3AF]\">\n        {{ formatDuration(config.duration) }}\n      </span>\n      <svg [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\n  <!-- Expanded Content -->\n  <div *ngIf=\"isExpanded\">\n    <!-- Iteration Selector -->\n    <div class=\"cqa-flex cqa-items-center cqa-gap-3 cqa-px-4 cqa-py-2 cqa-text-[10px] cqa-leading-[15px] cqa-font-medium cqa-text-[#737373]\">\n      <label>Iteration</label>\n      <div class=\"cqa-relative cqa-w-full cqa-max-w-[156px]\">\n        <!-- Status indicator for selected iteration -->\n        <div *ngIf=\"selectedIteration\" class=\"cqa-absolute cqa-left-[10px] cqa-top-1/2 cqa-transform cqa--translate-y-1/2 cqa-pointer-events-none cqa-z-10\">\n          <svg *ngIf=\"selectedIteration.status === 'success'\" width=\"6\" height=\"6\" viewBox=\"0 0 6 6\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><circle cx=\"3\" cy=\"3\" r=\"3\" fill=\"#00A63E\"/></svg>\n          <svg *ngIf=\"selectedIteration.status === 'failed'\" width=\"6\" height=\"6\" viewBox=\"0 0 6 6\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><circle cx=\"3\" cy=\"3\" r=\"3\" fill=\"#EF4444\"/></svg>\n          <svg *ngIf=\"selectedIteration.status === 'pending'\" width=\"6\" height=\"6\" viewBox=\"0 0 6 6\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><circle cx=\"3\" cy=\"3\" r=\"3\" fill=\"#9CA3AF\"/></svg>\n          <svg *ngIf=\"selectedIteration.status === 'running'\" width=\"6\" height=\"6\" viewBox=\"0 0 6 6\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><circle cx=\"3\" cy=\"3\" r=\"3\" fill=\"#3B82F6\"/></svg>\n        </div>\n        <select\n          class=\"cqa-pl-[22px] cqa-pr-6 cqa-py-[5px] cqa-w-full cqa-border cqa-border-[#E5E5E5] cqa-rounded-md cqa-text-[10px] cqa-leading-[15px] cqa-font-medium cqa-bg-[#FAFAFA] cqa-text-black-100 cqa-appearance-none\"\n          [(ngModel)]=\"selectedIteration\"\n          (ngModelChange)=\"handleIterationChange($event)\"\n          [compareWith]=\"compareIteration\"\n          [disabled]=\"!config?.iterations?.length\">\n          <option *ngFor=\"let iteration of config.iterations\" [ngValue]=\"iteration\">\n            {{ getIterationLabel(iteration) }}\n          </option>\n        </select>\n        <!-- Dropdown arrow -->\n        <div class=\"cqa-absolute cqa-right-2 cqa-top-1/2 cqa-transform cqa--translate-y-1/2 cqa-pointer-events-none\">\n          <svg width=\"10\" height=\"6\" viewBox=\"0 0 10 6\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M1 1L5 5L9 1\" stroke=\"#9CA3AF\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/></svg>\n        </div>\n      </div>\n      <span class=\"cqa-ml-auto\">\n        Default: {{ config.defaultIteration === 'last' ? 'last iteration' : 'first iteration' }}\n      </span>\n    </div>\n\n    <!-- Selected Iteration Sub-steps -->\n    <div *ngIf=\"selectedIteration && selectedIteration.subSteps\" class=\"cqa-flex cqa-flex-col cqa-gap-1 cqa-py-1 cqa-ml-9\" style=\"border-bottom: '1px solid #F3F4F6'\">\n      <div\n        *ngFor=\"let subStep of selectedIteration.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          {{ subStep.description }}\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\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            [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            [isLive]=\"isLive\">\n          </cqa-step-renderer>\n        </ng-container>\n      </div>\n    </div>\n\n    <!-- View All Iterations Link -->\n    <div *ngIf=\"config.showViewAllIterations && !isLive\" class=\"cqa-flex cqa-justify-end cqa-px-3 cqa-py-[10px]\">\n      <a href=\"#\" (click)=\"onViewAllIterationsClick($event)\" class=\"cqa-text-[12px] cqa-leading-[15px] cqa-no-underline cqa-text-primary cqa-font-semibold cqa-flex cqa-items-center cqa-gap-1\">\n        View all iterations\n        <svg width=\"14\" height=\"14\" viewBox=\"0 0 14 14\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M7.63636 11.267L6.75852 10.3977L9.38778 7.76847H3V6.49858H9.38778L6.75852 3.87358L7.63636 3L11.7699 7.13352L7.63636 11.267Z\" fill=\"#3F43EE\"/></svg>\n      </a>\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      (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\" 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      [testStepResultId]=\"testStepResultId\"\n      [timingBreakdown]=\"timingBreakdown\"\n      [expanded]=\"true\"\n      [subSteps]=\"getSubStepsForFailedStep()\"\n      [failureDetails]=\"failureDetails\"\n      [reasoning]=\"reasoning\"\n      [confidence]=\"confidence\"\n      [isUploadingBaseline]=\"isUploadingBaseline\"\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"]}
632
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"loop-step.component.js","sourceRoot":"","sources":["../../../../../../src/lib/execution-screen/loop-step/loop-step.component.ts","../../../../../../src/lib/execution-screen/loop-step/loop-step.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, Output, EventEmitter, OnInit, OnChanges, SimpleChanges, ChangeDetectorRef } from '@angular/core';\nimport { LoopStepConfig, LoopIteration, ExecutionStepConfig, StepStatus, TimingBreakdown, FailureDetails, SubStep, SelfHealAnalysisData, SelfHealAction, StepGroupConfig, ConditionBranch } 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-loop-step',\n  templateUrl: './loop-step.component.html',\n  styleUrls: [],\n  host: { class: 'cqa-ui-root' }\n})\nexport class LoopStepComponent 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() loopType?: 'for' | 'while';\n  @Input() iterations!: LoopIteration[];\n  @Input() selectedIterationId?: string;\n  @Input() defaultIteration?: 'first' | 'last' = 'last';\n  @Input() nestedSteps?: ExecutionStepConfig[];\n  @Input() showViewAllIterations?: boolean;\n  @Input() hasChild?: boolean;\n  @Input() isLive: boolean = false;\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() getLoopIterationsHandler?: (step: ExecutionStepConfig) => any[];\n  @Input() getApiAssertionsHandler?: (step: ExecutionStepConfig) => any[];\n  @Input() formatActionsHandler?: (step: ExecutionStepConfig) => any[];\n  @Input() onViewAllIterationsHandler?: (step: ExecutionStepConfig) => void;\n  \n  @Input() failureDetails?: FailureDetails;\n  @Input() reasoning?: string[];\n  @Input() confidence?: string;\n  @Input() isUploadingBaseline = {};\n  @Input() selfHealAnalysis?: SelfHealAnalysisData;\n  @Input() iterationData?: any;\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  // Output event for when the loop step expands\n  @Output() onExpand = new EventEmitter<void>();\n\n  // Output event for when \"View all iterations\" is clicked\n  @Output() onViewAllIterations = new EventEmitter<void>();\n\n  // Output event for when iteration selection changes\n  @Output() onIterationChange = new EventEmitter<string>();\n\n  // Config property for base class - built from individual inputs in ngOnInit\n  override config!: LoopStepConfig;\n\n  selectedIteration: LoopIteration | null = null;\n  private userSelectedIterationId: string | null = null; // Track user's manual selection\n  private previousStatus?: StepStatus;\n  private userManuallyClosed: boolean = false;\n\n  override ngOnInit(): void {\n    // Build config from individual inputs\n    // Use nestedSteps if provided, otherwise fall back to empty array\n    const stepsToUse = this.nestedSteps || [];\n    \n    // Use action as fallback for title if title is empty\n    // Check both instance property and config for action\n    const actionValue = (this as any).action || '';\n    const stepTitle = (this.title && this.title.trim()) ? this.title : actionValue;\n    \n    this.config = {\n      id: this.id,\n      testStepResultId: this.testStepResultId,\n      stepNumber: this.stepNumber,\n      title: stepTitle,\n      status: this.status,\n      duration: this.duration,\n      type: 'loop',\n      loopType: this.loopType,\n      iterations: this.iterations,\n      selectedIterationId: this.selectedIterationId,\n      defaultIteration: this.defaultIteration,\n      nestedSteps: stepsToUse,\n      showViewAllIterations: this.showViewAllIterations,\n      timingBreakdown: this.timingBreakdown,\n      expanded: this.expanded,\n    } as LoopStepConfig;\n\n    super.ngOnInit();\n    \n    // Initialize selection - prioritize selectedIterationId input, then default\n    if (this.selectedIterationId && this.iterations && this.iterations.length > 0) {\n      const found = this.iterations.find(iter => iter.id === this.selectedIterationId);\n      if (found) {\n        this.selectedIteration = found;\n        this.userSelectedIterationId = this.selectedIterationId;\n      } else {\n        this.selectDefaultIteration();\n      }\n    } else if (this.iterations && this.iterations.length > 0) {\n      this.selectDefaultIteration();\n      // If defaultIteration is 'last', also set userSelectedIterationId to the last iteration\n      if (this.defaultIteration === 'last' && this.selectedIteration) {\n        this.userSelectedIterationId = this.selectedIteration.id;\n      }\n    }\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    // Update selection when selectedIterationId input changes\n    if (changes['selectedIterationId'] && this.iterations && this.iterations.length > 0) {\n      const currentValue = changes['selectedIterationId'].currentValue;\n      const previousValue = changes['selectedIterationId'].previousValue;\n      \n      // Always update when selectedIterationId input changes from parent\n      if (currentValue !== previousValue) {\n        if (currentValue) {\n          const found = this.iterations.find(iter => iter.id === currentValue);\n          if (found) {\n            this.selectedIteration = found;\n            // Sync userSelectedIterationId with the input value\n            this.userSelectedIterationId = currentValue;\n          } else {\n            // If not found, select default\n            this.selectDefaultIteration();\n          }\n        } else {\n          // If no value provided, select default\n          this.selectDefaultIteration();\n        }\n      }\n    }\n    // Update selection when iterations array changes\n    if (changes['iterations'] && this.iterations && this.iterations.length > 0) {\n      // If we have a user selection, try to preserve it\n      if (this.userSelectedIterationId) {\n        const found = this.iterations.find(iter => iter.id === this.userSelectedIterationId);\n        if (found) {\n          this.selectedIteration = found;\n        } else {\n          // User selection no longer valid, use selectedIterationId or default\n          if (this.selectedIterationId) {\n            const foundById = this.iterations.find(iter => iter.id === this.selectedIterationId);\n            if (foundById) {\n              this.selectedIteration = foundById;\n            } else {\n              this.selectDefaultIteration();\n            }\n          } else {\n            this.selectDefaultIteration();\n          }\n        }\n      } else if (!this.selectedIteration || !this.iterations.some(iter => iter.id === this.selectedIteration?.id)) {\n        // No user selection, use selectedIterationId or default\n        if (this.selectedIterationId) {\n          const found = this.iterations.find(iter => iter.id === this.selectedIterationId);\n          if (found) {\n            this.selectedIteration = found;\n          } else {\n            this.selectDefaultIteration();\n          }\n        } else {\n          this.selectDefaultIteration();\n        }\n      }\n    }\n    // Update title if it changes - also check for action in config or instance\n    if (changes['title']) {\n      const actionValue = (this as any).action || (this.config as any)?.action || '';\n      const stepTitle = (this.title && this.title.trim()) ? this.title : actionValue;\n      if (this.config) {\n        this.config.title = stepTitle;\n      }\n    }\n    \n    // Update config when inputs change\n    if (changes['iterations'] || changes['selectedIterationId'] || changes['nestedSteps']) {\n      if (this.config) {\n        this.config.iterations = this.iterations;\n        this.config.selectedIterationId = this.selectedIterationId;\n        this.config.nestedSteps = this.nestedSteps || [];\n      }\n    }\n    \n    // Also handle when nestedSteps is passed via children property (for step-renderer compatibility)\n    if (changes['nestedSteps'] && this.nestedSteps) {\n      // Ensure config is updated with nestedSteps\n      if (this.config) {\n        this.config.nestedSteps = this.nestedSteps;\n      }\n    }\n    \n    // If nestedSteps is not provided but children is (from step-renderer), use children\n    if (!this.nestedSteps && (this.config as any).children && Array.isArray((this.config as any).children)) {\n      this.nestedSteps = (this.config as any).children;\n      if (this.config) {\n        this.config.nestedSteps = this.nestedSteps;\n      }\n    }\n\n    if(this.isLive) {\n      // Update subSteps array when new ones are added\n      if (changes['nestedSteps']) {\n        const previousSubStepsCount = changes['nestedSteps'].previousValue?.length || 0;\n        const currentSubStepsCount = (this.nestedSteps || []).length;\n        \n        // Sub-steps are appended externally, so we just update the config\n        if (this.config) {\n          this.config.nestedSteps = this.nestedSteps || [];\n        }\n        \n        // Auto-expand if step is running and new subSteps are added (logs coming in)\n        if (!changes['nestedSteps'].firstChange && \n            this.status === 'running' && \n            currentSubStepsCount > previousSubStepsCount &&\n            this.hasSubSteps && \n            !this.isExpanded && \n            !this.userManuallyClosed) {\n          this.autoExpand();\n        }\n      }\n\n      // Handle status changes - auto-expand when step starts executing\n      if (changes['status'] && !changes['status'].firstChange) {\n        const newStatus = changes['status'].currentValue;\n        const oldStatus = changes['status'].previousValue;\n        \n        // Auto-expand when status changes to 'running' and has subSteps (or will have soon)\n        if (newStatus === 'running' && oldStatus !== 'running' && !this.userManuallyClosed) {\n          // Expand immediately if already has subSteps, or wait for them\n          if (this.hasSubSteps) {\n            this.autoExpand();\n          }\n        }\n        \n        this.previousStatus = newStatus;\n      }\n    }\n  }\n\n  private autoExpand(): void {\n    if (!this.isExpanded && this.hasSubSteps) {\n      this.isExpanded = true;\n      this.userManuallyClosed = false;\n      this.toggleExpanded.emit(true);\n    }\n  }\n\n  get hasSubSteps(): boolean {\n    return this.nestedSteps !== undefined && this.nestedSteps.length > 0;\n  }\n\n  override toggle(): void {\n    const wasExpanded = this.isExpanded;\n    super.toggle();\n    // Emit event when expanding (transitioning from collapsed to expanded)\n    if (!wasExpanded && this.isExpanded) {\n      this.onExpand.emit();\n      // If this step has children (hasChild is true) and onExpandHandler is provided, call it to fetch children\n      if (this.onExpandHandler && this.config && this.hasChild) {\n        // Create a step config object for the handler with hasChild property\n        const stepConfig = {\n          ...this.config,\n          hasChild: true,\n          expanded: true, // Ensure expanded is set\n          testStepType: (this.config as any).testStepType || (this.loopType === 'for' ? 'FOR_LOOP' : 'WHILE_LOOP'),\n          children: this.config.nestedSteps || [],\n          testStepResultId: this.testStepResultId,\n          id: this.id\n        } as ExecutionStepConfig & { hasChild: boolean; testStepType?: string; children?: any[]; expanded?: boolean };\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  selectDefaultIteration(): void {\n    // First, try to use selectedIterationId if provided\n    if (this.selectedIterationId) {\n      const found = this.iterations.find(\n        iter => iter.id === this.selectedIterationId\n      );\n      if (found) {\n        this.selectedIteration = found;\n        return;\n      }\n    }\n    \n    // If user has manually selected something, preserve it\n    if (this.userSelectedIterationId) {\n      const found = this.iterations.find(iter => iter.id === this.userSelectedIterationId);\n      if (found) {\n        this.selectedIteration = found;\n        return;\n      }\n    }\n    \n    // Apply default based on defaultIteration setting\n    if (this.defaultIteration === 'last' && this.iterations.length > 0) {\n      const lastIteration = this.iterations[this.iterations.length - 1];\n      this.selectedIteration = lastIteration;\n      // Set userSelectedIterationId to track the default selection\n      this.userSelectedIterationId = lastIteration.id;\n    } else if (this.iterations.length > 0) {\n      const firstIteration = this.iterations[0];\n      this.selectedIteration = firstIteration;\n      // Set userSelectedIterationId to track the default selection\n      this.userSelectedIterationId = firstIteration.id;\n    }\n  }\n\n  handleIterationChange(iteration: LoopIteration): void {\n    // Store the user's manual selection\n    this.selectedIteration = iteration;\n    this.userSelectedIterationId = iteration.id;\n\n    if (this.isLive) {\n      const index = this.iterations.findIndex(iter => iter.id === iteration.id);\n\n      if (index > -1 && this.iterationData?.[index] && this.nestedSteps) {\n\n        const updatedNestedSteps: ExecutionStepConfig[] =\n          this.nestedSteps.map(step => {\n            const updatedSubSteps = this.iterationData[index][step.id];\n            step.duration = updatedSubSteps.reduce((acc: number, subStep: any) => acc + subStep?.duration || 0, 0);\n\n            if (updatedSubSteps) {\n              return {\n                ...step,\n                subSteps: [...updatedSubSteps]\n              };\n            }\n\n            return { ...step };\n          });\n\n        this.nestedSteps = updatedNestedSteps;\n\n        if (this.config) {\n          this.config = {\n            ...this.config,\n            nestedSteps: updatedNestedSteps\n          };\n        }\n      }\n    }\n    // Emit the event with the iteration ID\n    this.onIterationChange.emit(iteration.id);\n  }\n\n  compareIteration(a: LoopIteration, b: LoopIteration): boolean {\n    return a && b ? a.id === b.id : a === b;\n  }\n\n  getLoopTypeBadges(): string[] {\n    const badges: string[] = ['LOOP'];\n    if (this.loopType === 'for') {\n      badges.push('FOR');\n    } else if (this.loopType === 'while') {\n      badges.push('WHILE');\n    }\n    return badges;\n  }\n\n  getIterationLabel(iteration: LoopIteration): string {\n    return iteration.label;\n  }\n\n  onViewAllIterationsClick(event: Event): void {\n    event.preventDefault();\n    this.onViewAllIterations.emit();\n  }\n\n  onViewMoreFailedStepClick(expanded: boolean): void {\n    this.showFailedStepDetails = expanded;\n  }\n\n  getSubStepsForFailedStep(): SubStep[] {\n    return this.selectedIteration?.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() {\n    this.toggle();\n    if(!this.isExpanded){\n      this.showFailedStepDetails = false;\n    }\n  }\n\n  // Helper method to check if a step is a step-group with hasChild\n  isNestedStepGroupWithChildren(step: ExecutionStepConfig): boolean {\n    return step.type === 'step-group' && !!(step as any).hasChild;\n  }\n\n  // Helper method to get groupName from step config\n  getGroupName(step: ExecutionStepConfig): string {\n    return (step as StepGroupConfig).groupName || '';\n  }\n\n  // Helper method to get steps from step config\n  getSteps(step: ExecutionStepConfig): ExecutionStepConfig[] {\n    const stepGroup = step as StepGroupConfig;\n    return stepGroup.steps || (step as any).children || [];\n  }\n\n  // Helper method to check if a step is a condition step\n  isNestedConditionStep(step: ExecutionStepConfig): boolean {\n    const stepType = (step as any).testStepType || step.type;\n    return stepType === 'CONDITION_IF' || stepType === 'CONDITION_ELSE' || \n           stepType === 'CONDITION_ELSE_IF' || stepType === 'CONDITION_ELSEIF' ||\n           stepType === 'condition';\n  }\n\n  // Helper method to check if a step is a loop step\n  isNestedLoopStep(step: ExecutionStepConfig): boolean {\n    const stepType = (step as any).testStepType || step.type;\n    return stepType === 'FOR_LOOP' || stepType === 'WHILE_LOOP' || stepType === 'loop';\n  }\n\n  // Helper method to get loop type from step config\n  getLoopType(step: ExecutionStepConfig): 'for' | 'while' | undefined {\n    const stepType = (step as any).testStepType || step.type;\n    if (stepType === 'FOR_LOOP' || (step as LoopStepConfig).loopType === 'for') {\n      return 'for';\n    } else if (stepType === 'WHILE_LOOP' || (step as LoopStepConfig).loopType === 'while') {\n      return 'while';\n    }\n    return (step as LoopStepConfig).loopType;\n  }\n\n  // Helper method to get iterations from step config\n  getLoopIterations(step: ExecutionStepConfig): any[] {\n    // Use handler if available, otherwise use config\n    if (this.getLoopIterationsHandler) {\n      return this.getLoopIterationsHandler(step);\n    }\n    const loopStep = step as LoopStepConfig;\n    return loopStep.iterations || [];\n  }\n\n  // Helper method to get nested steps from loop step config\n  getLoopNestedSteps(step: ExecutionStepConfig): ExecutionStepConfig[] {\n    const loopStep = step as LoopStepConfig;\n    return loopStep.nestedSteps || (step as any).children || [];\n  }\n\n  // Helper method to handle nested loop step expansion\n  handleLoopStepExpand(step: ExecutionStepConfig): void {\n    if (this.onExpandHandler) {\n      this.onExpandHandler(step);\n    }\n  }\n\n  // Helper method to handle nested loop step iteration change\n  handleLoopStepIterationChange(step: ExecutionStepConfig, iterationId: string): void {\n    // This would typically be handled by the parent component\n    // For now, we just emit the expand event\n    if (this.onExpandHandler) {\n      this.onExpandHandler(step);\n    }\n  }\n\n  // Helper method to get step title\n  getStepTitle(step: ExecutionStepConfig): string {\n    return (step as any).action || step.title || '';\n  }\n\n  // Helper method to get step status\n  getStepStatus(step: ExecutionStepConfig): StepStatus {\n    const result = (step as any).result;\n    if (result) {\n      const resultLower = result.toLowerCase();\n      if (resultLower === 'success' || resultLower === 'passed') {\n        return 'success';\n      } else if (resultLower === 'failure' || resultLower === 'failed') {\n        return 'failed';\n      } else if (resultLower === 'pending' || resultLower === 'not-executed') {\n        return 'pending';\n      } else if (resultLower === 'running') {\n        return 'running';\n      }\n    }\n    return step.status || 'pending';\n  }\n\n  // Helper method to get step duration\n  getStepDuration(step: ExecutionStepConfig): number {\n    return (step as any).duration || step.duration || 0;\n  }\n\n  // Helper methods for condition step properties\n  getConditionStepDuration(step: ExecutionStepConfig): number {\n    const duration = this.getStepDuration(step);\n    if (this.convertMsToSecondsHandler) {\n      return this.convertMsToSecondsHandler(duration);\n    }\n    return duration;\n  }\n\n  getConditionStepExpanded(step: ExecutionStepConfig): boolean {\n    if (this.isStepExpandedHandler) {\n      return this.isStepExpandedHandler(step);\n    }\n    return step.expanded || false;\n  }\n\n  getConditionStepText(step: ExecutionStepConfig): string {\n    return (step as any).action || step.title || '';\n  }\n\n  getConditionStepBranches(step: ExecutionStepConfig): ConditionBranch[] {\n    if (this.getConditionBranchesHandler) {\n      return this.getConditionBranchesHandler(step);\n    }\n    return [];\n  }\n\n  getConditionStepLoading(step: ExecutionStepConfig): boolean {\n    if (this.isStepLoadingHandler) {\n      return this.isStepLoadingHandler(step);\n    }\n    return false;\n  }\n\n  handleConditionStepExpand(step: ExecutionStepConfig): void {\n    if (this.onExpandHandler) {\n      this.onExpandHandler(step);\n    }\n  }\n\n  getConditionStepFailureDetails(step: ExecutionStepConfig): any {\n    if (this.formatFailureDetailsHandler) {\n      return this.formatFailureDetailsHandler(step);\n    }\n    return undefined;\n  }\n\n  getConditionStepSelfHealAnalysis(step: ExecutionStepConfig): any {\n    if (this.getSelfHealAnalysisHandler) {\n      return this.getSelfHealAnalysisHandler(step);\n    }\n    return undefined;\n  }\n\n  handleConditionStepSelfHealAction(event: any): void {\n    if (this.onSelfHealActionHandler) {\n      this.onSelfHealActionHandler(event);\n    }\n  }\n\n  handleConditionStepMakeBaseline(event: any): void {\n    if (this.onMakeCurrentBaselineHandler) {\n      this.onMakeCurrentBaselineHandler(event);\n    }\n  }\n\n  handleConditionStepUploadBaseline(event: any): void {\n    if (this.onUploadBaselineHandler) {\n      this.onUploadBaselineHandler(event);\n    }\n  }\n\n  handleConditionStepAnalyze(): void {\n    if (this.onAnalyzeHandler) {\n      this.onAnalyzeHandler();\n    }\n  }\n\n  handleConditionStepViewLogs(): void {\n    if (this.onViewFullLogsHandler) {\n      this.onViewFullLogsHandler();\n    }\n  }\n\n  // Helper methods to safely access LoopStepConfig properties\n  getLoopSelectedIterationId(step: ExecutionStepConfig): string | undefined {\n    const loopStep = step as LoopStepConfig;\n    return loopStep.selectedIterationId;\n  }\n\n  getLoopDefaultIteration(step: ExecutionStepConfig): 'first' | 'last' | undefined {\n    const loopStep = step as LoopStepConfig;\n    return loopStep.defaultIteration || 'last';\n  }\n\n  getLoopShowViewAllIterations(step: ExecutionStepConfig): boolean | undefined {\n    const loopStep = step as LoopStepConfig;\n    return loopStep.showViewAllIterations;\n  }\n}\n","<div>\n  <!-- Header -->\n  <div\n    class=\"cqa-flex cqa-items-center cqa-gap-2 cqa-p-2 cqa-cursor-pointer\"\n    (click)=\"toggleHeader()\">\n    \n    <!-- Status Icon -->\n    <div>\n      <!-- Success -->\n      <svg *ngIf=\"status.toLowerCase() === 'success'\" 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      <!-- Failed -->\n      <svg *ngIf=\"status.toLowerCase() === 'failure' || status.toLowerCase() === 'failed'\" 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=\"#EF4444\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M4 4L8 8M8 4L4 8\" stroke=\"#EF4444\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/></svg>\n      <!-- Pending -->\n      <svg *ngIf=\"status.toLowerCase() === 'pending'\" 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      <!-- Running -->\n      <svg *ngIf=\"status.toLowerCase() === 'running'\" 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=\"#3B82F6\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M6 3V6L8 7\" stroke=\"#3B82F6\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/></svg>\n    </div>\n\n    <!-- Loop 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=\"#EBECFD\"/><path d=\"M9.66663 4.66666L11 5.99999L9.66663 7.33332\" stroke=\"#3F43EE\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M5 7.66667V7.33333C5 6.97971 5.14048 6.64057 5.39052 6.39052C5.64057 6.14048 5.97971 6 6.33333 6H11\" stroke=\"#3F43EE\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M6.33333 11.3333L5 9.99999L6.33333 8.66666\" stroke=\"#3F43EE\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M11 8.33334V8.66668C11 9.0203 10.8595 9.35944 10.6095 9.60949C10.3594 9.85953 10.0203 10 9.66667 10H5\" stroke=\"#3F43EE\" 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 }}. <span [innerHTML]=\"config.title\"></span>\n      </span>\n      \n      <!-- Loop Type Badges -->\n      <span *ngFor=\"let badge of getLoopTypeBadges()\" \n        class=\"cqa-px-1.5 cqa-rounded-full cqa-font-medium cqa-text-primary cqa-bg-[#EBECFD] cqa-text-[10px] cqa-leading-[15px]\">\n        {{ badge }}\n      </span>\n    </div>\n\n    <div class=\"cqa-flex cqa-items-center cqa-gap-1\">\n      <span class=\"cqa-text-[10px] cqa-leading-[15px] cqa-font-medium cqa-text-[#9CA3AF]\">\n        {{ formatDuration(config.duration) }}\n      </span>\n      <svg [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\n  <!-- Expanded Content -->\n  <div *ngIf=\"isExpanded\">\n    <!-- Iteration Selector -->\n    <div class=\"cqa-flex cqa-items-center cqa-gap-3 cqa-px-4 cqa-py-2 cqa-text-[10px] cqa-leading-[15px] cqa-font-medium cqa-text-[#737373]\">\n      <label>Iteration</label>\n      <div class=\"cqa-relative cqa-w-full cqa-max-w-[156px]\">\n        <!-- Status indicator for selected iteration -->\n        <div *ngIf=\"selectedIteration\" class=\"cqa-absolute cqa-left-[10px] cqa-top-1/2 cqa-transform cqa--translate-y-1/2 cqa-pointer-events-none cqa-z-10\">\n          <svg *ngIf=\"selectedIteration.status === 'success'\" width=\"6\" height=\"6\" viewBox=\"0 0 6 6\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><circle cx=\"3\" cy=\"3\" r=\"3\" fill=\"#00A63E\"/></svg>\n          <svg *ngIf=\"selectedIteration.status === 'failed'\" width=\"6\" height=\"6\" viewBox=\"0 0 6 6\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><circle cx=\"3\" cy=\"3\" r=\"3\" fill=\"#EF4444\"/></svg>\n          <svg *ngIf=\"selectedIteration.status === 'pending'\" width=\"6\" height=\"6\" viewBox=\"0 0 6 6\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><circle cx=\"3\" cy=\"3\" r=\"3\" fill=\"#9CA3AF\"/></svg>\n          <svg *ngIf=\"selectedIteration.status === 'running'\" width=\"6\" height=\"6\" viewBox=\"0 0 6 6\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><circle cx=\"3\" cy=\"3\" r=\"3\" fill=\"#3B82F6\"/></svg>\n        </div>\n        <select\n          class=\"cqa-pl-[22px] cqa-pr-6 cqa-py-[5px] cqa-w-full cqa-border cqa-border-[#E5E5E5] cqa-rounded-md cqa-text-[10px] cqa-leading-[15px] cqa-font-medium cqa-bg-[#FAFAFA] cqa-text-black-100 cqa-appearance-none\"\n          [(ngModel)]=\"selectedIteration\"\n          (ngModelChange)=\"handleIterationChange($event)\"\n          [compareWith]=\"compareIteration\"\n          [disabled]=\"!config?.iterations?.length\">\n          <option *ngFor=\"let iteration of config.iterations\" [ngValue]=\"iteration\">\n            {{ getIterationLabel(iteration) }}\n          </option>\n        </select>\n        <!-- Dropdown arrow -->\n        <div class=\"cqa-absolute cqa-right-2 cqa-top-1/2 cqa-transform cqa--translate-y-1/2 cqa-pointer-events-none\">\n          <svg width=\"10\" height=\"6\" viewBox=\"0 0 10 6\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M1 1L5 5L9 1\" stroke=\"#9CA3AF\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/></svg>\n        </div>\n      </div>\n      <span class=\"cqa-ml-auto\">\n        Default: {{ config.defaultIteration === 'last' ? 'last iteration' : 'first iteration' }}\n      </span>\n    </div>\n\n    <!-- Selected Iteration Sub-steps -->\n    <div *ngIf=\"selectedIteration && selectedIteration.subSteps\" class=\"cqa-flex cqa-flex-col cqa-gap-1 cqa-py-1 cqa-ml-9\" style=\"border-bottom: '1px solid #F3F4F6'\">\n      <div\n        *ngFor=\"let subStep of selectedIteration.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          {{ subStep.description }}\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\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            [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            [isLive]=\"isLive\">\n          </cqa-step-renderer>\n        </ng-container>\n      </div>\n    </div>\n\n    <!-- View All Iterations Link -->\n    <div *ngIf=\"config.showViewAllIterations && !isLive\" class=\"cqa-flex cqa-justify-end cqa-px-3 cqa-py-[10px]\">\n      <a href=\"#\" (click)=\"onViewAllIterationsClick($event)\" class=\"cqa-text-[12px] cqa-leading-[15px] cqa-no-underline cqa-text-primary cqa-font-semibold cqa-flex cqa-items-center cqa-gap-1\">\n        View all iterations\n        <svg width=\"14\" height=\"14\" viewBox=\"0 0 14 14\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M7.63636 11.267L6.75852 10.3977L9.38778 7.76847H3V6.49858H9.38778L6.75852 3.87358L7.63636 3L11.7699 7.13352L7.63636 11.267Z\" fill=\"#3F43EE\"/></svg>\n      </a>\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      (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\" 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      [testStepResultId]=\"testStepResultId\"\n      [timingBreakdown]=\"timingBreakdown\"\n      [expanded]=\"true\"\n      [subSteps]=\"getSubStepsForFailedStep()\"\n      [failureDetails]=\"failureDetails\"\n      [reasoning]=\"reasoning\"\n      [confidence]=\"confidence\"\n      [isUploadingBaseline]=\"isUploadingBaseline\"\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"]}