@cqa-lib/cqa-ui 1.1.390 → 1.1.392
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2020/lib/error-modal/error-modal.component.mjs +14 -5
- package/esm2020/lib/execution-screen/loop-step/loop-step.component.mjs +18 -8
- package/esm2020/lib/execution-screen/step-group/step-group.component.mjs +16 -6
- package/esm2020/lib/test-case-details/condition-step/condition-step.component.mjs +3 -3
- package/esm2020/lib/test-case-details/loop-step/loop-step.component.mjs +3 -3
- package/fesm2015/cqa-lib-cqa-ui.mjs +46 -18
- package/fesm2015/cqa-lib-cqa-ui.mjs.map +1 -1
- package/fesm2020/cqa-lib-cqa-ui.mjs +46 -18
- package/fesm2020/cqa-lib-cqa-ui.mjs.map +1 -1
- package/lib/error-modal/error-modal.component.d.ts +7 -1
- package/package.json +1 -1
|
@@ -46,19 +46,29 @@ export class StepGroupComponent extends BaseStepComponent {
|
|
|
46
46
|
return this.isDebug === true;
|
|
47
47
|
}
|
|
48
48
|
/** Per-step filtered three-dot menu options (e.g. hide Duplicate/Delete for step-group children). */
|
|
49
|
+
// get effectiveStepMoreMenuOptions(): StepMoreMenuOption[] {
|
|
50
|
+
// const base = this.stepMoreMenuOptions || [];
|
|
51
|
+
// // Always hide duplicate option for this container step
|
|
52
|
+
// let filtered = base.filter(opt => opt.id !== 'duplicate');
|
|
53
|
+
// const stepRef: any = this.step;
|
|
54
|
+
// if (!stepRef) return filtered;
|
|
55
|
+
// const isGroupChild = !!stepRef.isStepGroupChildren;
|
|
56
|
+
// // When step.stepMoreMenuOptions is truthy OR step is a step-group child, hide mutating items
|
|
57
|
+
// const suppressMutating = !!stepRef.stepMoreMenuOptions || isGroupChild;
|
|
58
|
+
// if (!suppressMutating) return filtered;
|
|
59
|
+
// return filtered.filter(opt => opt.id !== 'delete');
|
|
60
|
+
// }
|
|
49
61
|
get effectiveStepMoreMenuOptions() {
|
|
50
62
|
const base = this.stepMoreMenuOptions || [];
|
|
51
|
-
// Always hide duplicate option for this container step
|
|
52
|
-
let filtered = base.filter(opt => opt.id !== 'duplicate');
|
|
53
63
|
const stepRef = this.step;
|
|
54
64
|
if (!stepRef)
|
|
55
|
-
return
|
|
65
|
+
return base;
|
|
56
66
|
const isGroupChild = !!stepRef.isStepGroupChildren;
|
|
57
67
|
// When step.stepMoreMenuOptions is truthy OR step is a step-group child, hide mutating items
|
|
58
68
|
const suppressMutating = !!stepRef.stepMoreMenuOptions || isGroupChild;
|
|
59
69
|
if (!suppressMutating)
|
|
60
|
-
return
|
|
61
|
-
return
|
|
70
|
+
return base;
|
|
71
|
+
return base.filter(opt => opt.id !== 'duplicate' && opt.id !== 'delete');
|
|
62
72
|
}
|
|
63
73
|
/** True when this step-group's own breakpoint is disabled (used to propagate parentSkipped to children). */
|
|
64
74
|
get selfDebugDisabled() {
|
|
@@ -504,4 +514,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImpor
|
|
|
504
514
|
}], onExpand: [{
|
|
505
515
|
type: Output
|
|
506
516
|
}] } });
|
|
507
|
-
//# 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() parentSkipped?: 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  get stepBadges(): ('skipped' | 'edited' | 'added' | 'removed')[] {\n    const badge = (this.step as any)?.stepBadge;\n    if (!badge) return [];\n    return Array.isArray(badge) ? badge : [badge];\n  }\n\n  get isSkipped(): boolean {\n    return this.stepBadges.includes('skipped');\n  }\n\n  get isStepDeleted(): boolean {\n    return this.stepBadges.includes('removed');\n  }\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  /** Per-step filtered three-dot menu options (e.g. hide Duplicate/Delete for step-group children). */\n  get effectiveStepMoreMenuOptions(): StepMoreMenuOption[] {\n    const base = this.stepMoreMenuOptions || [];\n    // Always hide duplicate option for this container step\n    let filtered = base.filter(opt => opt.id !== 'duplicate');\n    \n    const stepRef: any = this.step;\n    if (!stepRef) return filtered;\n\n    const isGroupChild = !!stepRef.isStepGroupChildren;\n    // When step.stepMoreMenuOptions is truthy OR step is a step-group child, hide mutating items\n    const suppressMutating = !!stepRef.stepMoreMenuOptions || isGroupChild;\n    if (!suppressMutating) return filtered;\n\n    return filtered.filter(opt => opt.id !== 'delete');\n  }\n  \n  /** True when this step-group's own breakpoint is disabled (used to propagate parentSkipped to children). */\n  get selfDebugDisabled(): boolean {\n    return !!(this.step as any)?.debugPointDisabled || !!this.parentSkipped || this.isStepDeleted;\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'] || changes['stepNumber']) {\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    if (this.onEditStepHandler && this.step) {\n      this.onEditStepHandler(this.step);\n    } else {\n      this.editStep.emit();\n    }\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\" [class.cqa-opacity-50]=\"isDebug && isSkipped && !parentSkipped\" style=\"border-bottom: '1px solid #F3F4F6'\" [style.background-color]=\"!isDebug ? null : config.status.toLowerCase() === 'paused' ? '#FFF9E9' : config.status.toLowerCase() === 'failed' ? '#FEF2F2' : null\" (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      [matTooltip]=\"status.toLowerCase() === 'running' ? 'Breakpoint cannot be set on a running step' : (isStepDeleted ? 'Breakpoint cannot be set on deleted steps' : ((!!parentSkipped && !step?.debugPointDisabled) ? 'Breakpoint cannot be set on a running step' : (!!step?.debugPointDisabled ? 'Breakpoint cannot be set on skipped steps' : '')))\"\n      matTooltipPosition=\"right\">\n      <button type=\"button\" class=\"cqa-p-0 cqa-border-0 cqa-bg-transparent cqa-rounded-full cqa-transition-opacity focus:cqa-outline-none\"\n        [ngClass]=\"status.toLowerCase() === 'running' || !!step?.debugPointDisabled || !!parentSkipped || isStepDeleted ? 'cqa-cursor-not-allowed cqa-opacity-40 cqa-pointer-events-none' : 'cqa-cursor-pointer hover:cqa-opacity-80'\"\n        [disabled]=\"status.toLowerCase() === 'running' || !!step?.debugPointDisabled || !!parentSkipped || isStepDeleted\"\n        (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\" [attr.fill]=\"!!step?.debugPointDisabled || !!parentSkipped || isStepDeleted ? '#9E9E9E' : '#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\" [attr.stroke]=\"!!step?.debugPointDisabled || !!parentSkipped || isStepDeleted ? '#9E9E9E' : '#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 *ngIf=\"config.status.toLowerCase() === 'paused'\"><svg width=\"12\" height=\"12\" viewBox=\"0 0 12 12\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M8.5 2H7.5C7.22386 2 7 2.22386 7 2.5V9.5C7 9.77614 7.22386 10 7.5 10H8.5C8.77614 10 9 9.77614 9 9.5V2.5C9 2.22386 8.77614 2 8.5 2Z\" stroke=\"#E17100\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M4.5 2H3.5C3.22386 2 3 2.22386 3 2.5V9.5C3 9.77614 3.22386 10 3.5 10H4.5C4.77614 10 5 9.77614 5 9.5V2.5C5 2.22386 4.77614 2 4.5 2Z\" stroke=\"#E17100\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/></svg></div>\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      <!-- Step Change Badges (debug only) -->\n      <ng-container *ngIf=\"isDebug\">\n        <ng-container *ngFor=\"let badge of stepBadges\">\n        <cqa-badge\n          *ngIf=\"badge === 'skipped'\"\n          label=\"Skipped\"\n          size=\"small\"\n          [textColor]=\"'#4A5565'\"\n          [borderColor]=\"'#99A1AF'\"\n          [backgroundColor]=\"'#FFFFFF'\">\n        </cqa-badge>\n        <cqa-badge\n          *ngIf=\"badge === 'edited'\"\n          label=\"Edited\"\n          size=\"small\"\n          [textColor]=\"'#FBBF24'\"\n          [borderColor]=\"'#FDDF92'\"\n          [backgroundColor]=\"'#FFF9E9'\">\n        </cqa-badge>\n        <cqa-badge\n          *ngIf=\"badge === 'added'\"\n          label=\"Added\"\n          size=\"small\"\n          [textColor]=\"'#0DBD7D'\"\n          [borderColor]=\"'#5ED3A8'\"\n          [backgroundColor]=\"'#CFF2E5'\">\n        </cqa-badge>\n        <cqa-badge\n          *ngIf=\"badge === 'removed'\"\n          label=\"Removed\"\n          size=\"small\"\n          [textColor]=\"'#EE3F3F'\"\n          [borderColor]=\"'#F47F7F'\"\n          [backgroundColor]=\"'#FCD9D9'\">\n        </cqa-badge>\n        </ng-container>\n      </ng-container>\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 *ngIf=\"!step?.isStepGroupChildren\" 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 *ngIf=\"!step?.isStepGroupChildren\" 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 *ngIf=\"effectiveStepMoreMenuOptions.length\" 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 effectiveStepMoreMenuOptions\" (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]=\"step?.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            [parentSkipped]=\"selfDebugDisabled\"\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"]}
|
|
517
|
+
//# 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() parentSkipped?: 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  get stepBadges(): ('skipped' | 'edited' | 'added' | 'removed')[] {\n    const badge = (this.step as any)?.stepBadge;\n    if (!badge) return [];\n    return Array.isArray(badge) ? badge : [badge];\n  }\n\n  get isSkipped(): boolean {\n    return this.stepBadges.includes('skipped');\n  }\n\n  get isStepDeleted(): boolean {\n    return this.stepBadges.includes('removed');\n  }\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  /** Per-step filtered three-dot menu options (e.g. hide Duplicate/Delete for step-group children). */\n  // get effectiveStepMoreMenuOptions(): StepMoreMenuOption[] {\n  //   const base = this.stepMoreMenuOptions || [];\n  //   // Always hide duplicate option for this container step\n  //   let filtered = base.filter(opt => opt.id !== 'duplicate');\n    \n  //   const stepRef: any = this.step;\n  //   if (!stepRef) return filtered;\n\n  //   const isGroupChild = !!stepRef.isStepGroupChildren;\n  //   // When step.stepMoreMenuOptions is truthy OR step is a step-group child, hide mutating items\n  //   const suppressMutating = !!stepRef.stepMoreMenuOptions || isGroupChild;\n  //   if (!suppressMutating) return filtered;\n\n  //   return filtered.filter(opt => opt.id !== 'delete');\n  // }\n  get effectiveStepMoreMenuOptions(): StepMoreMenuOption[] {\n    const base = this.stepMoreMenuOptions || [];\n    const stepRef: any = this.step;\n    if (!stepRef) return base;\n\n    const isGroupChild = !!stepRef.isStepGroupChildren;\n    // When step.stepMoreMenuOptions is truthy OR step is a step-group child, hide mutating items\n    const suppressMutating = !!stepRef.stepMoreMenuOptions || isGroupChild;\n    if (!suppressMutating) return base;\n\n    return base.filter(opt => opt.id !== 'duplicate' && opt.id !== 'delete');\n  }\n  \n  /** True when this step-group's own breakpoint is disabled (used to propagate parentSkipped to children). */\n  get selfDebugDisabled(): boolean {\n    return !!(this.step as any)?.debugPointDisabled || !!this.parentSkipped || this.isStepDeleted;\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'] || changes['stepNumber']) {\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    if (this.onEditStepHandler && this.step) {\n      this.onEditStepHandler(this.step);\n    } else {\n      this.editStep.emit();\n    }\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\" [class.cqa-opacity-50]=\"isDebug && isSkipped && !parentSkipped\" style=\"border-bottom: '1px solid #F3F4F6'\" [style.background-color]=\"!isDebug ? null : config.status.toLowerCase() === 'paused' ? '#FFF9E9' : config.status.toLowerCase() === 'failed' ? '#FEF2F2' : null\" (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      [matTooltip]=\"status.toLowerCase() === 'running' ? 'Breakpoint cannot be set on a running step' : (isStepDeleted ? 'Breakpoint cannot be set on deleted steps' : ((!!parentSkipped && !step?.debugPointDisabled) ? 'Breakpoint cannot be set on a running step' : (!!step?.debugPointDisabled ? 'Breakpoint cannot be set on skipped steps' : '')))\"\n      matTooltipPosition=\"right\">\n      <button type=\"button\" class=\"cqa-p-0 cqa-border-0 cqa-bg-transparent cqa-rounded-full cqa-transition-opacity focus:cqa-outline-none\"\n        [ngClass]=\"status.toLowerCase() === 'running' || !!step?.debugPointDisabled || !!parentSkipped || isStepDeleted ? 'cqa-cursor-not-allowed cqa-opacity-40 cqa-pointer-events-none' : 'cqa-cursor-pointer hover:cqa-opacity-80'\"\n        [disabled]=\"status.toLowerCase() === 'running' || !!step?.debugPointDisabled || !!parentSkipped || isStepDeleted\"\n        (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\" [attr.fill]=\"!!step?.debugPointDisabled || !!parentSkipped || isStepDeleted ? '#9E9E9E' : '#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\" [attr.stroke]=\"!!step?.debugPointDisabled || !!parentSkipped || isStepDeleted ? '#9E9E9E' : '#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 *ngIf=\"config.status.toLowerCase() === 'paused'\"><svg width=\"12\" height=\"12\" viewBox=\"0 0 12 12\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M8.5 2H7.5C7.22386 2 7 2.22386 7 2.5V9.5C7 9.77614 7.22386 10 7.5 10H8.5C8.77614 10 9 9.77614 9 9.5V2.5C9 2.22386 8.77614 2 8.5 2Z\" stroke=\"#E17100\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M4.5 2H3.5C3.22386 2 3 2.22386 3 2.5V9.5C3 9.77614 3.22386 10 3.5 10H4.5C4.77614 10 5 9.77614 5 9.5V2.5C5 2.22386 4.77614 2 4.5 2Z\" stroke=\"#E17100\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/></svg></div>\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      <!-- Step Change Badges (debug only) -->\n      <ng-container *ngIf=\"isDebug\">\n        <ng-container *ngFor=\"let badge of stepBadges\">\n        <cqa-badge\n          *ngIf=\"badge === 'skipped'\"\n          label=\"Skipped\"\n          size=\"small\"\n          [textColor]=\"'#4A5565'\"\n          [borderColor]=\"'#99A1AF'\"\n          [backgroundColor]=\"'#FFFFFF'\">\n        </cqa-badge>\n        <cqa-badge\n          *ngIf=\"badge === 'edited'\"\n          label=\"Edited\"\n          size=\"small\"\n          [textColor]=\"'#FBBF24'\"\n          [borderColor]=\"'#FDDF92'\"\n          [backgroundColor]=\"'#FFF9E9'\">\n        </cqa-badge>\n        <cqa-badge\n          *ngIf=\"badge === 'added'\"\n          label=\"Added\"\n          size=\"small\"\n          [textColor]=\"'#0DBD7D'\"\n          [borderColor]=\"'#5ED3A8'\"\n          [backgroundColor]=\"'#CFF2E5'\">\n        </cqa-badge>\n        <cqa-badge\n          *ngIf=\"badge === 'removed'\"\n          label=\"Removed\"\n          size=\"small\"\n          [textColor]=\"'#EE3F3F'\"\n          [borderColor]=\"'#F47F7F'\"\n          [backgroundColor]=\"'#FCD9D9'\">\n        </cqa-badge>\n        </ng-container>\n      </ng-container>\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 *ngIf=\"!step?.isStepGroupChildren\" 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 *ngIf=\"!step?.isStepGroupChildren\" 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 *ngIf=\"effectiveStepMoreMenuOptions.length\" 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 effectiveStepMoreMenuOptions\" (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]=\"step?.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            [parentSkipped]=\"selfDebugDisabled\"\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"]}
|