@cqa-lib/cqa-ui 1.1.249 → 1.1.251

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.
Files changed (23) hide show
  1. package/esm2020/lib/execution-screen/ai-action-step/ai-action-step.component.mjs +2 -2
  2. package/esm2020/lib/execution-screen/ai-agent-step/ai-agent-step.component.mjs +2 -2
  3. package/esm2020/lib/execution-screen/api-step/api-step.component.mjs +2 -2
  4. package/esm2020/lib/execution-screen/basic-step/basic-step.component.mjs +2 -2
  5. package/esm2020/lib/execution-screen/condition-step/condition-step.component.mjs +2 -2
  6. package/esm2020/lib/execution-screen/db-verification-step/db-verification-step.component.mjs +2 -2
  7. package/esm2020/lib/execution-screen/document-verification-step/document-verification-step.component.mjs +2 -2
  8. package/esm2020/lib/execution-screen/execution-step.models.mjs +1 -1
  9. package/esm2020/lib/execution-screen/failed-step/failed-step.component.mjs +2 -2
  10. package/esm2020/lib/execution-screen/file-download-step/file-download-step.component.mjs +2 -2
  11. package/esm2020/lib/execution-screen/live-execution-step/live-execution-step.component.mjs +2 -2
  12. package/esm2020/lib/execution-screen/loop-step/loop-step.component.mjs +6 -6
  13. package/esm2020/lib/execution-screen/step-group/step-group.component.mjs +7 -7
  14. package/esm2020/lib/execution-screen/step-renderer/step-renderer.component.mjs +23 -23
  15. package/esm2020/lib/execution-screen/updated-failed-step/updated-failed-step.component.mjs +2 -2
  16. package/esm2020/lib/test-case-details/test-case-step.models.mjs +1 -1
  17. package/fesm2015/cqa-lib-cqa-ui.mjs +44 -44
  18. package/fesm2015/cqa-lib-cqa-ui.mjs.map +1 -1
  19. package/fesm2020/cqa-lib-cqa-ui.mjs +44 -44
  20. package/fesm2020/cqa-lib-cqa-ui.mjs.map +1 -1
  21. package/lib/execution-screen/execution-step.models.d.ts +12 -12
  22. package/lib/test-case-details/test-case-step.models.d.ts +1 -0
  23. package/package.json +1 -1
@@ -90,7 +90,7 @@ export class StepGroupComponent extends BaseStepComponent {
90
90
  title: this.title,
91
91
  status: this.status,
92
92
  duration: this.duration,
93
- type: 'step-group',
93
+ displayType: 'step-group',
94
94
  groupName: this.groupName,
95
95
  steps: this.steps || [],
96
96
  stepDeleted: this.stepDeleted,
@@ -139,7 +139,7 @@ export class StepGroupComponent extends BaseStepComponent {
139
139
  ...this.config,
140
140
  hasChild: true,
141
141
  expanded: true,
142
- testStepType: this.config.testStepType || 'STEP_GROUP',
142
+ displayType: this.config.displayType || 'STEP_GROUP',
143
143
  children: this.config.steps || [],
144
144
  testStepResultId: this.testStepResultId,
145
145
  id: this.id
@@ -181,7 +181,7 @@ export class StepGroupComponent extends BaseStepComponent {
181
181
  }
182
182
  // Helper method to check if a step is a step-group with hasChild
183
183
  isNestedStepGroupWithChildren(step) {
184
- return step.type === 'step-group' && !!step.hasChild;
184
+ return step.displayType === 'step-group' && !!step.hasChild;
185
185
  }
186
186
  // Helper method to get groupName from step config
187
187
  getGroupName(step) {
@@ -195,12 +195,12 @@ export class StepGroupComponent extends BaseStepComponent {
195
195
  }
196
196
  // Helper method to check if a step is a loop step
197
197
  isNestedLoopStep(step) {
198
- const stepType = step.testStepType || step.type;
198
+ const stepType = step.testStepType || step.displayType;
199
199
  return stepType === 'FOR_LOOP' || stepType === 'WHILE_LOOP' || stepType === 'loop';
200
200
  }
201
201
  // Helper method to check if a step is a condition step
202
202
  isNestedConditionStep(step) {
203
- const stepType = step.testStepType || step.type;
203
+ const stepType = step.testStepType || step.displayType;
204
204
  return stepType === 'CONDITION_IF' || stepType === 'CONDITION_ELSE' ||
205
205
  stepType === 'CONDITION_ELSE_IF' || stepType === 'CONDITION_ELSEIF' ||
206
206
  stepType === 'condition';
@@ -235,7 +235,7 @@ export class StepGroupComponent extends BaseStepComponent {
235
235
  }
236
236
  // Helper methods for loop step properties
237
237
  getLoopType(step) {
238
- const stepType = step.testStepType || step.type;
238
+ const stepType = step.testStepType || step.displayType;
239
239
  if (stepType === 'FOR_LOOP' || step.loopType === 'for') {
240
240
  return 'for';
241
241
  }
@@ -464,4 +464,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImpor
464
464
  }], onExpand: [{
465
465
  type: Output
466
466
  }] } });
467
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"step-group.component.js","sourceRoot":"","sources":["../../../../../../src/lib/execution-screen/step-group/step-group.component.ts","../../../../../../src/lib/execution-screen/step-group/step-group.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, Output, EventEmitter, OnInit, OnChanges, SimpleChanges, ChangeDetectorRef } from '@angular/core';\nimport { StepGroupConfig, LoopStepConfig, ConditionBranch, ExecutionStepConfig, StepStatus, TimingBreakdown, AddStepMenuOption, DEFAULT_ADD_STEP_MENU_OPTIONS, StepMoreMenuOption, DEFAULT_STEP_MORE_MENU_OPTIONS } from '../execution-step.models';\nimport { BaseStepComponent } from '../base-step.component';\n\n@Component({\n  selector: 'cqa-step-group',\n  templateUrl: './step-group.component.html',\n  host: { class: 'cqa-ui-root cqa-w-full' }\n})\nexport class StepGroupComponent 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() groupName!: string;\n  @Input() steps!: ExecutionStepConfig[];\n  @Input() hasChild?: boolean;\n  @Input() isLoading?: boolean;\n  @Input() stepDeleted?: boolean;\n  @Input() isDebug?: boolean = false;\n  @Input() debugPointSet?: boolean = false;\n  @Input() getDebugPointSetHandler?: (step: ExecutionStepConfig) => boolean;\n  @Input() onDebugPointChangeHandler?: (step: ExecutionStepConfig, value: boolean) => void;\n  @Output() debugPointChange = new EventEmitter<boolean>();\n  @Output() editStep = new EventEmitter<void>();\n  @Output() addStepOptionSelect = new EventEmitter<AddStepMenuOption>();\n  @Output() stepMoreOptionSelect = new EventEmitter<StepMoreMenuOption>();\n  @Input() addStepMenuOptions: AddStepMenuOption[] = DEFAULT_ADD_STEP_MENU_OPTIONS;\n  @Input() stepMoreMenuOptions: StepMoreMenuOption[] = DEFAULT_STEP_MORE_MENU_OPTIONS;\n\n  // Handler function to pass down to nested child step groups for recursive expansion\n  @Input() onExpandHandler?: (step: ExecutionStepConfig) => void;\n  /** When provided, passed to nested step-renderer so Edit on nested steps is forwarded with the step config. */\n  @Input() onEditStepHandler?: (step: ExecutionStepConfig) => void;\n  /** When provided, passed to nested step-renderer so Add-step menu selection on nested steps is forwarded. */\n  @Input() onAddStepOptionSelectHandler?: (option: AddStepMenuOption, step?: ExecutionStepConfig) => void;\n  /** When provided, passed to nested step-renderer so More options menu selection on nested steps is forwarded. */\n  @Input() onStepMoreOptionSelectHandler?: (option: StepMoreMenuOption, step?: ExecutionStepConfig) => void;\n  /** When provided, used to get add-step menu options per nested step at any depth; otherwise addStepMenuOptions is used. */\n  @Input() getAddStepMenuOptionsForNested?: (step: ExecutionStepConfig) => AddStepMenuOption[];\n  /** When provided, used to get step-more menu options per nested step at any depth; otherwise stepMoreMenuOptions is used. */\n  @Input() getStepMoreMenuOptionsForNested?: (step: ExecutionStepConfig) => StepMoreMenuOption[];\n\n  // Handler functions for nested components (optional, passed from parent)\n  @Input() getConditionBranchesHandler?: (step: ExecutionStepConfig) => ConditionBranch[];\n  @Input() onConditionBranchClickHandler?: (step: any, branch: any) => void;\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: { [key: string]: boolean }; isLoadingModifyAccept: { [key: string]: 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() onStepClickHandler?: (step: ExecutionStepConfig, event?: Event) => void;\n  @Input() onJsonPathCopiedHandler?: (event: { path: string; source: 'requestBody' | 'responseBody' | 'requestHeaders' | 'responseHeaders' }) => void;\n  @Input() onDownloadHandler?: (event: { fileName: string; filePath?: string; fileType: string; testStepResultId: string }) => void;\n  @Input() onFilePathCopiedHandler?: (event: { filePath: string; testStepResultId: string }) => void;\n  @Input() onTextCopiedHandler?: (event: { text: string; testStepResultId: string }) => void;\n  @Input() jumpToTimestampHandler?: (timestamp: number, testStepId?: number | string) => void;\n  @Input() downloadingStepId: string | null = null;\n  @Input() isUploadingBaseline?: any;\n  @Input() isMakingCurrentBaseline?: any;\n  @Input() isLive: boolean = false;\n  @Input() step?: ExecutionStepConfig;\n\n  // Output event for when the step group expands\n  @Output() onExpand = new EventEmitter<void>();\n\n  // Config property for base class - built from individual inputs in ngOnInit\n  override config!: StepGroupConfig;\n\n  // Track which steps are still loading to show skeleton\n  loadingSteps: Set<string> = new Set();\n\n  /** Show debug icon only when this step has no child steps (icon is shown on child steps instead). */\n  /** Show debug icon when debug mode is on (shown on parent and all child steps). */\n  get showDebugIcon(): boolean {\n    return this.isDebug === true;\n  }\n\n  constructor(private cdr: ChangeDetectorRef) {\n    super();\n  }\n\n  override ngOnInit(): void {\n    // Build config from individual inputs\n    this.updateConfig();\n\n    super.ngOnInit();\n    // Ensure isExpanded is set correctly after super.ngOnInit()\n    if (this.expanded !== undefined) {\n      this.isExpanded = this.expanded;\n    }\n\n    // Initialize loading state if already expanded\n    if (this.isExpanded && this.config.steps && this.config.steps.length > 0) {\n      this.loadingSteps.clear();\n      this.config.steps.forEach(step => {\n        const stepId = step.testStepResultId || step.id;\n        if (stepId) {\n          this.loadingSteps.add(String(stepId));\n        }\n      });\n    }\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    // Update config when steps input changes\n    if (changes['steps'] || changes['expanded'] || changes['status'] || changes['duration'] || changes['groupName'] || changes['stepDeleted']) {\n      this.updateConfig();\n    }\n\n    // Update expanded state if changed\n    if (changes['expanded'] && this.expanded !== undefined) {\n      this.isExpanded = this.expanded;\n    }\n\n    // // Initialize loading state when steps are added and step is expanded\n    // if (changes['steps'] && this.isExpanded && this.config.steps && this.config.steps.length > 0) {\n    //   this.loadingSteps.clear();\n    //   this.config.steps.forEach(step => {\n    //     const stepId = step.testStepResultId || step.id;\n    //     if (stepId) {\n    //       this.loadingSteps.add(String(stepId));\n    //     }\n    //   });\n    // }\n\n    // Initialize loading state if already expanded when component initializes\n    if (changes['expanded'] && this.isExpanded && this.config.steps && this.config.steps.length > 0) {\n      this.loadingSteps.clear();\n      this.config.steps.forEach(step => {\n        const stepId = step.testStepResultId || step.id;\n        if (stepId) {\n          this.loadingSteps.add(String(stepId));\n        }\n      });\n    }\n  }\n\n  private updateConfig(): void {\n    // Build or update config from individual inputs\n    this.config = {\n      id: this.id,\n      testStepId: this.step?.testStepId || undefined,\n      testStepResultId: this.testStepResultId,\n      stepNumber: this.stepNumber,\n      title: this.title,\n      status: this.status,\n      duration: this.duration,\n      type: 'step-group',\n      groupName: this.groupName,\n      steps: this.steps || [],\n      stepDeleted: this.stepDeleted,\n      timingBreakdown: this.timingBreakdown,\n      expanded: this.expanded,\n    } as StepGroupConfig;\n  }\n\n  onDebugPointClick(event: Event): void {\n    event.preventDefault();\n    event.stopPropagation();\n    this.debugPointChange.emit(!this.debugPointSet);\n  }\n\n  onEditStep(event: Event): void {\n    event.preventDefault();\n    event.stopPropagation();\n    this.editStep.emit();\n  }\n\n  onAddStepOptionSelect(option: AddStepMenuOption, event: Event): void {\n    event.preventDefault();\n    this.addStepOptionSelect.emit(option);\n  }\n\n  onStepMoreOptionSelect(option: StepMoreMenuOption, event: Event): void {\n    event.preventDefault();\n    this.stepMoreOptionSelect.emit(option);\n  }\n\n  override toggle(event?: Event): void {\n    if (event) {\n      event.preventDefault();\n      event.stopPropagation();\n    }\n    const wasExpanded = this.isExpanded;\n    super.toggle();\n    if (this.onStepClickHandler) {\n      const stepToPass = this.step || this.config;\n      if (stepToPass) {\n        this.onStepClickHandler(stepToPass, event);\n      }\n    }\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 || 'STEP_GROUP',\n          children: this.config.steps || [],\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      // Initialize loading state for all nested steps\n      if (this.config.steps && this.config.steps.length > 0) {\n        this.loadingSteps.clear();\n        this.config.steps.forEach(step => {\n          const stepId = step.testStepResultId || step.id;\n          if (stepId) {\n            this.loadingSteps.add(String(stepId));\n          }\n        });\n      }\n      this.cdr.detectChanges();\n    } else if (!this.isExpanded) {\n      // Clear loading state when collapsing\n      this.loadingSteps.clear();\n    }\n\n    // Ensure expanded state is synced with config\n    if (this.config) {\n      this.config.expanded = this.isExpanded;\n    }\n  }\n\n  // Check if a step is still loading\n  isNestedStepLoading(step: ExecutionStepConfig): boolean {\n    const stepId = step.testStepResultId || step.id;\n    return stepId ? this.loadingSteps.has(String(stepId)) : false;\n  }\n\n  // Mark a step as loaded (called when step-renderer is ready)\n  markStepLoaded(step: ExecutionStepConfig): void {\n    const stepId = step.testStepResultId || step.id;\n    if (stepId) {\n      this.loadingSteps.delete(String(stepId));\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    // Check both steps and children properties for compatibility\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 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 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 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 loop step properties\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  getLoopIterations(step: ExecutionStepConfig): any[] {\n    const loopStep = step as LoopStepConfig;\n    return loopStep.iterations || [];\n  }\n\n  getLoopNestedSteps(step: ExecutionStepConfig): ExecutionStepConfig[] {\n    const loopStep = step as LoopStepConfig;\n    return loopStep.nestedSteps || (step as any).children || [];\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  handleLoopStepExpand(step: ExecutionStepConfig): void {\n    if (this.onExpandHandler) {\n      this.onExpandHandler(step);\n    }\n  }\n\n  handleLoopStepIterationChange(step: ExecutionStepConfig, iterationId: string): void {\n    // This would typically be handled by the parent component\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  // 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  \n  // Check if this step is currently loading nested children\n  isStepLoading(): boolean {\n    if (this.isStepLoadingHandler && this.config) {\n      return this.isStepLoadingHandler(this.config);\n    }\n    return this.isLoading || false;\n  }\n\n  onJumpToTimestamp(event: Event): void {\n    event.stopPropagation();\n    if (this.jumpToTimestampHandler && this.step?.executedResult?.video_start_time !== undefined && this.step?.executedResult?.video_start_time !== null) {\n      const timestamp = typeof this.step.executedResult.video_start_time === 'number' \n        ? this.step.executedResult.video_start_time \n        : Number(this.step.executedResult.video_start_time);\n      const testStepId = this.step?.testStepId;\n      if (isFinite(timestamp) && timestamp >= 0) {\n        this.jumpToTimestampHandler(timestamp, testStepId);\n      }\n    }\n  }\n}\n","<div class=\"cqa-font-inter cqa-w-full\" style=\"border-bottom: '1px solid #F3F4F6'\" (click)=\"$event.stopPropagation()\">\n  <!-- Header -->\n  <div\n    class=\"cqa-flex cqa-items-center cqa-gap-2 cqa-p-2 cqa-cursor-pointer\"\n    (click)=\"toggle($event)\">\n    <div *ngIf=\"showDebugIcon\" class=\"cqa-flex cqa-items-center cqa-justify-center\">\n      <button type=\"button\" class=\"cqa-p-0 cqa-border-0 cqa-bg-transparent cqa-cursor-pointer cqa-rounded-full hover:cqa-opacity-80 cqa-transition-opacity focus:cqa-outline-none\" (click)=\"onDebugPointClick($event)\" [attr.aria-label]=\"debugPointSet ? 'Remove debug point' : 'Set debug point'\">\n        <svg *ngIf=\"debugPointSet\" width=\"14\" height=\"14\" viewBox=\"0 0 14 14\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n          <circle cx=\"7\" cy=\"7\" r=\"6\" fill=\"#C63535\"/>\n        </svg>\n        <svg *ngIf=\"!debugPointSet\" width=\"14\" height=\"14\" viewBox=\"0 0 14 14\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n          <circle cx=\"7\" cy=\"7\" r=\"6\" stroke=\"#C63535\" stroke-width=\"1.5\" fill=\"none\"/>\n        </svg>\n      </button>\n    </div>\n    <!-- Status Icon -->\n    <div class=\"cqa-flex cqa-items-center cqa-justify-center\">\n      <!-- Success -->\n      <svg *ngIf=\"config.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=\"config.status.toLowerCase() === 'failure' || config.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=\"config.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=\"config.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      \n      <span *ngIf=\"config.status.toLowerCase() === 'skipped'\" class=\"material-symbols-outlined cqa-text-[#9CA3AF] cqa-text-[12px]\">\n        skip_next\n      </span>\n    </div>\n\n    <!-- Folder Icon -->\n    <div><svg width=\"14\" height=\"14\" viewBox=\"0 0 14 14\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M11.6666 11.6667C11.976 11.6667 12.2728 11.5437 12.4916 11.325C12.7104 11.1062 12.8333 10.8094 12.8333 10.5V4.66667C12.8333 4.35725 12.7104 4.0605 12.4916 3.84171C12.2728 3.62292 11.976 3.5 11.6666 3.5H7.05829C6.86318 3.50191 6.67069 3.45486 6.49847 3.36314C6.32624 3.27142 6.17977 3.13797 6.07246 2.975L5.59996 2.275C5.49373 2.11369 5.34911 1.98128 5.17908 1.88965C5.00906 1.79802 4.81894 1.75003 4.62579 1.75H2.33329C2.02387 1.75 1.72713 1.87292 1.50833 2.09171C1.28954 2.3105 1.16663 2.60725 1.16663 2.91667V10.5C1.16663 10.8094 1.28954 11.1062 1.50833 11.325C1.72713 11.5437 2.02387 11.6667 2.33329 11.6667H11.6666Z\" fill=\"#EFF6FF\" stroke=\"#60A5FA\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/></svg></div>\n\n    <!-- Step Number and Title -->\n    <div class=\"cqa-font-semibold cqa-flex-1 cqa-text-[#334155] cqa-text-[14px] cqa-leading-[18px] cqa-font-inter cqa-flex cqa-items-center cqa-gap-1\" style=\"word-break: break-word;\">\n      <span>{{ config?.stepNumber }}. Step group: {{ config.groupName }}</span>\n      <span *ngIf=\"config.stepDeleted\" class=\"cqa-px-1.5 cqa-py-[2px] cqa-rounded-[4px] cqa-text-[10px] cqa-leading-[12px] cqa-font-medium cqa-text-[#B42318] cqa-bg-[#FEF3F2] cqa-border cqa-border-[#FEE4E2]\">\n        Deleted\n      </span>\n    </div>\n\n    <div class=\"cqa-flex cqa-items-center cqa-gap-1 cqa-font-inter\">\n      <div class=\"cqa-flex cqa-items-center cqa-gap-1 cqa-rounded-[4px] cqa-py-0.5 cqa-px-1 cqa-bg-[#6366F11A] cqa-ml-1 cqa-cursor-pointer hover:cqa-opacity-80 cqa-transition-opacity\" \n           *ngIf=\"step?.executedResult?.video_start_time\" \n           [matTooltip]=\"'Jump to video time'\" \n           matTooltipPosition=\"below\"\n           (click)=\"onJumpToTimestamp($event)\">\n        <mat-icon class=\"cqa-text-[#636363] !cqa-text-[10px] !cqa-w-[10px] !cqa-h-[10px]\">\n          play_arrow\n        </mat-icon>\n        <span class=\"cqa-text-[8px] cqa-leading-[12px] cqa-font-normal cqa-text-[#636363]\">\n          {{ formatDurationClock(step?.executedResult?.video_start_time || 0) }}\n        </span>\n      </div>\n      <div *ngIf=\"isDebug\" class=\"cqa-flex cqa-items-center cqa-gap-0.5 cqa-text-[#9CA3AF]\" (click)=\"$event.stopPropagation()\">\n        <button type=\"button\" class=\"cqa-p-0 cqa-border-0 cqa-bg-transparent cqa-cursor-pointer hover:cqa-opacity-80 cqa-transition-opacity focus:cqa-outline-none\" aria-label=\"Edit\" (click)=\"onEditStep($event)\">\n          <mat-icon class=\"!cqa-text-[14px] !cqa-w-[14px] !cqa-h-[14px]\">edit</mat-icon>\n        </button>\n        <button type=\"button\" class=\"cqa-p-0 cqa-border-0 cqa-bg-transparent cqa-cursor-pointer hover:cqa-opacity-80 cqa-transition-opacity focus:cqa-outline-none\" aria-label=\"Add\" [matMenuTriggerFor]=\"addStepMenu\">\n          <mat-icon class=\"!cqa-text-[14px] !cqa-w-[14px] !cqa-h-[14px]\">add</mat-icon>\n        </button>\n        <mat-menu #addStepMenu=\"matMenu\" class=\"cqa-add-step-menu\" xPosition=\"before\" yPosition=\"below\">\n          <button mat-menu-item *ngFor=\"let opt of addStepMenuOptions\" (click)=\"onAddStepOptionSelect(opt, $event)\">\n            {{ opt.label }}\n          </button>\n        </mat-menu>\n        <button type=\"button\" class=\"cqa-p-0 cqa-border-0 cqa-bg-transparent cqa-cursor-pointer hover:cqa-opacity-80 cqa-transition-opacity focus:cqa-outline-none\" aria-label=\"More options\" [matMenuTriggerFor]=\"stepMoreMenu\">\n          <mat-icon class=\"!cqa-text-[14px] !cqa-w-[14px] !cqa-h-[14px]\">more_vert</mat-icon>\n        </button>\n        <mat-menu #stepMoreMenu=\"matMenu\" class=\"cqa-step-more-menu\" xPosition=\"before\" yPosition=\"below\">\n          <button mat-menu-item *ngFor=\"let opt of stepMoreMenuOptions\" (click)=\"onStepMoreOptionSelect(opt, $event)\">{{ opt.label }}</button>\n        </mat-menu>\n      </div>\n      <span class=\"cqa-text-[12px] 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    <!-- Nested Steps -->\n    <div class=\"cqa-flex cqa-flex-col cqa-gap-2 cqa-mt-2 cqa-ml-[18px]\">\n      <!-- Loading indicator for nested steps -->\n      <div *ngIf=\"hasChild && (!config.steps || config.steps.length === 0) && isStepLoading()\" \n           class=\"cqa-flex cqa-items-center cqa-gap-2 cqa-py-2 cqa-px-3\">\n        <svg class=\"cqa-animate-spin cqa-text-[#3B82F6]\" width=\"14\" height=\"14\" viewBox=\"0 0 14 14\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n          <circle cx=\"7\" cy=\"7\" r=\"6\" stroke=\"currentColor\" stroke-width=\"1.5\" fill=\"none\" opacity=\"0.25\"/>\n          <path d=\"M7 1A6 6 0 0 1 13 7\" stroke=\"currentColor\" stroke-width=\"1.5\" fill=\"none\" stroke-linecap=\"round\"/>\n        </svg>\n        <span class=\"cqa-text-[11px] cqa-leading-[13px] cqa-text-[#737373]\">Loading nested steps...</span>\n      </div>\n\n      <ng-container *ngFor=\"let step of config.steps; index as i\">\n        <!-- Wrapper to show skeleton while step-renderer is loading -->\n        <div\n          class=\"cqa-step-renderer-wrapper\"\n          [attr.id]=\"'exc-' + step.id\"\n          [class.loaded]=\"!isNestedStepLoading(step)\">\n          <!-- Loading skeleton overlay -->\n          <!-- <div *ngIf=\"isNestedStepLoading(step)\" class=\"cqa-step-skeleton-overlay\">\n            <div class=\"cqa-step-skeleton cqa-mx-3 cqa-my-1\"></div>\n          </div> -->\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            [stepNumber]=\"stepNumber + '.' + (i + 1)\"\n            [onExpandHandler]=\"onExpandHandler\"\n            [getConditionBranchesHandler]=\"getConditionBranchesHandler\"\n            [onConditionBranchClickHandler]=\"onConditionBranchClickHandler\"\n            [isStepLoadingHandler]=\"isStepLoadingHandler\"\n            [isStepExpandedHandler]=\"isStepExpandedHandler\"\n            [convertMsToSecondsHandler]=\"convertMsToSecondsHandler\"\n            [formatFailureDetailsHandler]=\"formatFailureDetailsHandler\"\n            [getSelfHealAnalysisHandler]=\"getSelfHealAnalysisHandler\"\n            [getSelfHealLoadingStatesHandler]=\"getSelfHealLoadingStatesHandler\"\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            [onStepClickHandler]=\"onStepClickHandler\"\n            [onJsonPathCopiedHandler]=\"onJsonPathCopiedHandler\"\n            [onDownloadHandler]=\"onDownloadHandler\"\n            [onFilePathCopiedHandler]=\"onFilePathCopiedHandler\"\n            [onTextCopiedHandler]=\"onTextCopiedHandler\"\n            [jumpToTimestampHandler]=\"jumpToTimestampHandler\"\n            [downloadingStepId]=\"downloadingStepId\"\n            [isUploadingBaseline]=\"isUploadingBaseline\"\n            [isMakingCurrentBaseline]=\"isMakingCurrentBaseline\"\n            [selectedIterationId]=\"step?.selectedIterationId || ''\"\n            [isLive]=\"isLive\"\n            [isDebug]=\"isDebug\"\n            [debugPointSet]=\"getDebugPointSetHandler ? getDebugPointSetHandler(step) : debugPointSet\"\n            [getDebugPointSetHandler]=\"getDebugPointSetHandler\"\n            [onDebugPointChangeHandler]=\"onDebugPointChangeHandler\"\n            [onEditStepHandler]=\"onEditStepHandler\"\n            [addStepMenuOptions]=\"getAddStepMenuOptionsForNested ? getAddStepMenuOptionsForNested(step) : addStepMenuOptions\"\n            [onAddStepOptionSelectHandler]=\"onAddStepOptionSelectHandler\"\n            [stepMoreMenuOptions]=\"getStepMoreMenuOptionsForNested ? getStepMoreMenuOptionsForNested(step) : stepMoreMenuOptions\"\n            [onStepMoreOptionSelectHandler]=\"onStepMoreOptionSelectHandler\"\n            [getAddStepMenuOptionsForNested]=\"getAddStepMenuOptionsForNested\"\n            [getStepMoreMenuOptionsForNested]=\"getStepMoreMenuOptionsForNested\"\n            (componentReady)=\"markStepLoaded(step)\">\n          </cqa-step-renderer>\n        </div>\n      </ng-container>\n    </div>\n  </div>\n</div>\n"]}
467
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"step-group.component.js","sourceRoot":"","sources":["../../../../../../src/lib/execution-screen/step-group/step-group.component.ts","../../../../../../src/lib/execution-screen/step-group/step-group.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, Output, EventEmitter, OnInit, OnChanges, SimpleChanges, ChangeDetectorRef } from '@angular/core';\nimport { StepGroupConfig, LoopStepConfig, ConditionBranch, ExecutionStepConfig, StepStatus, TimingBreakdown, AddStepMenuOption, DEFAULT_ADD_STEP_MENU_OPTIONS, StepMoreMenuOption, DEFAULT_STEP_MORE_MENU_OPTIONS } from '../execution-step.models';\nimport { BaseStepComponent } from '../base-step.component';\n\n@Component({\n  selector: 'cqa-step-group',\n  templateUrl: './step-group.component.html',\n  host: { class: 'cqa-ui-root cqa-w-full' }\n})\nexport class StepGroupComponent 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() groupName!: string;\n  @Input() steps!: ExecutionStepConfig[];\n  @Input() hasChild?: boolean;\n  @Input() isLoading?: boolean;\n  @Input() stepDeleted?: boolean;\n  @Input() isDebug?: boolean = false;\n  @Input() debugPointSet?: boolean = false;\n  @Input() getDebugPointSetHandler?: (step: ExecutionStepConfig) => boolean;\n  @Input() onDebugPointChangeHandler?: (step: ExecutionStepConfig, value: boolean) => void;\n  @Output() debugPointChange = new EventEmitter<boolean>();\n  @Output() editStep = new EventEmitter<void>();\n  @Output() addStepOptionSelect = new EventEmitter<AddStepMenuOption>();\n  @Output() stepMoreOptionSelect = new EventEmitter<StepMoreMenuOption>();\n  @Input() addStepMenuOptions: AddStepMenuOption[] = DEFAULT_ADD_STEP_MENU_OPTIONS;\n  @Input() stepMoreMenuOptions: StepMoreMenuOption[] = DEFAULT_STEP_MORE_MENU_OPTIONS;\n\n  // Handler function to pass down to nested child step groups for recursive expansion\n  @Input() onExpandHandler?: (step: ExecutionStepConfig) => void;\n  /** When provided, passed to nested step-renderer so Edit on nested steps is forwarded with the step config. */\n  @Input() onEditStepHandler?: (step: ExecutionStepConfig) => void;\n  /** When provided, passed to nested step-renderer so Add-step menu selection on nested steps is forwarded. */\n  @Input() onAddStepOptionSelectHandler?: (option: AddStepMenuOption, step?: ExecutionStepConfig) => void;\n  /** When provided, passed to nested step-renderer so More options menu selection on nested steps is forwarded. */\n  @Input() onStepMoreOptionSelectHandler?: (option: StepMoreMenuOption, step?: ExecutionStepConfig) => void;\n  /** When provided, used to get add-step menu options per nested step at any depth; otherwise addStepMenuOptions is used. */\n  @Input() getAddStepMenuOptionsForNested?: (step: ExecutionStepConfig) => AddStepMenuOption[];\n  /** When provided, used to get step-more menu options per nested step at any depth; otherwise stepMoreMenuOptions is used. */\n  @Input() getStepMoreMenuOptionsForNested?: (step: ExecutionStepConfig) => StepMoreMenuOption[];\n\n  // Handler functions for nested components (optional, passed from parent)\n  @Input() getConditionBranchesHandler?: (step: ExecutionStepConfig) => ConditionBranch[];\n  @Input() onConditionBranchClickHandler?: (step: any, branch: any) => void;\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: { [key: string]: boolean }; isLoadingModifyAccept: { [key: string]: 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() onStepClickHandler?: (step: ExecutionStepConfig, event?: Event) => void;\n  @Input() onJsonPathCopiedHandler?: (event: { path: string; source: 'requestBody' | 'responseBody' | 'requestHeaders' | 'responseHeaders' }) => void;\n  @Input() onDownloadHandler?: (event: { fileName: string; filePath?: string; fileType: string; testStepResultId: string }) => void;\n  @Input() onFilePathCopiedHandler?: (event: { filePath: string; testStepResultId: string }) => void;\n  @Input() onTextCopiedHandler?: (event: { text: string; testStepResultId: string }) => void;\n  @Input() jumpToTimestampHandler?: (timestamp: number, testStepId?: number | string) => void;\n  @Input() downloadingStepId: string | null = null;\n  @Input() isUploadingBaseline?: any;\n  @Input() isMakingCurrentBaseline?: any;\n  @Input() isLive: boolean = false;\n  @Input() step?: ExecutionStepConfig;\n\n  // Output event for when the step group expands\n  @Output() onExpand = new EventEmitter<void>();\n\n  // Config property for base class - built from individual inputs in ngOnInit\n  override config!: StepGroupConfig;\n\n  // Track which steps are still loading to show skeleton\n  loadingSteps: Set<string> = new Set();\n\n  /** Show debug icon only when this step has no child steps (icon is shown on child steps instead). */\n  /** Show debug icon when debug mode is on (shown on parent and all child steps). */\n  get showDebugIcon(): boolean {\n    return this.isDebug === true;\n  }\n\n  constructor(private cdr: ChangeDetectorRef) {\n    super();\n  }\n\n  override ngOnInit(): void {\n    // Build config from individual inputs\n    this.updateConfig();\n\n    super.ngOnInit();\n    // Ensure isExpanded is set correctly after super.ngOnInit()\n    if (this.expanded !== undefined) {\n      this.isExpanded = this.expanded;\n    }\n\n    // Initialize loading state if already expanded\n    if (this.isExpanded && this.config.steps && this.config.steps.length > 0) {\n      this.loadingSteps.clear();\n      this.config.steps.forEach(step => {\n        const stepId = step.testStepResultId || step.id;\n        if (stepId) {\n          this.loadingSteps.add(String(stepId));\n        }\n      });\n    }\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    // Update config when steps input changes\n    if (changes['steps'] || changes['expanded'] || changes['status'] || changes['duration'] || changes['groupName'] || changes['stepDeleted']) {\n      this.updateConfig();\n    }\n\n    // Update expanded state if changed\n    if (changes['expanded'] && this.expanded !== undefined) {\n      this.isExpanded = this.expanded;\n    }\n\n    // // Initialize loading state when steps are added and step is expanded\n    // if (changes['steps'] && this.isExpanded && this.config.steps && this.config.steps.length > 0) {\n    //   this.loadingSteps.clear();\n    //   this.config.steps.forEach(step => {\n    //     const stepId = step.testStepResultId || step.id;\n    //     if (stepId) {\n    //       this.loadingSteps.add(String(stepId));\n    //     }\n    //   });\n    // }\n\n    // Initialize loading state if already expanded when component initializes\n    if (changes['expanded'] && this.isExpanded && this.config.steps && this.config.steps.length > 0) {\n      this.loadingSteps.clear();\n      this.config.steps.forEach(step => {\n        const stepId = step.testStepResultId || step.id;\n        if (stepId) {\n          this.loadingSteps.add(String(stepId));\n        }\n      });\n    }\n  }\n\n  private updateConfig(): void {\n    // Build or update config from individual inputs\n    this.config = {\n      id: this.id,\n      testStepId: this.step?.testStepId || undefined,\n      testStepResultId: this.testStepResultId,\n      stepNumber: this.stepNumber,\n      title: this.title,\n      status: this.status,\n      duration: this.duration,\n      displayType: 'step-group',\n      groupName: this.groupName,\n      steps: this.steps || [],\n      stepDeleted: this.stepDeleted,\n      timingBreakdown: this.timingBreakdown,\n      expanded: this.expanded,\n    } as StepGroupConfig;\n  }\n\n  onDebugPointClick(event: Event): void {\n    event.preventDefault();\n    event.stopPropagation();\n    this.debugPointChange.emit(!this.debugPointSet);\n  }\n\n  onEditStep(event: Event): void {\n    event.preventDefault();\n    event.stopPropagation();\n    this.editStep.emit();\n  }\n\n  onAddStepOptionSelect(option: AddStepMenuOption, event: Event): void {\n    event.preventDefault();\n    this.addStepOptionSelect.emit(option);\n  }\n\n  onStepMoreOptionSelect(option: StepMoreMenuOption, event: Event): void {\n    event.preventDefault();\n    this.stepMoreOptionSelect.emit(option);\n  }\n\n  override toggle(event?: Event): void {\n    if (event) {\n      event.preventDefault();\n      event.stopPropagation();\n    }\n    const wasExpanded = this.isExpanded;\n    super.toggle();\n    if (this.onStepClickHandler) {\n      const stepToPass = this.step || this.config;\n      if (stepToPass) {\n        this.onStepClickHandler(stepToPass, event);\n      }\n    }\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          displayType: (this.config as any).displayType || 'STEP_GROUP',\n          children: this.config.steps || [],\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      // Initialize loading state for all nested steps\n      if (this.config.steps && this.config.steps.length > 0) {\n        this.loadingSteps.clear();\n        this.config.steps.forEach(step => {\n          const stepId = step.testStepResultId || step.id;\n          if (stepId) {\n            this.loadingSteps.add(String(stepId));\n          }\n        });\n      }\n      this.cdr.detectChanges();\n    } else if (!this.isExpanded) {\n      // Clear loading state when collapsing\n      this.loadingSteps.clear();\n    }\n\n    // Ensure expanded state is synced with config\n    if (this.config) {\n      this.config.expanded = this.isExpanded;\n    }\n  }\n\n  // Check if a step is still loading\n  isNestedStepLoading(step: ExecutionStepConfig): boolean {\n    const stepId = step.testStepResultId || step.id;\n    return stepId ? this.loadingSteps.has(String(stepId)) : false;\n  }\n\n  // Mark a step as loaded (called when step-renderer is ready)\n  markStepLoaded(step: ExecutionStepConfig): void {\n    const stepId = step.testStepResultId || step.id;\n    if (stepId) {\n      this.loadingSteps.delete(String(stepId));\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.displayType === '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    // Check both steps and children properties for compatibility\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 loop step\n  isNestedLoopStep(step: ExecutionStepConfig): boolean {\n    const stepType = (step as any).testStepType || (step as any).displayType;\n    return stepType === 'FOR_LOOP' || stepType === 'WHILE_LOOP' || stepType === 'loop';\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 as any).displayType;\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 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 loop step properties\n  getLoopType(step: ExecutionStepConfig): 'for' | 'while' | undefined {\n    const stepType = (step as any).testStepType || (step as any).displayType;\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  getLoopIterations(step: ExecutionStepConfig): any[] {\n    const loopStep = step as LoopStepConfig;\n    return loopStep.iterations || [];\n  }\n\n  getLoopNestedSteps(step: ExecutionStepConfig): ExecutionStepConfig[] {\n    const loopStep = step as LoopStepConfig;\n    return loopStep.nestedSteps || (step as any).children || [];\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  handleLoopStepExpand(step: ExecutionStepConfig): void {\n    if (this.onExpandHandler) {\n      this.onExpandHandler(step);\n    }\n  }\n\n  handleLoopStepIterationChange(step: ExecutionStepConfig, iterationId: string): void {\n    // This would typically be handled by the parent component\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  // 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  \n  // Check if this step is currently loading nested children\n  isStepLoading(): boolean {\n    if (this.isStepLoadingHandler && this.config) {\n      return this.isStepLoadingHandler(this.config);\n    }\n    return this.isLoading || false;\n  }\n\n  onJumpToTimestamp(event: Event): void {\n    event.stopPropagation();\n    if (this.jumpToTimestampHandler && this.step?.executedResult?.video_start_time !== undefined && this.step?.executedResult?.video_start_time !== null) {\n      const timestamp = typeof this.step.executedResult.video_start_time === 'number' \n        ? this.step.executedResult.video_start_time \n        : Number(this.step.executedResult.video_start_time);\n      const testStepId = this.step?.testStepId;\n      if (isFinite(timestamp) && timestamp >= 0) {\n        this.jumpToTimestampHandler(timestamp, testStepId);\n      }\n    }\n  }\n}\n","<div class=\"cqa-font-inter cqa-w-full\" style=\"border-bottom: '1px solid #F3F4F6'\" (click)=\"$event.stopPropagation()\">\n  <!-- Header -->\n  <div\n    class=\"cqa-flex cqa-items-center cqa-gap-2 cqa-p-2 cqa-cursor-pointer\"\n    (click)=\"toggle($event)\">\n    <div *ngIf=\"showDebugIcon\" class=\"cqa-flex cqa-items-center cqa-justify-center\">\n      <button type=\"button\" class=\"cqa-p-0 cqa-border-0 cqa-bg-transparent cqa-cursor-pointer cqa-rounded-full hover:cqa-opacity-80 cqa-transition-opacity focus:cqa-outline-none\" (click)=\"onDebugPointClick($event)\" [attr.aria-label]=\"debugPointSet ? 'Remove debug point' : 'Set debug point'\">\n        <svg *ngIf=\"debugPointSet\" width=\"14\" height=\"14\" viewBox=\"0 0 14 14\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n          <circle cx=\"7\" cy=\"7\" r=\"6\" fill=\"#C63535\"/>\n        </svg>\n        <svg *ngIf=\"!debugPointSet\" width=\"14\" height=\"14\" viewBox=\"0 0 14 14\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n          <circle cx=\"7\" cy=\"7\" r=\"6\" stroke=\"#C63535\" stroke-width=\"1.5\" fill=\"none\"/>\n        </svg>\n      </button>\n    </div>\n    <!-- Status Icon -->\n    <div class=\"cqa-flex cqa-items-center cqa-justify-center\">\n      <!-- Success -->\n      <svg *ngIf=\"config.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=\"config.status.toLowerCase() === 'failure' || config.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=\"config.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=\"config.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      \n      <span *ngIf=\"config.status.toLowerCase() === 'skipped'\" class=\"material-symbols-outlined cqa-text-[#9CA3AF] cqa-text-[12px]\">\n        skip_next\n      </span>\n    </div>\n\n    <!-- Folder Icon -->\n    <div><svg width=\"14\" height=\"14\" viewBox=\"0 0 14 14\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M11.6666 11.6667C11.976 11.6667 12.2728 11.5437 12.4916 11.325C12.7104 11.1062 12.8333 10.8094 12.8333 10.5V4.66667C12.8333 4.35725 12.7104 4.0605 12.4916 3.84171C12.2728 3.62292 11.976 3.5 11.6666 3.5H7.05829C6.86318 3.50191 6.67069 3.45486 6.49847 3.36314C6.32624 3.27142 6.17977 3.13797 6.07246 2.975L5.59996 2.275C5.49373 2.11369 5.34911 1.98128 5.17908 1.88965C5.00906 1.79802 4.81894 1.75003 4.62579 1.75H2.33329C2.02387 1.75 1.72713 1.87292 1.50833 2.09171C1.28954 2.3105 1.16663 2.60725 1.16663 2.91667V10.5C1.16663 10.8094 1.28954 11.1062 1.50833 11.325C1.72713 11.5437 2.02387 11.6667 2.33329 11.6667H11.6666Z\" fill=\"#EFF6FF\" stroke=\"#60A5FA\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/></svg></div>\n\n    <!-- Step Number and Title -->\n    <div class=\"cqa-font-semibold cqa-flex-1 cqa-text-[#334155] cqa-text-[14px] cqa-leading-[18px] cqa-font-inter cqa-flex cqa-items-center cqa-gap-1\" style=\"word-break: break-word;\">\n      <span>{{ config?.stepNumber }}. Step group: {{ config.groupName }}</span>\n      <span *ngIf=\"config.stepDeleted\" class=\"cqa-px-1.5 cqa-py-[2px] cqa-rounded-[4px] cqa-text-[10px] cqa-leading-[12px] cqa-font-medium cqa-text-[#B42318] cqa-bg-[#FEF3F2] cqa-border cqa-border-[#FEE4E2]\">\n        Deleted\n      </span>\n    </div>\n\n    <div class=\"cqa-flex cqa-items-center cqa-gap-1 cqa-font-inter\">\n      <div class=\"cqa-flex cqa-items-center cqa-gap-1 cqa-rounded-[4px] cqa-py-0.5 cqa-px-1 cqa-bg-[#6366F11A] cqa-ml-1 cqa-cursor-pointer hover:cqa-opacity-80 cqa-transition-opacity\" \n           *ngIf=\"step?.executedResult?.video_start_time\" \n           [matTooltip]=\"'Jump to video time'\" \n           matTooltipPosition=\"below\"\n           (click)=\"onJumpToTimestamp($event)\">\n        <mat-icon class=\"cqa-text-[#636363] !cqa-text-[10px] !cqa-w-[10px] !cqa-h-[10px]\">\n          play_arrow\n        </mat-icon>\n        <span class=\"cqa-text-[8px] cqa-leading-[12px] cqa-font-normal cqa-text-[#636363]\">\n          {{ formatDurationClock(step?.executedResult?.video_start_time || 0) }}\n        </span>\n      </div>\n      <div *ngIf=\"isDebug\" class=\"cqa-flex cqa-items-center cqa-gap-0.5 cqa-text-[#9CA3AF]\" (click)=\"$event.stopPropagation()\">\n        <button type=\"button\" class=\"cqa-p-0 cqa-border-0 cqa-bg-transparent cqa-cursor-pointer hover:cqa-opacity-80 cqa-transition-opacity focus:cqa-outline-none\" aria-label=\"Edit\" (click)=\"onEditStep($event)\">\n          <mat-icon class=\"!cqa-text-[14px] !cqa-w-[14px] !cqa-h-[14px]\">edit</mat-icon>\n        </button>\n        <button type=\"button\" class=\"cqa-p-0 cqa-border-0 cqa-bg-transparent cqa-cursor-pointer hover:cqa-opacity-80 cqa-transition-opacity focus:cqa-outline-none\" aria-label=\"Add\" [matMenuTriggerFor]=\"addStepMenu\">\n          <mat-icon class=\"!cqa-text-[14px] !cqa-w-[14px] !cqa-h-[14px]\">add</mat-icon>\n        </button>\n        <mat-menu #addStepMenu=\"matMenu\" class=\"cqa-add-step-menu\" xPosition=\"before\" yPosition=\"below\">\n          <button mat-menu-item *ngFor=\"let opt of addStepMenuOptions\" (click)=\"onAddStepOptionSelect(opt, $event)\">\n            {{ opt.label }}\n          </button>\n        </mat-menu>\n        <button type=\"button\" class=\"cqa-p-0 cqa-border-0 cqa-bg-transparent cqa-cursor-pointer hover:cqa-opacity-80 cqa-transition-opacity focus:cqa-outline-none\" aria-label=\"More options\" [matMenuTriggerFor]=\"stepMoreMenu\">\n          <mat-icon class=\"!cqa-text-[14px] !cqa-w-[14px] !cqa-h-[14px]\">more_vert</mat-icon>\n        </button>\n        <mat-menu #stepMoreMenu=\"matMenu\" class=\"cqa-step-more-menu\" xPosition=\"before\" yPosition=\"below\">\n          <button mat-menu-item *ngFor=\"let opt of stepMoreMenuOptions\" (click)=\"onStepMoreOptionSelect(opt, $event)\">{{ opt.label }}</button>\n        </mat-menu>\n      </div>\n      <span class=\"cqa-text-[12px] 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    <!-- Nested Steps -->\n    <div class=\"cqa-flex cqa-flex-col cqa-gap-2 cqa-mt-2 cqa-ml-[18px]\">\n      <!-- Loading indicator for nested steps -->\n      <div *ngIf=\"hasChild && (!config.steps || config.steps.length === 0) && isStepLoading()\" \n           class=\"cqa-flex cqa-items-center cqa-gap-2 cqa-py-2 cqa-px-3\">\n        <svg class=\"cqa-animate-spin cqa-text-[#3B82F6]\" width=\"14\" height=\"14\" viewBox=\"0 0 14 14\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n          <circle cx=\"7\" cy=\"7\" r=\"6\" stroke=\"currentColor\" stroke-width=\"1.5\" fill=\"none\" opacity=\"0.25\"/>\n          <path d=\"M7 1A6 6 0 0 1 13 7\" stroke=\"currentColor\" stroke-width=\"1.5\" fill=\"none\" stroke-linecap=\"round\"/>\n        </svg>\n        <span class=\"cqa-text-[11px] cqa-leading-[13px] cqa-text-[#737373]\">Loading nested steps...</span>\n      </div>\n\n      <ng-container *ngFor=\"let step of config.steps; index as i\">\n        <!-- Wrapper to show skeleton while step-renderer is loading -->\n        <div\n          class=\"cqa-step-renderer-wrapper\"\n          [attr.id]=\"'exc-' + step.id\"\n          [class.loaded]=\"!isNestedStepLoading(step)\">\n          <!-- Loading skeleton overlay -->\n          <!-- <div *ngIf=\"isNestedStepLoading(step)\" class=\"cqa-step-skeleton-overlay\">\n            <div class=\"cqa-step-skeleton cqa-mx-3 cqa-my-1\"></div>\n          </div> -->\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            [stepNumber]=\"stepNumber + '.' + (i + 1)\"\n            [onExpandHandler]=\"onExpandHandler\"\n            [getConditionBranchesHandler]=\"getConditionBranchesHandler\"\n            [onConditionBranchClickHandler]=\"onConditionBranchClickHandler\"\n            [isStepLoadingHandler]=\"isStepLoadingHandler\"\n            [isStepExpandedHandler]=\"isStepExpandedHandler\"\n            [convertMsToSecondsHandler]=\"convertMsToSecondsHandler\"\n            [formatFailureDetailsHandler]=\"formatFailureDetailsHandler\"\n            [getSelfHealAnalysisHandler]=\"getSelfHealAnalysisHandler\"\n            [getSelfHealLoadingStatesHandler]=\"getSelfHealLoadingStatesHandler\"\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            [onStepClickHandler]=\"onStepClickHandler\"\n            [onJsonPathCopiedHandler]=\"onJsonPathCopiedHandler\"\n            [onDownloadHandler]=\"onDownloadHandler\"\n            [onFilePathCopiedHandler]=\"onFilePathCopiedHandler\"\n            [onTextCopiedHandler]=\"onTextCopiedHandler\"\n            [jumpToTimestampHandler]=\"jumpToTimestampHandler\"\n            [downloadingStepId]=\"downloadingStepId\"\n            [isUploadingBaseline]=\"isUploadingBaseline\"\n            [isMakingCurrentBaseline]=\"isMakingCurrentBaseline\"\n            [selectedIterationId]=\"step?.selectedIterationId || ''\"\n            [isLive]=\"isLive\"\n            [isDebug]=\"isDebug\"\n            [debugPointSet]=\"getDebugPointSetHandler ? getDebugPointSetHandler(step) : debugPointSet\"\n            [getDebugPointSetHandler]=\"getDebugPointSetHandler\"\n            [onDebugPointChangeHandler]=\"onDebugPointChangeHandler\"\n            [onEditStepHandler]=\"onEditStepHandler\"\n            [addStepMenuOptions]=\"getAddStepMenuOptionsForNested ? getAddStepMenuOptionsForNested(step) : addStepMenuOptions\"\n            [onAddStepOptionSelectHandler]=\"onAddStepOptionSelectHandler\"\n            [stepMoreMenuOptions]=\"getStepMoreMenuOptionsForNested ? getStepMoreMenuOptionsForNested(step) : stepMoreMenuOptions\"\n            [onStepMoreOptionSelectHandler]=\"onStepMoreOptionSelectHandler\"\n            [getAddStepMenuOptionsForNested]=\"getAddStepMenuOptionsForNested\"\n            [getStepMoreMenuOptionsForNested]=\"getStepMoreMenuOptionsForNested\"\n            (componentReady)=\"markStepLoaded(step)\">\n          </cqa-step-renderer>\n        </div>\n      </ng-container>\n    </div>\n  </div>\n</div>\n"]}