@cqa-lib/cqa-ui 1.1.398 → 1.1.400

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.
@@ -253,7 +253,8 @@ export class TestCaseConditionStepComponent {
253
253
  }
254
254
  buildElseIfBranch(index) {
255
255
  // Initialize ELSE IF form with empty values or from existing ELSE IF branch if available
256
- const elseIfBranches = this.branches?.filter(b => b.type === 'else-if') || [];
256
+ // Use getAllBranchesFlat to include chained nextBranch ELSE IFs
257
+ const elseIfBranches = this.getAllBranchesFlat().filter(b => b.type === 'else-if');
257
258
  const branchIndex = index !== undefined ? index : elseIfBranches.length;
258
259
  const elseIfBranch = elseIfBranches[branchIndex];
259
260
  const elseCondition = elseIfBranch?.action || '';
@@ -581,8 +582,25 @@ export class TestCaseConditionStepComponent {
581
582
  }
582
583
  /** Count and summarize condition branches using their display step numbers.
583
584
  * Example: IF + 2x ELSE IF + ELSE → "Steps 6-9 (4 steps)". */
585
+ /**
586
+ * Returns a flat list of all branches including those chained via nextBranch.
587
+ * Used for counting, badge display, and summary when the condition uses a chained structure.
588
+ */
589
+ getAllBranchesFlat() {
590
+ const result = [];
591
+ const traverse = (branches) => {
592
+ for (const b of branches) {
593
+ result.push(b);
594
+ if (b.nextBranch)
595
+ traverse([b.nextBranch]);
596
+ }
597
+ };
598
+ traverse(this.branches || []);
599
+ return result;
600
+ }
584
601
  getStepsSummary() {
585
- const branchCount = this.branches?.length ?? 0;
602
+ const allBranches = this.getAllBranchesFlat();
603
+ const branchCount = allBranches.length;
586
604
  if (branchCount === 0) {
587
605
  return '0 steps';
588
606
  }
@@ -596,7 +614,8 @@ export class TestCaseConditionStepComponent {
596
614
  /** Branch type badges for step row: IF, ELSE IF (with count if multiple), ELSE */
597
615
  getBranchTypeBadges() {
598
616
  const badges = [];
599
- const elseIfCount = this.branches?.filter(b => b.type === 'else-if').length ?? 0;
617
+ const allBranches = this.getAllBranchesFlat();
618
+ const elseIfCount = allBranches.filter(b => b.type === 'else-if').length;
600
619
  const hasElse = this.hasElseBranch;
601
620
  badges.push({ label: 'IF', type: 'if', badgeClass: 'cqa-bg-[#0DBD7D1A] cqa-text-[#0D542B] cqa-border cqa-border-solid cqa-border-[#0DBD7D]' });
602
621
  if (elseIfCount > 0) {
@@ -815,7 +834,7 @@ export class TestCaseConditionStepComponent {
815
834
  }
816
835
  /** True when condition already has an ELSE branch (disables Add ELSE IF / Add ELSE). */
817
836
  get hasElseBranch() {
818
- return this.branches?.some(b => b.type === 'else') ?? false;
837
+ return this.getAllBranchesFlat().some(b => b.type === 'else');
819
838
  }
820
839
  onOpenExternal() {
821
840
  // Not used in condition step, but needed for recursive step groups
@@ -1023,6 +1042,7 @@ export class TestCaseConditionStepComponent {
1023
1042
  let updatedConfig;
1024
1043
  if (isEditingElseIfBranch && branchForEdit && branchForEdit.id != null) {
1025
1044
  // Editing existing ELSE IF branch: target that branch's step ID and send raw condition so backend updates the branch only.
1045
+ // Any new ELSE IF added here chains off this specific ELSE IF (handled by step-list since updatedConfig.id = this branch's id).
1026
1046
  updatedConfig = {
1027
1047
  ...updatedConfigBase,
1028
1048
  id: String(branchForEdit.id),
@@ -1032,10 +1052,15 @@ export class TestCaseConditionStepComponent {
1032
1052
  };
1033
1053
  }
1034
1054
  else {
1035
- // IF condition edit (step row or IF branch row): use formatted condition for display
1055
+ // IF condition edit (step row or IF branch row): use formatted condition for display.
1056
+ // When editing from the IF TRUE branch row (branchIndex === 0), any new ELSE IFs must be
1057
+ // inserted directly after the IF branch — not at the end of the chain.
1058
+ // Pass insertAfterBranchId so step-list knows the exact insertion point.
1059
+ const isEditingIfBranchRow = isEditingBranchRow && branchForEdit?.type === 'if' && branchForEdit.id != null;
1036
1060
  updatedConfig = {
1037
1061
  ...updatedConfigBase,
1038
1062
  condition: this.condition,
1063
+ ...(isEditingIfBranchRow && { insertAfterBranchId: String(branchForEdit.id) }),
1039
1064
  };
1040
1065
  }
1041
1066
  // Emit individual change event
@@ -1287,4 +1312,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImpor
1287
1312
  }], openExternal: [{
1288
1313
  type: Output
1289
1314
  }] } });
1290
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"condition-step.component.js","sourceRoot":"","sources":["../../../../../../src/lib/test-case-details/condition-step/condition-step.component.ts","../../../../../../src/lib/test-case-details/condition-step/condition-step.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, Output, EventEmitter, OnInit, OnChanges, ChangeDetectorRef, ViewChild, ElementRef } from '@angular/core';\nimport { FormBuilder, FormGroup, FormControl } from '@angular/forms';\nimport { DndDropEvent } from 'ngx-drag-drop';\nimport { ConditionStepConfig, ConditionBranch, TestCaseStepConfig, NormalStepConfig, LoopStepConfig, StepGroupConfig, StepTypes } from '../test-case-step.models';\nimport { STEP_ROW_ACTIONS_STYLES } from '../step-row-actions.styles';\nimport { DynamicSelectFieldConfig, SelectOption } from '../../dynamic-select/dynamic-select-field.component';\nimport { CqaAutocompleteOption } from '../../autocomplete/autocomplete.model';\nimport { ViewDetailsPayload } from '../step-details-modal/step-details-modal-data';\n\nconst CONDITION_BRANCH_EMPTY_STYLES = `\n  /* Empty drop zone: ensure min height for drag-drop to work (IF/ELSE IF/ELSE branches) */\n  .nested-step-drop-list:has(.step-drag-placeholder-nested:only-child) {\n    min-height: 52px;\n  }\n  /* Empty IF / ELSE IF / ELSE: always show plus icon when no steps (visible without hover) */\n  .condition-branch-empty {\n    opacity: 1;\n    transition: opacity 0.1s ease;\n  }\n  /* Show edit/delete icons when hovering over branch row header (IF TRUE, ELSE IF, ELSE) */\n  .condition-branch-row:hover .step-actions {\n    opacity: 1;\n  }\n  .condition-branch-empty-add {\n    padding: 0;\n    background: transparent;\n    border: 0;\n    cursor: pointer;\n    color: #3F43EE;\n    transition: opacity 0.15s ease;\n  }\n  .condition-branch-empty-add:hover {\n    opacity: 0.9;\n  }\n`;\n@Component({\n  selector: 'cqa-test-case-condition-step',\n  templateUrl: './condition-step.component.html',\n  host: { class: 'cqa-ui-root' },\n  styles: [\n    STEP_ROW_ACTIONS_STYLES,\n    CONDITION_BRANCH_EMPTY_STYLES,\n  ],\n})\nexport class TestCaseConditionStepComponent implements OnInit, OnChanges {\n  @Input() config!: ConditionStepConfig;\n  @Input() id!: string;\n  @Input() stepNumber!: number | string;\n  /** Array index from parent renderer - use this for editInDepth instead of stepNumber (stepNumber \"10.3\" parses to 10) */\n  @Input() index?: number;\n  @Input() condition!: string;\n  @Input() branches: ConditionBranch[] = [];\n  @Input() expanded: boolean = true;\n  @Input() isNested: boolean = false;\n  @Input() isInsideLoop: boolean = false;\n  @Input() isInsideStepGroup: boolean = false;\n  @Input() isReorder: boolean = false;\n  @Input() editable: boolean = true;\n  /** Visual indentation level for nested structures (passed down from renderer). */\n  @Input() nestingLevel: number = 0;\n  @Input() selected: boolean = false;\n  /** Options for the data profile dropdown */\n  @Input() dataProfileOptions: any[] = [];\n  /** Indicates if more data profiles are available for loading */\n  @Input() hasMoreDataProfiles: boolean = false;\n  /** Loading state for data profiles */\n  @Input() isLoadingDataProfiles: boolean = false;\n  /** Natural text actions options for while loop condition */\n  @Input() naturalTextActionsOptions: any[] = [];\n  /** Function to process template variables (similar to step-builder-condition) */\n  @Input() setConditionTemplateVariables: (template: any) => any[] = () => [];\n  /** Show \"Add Step Between\" button above nested steps */\n  @Input() addStepBetweenAbove: boolean = false;\n  /** Show \"Add Step Between\" button below nested steps */\n  @Input() addStepBetweenBelow: boolean = false;\n  /** @deprecated Use addStepBetweenAbove and addStepBetweenBelow instead. If set, applies to both buttons. */\n  @Input() addStepBetween: boolean = false;\n\n  /** When non-null, edit mode is open: 'stepRow' = edit UI in step row only, 'branchRow' = edit UI in branch row only */\n  editContext: 'stepRow' | 'branchRow' | null = null;\n\n  /** Base left padding for step rows (matches px-4 = 16px) plus 24px per nesting level (matches pl-10 = 40px at level 1). */\n  getRowPaddingLeftPx(): number {\n    const level = Number(this.nestingLevel) || 0;\n    return 16 + (level * 24);\n  }\n\n  /** Which branch index is being edited when editContext === 'branchRow' (0 = IF TRUE, 1+ = ELSE IF) */\n  editingBranchIndex: number = 0;\n\n  /** True when editContext is set (either step row or branch row edit). */\n  get isEditing(): boolean {\n    return this.editContext !== null;\n  }\n\n  /** Array of ELSE IF branches in edit mode */\n  elseIfBranches: Array<{\n    id: string;\n    form: FormGroup;\n    selectedTemplate: any;\n    templateVariables: any[];\n    templateVariablesForm: FormGroup;\n    snapshot: { conditionLeft?: string; conditionOperator?: string; conditionRight?: string };\n  }> = [];\n\n  /** Form for edit mode; bound to cqa-dynamic-select and cqa-custom-input */\n  editForm!: FormGroup;\n\n  /** Operator dropdown config (IS, IS NOT, CONTAINS, etc.) */\n  operatorSelectConfig!: DynamicSelectFieldConfig;\n  /** Condition left operand dropdown config (natural text actions with IF_CONDITION) */\n  conditionLeftSelectConfig!: DynamicSelectFieldConfig;\n\n  /** Snapshot for Cancel revert */\n  private editSnapshot: { conditionLeft?: string; conditionOperator?: string; conditionRight?: string } = {};\n  \n  /** Selected template for IF condition */\n  selectedTemplate: any = null;\n  /** Template variables for IF condition */\n  templateVariables: any[] = [];\n  /** Form group for template variables */\n  templateVariablesForm!: FormGroup;\n\n  @ViewChild('viewDetailsTrigger', { static: false }) viewDetailsTrigger?: ElementRef<HTMLElement>;\n\n  @Output() toggleExpanded = new EventEmitter<{config: ConditionStepConfig, expanded: boolean}>();\n  @Output() conditionChange = new EventEmitter<string>();\n  @Output() branchStepChange = new EventEmitter<{ branch: ConditionBranch; step: TestCaseStepConfig; stepIndex: number }>();\n  @Output() addStep = new EventEmitter<{ branch: ConditionBranch }>();\n  /** Emitted when a nested loop-step emits addStepForLoop (empty state plus button). */\n  @Output() addStepForLoop = new EventEmitter<{ loopStepConfig: LoopStepConfig }>();\n  @Output() deleteStep = new EventEmitter<{ branch: ConditionBranch; stepIndex: number }>();\n  @Output() addBranch = new EventEmitter<void>();\n  /** Emitted when user clicks \"Add Else\" so the parent can call POST test_steps with conditionType CONDITION_ELSE */\n  @Output() addElse = new EventEmitter<{ conditionStepConfig: ConditionStepConfig }>();\n  /** Payload can be branch only (legacy) or { branch, stepNumber } for delete modal label e.g. \"Step 5 ELSE\". */\n  @Output() deleteBranch = new EventEmitter<ConditionBranch | { branch: ConditionBranch; stepNumber?: number | string }>();\n  @Output() duplicate = new EventEmitter<void>();\n  @Output() delete = new EventEmitter<void>();\n  @Output() edit = new EventEmitter<{ step: TestCaseStepConfig; index: number }>();\n  @Output() moreOptions = new EventEmitter<void>();\n  @Output() viewDetails = new EventEmitter<ViewDetailsPayload>();\n  @Output() editInDepth = new EventEmitter<{ step: TestCaseStepConfig; index?: number; templateOverride?: any; isCreateMode?: boolean; createModeBranchData?: any }>();\n  @Output() dndDropInZone = new EventEmitter<{ event: DndDropEvent; targetList: TestCaseStepConfig[] }>();\n  /** Emit when more data profiles need to be loaded */\n  @Output() loadMoreDataProfiles = new EventEmitter<string>();\n  /** Emit when data profile search query changes */\n  @Output() searchDataProfiles = new EventEmitter<string>();\n  /** Emit when a nested step is updated (e.g., Apply button clicked in loop-step edit mode) */\n  @Output() stepUpdate = new EventEmitter<TestCaseStepConfig>();\n  /** Re-emit when a nested step (e.g. normal-step) emits clickAction (e.g. element/label click for popup) */\n  @Output() clickAction = new EventEmitter<{ event: MouseEvent; step: TestCaseStepConfig }>();\n  /** Re-emit addStepBetweenClick from nested renderers */\n  @Output() addStepBetweenClick = new EventEmitter<{step: TestCaseStepConfig, index: number, position: 'ABOVE' | 'BELOW'}>();\n  @Output() selectionChange = new EventEmitter<boolean>();\n  /** Re-emit when nested step group emits openExternal (redirect to step group in new tab) */\n  @Output() openExternal = new EventEmitter<{ step: TestCaseStepConfig }>();\n\n  onDndDrop(event: DndDropEvent, branch: ConditionBranch): void {\n    this.dndDropInZone.emit({ event, targetList: branch.nestedSteps });\n  }\n\n  /** Emit clickAction when user clicks on condition/branch action badges (element, test_data, etc.) so parent can open edit modals */\n  onConditionActionClick(event: MouseEvent, branch?: ConditionBranch): void {\n    if (this.isInsideStepGroup) return;\n    const step: TestCaseStepConfig = branch?.id != null\n      ? { ...this.config, id: String(branch.id) } as TestCaseStepConfig\n      : this.config;\n    this.clickAction.emit({ event, step });\n  }\n\n  /** Forward clickAction from nested steps only when not inside a step-group (Element/Test Data modals disabled there). */\n  onNestedClickAction(payload: { event: MouseEvent; step: TestCaseStepConfig }): void {\n    if (!this.isInsideStepGroup) {\n      this.clickAction.emit(payload);\n    }\n  }\n\n  constructor(\n    private fb: FormBuilder,\n    private cdr: ChangeDetectorRef\n  ) {}\n\n  ngOnInit(): void {\n    if (this.config) {\n      this.id = this.config.id;\n      this.stepNumber = this.config.stepNumber;\n      this.condition = this.config.condition;\n      this.branches = this.config.branches || [];\n      this.expanded = this.config.expanded !== undefined ? this.config.expanded : true;\n      this.selected = (this.config as any).selected || false;\n    }\n    this.buildEditForm();\n    this.buildOperatorSelectConfig();\n    this.updateConditionLeftSelectConfig();\n  }\n\n  ngOnChanges(changes: any): void {\n    if (changes['config'] && this.config) {\n      this.selected = (this.config as any).selected || false;\n      // Update condition and branches when config changes (important for immediate UI updates)\n      // This ensures the UI reflects changes immediately, even if config object reference doesn't change\n      if (this.config.condition !== undefined) {\n        this.condition = this.config.condition;\n      }\n      if (this.config.branches) {\n        this.branches = this.config.branches;\n      }\n      // Trigger change detection to ensure UI updates\n      this.cdr.detectChanges();\n    }\n    if (changes['condition'] && this.condition !== undefined) {\n      // Condition input changed, update from config if available\n      if (this.config && this.config.condition !== undefined) {\n        this.condition = this.config.condition;\n      }\n      // Trigger change detection\n      this.cdr.detectChanges();\n    }\n    if (changes['branches'] && this.branches) {\n      // Branches changed, trigger change detection\n      this.cdr.detectChanges();\n    }\n    if (changes['naturalTextActionsOptions']) {\n      this.updateConditionLeftSelectConfig();\n      // Rebuild form when options are loaded to populate initial value from naturalTextActionId\n      if (this.editForm && this.naturalTextActionsOptions && this.naturalTextActionsOptions.length > 0) {\n        this.rebuildEditFormWithNaturalTextAction();\n      }\n    }\n  }\n\n  /** Rebuild edit form when naturalTextActionsOptions are loaded to populate from naturalTextActionId */\n  private rebuildEditFormWithNaturalTextAction(): void {\n    if (!this.editForm) {\n      return;\n    }\n    const configWithId = this.config as any;\n    if (configWithId.naturalTextActionId && this.naturalTextActionsOptions && this.naturalTextActionsOptions.length > 0) {\n      const matchingOption = this.naturalTextActionsOptions.find(\n        (option: any) => String(option.id) === String(configWithId.naturalTextActionId)\n      );\n      if (matchingOption) {\n        const naturalText = matchingOption.naturalText ?? matchingOption.name ?? matchingOption.value ?? '';\n        if (naturalText) {\n          const currentValue = this.editForm.get('conditionLeft')?.value ?? '';\n          // Only update if current value is empty or doesn't match\n          if (!currentValue || currentValue !== naturalText) {\n            this.editForm.get('conditionLeft')?.setValue(naturalText);\n          }\n        }\n        // Get the full template object (NaturalTextActions) from the option\n        const fullTemplate = matchingOption.template || matchingOption;\n        // Store selected template and get variables\n        this.selectedTemplate = fullTemplate;\n        if (fullTemplate && fullTemplate.variables) {\n          this.templateVariables = this.setConditionTemplateVariables(fullTemplate);\n          this.buildTemplateVariablesForm();\n        }\n      }\n    }\n  }\n\n  private buildEditForm(): void {\n    // If config has naturalTextActionId, find the matching natural text action\n    let conditionLeftValue = '';\n    const configWithId = this.config as any;\n    if (configWithId.naturalTextActionId && this.naturalTextActionsOptions && this.naturalTextActionsOptions.length > 0) {\n      const matchingOption = this.naturalTextActionsOptions.find(\n        (option: any) => String(option.id) === String(configWithId.naturalTextActionId)\n      );\n      if (matchingOption) {\n        // Use naturalText exactly as received from API\n        conditionLeftValue = matchingOption.naturalText ?? matchingOption.name ?? matchingOption.value ?? '';\n        // Get the full template object (NaturalTextActions) from the option\n        const fullTemplate = matchingOption.template || matchingOption;\n        // Store selected template and get variables\n        this.selectedTemplate = fullTemplate;\n        if (fullTemplate && fullTemplate.variables) {\n          this.templateVariables = this.setConditionTemplateVariables(fullTemplate);\n          this.buildTemplateVariablesForm();\n        }\n      }\n    }\n    \n    // If no naturalTextActionId match found, parse from condition string\n    if (!conditionLeftValue) {\n      const { left } = this.parseCondition(this.condition);\n      conditionLeftValue = left;\n    }\n    \n    const { operator, right } = this.parseCondition(this.condition);\n    this.editForm = this.fb.group({\n      conditionLeft: [conditionLeftValue],\n      conditionOperator: [operator],\n      conditionRight: [right],\n    });\n    \n    // Initialize template variables form if not already initialized\n    if (!this.templateVariablesForm) {\n      this.templateVariablesForm = this.fb.group({});\n    }\n  }\n\n  private buildElseIfBranch(index?: number): {\n    id: string;\n    form: FormGroup;\n    selectedTemplate: any;\n    templateVariables: any[];\n    templateVariablesForm: FormGroup;\n    snapshot: { conditionLeft?: string; conditionOperator?: string; conditionRight?: string };\n  } {\n    // Initialize ELSE IF form with empty values or from existing ELSE IF branch if available\n    const elseIfBranches = this.branches?.filter(b => b.type === 'else-if') || [];\n    const branchIndex = index !== undefined ? index : elseIfBranches.length;\n    const elseIfBranch = elseIfBranches[branchIndex];\n    const elseCondition = elseIfBranch?.action || '';\n    const { left, operator, right } = this.parseCondition(elseCondition);\n    \n    const form = this.fb.group({\n      conditionLeft: [left],\n      conditionOperator: [operator],\n      conditionRight: [right],\n    });\n    \n    const templateVariablesForm = this.fb.group({});\n    \n    return {\n      id: `else-if-${Date.now()}-${Math.random()}`,\n      form,\n      selectedTemplate: null,\n      templateVariables: [],\n      templateVariablesForm,\n      snapshot: { conditionLeft: left, conditionOperator: operator, conditionRight: right }\n    };\n  }\n\n  private buildOperatorSelectConfig(): void {\n    const options: SelectOption[] = [\n      { id: 'is', value: 'is', name: 'IS', label: 'IS' },\n      { id: 'is not', value: 'is not', name: 'IS NOT', label: 'IS NOT' },\n      { id: 'contains', value: 'contains', name: 'CONTAINS', label: 'CONTAINS' },\n      { id: 'equals', value: 'equals', name: 'EQUALS', label: 'EQUALS' },\n      { id: 'starts with', value: 'starts with', name: 'STARTS WITH', label: 'STARTS WITH' },\n      { id: 'ends with', value: 'ends with', name: 'ENDS WITH', label: 'ENDS WITH' },\n    ];\n    this.operatorSelectConfig = {\n      key: 'conditionOperator',\n      placeholder: 'Operator',\n      searchable: false,\n      options,\n    };\n  }\n\n  /** Update condition left select config with filtered natural text actions (IF_CONDITION only) */\n  private updateConditionLeftSelectConfig(): void {\n    // Filter natural text actions to only include those with stepActionType === \"IF_CONDITION\"\n    const filteredOptions = (this.naturalTextActionsOptions || []).filter((option: any) => {\n      return option.stepActionType === 'IF_CONDITION';\n    });\n\n    this.conditionLeftSelectConfig = {\n      key: 'conditionLeft',\n      placeholder: 'Select Condition',\n      searchable: true,\n      options: filteredOptions,\n    };\n  }\n\n  /** Options for the condition left autocomplete (IF_CONDITION natural text actions) */\n  get conditionLeftAutocompleteOptions(): CqaAutocompleteOption[] {\n    const opts = this.conditionLeftSelectConfig?.options ?? [];\n    return opts.map((option: any) => {\n      // Use naturalText exactly as received from API, fallback to name/value/id\n      const naturalText = option.naturalText ?? option.name ?? option.value ?? String(option.id ?? '');\n      return {\n        value: naturalText,\n        label: naturalText,\n        // Store the full template object (NaturalTextActions) for template variables processing\n        // Use option.template if available (full NaturalTextActions), otherwise use option itself\n        template: option.template || option,\n      } as CqaAutocompleteOption & { template?: any };\n    });\n  }\n\n  /**\n   * Display value for IF/ELSE IF condition autocomplete.\n   * - For IF (step row / IF branch edit), show naturalText from option matching naturalTextActionId when form is empty.\n   * - For ELSE IF branch edit, always use the form value (so clearing leaves the field empty instead of reverting to IF).\n   */\n  get conditionLeftDisplayValue(): string {\n    const configWithId = this.config as any;\n    const formValue = this.editForm?.get('conditionLeft')?.value ?? '';\n    const isFormHtml = formValue && (String(formValue).includes('<') || String(formValue).includes('>'));\n\n    // When editing an ELSE IF branch, don't fall back to IF's naturalText; just show the current form value.\n    const isEditingElseIfBranch =\n      this.editContext === 'branchRow' &&\n      typeof this.editingBranchIndex === 'number' &&\n      this.editingBranchIndex > 0;\n    if (isEditingElseIfBranch) {\n      if (isFormHtml) return '';\n      return formValue;\n    }\n\n    if (configWithId?.naturalTextActionId != null && this.naturalTextActionsOptions?.length) {\n      const matchingOption = this.naturalTextActionsOptions.find(\n        (option: any) => String(option.id) === String(configWithId.naturalTextActionId)\n      );\n      if (matchingOption) {\n        const naturalText = matchingOption.naturalText ?? matchingOption.name ?? matchingOption.value ?? '';\n        if (naturalText) {\n          const naturalTextStr = String(naturalText);\n          if (!formValue || formValue === naturalTextStr || isFormHtml) return naturalTextStr;\n          return formValue;\n        }\n      }\n    }\n    if (isFormHtml) return '';\n    return formValue;\n  }\n\n  onConditionLeftSelect(option: CqaAutocompleteOption & { template?: any }): void {\n    this.editForm?.get('conditionLeft')?.setValue(option.value);\n    \n    // Get template from option - option.template should contain the full NaturalTextActions object\n    const matchingTemplate = option.template;\n    \n    // If template not in option, try to find from naturalTextActionsOptions by matching naturalText\n    let fullTemplate = matchingTemplate;\n    if (!fullTemplate || !fullTemplate.variables) {\n      const optVal = (option.value ?? '').toString().trim();\n      const matchingOption = this.naturalTextActionsOptions.find(\n        (opt: any) => {\n          const n = (opt.naturalText ?? opt.name ?? opt.value ?? '').toString().trim();\n          return n === optVal || (opt.template && (opt.template as any).naturalText?.toString().trim() === optVal);\n        }\n      );\n      // Use template property from option if available, otherwise use the option itself\n      fullTemplate = matchingOption?.template || matchingOption;\n    }\n    \n    if (fullTemplate && fullTemplate.variables) {\n      // Store the full template for reference\n      this.selectedTemplate = fullTemplate;\n      \n      // Get template variables using the provided function\n      // Pass the full NaturalTextActions object which has the variables property\n      const variables = this.setConditionTemplateVariables(fullTemplate);\n      console.log('Template variables loaded:', variables, 'from template:', fullTemplate);\n      \n      this.templateVariables = variables || [];\n      // Build form for template variables\n      this.buildTemplateVariablesForm();\n      // Trigger change detection to update the template\n      this.cdr.detectChanges();\n    } else {\n      console.log('No matching template found or template has no variables', {\n        fullTemplate,\n        hasVariables: fullTemplate?.variables,\n        optionValue: option.value,\n        optionTemplate: option.template\n      });\n      this.selectedTemplate = null;\n      this.templateVariables = [];\n      if (!this.templateVariablesForm) {\n        this.templateVariablesForm = this.fb.group({});\n      }\n      // Trigger change detection to update the template\n      this.cdr.detectChanges();\n    }\n    // Auto-open Edit In depth when user selects a condition from the autocomplete.\n    // Pass the selected template so the modal shows the newly selected template, not the old step template.\n    // Prefer selectedTemplate (validated), then fullTemplate, then option.template (from autocomplete)\n    const templateToPass = this.selectedTemplate || fullTemplate || option.template;\n    setTimeout(() => this.onEditInDepth(templateToPass), 100);\n  }\n  \n  private buildTemplateVariablesForm(): void {\n    if (!this.templateVariablesForm) {\n      this.templateVariablesForm = this.fb.group({});\n    }\n    \n    // Clear existing form controls\n    Object.keys(this.templateVariablesForm.controls).forEach(key => {\n      this.templateVariablesForm.removeControl(key);\n    });\n    \n    // Get existing template variables data from config if available\n    const configWithData = this.config as any;\n    const existingData = configWithData.templateVariablesData || {};\n    \n    // Add form controls for each variable\n    this.templateVariables.forEach(variable => {\n      // Try to get value from existing data first, then from variable default\n      let defaultValue: any;\n      if (existingData.hasOwnProperty(variable.name)) {\n        defaultValue = existingData[variable.name];\n      } else {\n        defaultValue = variable.type === 'boolean' \n          ? (variable.value === true || variable.value === 'true' || variable.value === 1)\n          : (variable.value || '');\n      }\n      \n      // Convert boolean string to boolean\n      if (variable.type === 'boolean' && typeof defaultValue === 'string') {\n        defaultValue = defaultValue === 'true' || defaultValue === '1';\n      }\n      \n      this.templateVariablesForm.addControl(variable.name, new FormControl(defaultValue));\n    });\n  }\n\n  onElseConditionLeftSelect(option: CqaAutocompleteOption & { template?: any }, branchId: string): void {\n    const branch = this.elseIfBranches.find(b => b.id === branchId);\n    if (!branch) return;\n    \n    branch.form?.get('conditionLeft')?.setValue(option.value);\n    \n    // Get template from option - option.template should contain the full NaturalTextActions object\n    const matchingTemplate = option.template;\n    \n    // If template not in option, try to find from naturalTextActionsOptions by matching naturalText\n    let fullTemplate = matchingTemplate;\n    if (!fullTemplate || !fullTemplate.variables) {\n      const matchingOption = this.naturalTextActionsOptions.find(\n        (opt: any) => opt.naturalText === option.value || opt.name === option.value || opt.value === option.value\n      );\n      // Use template property from option if available, otherwise use the option itself\n      fullTemplate = matchingOption?.template || matchingOption;\n    }\n    \n    if (fullTemplate && fullTemplate.variables) {\n      // Store the full template for reference\n      branch.selectedTemplate = fullTemplate;\n      // Get template variables using the provided function\n      branch.templateVariables = this.setConditionTemplateVariables(fullTemplate);\n      // Build form for template variables\n      this.buildElseTemplateVariablesForm(branch);\n      // Trigger change detection to update the template\n      this.cdr.detectChanges();\n    } else {\n      branch.selectedTemplate = null;\n      branch.templateVariables = [];\n      if (!branch.templateVariablesForm) {\n        branch.templateVariablesForm = this.fb.group({});\n      }\n      // Trigger change detection to update the template\n      this.cdr.detectChanges();\n    }\n    // Auto-open Edit In depth when user selects a condition from the ELSE IF autocomplete.\n    // For existing branch: pass branch and branchIndex so modal shows \"Edit Step N\".\n    // For new branch (id starts with \"else-if-\" = temp UI id): pass isCreateMode so modal shows \"Create Step\" and calls create API on save.\n    const configBranch = this.getBranchById(branchId);\n    const branchIndex = this.getBranchIndexById(branchId);\n    const isNewBranch = typeof branchId === 'string' && branchId.startsWith('else-if-');\n    setTimeout(() => this.onEditInDepth(fullTemplate, configBranch ?? undefined, branchIndex >= 0 ? branchIndex : undefined, isNewBranch, branch), 100);\n  }\n  \n  private buildElseTemplateVariablesForm(branch: {\n    id: string;\n    form: FormGroup;\n    selectedTemplate: any;\n    templateVariables: any[];\n    templateVariablesForm: FormGroup;\n    snapshot: { conditionLeft?: string; conditionOperator?: string; conditionRight?: string };\n  }): void {\n    if (!branch.templateVariablesForm) {\n      branch.templateVariablesForm = this.fb.group({});\n    }\n    \n    // Clear existing form controls\n    Object.keys(branch.templateVariablesForm.controls).forEach(key => {\n      branch.templateVariablesForm.removeControl(key);\n    });\n    \n    // Get existing template variables data from config if available (for ELSE IF branch)\n    const configWithData = this.config as any;\n    const existingData = configWithData.elseTemplateVariablesData || {};\n    \n    // Add form controls for each variable\n    branch.templateVariables.forEach(variable => {\n      // Try to get value from existing data first, then from variable default\n      let defaultValue: any;\n      if (existingData.hasOwnProperty(variable.name)) {\n        defaultValue = existingData[variable.name];\n      } else {\n        defaultValue = variable.type === 'boolean' \n          ? (variable.value === true || variable.value === 'true' || variable.value === 1)\n          : (variable.value || '');\n      }\n      \n      // Convert boolean string to boolean\n      if (variable.type === 'boolean' && typeof defaultValue === 'string') {\n        defaultValue = defaultValue === 'true' || defaultValue === '1';\n      }\n      \n      branch.templateVariablesForm.addControl(variable.name, new FormControl(defaultValue));\n    });\n  }\n\n  onAddElse(): void {\n    // Add a new ELSE IF branch (UI row only; APIs are called when user clicks Apply)\n    const newBranch = this.buildElseIfBranch();\n    this.elseIfBranches.push(newBranch);\n  }\n\n  onAddElseBranch(): void {\n    // Emit so parent can call POST test_steps with conditionType CONDITION_ELSE\n    if (this.config) {\n      this.addElse.emit({ conditionStepConfig: this.config });\n    }\n  }\n\n  onRemoveElse(branchId: string): void {\n    // Remove the ELSE IF branch with the given ID\n    const index = this.elseIfBranches.findIndex(b => b.id === branchId);\n    if (index !== -1) {\n      this.elseIfBranches.splice(index, 1);\n    }\n  }\n\n  /** Strip HTML tags from a string to get plain text */\n  private stripHtmlTags(html: string): string {\n    if (!html || typeof html !== 'string') return html;\n    // Create a temporary div element to parse HTML and extract text\n    const div = document.createElement('div');\n    div.innerHTML = html;\n    return div.textContent || div.innerText || html.replace(/<[^>]*>/g, '');\n  }\n\n  /** Parse condition string into left, operator, right (e.g. \"Usertype is Premium\")\n   * Strips HTML tags before parsing to handle formatted conditions */\n  private parseCondition(c: string): { left: string; operator: string; right: string } {\n    if (!c || typeof c !== 'string') {\n      return { left: '', operator: 'is', right: '' };\n    }\n    // Strip HTML tags before parsing to avoid issues with formatted conditions\n    const plainText = this.stripHtmlTags(c).trim();\n    const operators = [' is not ', ' is ', ' contains ', ' equals ', ' starts with ', ' ends with '];\n    for (const op of operators) {\n      const i = plainText.toLowerCase().indexOf(op);\n      if (i !== -1) {\n        return {\n          left: plainText.slice(0, i).trim(),\n          operator: op.trim(),\n          right: plainText.slice(i + op.length).trim(),\n        };\n      }\n    }\n    return { left: plainText, operator: 'is', right: '' };\n  }\n\n  /** Build condition string from form values */\n  private buildConditionFromForm(): string {\n    let left = this.editForm.get('conditionLeft')?.value ?? '';\n    const op = this.editForm.get('conditionOperator')?.value ?? 'is';\n    const right = this.editForm.get('conditionRight')?.value ?? '';\n    \n    // If left is an ID (number), find the naturalText from options\n    if (left && this.naturalTextActionsOptions && this.naturalTextActionsOptions.length > 0) {\n      const leftValue = String(left);\n      // Check if it's a number (ID) or if we need to find the naturalText\n      const isNumericId = !isNaN(Number(leftValue)) && leftValue.trim() !== '';\n      \n      if (isNumericId) {\n        // Find the option by ID and use its naturalText\n        const selectedAction = this.naturalTextActionsOptions.find(\n          (option: any) => String(option.id) === leftValue\n        );\n        if (selectedAction && selectedAction.naturalText) {\n          left = String(selectedAction.naturalText);\n        }\n      } else {\n        // Check if it's already a naturalText or needs to be found\n        const selectedAction = this.naturalTextActionsOptions.find(\n          (option: any) => option.naturalText === left || option.name === left || option.value === left\n        );\n        if (selectedAction && selectedAction.naturalText) {\n          left = String(selectedAction.naturalText);\n        }\n      }\n    }\n    \n    return [left, op, right].filter(Boolean).join(' ');\n  }\n\n  onEditFormFieldChange(controlName: string, value: string): void {\n    this.editForm.get(controlName)?.setValue(value);\n  }\n\n  /** Count and summarize condition branches using their display step numbers.\n   * Example: IF + 2x ELSE IF + ELSE → \"Steps 6-9 (4 steps)\". */\n  getStepsSummary(): string {\n    const branchCount = this.branches?.length ?? 0;\n    if (branchCount === 0) {\n      return '0 steps';\n    }\n\n    const first = this.getBranchDisplayNumber(0);\n    const last = this.getBranchDisplayNumber(branchCount - 1);\n\n    if (branchCount === 1) {\n      return `Steps ${first} (1 step)`;\n    }\n    return `Steps ${first}-${last} (${branchCount} steps)`;\n  }\n\n  /** Branch type badges for step row: IF, ELSE IF (with count if multiple), ELSE */\n  getBranchTypeBadges(): { label: string; count?: number; type: 'if' | 'else-if' | 'else'; badgeClass: string }[] {\n    const badges: { label: string; count?: number; type: 'if' | 'else-if' | 'else'; badgeClass: string }[] = [];\n    const elseIfCount = this.branches?.filter(b => b.type === 'else-if').length ?? 0;\n    const hasElse = this.hasElseBranch;\n\n    badges.push({ label: 'IF', type: 'if', badgeClass: 'cqa-bg-[#0DBD7D1A] cqa-text-[#0D542B] cqa-border cqa-border-solid cqa-border-[#0DBD7D]' });\n    if (elseIfCount > 0) {\n      badges.push({\n        label: 'ELSE IF',\n        count: elseIfCount > 1 ? elseIfCount : undefined,\n        type: 'else-if',\n        badgeClass: 'cqa-bg-yellow-50 cqa-text-yellow-700 cqa-border cqa-border-solid cqa-border-yellow-200'\n      });\n    }\n    if (hasElse) {\n      badges.push({ label: 'ELSE', type: 'else', badgeClass: 'cqa-bg-red-50 cqa-text-red-700 cqa-border cqa-border-solid cqa-border-red-200' });\n    }\n    return badges;\n  }\n\n  /** Condition text as plain text (strips HTML), truncated with \"...\" if long */\n  getConditionPlainText(maxLength: number = 60): string {\n    if (!this.condition || typeof this.condition !== 'string') return '';\n    const plain = this.condition.replace(/<[^>]*>/g, '').trim();\n    if (plain.length <= maxLength) return plain;\n    let truncated = plain.slice(0, maxLength);\n    // Trim trailing punctuation to avoid \"....\" when text ends with \".\"\n    truncated = truncated.replace(/[.,;:!?]+$/, '');\n    return truncated + '...';\n  }\n\n  /** Event key-value pairs for display, excluding customEvent */\n  getEventDetailsForDisplay(): { key: string; value: string }[] {\n    const event = this.config?.event;\n    if (!event || typeof event !== 'object') return [];\n    return Object.entries(event)\n      .filter(([key]) => key !== 'customEvent')\n      .map(([key, value]) => ({\n        key,\n        value: value != null ? String(value) : ''\n      }));\n  }\n\n  /** Event key-value pairs for a branch (e.g. selector, element) - for IF uses config.event, for ELSE IF/ELSE uses branch.event */\n  getBranchEventDetailsForDisplay(branch: ConditionBranch): { key: string; value: string }[] {\n    const event = (branch as any).event ?? (branch.type === 'if' ? this.config?.event : undefined);\n    if (!event || typeof event !== 'object') return [];\n    return Object.entries(event)\n      .filter(([key]) => key !== 'customEvent')\n      .map(([key, value]) => ({\n        key,\n        value: value != null ? String(value) : ''\n      }));\n  }\n\n  onToggleExpanded(): void {\n    this.expanded = !this.expanded;\n    this.toggleExpanded.emit({config:this.config, expanded:this.expanded});\n  }\n\n  onConditionChange(value: string): void {\n    this.condition = value;\n    this.conditionChange.emit(value);\n  }\n\n  onBranchStepChange(branch: ConditionBranch, step: TestCaseStepConfig, stepIndex: number): void {\n    this.branchStepChange.emit({ branch, step, stepIndex });\n  }\n\n  /** Re-emit openExternal from nested step group so redirect works for step groups inside condition branches. */\n  onNestedOpenExternal(payload: { step: TestCaseStepConfig }): void {\n    if (payload?.step) {\n      this.openExternal.emit(payload);\n    }\n  }\n\n  onNestedToggleExpanded(event: boolean | {config: TestCaseStepConfig, expanded: boolean}, branch: ConditionBranch, step: TestCaseStepConfig, index: number): void {\n    // Handle both boolean and object formats\n    if (typeof event === 'object' && event !== null && 'expanded' in event) {\n      // Object format from step-group: {config, expanded}\n      (step as any).expanded = event.expanded;\n      // Check if the event's config is a step-group (not the current step)\n      // This ensures nested step-group events bubble up correctly\n      if (this.isStepGroup(event.config)) {\n        // Re-emit the toggleExpanded event with the object format, preserving the original config\n        // Cast to satisfy TypeScript - the renderer accepts TestCaseStepConfig which includes StepGroupConfig\n        this.toggleExpanded.emit({config: event.config as any as ConditionStepConfig, expanded: event.expanded});\n      }\n    } else {\n      // Boolean format from other step types\n      (step as any).expanded = event as boolean;\n    }\n    this.onBranchStepChange(branch, step, index);\n  }\n\n  onAddStep(branch: ConditionBranch): void {\n    this.addStep.emit({ branch });\n  }\n\n  /** Handle addStepForLoop event from nested loop-step (empty state plus button). */\n  onAddStepForLoop(event: { loopStepConfig: LoopStepConfig }, branch: ConditionBranch): void {\n    // Re-emit addStepForLoop so it bubbles up to the portal, which will handle creating the step\n    // with the correct parentId (loop step id) and branch context\n    this.addStepForLoop.emit(event);\n  }\n\n  onDeleteStep(branch: ConditionBranch, stepIndex: number): void {\n    this.deleteStep.emit({ branch, stepIndex });\n  }\n\n  /** Re-emit edit from nested step in a branch so the portal can open edit modal (same as root level). */\n  onNestedEdit(event: { step: TestCaseStepConfig; index: number }): void {\n    if (event?.step != null) this.edit.emit(event as any);\n  }\n\n  /** Re-emit duplicate from nested step in a branch so the portal can duplicate (same as root level). */\n  onNestedDuplicate(event: any, step: TestCaseStepConfig): void {\n    this.duplicate.emit((event && event.step != null) ? event : { step } as any);\n  }\n\n  onAddBranch(): void {\n    this.addBranch.emit();\n  }\n\n  onDeleteBranch(branch: ConditionBranch): void {\n    const branchIndex = this.branches?.indexOf(branch) ?? 0;\n    const displayNumber = this.getBranchDisplayNumber(branchIndex);\n    this.deleteBranch.emit({ branch, stepNumber: displayNumber });\n  }\n\n  onNestedConditionAddBranch(nestedStep: ConditionStepConfig): void {\n    // Add a new branch to the nested condition step\n    if (!nestedStep.branches) {\n      nestedStep.branches = [];\n    }\n    const newBranch: ConditionBranch = {\n      type: nestedStep.branches.length === 0 ? 'if' : 'else',\n      label: nestedStep.branches.length === 0 ? 'IF TRUE' : 'ELSE',\n      stepType: StepTypes.CONDITION_IF,\n      nestedSteps: []\n    };\n    nestedStep.branches.push(newBranch);\n  }\n\n  onNestedConditionDeleteBranch(nestedStep: ConditionStepConfig, payload: ConditionBranch | { branch: ConditionBranch; stepNumber?: number | string }): void {\n    // Re-emit deleteBranch so step-list can open delete modal and call API.\n    const branch = payload && typeof payload === 'object' && 'branch' in payload ? (payload as { branch: ConditionBranch }).branch : (payload as ConditionBranch);\n    const branchIndex = this.branches?.indexOf(branch) ?? 0;\n    const displayNumber = this.getBranchDisplayNumber(branchIndex);\n    const toEmit: { branch: ConditionBranch; stepNumber?: number | string } =\n      payload && typeof payload === 'object' && 'branch' in payload\n        ? { branch: (payload as { branch: ConditionBranch }).branch, stepNumber: (payload as any).stepNumber ?? displayNumber }\n        : { branch: payload as ConditionBranch, stepNumber: displayNumber };\n    this.deleteBranch.emit(toEmit);\n  }\n\n  isNormalStep(step: TestCaseStepConfig): step is NormalStepConfig {\n    return 'eventType' in step;\n  }\n\n  isLoopStep(step: TestCaseStepConfig): step is LoopStepConfig {\n    return 'loopType' in step;\n  }\n\n  isConditionStep(step: TestCaseStepConfig): step is ConditionStepConfig {\n    return 'condition' in step && 'branches' in step;\n  }\n\n  isStepGroup(step: TestCaseStepConfig): step is StepGroupConfig {\n    return 'groupName' in step;\n  }\n\n  getBranchLabel(branch: ConditionBranch): string {\n    return branch.label || (branch.type === 'if' ? 'IF TRUE' : branch.type === 'else-if' ? 'ELSE IF' : 'ELSE');\n  }\n\n  /** Condition text for branch header display: IF uses main condition, ELSE IF/ELSE use branch.action */\n  getBranchConditionDisplay(branch: ConditionBranch): string {\n    if (branch.type === 'if') {\n      return this.condition ?? '';\n    }\n    return branch.action ?? '';\n  }\n\n  /** Start marker label for each branch: START IF, START ELSE IF, or START ELSE */\n  getStartBranchLabel(branch: ConditionBranch): string {\n    return branch.type === 'if' ? 'START IF' : branch.type === 'else-if' ? 'START ELSE IF' : 'START ELSE';\n  }\n\n  /** End marker label for each branch: END IF, END ELSE IF, or END ELSE */\n  getEndBranchLabel(branch: ConditionBranch): string {\n    return branch.type === 'if' ? 'END IF' : branch.type === 'else-if' ? 'END ELSE IF' : 'END ELSE';\n  }\n\n  /** Branch display number: full hierarchical number. IF = stepNumber (e.g. 2.1.50), ELSE IF = 2.1.51, ELSE = 2.1.52. */\n  getBranchDisplayNumber(branchIndex: number): number | string {\n    if (branchIndex === 0) {\n      return this.stepNumber;\n    }\n    const parts = String(this.stepNumber).split('.');\n    const lastNum = parseInt(parts[parts.length - 1], 10) || 0;\n    parts[parts.length - 1] = String(lastNum + branchIndex);\n    return parts.join('.');\n  }\n\n  /** Find branch in branches by id (for elseIfBranches which use same id). */\n  getBranchById(branchId?: string | number): ConditionBranch | undefined {\n    if (branchId == null) return undefined;\n    return this.branches?.find(b => b.id != null && String(b.id) === String(branchId));\n  }\n\n  /** Get branch index in branches by id. */\n  getBranchIndexById(branchId?: string | number): number {\n    const branch = this.getBranchById(branchId);\n    return branch != null ? (this.branches?.indexOf(branch) ?? -1) : -1;\n  }\n\n  getBranchColorClass(branch: ConditionBranch): string {\n    if (branch.type === 'if') {\n      return 'cqa-bg-[#0DBD7D1A]';\n    } else if (branch.type === 'else-if') {\n      return 'cqa-bg-yellow-50 cqa-border-yellow-200';\n    } else {\n      return 'cqa-bg-red-50 cqa-border-red-200';\n    }\n  }\n\n  getBranchTextColor(branch: ConditionBranch): string {\n    if (branch.type === 'if') {\n      return 'cqa-text-[#0D542B]';\n    } else if (branch.type === 'else-if') {\n      return 'cqa-text-yellow-700';\n    } else {\n      return 'cqa-text-red-700';\n    }\n  }\n\n  /** Created date for branch header display: branch-specific or fallback to config. */\n  getBranchCreatedDate(branch: ConditionBranch): number | undefined {\n    return branch.createdDate ?? this.config?.createdDate;\n  }\n\n  /** True when condition already has an ELSE branch (disables Add ELSE IF / Add ELSE). */\n  get hasElseBranch(): boolean {\n    return this.branches?.some(b => b.type === 'else') ?? false;\n  }\n\n  onOpenExternal(): void {\n    // Not used in condition step, but needed for recursive step groups\n  }\n\n  /** Shared init for edit mode; then call onEditFromStepRow or onEditFromBranchRow to set context. */\n  private initEditForm(branch?: ConditionBranch | null): void {\n    this.editSnapshot = {\n      conditionLeft: this.editForm?.get('conditionLeft')?.value,\n      conditionOperator: this.editForm?.get('conditionOperator')?.value,\n      conditionRight: this.editForm?.get('conditionRight')?.value,\n    };\n\n    let conditionLeftValue = '';\n    const configWithId = this.config as any;\n    const editingElseIf = !!branch && branch.type === 'else-if';\n    const hasTemplate =\n      !editingElseIf &&\n      configWithId.naturalTextActionId &&\n      this.naturalTextActionsOptions &&\n      this.naturalTextActionsOptions.length > 0;\n\n    if (hasTemplate) {\n      const matchingAction = this.naturalTextActionsOptions.find(\n        (option: any) => String(option.id) === String(configWithId.naturalTextActionId)\n      );\n      if (matchingAction) {\n        // For template-based conditions, use the full naturalText (it's a complete sentence)\n        conditionLeftValue = matchingAction.naturalText ?? matchingAction.name ?? matchingAction.value ?? '';\n      }\n    }\n\n    if (!conditionLeftValue) {\n      // No template or editing ELSE IF: parse from the appropriate condition string\n      const sourceText =\n        editingElseIf && branch?.action ? String(branch.action) : (this.condition ?? '');\n      const { left } = this.parseCondition(sourceText);\n      conditionLeftValue = left;\n    }\n\n    // Only parse operator and right if we don't have a template (templates are complete sentences)\n    if (!hasTemplate) {\n      const sourceText =\n        editingElseIf && branch?.action ? String(branch.action) : (this.condition ?? '');\n      const { operator, right } = this.parseCondition(sourceText);\n      this.editForm?.get('conditionOperator')?.setValue(operator);\n      this.editForm?.get('conditionRight')?.setValue(right);\n    } else {\n      // For templates, clear operator and right (template naturalText is the full condition)\n      this.editForm?.get('conditionOperator')?.setValue('is');\n      this.editForm?.get('conditionRight')?.setValue('');\n    }\n    \n    this.editForm?.get('conditionLeft')?.setValue(conditionLeftValue);\n    this.elseIfBranches = [];\n  }\n\n  /** Edit from step row: edit UI appears in the step row only (first branch stays read-only). */\n  onEditFromStepRow(): void {\n    this.initEditForm();\n    this.editContext = 'stepRow';\n  }\n\n  /** Edit from branch row: edit UI appears in that branch row (IF TRUE or ELSE IF). */\n  onEditFromBranchRow(branchIndex: number = 0): void {\n    const branch = this.branches && this.branches.length > branchIndex\n      ? this.branches[branchIndex]\n      : undefined;\n    this.initEditForm(branch);\n    this.editingBranchIndex = branchIndex;\n    this.editContext = 'branchRow';\n  }\n\n  /** @deprecated Use onEditFromStepRow or onEditFromBranchRow. Kept for compatibility. */\n  onEdit(): void {\n    this.initEditForm();\n    this.editContext = 'branchRow';\n  }\n\n  onEditCancel(): void {\n    this.editForm?.get('conditionLeft')?.setValue(this.editSnapshot.conditionLeft ?? '');\n    this.editForm?.get('conditionOperator')?.setValue(this.editSnapshot.conditionOperator ?? 'is');\n    this.editForm?.get('conditionRight')?.setValue(this.editSnapshot.conditionRight ?? '');\n    \n    // Reset all ELSE IF branches to their snapshots\n    this.elseIfBranches.forEach(branch => {\n      branch.form?.get('conditionLeft')?.setValue(branch.snapshot.conditionLeft ?? '');\n      branch.form?.get('conditionOperator')?.setValue(branch.snapshot.conditionOperator ?? 'is');\n      branch.form?.get('conditionRight')?.setValue(branch.snapshot.conditionRight ?? '');\n    });\n    \n    // Clear all ELSE IF branches\n    this.elseIfBranches = [];\n\n    this.editContext = null;\n    this.editingBranchIndex = 0;\n  }\n\n  /**\n   * Build payload for one ELSE IF branch (action, naturalTextActionId, templateVariablesData, testDataList)\n   * so the parent can create the step via POST then PUT when Apply is clicked.\n   */\n  private buildElseIfBranchPayload(branch: {\n    form: FormGroup;\n    selectedTemplate: any;\n    templateVariables: any[];\n    templateVariablesForm: FormGroup;\n  }): { action: string; naturalTextActionId?: number; templateVariablesData?: any; testDataList?: Array<{ testData: string; testDataType: string }> } {\n    const conditionLeft = branch.form?.get('conditionLeft')?.value ?? '';\n    const conditionOperator = branch.form?.get('conditionOperator')?.value ?? 'is';\n    const conditionRight = branch.form?.get('conditionRight')?.value ?? '';\n    let naturalTextActionId: number | undefined;\n    let naturalTextValue: string = conditionLeft;\n    if (conditionLeft && this.naturalTextActionsOptions && this.naturalTextActionsOptions.length > 0) {\n      const leftValue = String(conditionLeft);\n      const isNumericId = !isNaN(Number(leftValue)) && leftValue.trim() !== '';\n      const selectedAction: any = isNumericId\n        ? this.naturalTextActionsOptions.find((opt: any) => String(opt.id) === leftValue)\n        : this.naturalTextActionsOptions.find(\n            (opt: any) => opt.naturalText === conditionLeft || opt.name === conditionLeft || opt.value === conditionLeft\n          );\n      if (selectedAction) {\n        naturalTextActionId = selectedAction.id;\n        naturalTextValue = selectedAction.naturalText || selectedAction.name || selectedAction.value || conditionLeft;\n      }\n    }\n    const templateVariablesData: any = {};\n    const testDataList: Array<{ testData: string; testDataType: string }> = [];\n    if (branch.templateVariablesForm && branch.templateVariables && branch.templateVariables.length > 0) {\n      branch.templateVariables.forEach((variable: any) => {\n        const value = branch.templateVariablesForm.get(variable.name)?.value;\n        if (value !== undefined && value !== null && value !== '') {\n          templateVariablesData[variable.name] = value;\n          testDataList.push({ testData: String(value), testDataType: 'raw' });\n        }\n      });\n    }\n    const action = [naturalTextValue, conditionOperator, conditionRight].filter(Boolean).join(' ');\n    return {\n      action: action || (branch.selectedTemplate?.naturalText ?? ''),\n      ...(naturalTextActionId !== undefined && { naturalTextActionId }),\n      ...(Object.keys(templateVariablesData).length > 0 && { templateVariablesData }),\n      ...(testDataList.length > 0 && { testDataList }),\n    };\n  }\n\n  onEditApply(): void {\n    const formValues = this.editForm.value;\n    const conditionLeft = formValues.conditionLeft ?? '';\n    const conditionOperator = formValues.conditionOperator ?? 'is';\n    const conditionRight = formValues.conditionRight ?? '';\n\n    // Find the selected natural text action and get naturalText (not ID)\n    let naturalTextActionId: number | undefined;\n    let naturalTextValue: string = conditionLeft; // Default to conditionLeft\n    \n    if (conditionLeft && this.naturalTextActionsOptions && this.naturalTextActionsOptions.length > 0) {\n      const leftValue = String(conditionLeft);\n      const isNumericId = !isNaN(Number(leftValue)) && leftValue.trim() !== '';\n      \n      let selectedAction: any;\n      if (isNumericId) {\n        // Find by ID and get naturalText\n        selectedAction = this.naturalTextActionsOptions.find(\n          (option: any) => String(option.id) === leftValue\n        );\n      } else {\n        // Find by naturalText, name, or value\n        selectedAction = this.naturalTextActionsOptions.find(\n          (option: any) => option.naturalText === conditionLeft || option.name === conditionLeft || option.value === conditionLeft\n        );\n      }\n      \n      if (selectedAction) {\n        naturalTextActionId = selectedAction.id;\n        // Use naturalText if available, otherwise fall back to name or value\n        naturalTextValue = selectedAction.naturalText || selectedAction.name || selectedAction.value || conditionLeft;\n      }\n    }\n    \n    // Collect template variables values for event object\n    const templateVariablesData: any = {};\n    // Build testDataList array in the order of template variables\n    const testDataList: Array<{ testData: string; testDataType: string }> = [];\n    \n    if (this.templateVariablesForm && this.templateVariables.length > 0) {\n      this.templateVariables.forEach(variable => {\n        const value = this.templateVariablesForm.get(variable.name)?.value;\n        if (value !== undefined && value !== null && value !== '') {\n          // Add to event object (e.g., source_value, target_value)\n          templateVariablesData[variable.name] = value;\n          // Add to testDataList array (order matters - maintain template variable order)\n          testDataList.push({\n            testData: String(value),\n            testDataType: 'raw'\n          });\n        }\n      });\n    }\n    \n    // Build condition string\n    // If we have a naturalTextActionId (template), use the full naturalTextValue as-is (it's already a complete sentence)\n    // Otherwise, build from parts: conditionLeft + operator + conditionRight\n    let rawCondition: string;\n    if (naturalTextActionId !== undefined) {\n      // Template-based condition: naturalTextValue is the full template (e.g., \"Check the text #{label} is present on the current page\")\n      rawCondition = naturalTextValue;\n    } else {\n      // Manual condition: build from parts\n      rawCondition = [naturalTextValue, conditionOperator, conditionRight].filter(Boolean).join(' ');\n    }\n\n    const isEditingBranchRow = this.editContext === 'branchRow';\n    const branchForEdit = isEditingBranchRow && this.branches && this.branches.length > this.editingBranchIndex\n      ? this.branches[this.editingBranchIndex]\n      : null;\n    const isEditingElseIfBranch = !!branchForEdit && branchForEdit.type === 'else-if';\n\n    // For display in the header, substitute #{variable} placeholders with HTML badges using templateVariablesData.\n    // This mirrors the renderer behavior so users never see raw #{label} text while editing.\n    // - For IF (step row / IF branch edit), update main condition header.\n    // - For ELSE IF edit, update only that branch's action text; keep IF header unchanged.\n    const formattedForDisplay = this.substituteTemplateVariablesToHtmlForCondition(rawCondition, templateVariablesData);\n    if (isEditingElseIfBranch && branchForEdit) {\n      // Update ELSE IF branch action for immediate UI feedback\n      (branchForEdit as any).action = formattedForDisplay;\n    } else {\n      this.condition = formattedForDisplay;\n    }\n\n    // Build payload for each newly added ELSE IF (so parent can call POST then PUT when Apply is clicked)\n    const newElseIfBranches = this.elseIfBranches.map(b => this.buildElseIfBranchPayload(b));\n    \n    // Update config with new values\n    const updatedConfigBase: ConditionStepConfig & {\n      id?: string;\n      naturalTextActionId?: number;\n      templateVariablesData?: any;\n      testDataList?: Array<{ testData: string; testDataType: string }>;\n      newElseIfBranches?: Array<{ action: string; naturalTextActionId?: number; templateVariablesData?: any; testDataList?: Array<{ testData: string; testDataType: string }> }>;\n      isElseIfBranch?: boolean;\n      parentConditionId?: string;\n    } = {\n      ...this.config,\n      stepType: this.config.stepType || StepTypes.CONDITION_IF, // Ensure stepType is set\n      ...(naturalTextActionId !== undefined && { naturalTextActionId } as any),\n      ...(Object.keys(templateVariablesData).length > 0 && { templateVariablesData } as any),\n      ...(testDataList.length > 0 && { testDataList } as any),\n      ...(newElseIfBranches.length > 0 && { newElseIfBranches } as any),\n    };\n\n    let updatedConfig: typeof updatedConfigBase;\n    if (isEditingElseIfBranch && branchForEdit && branchForEdit.id != null) {\n      // Editing existing ELSE IF branch: target that branch's step ID and send raw condition so backend updates the branch only.\n      updatedConfig = {\n        ...updatedConfigBase,\n        id: String(branchForEdit.id),\n        condition: rawCondition,\n        isElseIfBranch: true,\n        parentConditionId: String(this.config.id),\n      } as any;\n    } else {\n      // IF condition edit (step row or IF branch row): use formatted condition for display\n      updatedConfig = {\n        ...updatedConfigBase,\n        condition: this.condition,\n      } as any;\n    }\n    \n    // Emit individual change event\n    this.conditionChange.emit(this.condition);\n    \n    // Emit step update event with full config (includes newElseIfBranches so parent can create steps on Apply)\n    console.log('Condition-step: Emitting stepUpdate event', updatedConfig);\n    this.stepUpdate.emit(updatedConfig);\n\n    this.editContext = null;\n  }\n\n  /**\n   * Local helper to substitute #{variable} placeholders in the condition text with HTML badge spans.\n   * Mirrors the portal renderer's substituteTemplateVariablesToHtml so inline edit mode never shows raw #{label}.\n   */\n  private substituteTemplateVariablesToHtmlForCondition(\n    text: string,\n    variables: Record<string, unknown> | null | undefined\n  ): string {\n    if (!text || typeof text !== 'string') return text;\n    const data = variables && typeof variables === 'object' ? variables : {};\n    const escape = (v: string) => {\n      const div = document.createElement('div');\n      div.textContent = v;\n      return div.innerHTML;\n    };\n    const elementVars = ['label', 'description', 'element', 'selector', 'ai_task', 'query', 'custom_code'];\n    const attributeVars = ['attribute'];\n\n    return text.replace(/\\#\\{([^}]+)\\}/g, (_, key: string) => {\n      const val = (data as any)[key];\n      const displayVal = val != null && val !== '' ? String(val) : key;\n      const escaped = escape(displayVal);\n      if (elementVars.includes(key)) {\n        return `<span data-key=\"${key}\" data-event-key=\"${key}\" class=\"element\">${escaped}</span>`;\n      }\n      if (attributeVars.includes(key)) {\n        return `<span data-key=\"${key}\" data-event-key=\"${key}\" class=\"attribute\">${escaped}</span>`;\n      }\n      return `<span data-key=\"${key}\" data-event-key=\"${key}\" class=\"test_data\">${escaped}</span>`;\n    });\n  }\n\n  /**\n   * Emit editInDepth. When branch is provided (ELSE IF/ELSE branch row), use branch's nested condition step\n   * and branch display number for correct \"Edit Step N\" title. When isCreateMode (new ELSE IF), modal shows \"Create In depth\" and calls create API on save.\n   */\n  onEditInDepth(templateOverride?: any, branch?: ConditionBranch, branchIndex?: number, isCreateMode?: boolean, elseIfBranch?: any): void {\n    this.moreOptions.emit();\n    let step: TestCaseStepConfig;\n    let index: number | undefined;\n    if (branch != null && branchIndex != null && branchIndex >= 0 && !isCreateMode) {\n      // Branch row (ELSE IF/ELSE) - existing branch: use nested condition step if present, else main config with branch id\n      const nestedCondition = branch.nestedSteps?.[0] as ConditionStepConfig | undefined;\n      step = (nestedCondition && this.isConditionStep(nestedCondition))\n        ? nestedCondition\n        : ({ ...this.config, id: branch.id != null ? String(branch.id) : this.config.id } as TestCaseStepConfig);\n      // Display index: getBranchDisplayNumber(1)=93 -> index 92 for \"Edit Step 93\"\n      const displayNum = this.getBranchDisplayNumber(branchIndex);\n      index = typeof displayNum === 'number' ? displayNum - 1 : (typeof displayNum === 'string' ? parseInt(String(displayNum), 10) - 1 : 0);\n    } else if (isCreateMode) {\n      // Create mode (new ELSE IF branch) - don't set index so modal shows \"Create Step\"\n      step = this.config as TestCaseStepConfig;\n      index = undefined;\n    } else {\n      // Main step row, IF branch\n      index = typeof this.index === 'number'\n        ? this.index\n        : (typeof this.stepNumber === 'number' ? this.stepNumber : (typeof this.stepNumber === 'string' ? parseInt(this.stepNumber, 10) : 0));\n      step = this.config as TestCaseStepConfig;\n    }\n    const payload: { step: TestCaseStepConfig; index?: number; templateOverride?: any; isCreateMode?: boolean; createModeBranchData?: any } = {\n      step,\n      index: index !== undefined ? (isNaN(index) ? 0 : Math.max(0, index)) : undefined,\n    };\n    if (templateOverride) {\n      payload.templateOverride = templateOverride;\n    }\n    if (isCreateMode && elseIfBranch) {\n      payload.isCreateMode = true;\n      // Pass template variables form data for create mode\n      if (elseIfBranch.templateVariablesForm && elseIfBranch.selectedTemplate) {\n        payload.createModeBranchData = {\n          templateVariablesForm: elseIfBranch.templateVariablesForm,\n          selectedTemplate: elseIfBranch.selectedTemplate\n        };\n      }\n    }\n    this.editInDepth.emit(payload);\n  }\n\n  onLink(): void {\n    // Not used in condition step, but needed for recursive step groups\n  }\n\n  onDuplicate(): void {\n    this.duplicate.emit();\n  }\n\n  onDelete(): void {\n    this.delete.emit();\n  }\n\n  onSelectionChange(checked: boolean): void {\n    this.selected = checked;\n    this.selectionChange.emit(checked);\n  }\n\n  onMoreOptions(): void {\n    this.moreOptions.emit();\n  }\n\n  onViewDetails(event?: MouseEvent): void {\n    if (event) {\n      event.preventDefault();\n      event.stopPropagation();\n    }\n    \n    if (!this.config.description || this.config.description.trim() === '') {\n      return;\n    }\n\n    if (event) {\n      this.viewDetails.emit({\n        event,\n        title: 'IF / ELSE Step Details',\n        description: this.config.description,\n      });\n    }\n  }\n  \n  /** Get select config for a template variable */\n  getSelectConfigForVariable(variable: any, branchIdOrIsElse: string | boolean = false): DynamicSelectFieldConfig {\n    const options: SelectOption[] = (variable.options || []).map((opt: string) => ({\n      id: opt,\n      value: opt,\n      name: opt,\n      label: opt\n    }));\n\n    // If branchIdOrIsElse is a string, it's a branch ID; otherwise it's a boolean for backward compatibility\n    let form: FormGroup;\n    if (typeof branchIdOrIsElse === 'string') {\n      const branch = this.elseIfBranches.find(b => b.id === branchIdOrIsElse);\n      form = branch?.templateVariablesForm || this.fb.group({});\n    } else {\n      form = branchIdOrIsElse ? (this.elseIfBranches[0]?.templateVariablesForm || this.fb.group({})) : this.templateVariablesForm;\n    }\n\n    return {\n      key: variable.name,\n      placeholder: `Select ${variable.label}`,\n      multiple: false,\n      searchable: false,\n      options: options,\n      onChange: (value: any) => {\n        if (form && form.get(variable.name)) {\n          form.get(variable.name)?.setValue(value);\n        }\n      }\n    };\n  }\n}\n","<div [class]=\"'cqa-flex cqa-flex-col cqa-border cqa-border-solid cqa-border-[#E5E7EB] ' + (isNested ? ' cqa-pl-[24px]' : '')\" style=\"min-height: 50px\">\n  <!-- Inline Edit Mode: shown in first branch row below when user clicks Edit from branch row (top block hidden) -->\n  <div *ngIf=\"false && isEditing\" class=\"cqa-py-2.5 cqa-px-4 cqa-flex cqa-flex-col cqa-gap-3\" (click)=\"$event.stopPropagation()\" (mousedown)=\"$event.stopPropagation()\" style=\"min-height: 50px\">\n    <!-- First Row: CONDITION tag, autocomplete, IF/ELSE indicators, Edit In depth, Cancel/Apply -->\n    <div class=\"cqa-flex cqa-items-center cqa-gap-3 cqa-justify-between\">\n      <div class=\"cqa-flex cqa-items-center cqa-gap-3 cqa-flex-grow\">\n        <!-- CONDITION Tag (orange) -->\n        <span class=\"cqa-px-1.5 cqa-rounded-md cqa-text-[#EA580C] cqa-text-[10px] cqa-leading-[15px] cqa-font-medium cqa-bg-[#FFEDD5]\">\n          CONDITION\n        </span>\n\n        <!-- First field: left operand (e.g. Usertype) - autocomplete with IF_CONDITION natural text actions -->\n        <cqa-autocomplete\n          *ngIf=\"editForm\"\n          [options]=\"conditionLeftAutocompleteOptions\"\n          [value]=\"conditionLeftDisplayValue\"\n          (valueChange)=\"onEditFormFieldChange('conditionLeft', $event)\"\n          (optionSelect)=\"onConditionLeftSelect($event)\"\n          placeholder=\"Select Condition\"\n          [fullWidth]=\"true\"\n          class=\"cqa-w-full cqa-max-w-[216px]\"></cqa-autocomplete>\n\n        <!-- Second Row: Template Variables Section (shown when template is selected, inline before Edit In depth) -->\n        <div *ngIf=\"selectedTemplate && templateVariables && templateVariables.length > 0\" class=\"cqa-flex cqa-flex-row cqa-flex-wrap cqa-gap-3\">\n          <ng-container *ngFor=\"let variable of templateVariables\">\n            <!-- Boolean variables with mat-slide-toggle -->\n            <ng-container *ngIf=\"variable.type === 'boolean'\">\n              <div class=\"cqa-flex cqa-items-center cqa-gap-2\">\n                <label class=\"cqa-text-[12px] cqa-font-medium cqa-text-gray-700\">\n                  {{ variable.label }}\n                </label>\n                <mat-slide-toggle\n                  [checked]=\"templateVariablesForm.get(variable.name)?.value || variable.value || false\"\n                  (change)=\"templateVariablesForm.get(variable.name)?.setValue($event.checked)\"\n                  color=\"primary\">\n                </mat-slide-toggle>\n              </div>\n            </ng-container>\n            \n            <!-- Non-boolean variables -->\n            <ng-container *ngIf=\"variable.type !== 'boolean' && variable.name !== 'custom_code'\">\n              <!-- Dropdown for select variables -->\n              <ng-container *ngIf=\"variable.name === 'type' || variable.name === 'scrollTo' || variable.options\">\n                <div class=\"cqa-flex cqa-flex-col\" style=\"min-width: 150px;\">\n                  <!-- <label class=\"cqa-text-[12px] cqa-font-medium cqa-text-gray-700 cqa-mb-1\">\n                    {{ variable.label }}\n                  </label> -->\n                  <cqa-dynamic-select \n                    [form]=\"templateVariablesForm\"\n                    [config]=\"getSelectConfigForVariable(variable, false)\">\n                  </cqa-dynamic-select>\n                </div>\n              </ng-container>\n              <!-- Text Input for other variables -->\n              <ng-container *ngIf=\"variable.name !== 'type' && variable.name !== 'scrollTo' && !variable.options\">\n                <div class=\"cqa-flex cqa-flex-col\" style=\"min-width: 150px;\">\n                  <!-- <label class=\"cqa-text-[12px] cqa-font-medium cqa-text-gray-700 cqa-mb-1\">\n                    {{ variable.label }}\n                  </label> -->\n                  <cqa-custom-input\n                    [placeholder]=\"'Enter ' + variable.label\"\n                    [value]=\"templateVariablesForm.get(variable.name)?.value || variable.value || ''\"\n                    [fullWidth]=\"true\"\n                    (valueChange)=\"templateVariablesForm.get(variable.name)?.setValue($event)\">\n                  </cqa-custom-input>\n                </div>\n              </ng-container>\n            </ng-container>\n          </ng-container>\n        </div>\n\n        <!-- IF / ELSE indicators -->\n        <span class=\"cqa-px-2 cqa-py-[2px] cqa-rounded-[4px] cqa-text-[8px] cqa-leading-[12px] cqa-bg-[#DCFCE7] cqa-text-[#008236] cqa-border cqa-border-solid cqa-border-[#B9F8CF] cqa-flex cqa-items-center cqa-gap-1.5\">\n          <svg width=\"8\" height=\"8\" viewBox=\"0 0 8 8\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M6.66634 2L2.99967 5.66667L1.33301 4\" stroke=\"#008236\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/></svg>\n          IF\n        </span>\n        <!-- Add ELSE IF button - disabled when ELSE already exists -->\n        <button\n          type=\"button\"\n          (click)=\"onAddElse()\"\n          [disabled]=\"hasElseBranch\"\n          class=\"cqa-px-2 cqa-py-[2px] cqa-rounded-[4px] cqa-text-[8px] cqa-leading-[12px] cqa-bg-[#fff9e9] cqa-text-[#E65100] cqa-border cqa-border-solid cqa-border-[#feecbd] cqa-flex cqa-items-center cqa-gap-1.5 cqa-transition-colors\"\n          [class.cqa-cursor-pointer]=\"!hasElseBranch\"\n          [class.cqa-cursor-not-allowed]=\"hasElseBranch\"\n          [class.cqa-opacity-60]=\"hasElseBranch\">\n          Add ELSE IF\n        </button>\n        <!-- Add Else button - disabled when ELSE already exists -->\n        <button\n          type=\"button\"\n          (click)=\"onAddElseBranch()\"\n          [disabled]=\"hasElseBranch\"\n          class=\"cqa-px-2 cqa-py-[2px] cqa-rounded-[4px] cqa-text-[8px] cqa-leading-[12px] cqa-bg-[#fff9e9] cqa-text-[#E65100] cqa-border cqa-border-solid cqa-border-[#feecbd] cqa-flex cqa-items-center cqa-gap-1.5 cqa-transition-colors\"\n          [class.cqa-cursor-pointer]=\"!hasElseBranch\"\n          [class.cqa-cursor-not-allowed]=\"hasElseBranch\"\n          [class.cqa-opacity-60]=\"hasElseBranch\">\n          Add ELSE\n        </button>\n\n        <!-- Edit In depth link -->\n        <a href=\"#\" (click)=\"onEditInDepth(); $event.preventDefault()\"\n          class=\"cqa-text-[#3F43EE] cqa-text-[10px] cqa-leading-[15px] cqa-font-medium cqa-flex cqa-items-center cqa-gap-[2px] cqa-no-underline\">\n          Edit In depth\n          <svg width=\"8\" height=\"8\" viewBox=\"0 0 8 8\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M2.03809 6.74329L2.62809 7.33329L5.96142 3.99996L2.62809 0.666626L2.03809 1.25663L4.78142 3.99996L2.03809 6.74329Z\" fill=\"#3F43EE\"/></svg>\n        </a>      \n      </div>\n      <!-- Cancel / Apply buttons - shown on IF row when no ELSE IF branches are present -->\n      <div *ngIf=\"elseIfBranches.length === 0\" class=\"cqa-flex cqa-items-center cqa-gap-2\">\n        <cqa-button variant=\"outlined\" btnSize=\"lg\" [customClass]=\"'cqa-text-[14px] cqa-py-[9px]'\" [text]=\"'Cancel'\" (clicked)=\"onEditCancel()\"></cqa-button>\n        <cqa-button variant=\"filled\" btnSize=\"lg\" [customClass]=\"'cqa-text-[14px] cqa-py-[9px]'\" [text]=\"'Apply'\" (clicked)=\"onEditApply()\"></cqa-button>\n      </div>\n    </div>\n    \n    \n  </div>\n\n  <!-- Step row: always visible (no template edit here; template edit only in branch row below). Has edit/delete. -->\n  <div\n    [class]=\"'step-row cqa-flex cqa-items-center cqa-gap-3 cqa-py-2 cqa-pr-4' + (config?.shouldSkip ? ' cqa-step-skipped' : '')\"\n    [style.opacity]=\"config?.shouldSkip ? '0.6' : null\"\n    [style.padding-left.px]=\"getRowPaddingLeftPx()\"\n    style=\"border-bottom: 1px solid #E5E7EB; min-height: 50px\">\n    <!-- Checkbox/Drag Handle column - same structure as normal-step for alignment -->\n    <div class=\"cqa-inline-flex cqa-items-center\">\n    <div *ngIf=\"isReorder && !isInsideStepGroup\" class=\"cqa-mr-2 cqa-cursor-move cqa-text-[#6B7280] hover:cqa-text-[#111827]\">\n      <svg width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n        <circle cx=\"3\" cy=\"3\" r=\"1.5\" fill=\"currentColor\"/>\n        <circle cx=\"8\" cy=\"3\" r=\"1.5\" fill=\"currentColor\"/>\n        <circle cx=\"13\" cy=\"3\" r=\"1.5\" fill=\"currentColor\"/>\n        <circle cx=\"3\" cy=\"8\" r=\"1.5\" fill=\"currentColor\"/>\n        <circle cx=\"8\" cy=\"8\" r=\"1.5\" fill=\"currentColor\"/>\n        <circle cx=\"13\" cy=\"8\" r=\"1.5\" fill=\"currentColor\"/>\n        <circle cx=\"3\" cy=\"13\" r=\"1.5\" fill=\"currentColor\"/>\n        <circle cx=\"8\" cy=\"13\" r=\"1.5\" fill=\"currentColor\"/>\n        <circle cx=\"13\" cy=\"13\" r=\"1.5\" fill=\"currentColor\"/>\n      </svg>\n    </div>\n    <!-- Checkbox (when isReorder is false and not inside step group - hide for steps inside step groups) -->\n    <label *ngIf=\"editable && !isReorder && !isInsideStepGroup\" class=\"cqa-flex cqa-items-center cqa-cursor-pointer cqa-relative cqa-mr-2\">\n      <input type=\"checkbox\"\n        [ngModel]=\"selected\"\n        (ngModelChange)=\"onSelectionChange($event)\"\n        class=\"cqa-h-4 cqa-w-4 cqa-cursor-pointer cqa-transition-all cqa-appearance-none cqa-rounded shadow hover:cqa-shadow-md cqa-border cqa-border-solid cqa-border-slate-300 cqa-flex-shrink-0\"\n        [class.cqa-bg-[#3F43EE]]=\"selected\"\n        [class.cqa-border-[#3F43EE]]=\"selected\"\n        id=\"check-condition\" />\n      <span class=\"cqa-absolute cqa-text-white cqa-top-1/2 cqa-left-1/2 cqa--translate-x-1/2 cqa--translate-y-1/2 cqa-pointer-events-none cqa-flex cqa-items-center cqa-justify-center\"\n        [class.cqa-opacity-0]=\"!selected\"\n        [class.cqa-opacity-100]=\"selected\">\n        <svg width=\"12\" height=\"13\" viewBox=\"0 0 12 13\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M10 3.125L4.5 8.625L2 6.125\" stroke=\"white\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/></svg>\n      </span>\n    </label>\n    </div>\n    <div *ngIf=\"isInsideStepGroup\" class=\"cqa-ml-1 cqa-mr-1 cqa-text-[#9CA3AF]\">\n      <svg width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n        <path d=\"M11.9998 5.66667H11.3332V4.33333C11.3332 2.49333 9.83984 1 7.99984 1C6.15984 1 4.6665 2.49333 4.6665 4.33333V5.66667H3.99984C3.2665 5.66667 2.6665 6.26667 2.6665 7V13.6667C2.6665 14.4 3.2665 15 3.99984 15H11.9998C12.7332 15 13.3332 14.4 13.3332 13.6667V7C13.3332 6.26667 12.7332 5.66667 11.9998 5.66667ZM5.99984 4.33333C5.99984 3.22667 6.89317 2.33333 7.99984 2.33333C9.1065 2.33333 9.99984 3.22667 9.99984 4.33333V5.66667H5.99984V4.33333ZM11.9998 13.6667H3.99984V7H11.9998V13.6667ZM7.99984 11.6667C8.73317 11.6667 9.33317 11.0667 9.33317 10.3333C9.33317 9.6 8.73317 9 7.99984 9C7.2665 9 6.6665 9.6 6.6665 10.3333C6.6665 11.0667 7.2665 11.6667 7.99984 11.6667Z\" fill=\"currentColor\"/>\n      </svg>\n    </div>\n    <span class=\"cqa-text-[#6B7280] cqa-text-[14px] cqa-leading-[18px] cqa-min-w-[32px]\">{{ stepNumber }}</span>\n    <!-- Expand/Collapse Icon -->\n    <button type=\"button\" (click)=\"onToggleExpanded()\" class=\"cqa-p-0\">\n      <svg [class.cqa-rotate-180]=\"!expanded\" class=\"cqa-transition-transform\" width=\"16\" height=\"16\"\n        viewBox=\"0 0 16 16\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n        <path d=\"M12 10L8 6L4 10\" stroke=\"#6B7280\" stroke-width=\"1.33333\" stroke-linecap=\"round\"\n          stroke-linejoin=\"round\" />\n      </svg>\n    </button>\n\n    <!-- IF/ELSE Icon -->\n    <div><svg width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n        <path d=\"M4 2V10\" stroke=\"#7B3306\" stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n        <path\n          d=\"M12 6C13.1046 6 14 5.10457 14 4C14 2.89543 13.1046 2 12 2C10.8954 2 10 2.89543 10 4C10 5.10457 10.8954 6 12 6Z\"\n          stroke=\"#7B3306\" stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n        <path\n          d=\"M4 14C5.10457 14 6 13.1046 6 12C6 10.8954 5.10457 10 4 10C2.89543 10 2 10.8954 2 12C2 13.1046 2.89543 14 4 14Z\"\n          stroke=\"#7B3306\" stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n        <path d=\"M12 6C12 7.5913 11.3679 9.11742 10.2426 10.2426C9.11742 11.3679 7.5913 12 6 12\" stroke=\"#7B3306\"\n          stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n      </svg></div>\n\n    <!-- IF/ELSE Label -->\n    <span class=\"cqa-font-semibold cqa-text-[#7B3306] cqa-text-[12px] cqa-leading-none\">\n      CONDITION\n    </span>\n\n    <!-- Step row: read-only (condition, summary, actions) when not editing step row -->\n    <ng-container *ngIf=\"editContext !== 'stepRow'\">\n      <!-- First condition text as plain text (no HTML) -->\n      <div *ngIf=\"getConditionPlainText()\" class=\"cqa-flex cqa-items-center cqa-gap-3 cqa-ml-2 cqa-flex-1 cqa-flex-wrap cqa-px-1 cqa-min-w-0\">\n        <span class=\"cqa-text-[#111827] cqa-text-[14px] cqa-leading-[18px] cqa-truncate\">{{ getConditionPlainText() }}</span>\n      </div>\n\n      <div class=\"cqa-flex cqa-items-center cqa-gap-2 cqa-ml-auto cqa-flex-wrap cqa-px-1 cqa-self-center\">\n        <span *ngIf=\"config?.shouldSkip\" class=\"cqa-border cqa-border-solid cqa-border-[#E5E5E5] cqa-rounded-lg cqa-py-0.5 cqa-px-2 cqa-text-[#0A0A0A] cqa-text-[12px] cqa-leading-[15px] cqa-flex-shrink-0\">Skipped</span>\n        <!-- Branch type badges: IF, ELSE IF (with count), ELSE -->\n        <div class=\"cqa-flex cqa-items-center cqa-gap-1.5 cqa-flex-shrink-0\">\n          <span *ngFor=\"let badge of getBranchTypeBadges()\"\n            [class]=\"'cqa-inline-flex cqa-items-center cqa-gap-1 cqa-px-2 cqa-py-0.5 cqa-rounded cqa-text-[10px] cqa-leading-[15px] cqa-font-medium ' + badge.badgeClass\">\n            {{ badge.label }}\n            <ng-container *ngIf=\"badge.count\">+{{ badge.count }}</ng-container>\n          </span>\n        </div>\n        <div\n          class=\"cqa-border cqa-border-solid cqa-border-[#E5E5E5] cqa-rounded-lg cqa-py-0.5 cqa-px-2 cqa-text-[#0A0A0A] cqa-text-[12px] cqa-leading-[15px]\">\n          {{ getStepsSummary() }}\n        </div>\n        <a *ngIf=\"config.description && config.description.trim() !== ''\" #viewDetailsTrigger href=\"#\" (click)=\"onViewDetails($event)\" class=\"cqa-text-[#3F43EE] cqa-text-[10px] cqa-leading-[15px] cqa-font-medium cqa-flex cqa-items-center cqa-gap-1 cqa-no-underline\">View Details<svg width=\"8\" height=\"8\" viewBox=\"0 0 8 8\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M2.03809 6.74329L2.62809 7.33329L5.96142 3.99996L2.62809 0.666626L2.03809 1.25663L4.78142 3.99996L2.03809 6.74329Z\" fill=\"#3F43EE\"/></svg></a>\n        <a href=\"#\" (click)=\"onEditInDepth(); $event.preventDefault()\" class=\"cqa-text-[#3F43EE] cqa-text-[10px] cqa-leading-[15px] cqa-font-medium cqa-flex cqa-items-center cqa-gap-1 cqa-no-underline\">Edit In depth<svg width=\"8\" height=\"8\" viewBox=\"0 0 8 8\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M2.03809 6.74329L2.62809 7.33329L5.96142 3.99996L2.62809 0.666626L2.03809 1.25663L4.78142 3.99996L2.03809 6.74329Z\" fill=\"#3F43EE\"/></svg></a>\n        <!-- Created Date (from API) - last so aligned across all steps, format: 25 Feb 2026 -->\n        <span *ngIf=\"config.createdDate\" class=\"step-date cqa-text-[#6B7280] cqa-text-[12px] cqa-leading-[15px] cqa-ml-auto cqa-flex-shrink-0\">\n          {{ config.createdDate | date:'d MMM yyyy' }}\n        </span>\n      </div>\n    </ng-container>\n\n    <!-- Step row: edit mode (CONDITION, autocomplete, IF, Add ELSE IF, Add ELSE, Edit In depth, Cancel, Apply) when editContext === 'stepRow' -->\n    <ng-container *ngIf=\"editContext === 'stepRow'\">\n      <div class=\"cqa-flex cqa-items-center cqa-gap-3 cqa-ml-2 cqa-flex-1 cqa-flex-wrap cqa-min-w-0\">\n        <span class=\"cqa-px-1.5 cqa-rounded-md cqa-text-[#EA580C] cqa-text-[10px] cqa-leading-[15px] cqa-font-medium cqa-bg-[#FFEDD5]\">CONDITION</span>\n        <cqa-autocomplete\n          *ngIf=\"editForm\"\n          [options]=\"conditionLeftAutocompleteOptions\"\n          [value]=\"conditionLeftDisplayValue\"\n          (valueChange)=\"onEditFormFieldChange('conditionLeft', $event)\"\n          (optionSelect)=\"onConditionLeftSelect($event)\"\n          placeholder=\"Select Condition\"\n          [fullWidth]=\"true\"\n          class=\"cqa-w-full cqa-max-w-[216px]\"></cqa-autocomplete>\n        <span class=\"cqa-px-2 cqa-py-[2px] cqa-rounded-[4px] cqa-text-[8px] cqa-leading-[12px] cqa-bg-[#DCFCE7] cqa-text-[#008236] cqa-border cqa-border-solid cqa-border-[#B9F8CF] cqa-flex cqa-items-center cqa-gap-1.5\">IF</span>\n        <button type=\"button\" (click)=\"onAddElse()\" class=\"cqa-px-2 cqa-py-[2px] cqa-rounded-[4px] cqa-text-[8px] cqa-leading-[12px] cqa-bg-[#fff9e9] cqa-text-[#E65100] cqa-border cqa-border-solid cqa-border-[#feecbd] cqa-flex cqa-items-center cqa-gap-1.5 cqa-transition-colors cqa-cursor-pointer\">Add ELSE IF</button>\n        <button type=\"button\" (click)=\"onAddElseBranch()\" [disabled]=\"hasElseBranch\" [attr.aria-disabled]=\"hasElseBranch\" class=\"cqa-px-2 cqa-py-[2px] cqa-rounded-[4px] cqa-text-[8px] cqa-leading-[12px] cqa-bg-[#fff9e9] cqa-text-[#E65100] cqa-border cqa-border-solid cqa-border-[#feecbd] cqa-flex cqa-items-center cqa-gap-1.5 cqa-transition-colors\" [class.cqa-cursor-pointer]=\"!hasElseBranch\" [class.cqa-cursor-not-allowed]=\"hasElseBranch\" [class.cqa-opacity-60]=\"hasElseBranch\">Add ELSE</button>\n        <a href=\"#\" (click)=\"onEditInDepth(); $event.preventDefault()\" class=\"cqa-text-[#3F43EE] cqa-text-[10px] cqa-leading-[15px] cqa-font-medium cqa-flex cqa-items-center cqa-gap-[2px] cqa-no-underline\">Edit In depth<svg width=\"8\" height=\"8\" viewBox=\"0 0 8 8\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M2.03809 6.74329L2.62809 7.33329L5.96142 3.99996L2.62809 0.666626L2.03809 1.25663L4.78142 3.99996L2.03809 6.74329Z\" fill=\"#3F43EE\"/></svg></a>\n      </div>\n      <div class=\"cqa-flex cqa-items-center cqa-gap-2 cqa-flex-shrink-0\">\n        <cqa-button variant=\"outlined\" btnSize=\"lg\" [customClass]=\"'cqa-text-[14px] cqa-py-[9px]'\" [text]=\"'Cancel'\" (clicked)=\"onEditCancel()\"></cqa-button>\n        <cqa-button variant=\"filled\" btnSize=\"lg\" [customClass]=\"'cqa-text-[14px] cqa-py-[9px]'\" [text]=\"'Apply'\" (clicked)=\"onEditApply()\"></cqa-button>\n      </div>\n    </ng-container>\n  </div>\n\n  <!-- ELSE IF Sections in Edit Mode - shown below step row when editing and has ELSE IF branches -->\n  <ng-container *ngFor=\"let branch of elseIfBranches; let i = index\">\n    <div *ngIf=\"isEditing\" class=\"cqa-py-2.5 cqa-px-1 cqa-flex cqa-flex-col cqa-gap-3 cqa-border-t cqa-border-solid cqa-border-[#E5E7EB]\">\n      <!-- First Row: Remove ELSE IF button, autocomplete, Edit In depth, Cancel/Apply -->\n      <div class=\"cqa-flex cqa-items-center cqa-gap-3 cqa-justify-between\">\n        <div class=\"cqa-flex cqa-items-center cqa-gap-3 cqa-flex-grow\">\n          <!-- Remove ELSE IF button -->\n          <button\n            type=\"button\"\n            (click)=\"onRemoveElse(branch.id)\"\n            class=\"cqa-px-2 cqa-py-[2px] cqa-rounded-[4px] cqa-text-[8px] cqa-leading-[12px] cqa-bg-[#F3F4F6] cqa-text-[#99A1AF] cqa-border cqa-border-solid cqa-border-[#E5E7EB] cqa-cursor-pointer hover:cqa-bg-[#E5E7EB] cqa-transition-colors\">\n            Remove ELSE IF\n          </button>\n\n          <!-- ELSE IF autocomplete field: same as IF condition -->\n          <cqa-autocomplete\n            *ngIf=\"branch.form\"\n            [options]=\"conditionLeftAutocompleteOptions\"\n            [value]=\"branch.form.get('conditionLeft')?.value ?? ''\"\n            (valueChange)=\"branch.form.get('conditionLeft')?.setValue($event)\"\n            (optionSelect)=\"onElseConditionLeftSelect($event, branch.id)\"\n            placeholder=\"Select Condition\"\n            [fullWidth]=\"true\"\n            [compact]=\"true\"\n            class=\"cqa-w-full cqa-max-w-[216px]\"></cqa-autocomplete>\n          \n          <!-- Second Row: ELSE IF Template Variables Section (shown when template is selected, inline before Edit In depth) -->\n          <div *ngIf=\"branch.selectedTemplate && branch.templateVariables && branch.templateVariables.length > 0\" class=\"cqa-flex cqa-flex-row cqa-flex-wrap cqa-gap-3\">\n            <ng-container *ngFor=\"let variable of branch.templateVariables\">\n              <!-- Boolean variables with mat-slide-toggle -->\n              <ng-container *ngIf=\"variable.type === 'boolean'\">\n                <div class=\"cqa-flex cqa-items-center cqa-gap-2\">\n                  <mat-slide-toggle\n                    [checked]=\"branch.templateVariablesForm.get(variable.name)?.value || variable.value || false\"\n                    (change)=\"branch.templateVariablesForm.get(variable.name)?.setValue($event.checked)\"\n                    color=\"primary\">\n                  </mat-slide-toggle>\n                </div>\n              </ng-container>\n              \n              <!-- Non-boolean variables -->\n              <ng-container *ngIf=\"variable.type !== 'boolean' && variable.name !== 'custom_code'\">\n                <ng-container *ngIf=\"variable.name === 'type' || variable.name === 'scrollTo' || variable.options\">\n                  <div class=\"cqa-flex cqa-flex-col\" style=\"min-width: 150px;\">\n                    <cqa-dynamic-select \n                      [form]=\"branch.templateVariablesForm\"\n                      [config]=\"getSelectConfigForVariable(variable, branch.id)\">\n                    </cqa-dynamic-select>\n                  </div>\n                </ng-container>\n                \n                <ng-container *ngIf=\"variable.name !== 'type' && variable.name !== 'scrollTo' && !variable.options\">\n                  <div class=\"cqa-flex cqa-flex-col\" style=\"min-width: 150px;\">\n                    <cqa-custom-input\n                      [value]=\"branch.templateVariablesForm.get(variable.name)?.value || variable.value || ''\"\n                      (valueChange)=\"branch.templateVariablesForm.get(variable.name)?.setValue($event)\"\n                      [placeholder]=\"variable.label\">\n                    </cqa-custom-input>\n                  </div>\n                </ng-container>\n              </ng-container>\n            </ng-container>\n          </div>\n\n          <!-- Edit In depth link -->\n          <a href=\"#\" (click)=\"onEditInDepth(undefined, getBranchById(branch.id), getBranchIndexById(branch.id)); $event.preventDefault()\"\n            class=\"cqa-text-[#3F43EE] cqa-text-[10px] cqa-leading-[15px] cqa-font-medium cqa-flex cqa-items-center cqa-gap-[2px] cqa-no-underline\">\n            Edit In depth\n            <svg width=\"8\" height=\"8\" viewBox=\"0 0 8 8\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M2.03809 6.74329L2.62809 7.33329L5.96142 3.99996L2.62809 0.666626L2.03809 1.25663L4.78142 3.99996L2.03809 6.74329Z\" fill=\"#3F43EE\"/></svg>\n          </a>\n        </div>\n        <!-- Cancel / Apply buttons - shown in last ELSE IF row -->\n        <div *ngIf=\"i === elseIfBranches.length - 1\" class=\"cqa-flex cqa-items-center cqa-gap-2\">\n          <cqa-button variant=\"outlined\" btnSize=\"lg\" [customClass]=\"'cqa-text-[14px] cqa-py-[9px]'\" [text]=\"'Cancel'\" (clicked)=\"onEditCancel()\"></cqa-button>\n          <cqa-button variant=\"filled\" btnSize=\"lg\" [customClass]=\"'cqa-text-[14px] cqa-py-[9px]'\" [text]=\"'Apply'\" (clicked)=\"onEditApply()\"></cqa-button>\n        </div>\n      </div>\n    </div>\n  </ng-container>\n\n  <!-- Expanded Content with Branches (shown when expanded or when editing so edit UI appears in first branch row) -->\n  <div *ngIf=\"expanded || isEditing\" class=\"cqa-flex cqa-flex-col\">\n    <!-- Branches (IF TRUE, ELSE IF, ELSE) -->\n    <div *ngFor=\"let branch of branches; let branchIndex = index\" class=\"condition-branch-row cqa-flex cqa-flex-col\" [attr.data-branch-id]=\"branch?.id\">\n      <!-- Edit mode (IF TRUE branch): shows CONDITION, autocomplete, IF, Add ELSE IF, Add ELSE, Edit In depth, Edit/Delete, Cancel/Apply -->\n      <div\n        *ngIf=\"editContext === 'branchRow' && branchIndex === 0 && editingBranchIndex === 0\"\n        (click)=\"$event.stopPropagation()\"\n        (mousedown)=\"$event.stopPropagation()\"\n        [class]=\"'cqa-px-1 cqa-py-2.5 cqa-text-[12px] cqa-leading-[15px] cqa-flex cqa-items-center cqa-gap-3 cqa-justify-between cqa-flex-wrap ' + getBranchTextColor(branch) + ' ' + getBranchColorClass(branch)\">\n        <div class=\"cqa-flex cqa-items-center cqa-gap-3 cqa-flex-grow cqa-flex-wrap cqa-min-w-0\">\n          <span class=\"cqa-text-[#6B7280] cqa-text-[14px] cqa-leading-[18px] cqa-min-w-[32px] cqa-flex-shrink-0\">{{ getBranchDisplayNumber(branchIndex) }}</span>\n          <span>{{ getBranchLabel(branch) }}</span>\n          <span class=\"cqa-px-1.5 cqa-rounded-md cqa-text-[#EA580C] cqa-text-[10px] cqa-leading-[15px] cqa-font-medium cqa-bg-[#FFEDD5]\">CONDITION</span>\n          <cqa-autocomplete\n            *ngIf=\"editForm\"\n            [options]=\"conditionLeftAutocompleteOptions\"\n            [value]=\"conditionLeftDisplayValue\"\n            (valueChange)=\"onEditFormFieldChange('conditionLeft', $event)\"\n            (optionSelect)=\"onConditionLeftSelect($event)\"\n            placeholder=\"Select Condition\"\n            [fullWidth]=\"true\"\n            class=\"cqa-w-full cqa-max-w-[216px]\"></cqa-autocomplete>\n          <span class=\"cqa-px-2 cqa-py-[2px] cqa-rounded-[4px] cqa-text-[8px] cqa-leading-[12px] cqa-bg-[#DCFCE7] cqa-text-[#008236] cqa-border cqa-border-solid cqa-border-[#B9F8CF] cqa-flex cqa-items-center cqa-gap-1.5\">IF</span>\n          <button type=\"button\" (click)=\"onAddElse(); $event.stopPropagation()\" class=\"cqa-px-2 cqa-py-[2px] cqa-rounded-[4px] cqa-text-[8px] cqa-leading-[12px] cqa-bg-[#fff9e9] cqa-text-[#E65100] cqa-border cqa-border-solid cqa-border-[#feecbd] cqa-flex cqa-items-center cqa-gap-1.5 cqa-transition-colors cqa-cursor-pointer\">Add ELSE IF</button>\n          <button type=\"button\" (click)=\"onAddElseBranch(); $event.stopPropagation()\" [disabled]=\"hasElseBranch\" [attr.aria-disabled]=\"hasElseBranch\" class=\"cqa-px-2 cqa-py-[2px] cqa-rounded-[4px] cqa-text-[8px] cqa-leading-[12px] cqa-bg-[#fff9e9] cqa-text-[#E65100] cqa-border cqa-border-solid cqa-border-[#feecbd] cqa-flex cqa-items-center cqa-gap-1.5 cqa-transition-colors\" [class.cqa-cursor-pointer]=\"!hasElseBranch\" [class.cqa-cursor-not-allowed]=\"hasElseBranch\" [class.cqa-opacity-60]=\"hasElseBranch\">Add ELSE</button>\n          <a href=\"#\" (click)=\"onEditInDepth(undefined, branch, 0); $event.preventDefault()\" class=\"cqa-text-[#3F43EE] cqa-text-[10px] cqa-leading-[15px] cqa-font-medium cqa-flex cqa-items-center cqa-gap-[2px] cqa-no-underline\">Edit In depth<svg width=\"8\" height=\"8\" viewBox=\"0 0 8 8\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M2.03809 6.74329L2.62809 7.33329L5.96142 3.99996L2.62809 0.666626L2.03809 1.25663L4.78142 3.99996L2.03809 6.74329Z\" fill=\"#3F43EE\"/></svg></a>\n        </div>\n        <div class=\"cqa-flex cqa-items-center cqa-gap-2 cqa-flex-shrink-0\">\n          <cqa-button variant=\"outlined\" btnSize=\"lg\" [customClass]=\"'cqa-text-[14px] cqa-py-[9px]'\" [text]=\"'Cancel'\" (clicked)=\"onEditCancel()\"></cqa-button>\n          <cqa-button variant=\"filled\" btnSize=\"lg\" [customClass]=\"'cqa-text-[14px] cqa-py-[9px]'\" [text]=\"'Apply'\" (clicked)=\"onEditApply()\"></cqa-button>\n        </div>\n      </div>\n      <!-- Edit mode (ELSE IF branch): shows CONDITION, autocomplete, Add ELSE IF / Add ELSE, Edit In depth, Cancel/Apply -->\n      <div\n        *ngIf=\"editContext === 'branchRow' && branchIndex === editingBranchIndex && branch.type === 'else-if'\"\n        (click)=\"$event.stopPropagation()\"\n        (mousedown)=\"$event.stopPropagation()\"\n        [class]=\"'cqa-px-1 cqa-py-2.5 cqa-text-[12px] cqa-leading-[15px] cqa-flex cqa-items-center cqa-gap-3 cqa-justify-between cqa-flex-wrap ' + getBranchTextColor(branch) + ' ' + getBranchColorClass(branch)\">\n        <div class=\"cqa-flex cqa-items-center cqa-gap-3 cqa-flex-grow cqa-flex-wrap cqa-min-w-0\">\n          <span class=\"cqa-text-[#6B7280] cqa-text-[14px] cqa-leading-[18px] cqa-min-w-[32px] cqa-flex-shrink-0\">{{ getBranchDisplayNumber(branchIndex) }}</span>\n          <span>{{ getBranchLabel(branch) }}</span>\n          <span class=\"cqa-px-1.5 cqa-rounded-md cqa-text-[#EA580C] cqa-text-[10px] cqa-leading-[15px] cqa-font-medium cqa-bg-[#FFEDD5]\">CONDITION</span>\n          <!-- ELSE IF condition autocomplete: same options and value model as IF, but initialized from this branch's condition -->\n          <cqa-autocomplete\n            *ngIf=\"editForm\"\n            [options]=\"conditionLeftAutocompleteOptions\"\n            [value]=\"conditionLeftDisplayValue\"\n            (valueChange)=\"onEditFormFieldChange('conditionLeft', $event)\"\n            (optionSelect)=\"onConditionLeftSelect($event)\"\n            placeholder=\"Select Condition\"\n            [fullWidth]=\"true\"\n            class=\"cqa-w-full cqa-max-w-[216px]\"></cqa-autocomplete>\n          <button type=\"button\" (click)=\"onAddElse(); $event.stopPropagation()\" class=\"cqa-px-2 cqa-py-[2px] cqa-rounded-[4px] cqa-text-[8px] cqa-leading-[12px] cqa-bg-[#fff9e9] cqa-text-[#E65100] cqa-border cqa-border-solid cqa-border-[#feecbd] cqa-flex cqa-items-center cqa-gap-1.5 cqa-transition-colors cqa-cursor-pointer\">Add ELSE IF</button>\n          <button type=\"button\" (click)=\"onAddElseBranch(); $event.stopPropagation()\" [disabled]=\"hasElseBranch\" [attr.aria-disabled]=\"hasElseBranch\" class=\"cqa-px-2 cqa-py-[2px] cqa-rounded-[4px] cqa-text-[8px] cqa-leading-[12px] cqa-bg-[#fff9e9] cqa-text-[#E65100] cqa-border cqa-border-solid cqa-border-[#feecbd] cqa-flex cqa-items-center cqa-gap-1.5 cqa-transition-colors\" [class.cqa-cursor-pointer]=\"!hasElseBranch\" [class.cqa-cursor-not-allowed]=\"hasElseBranch\" [class.cqa-opacity-60]=\"hasElseBranch\">Add ELSE</button>\n          <a href=\"#\" (click)=\"onEditInDepth(undefined, branch, branchIndex); $event.preventDefault()\" class=\"cqa-text-[#3F43EE] cqa-text-[10px] cqa-leading-[15px] cqa-font-medium cqa-flex cqa-items-center cqa-gap-[2px] cqa-no-underline\">Edit In depth<svg width=\"8\" height=\"8\" viewBox=\"0 0 8 8\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M2.03809 6.74329L2.62809 7.33329L5.96142 3.99996L2.62809 0.666626L2.03809 1.25663L4.78142 3.99996L2.03809 6.74329Z\" fill=\"#3F43EE\"/></svg></a>\n        </div>\n        <div class=\"cqa-flex cqa-items-center cqa-gap-2 cqa-flex-shrink-0\">\n          <cqa-button variant=\"outlined\" btnSize=\"lg\" [customClass]=\"'cqa-text-[14px] cqa-py-[9px]'\" [text]=\"'Cancel'\" (clicked)=\"onEditCancel()\"></cqa-button>\n          <cqa-button variant=\"filled\" btnSize=\"lg\" [customClass]=\"'cqa-text-[14px] cqa-py-[9px]'\" [text]=\"'Apply'\" (clicked)=\"onEditApply()\"></cqa-button>\n        </div>\n      </div>\n      <!-- Branch Header (read-only): display when not editing this branch row. Order: branch content (left), then step-actions, then date (right, same as other steps). -->\n      <div\n        *ngIf=\"editContext !== 'branchRow' || branchIndex !== editingBranchIndex\"\n        [class]=\"'cqa-px-4 cqa-py-2 cqa-text-[12px] cqa-leading-[15px] cqa-flex cqa-items-center cqa-gap-2 cqa-justify-between ' + getBranchTextColor(branch) + ' ' + getBranchColorClass(branch)\">\n        <div class=\"cqa-flex cqa-items-center cqa-gap-2 cqa-flex-grow cqa-flex-wrap cqa-min-w-0\">\n          <span class=\"cqa-text-[#6B7280] cqa-text-[14px] cqa-leading-[18px] cqa-min-w-[32px] cqa-flex-shrink-0\">{{ getBranchDisplayNumber(branchIndex) }}</span>\n          <span>{{ getBranchLabel(branch) }}</span>\n          <span\n            *ngIf=\"getBranchConditionDisplay(branch)\"\n            [innerHTML]=\"getBranchConditionDisplay(branch) | cqaSafeHtml\"\n            (click)=\"onConditionActionClick($event, branch)\"\n            class=\"cqa-text-[#111827] cqa-text-[14px] cqa-leading-[18px] cqa-action-format\"></span>\n          <ng-container *ngIf=\"getBranchEventDetailsForDisplay(branch).length > 0\">\n            <span *ngFor=\"let item of getBranchEventDetailsForDisplay(branch)\" class=\"cqa-inline-flex cqa-items-center cqa-gap-1 cqa-py-0.5 cqa-px-2 cqa-rounded cqa-text-[12px] cqa-leading-[15px] cqa-bg-[#F3F4F6] cqa-text-[#374151] cqa-border cqa-border-solid cqa-border-[#E5E7EB]\" (click)=\"onConditionActionClick($event, branch)\">\n              <span class=\"cqa-font-medium cqa-text-[#6B7280]\">{{ item.key }}:</span>\n              <span class=\"cqa-text-[#111827]\">{{ item.value }}</span>\n            </span>\n          </ng-container>\n        </div>\n        <!-- Right section: step-actions then date (same order as other step types) -->\n        <div *ngIf=\"editable && !isInsideStepGroup && !isReorder\" class=\"step-actions cqa-flex cqa-items-center cqa-gap-1.5 cqa-pr-2 cqa-flex-shrink-0\">\n          <button *ngIf=\"branchIndex === 0 || branch.type === 'else-if'\" type=\"button\" (click)=\"onEditFromBranchRow(branchIndex); $event.stopPropagation()\" title=\"Edit\" class=\"cqa-p-0 cqa-text-[#99A1Af] hover:cqa-text-[#1447E6]\">\n            <svg width=\"14\" height=\"14\" viewBox=\"0 0 14 14\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M7 11.6666H12.25\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M9.55208 2.1128C9.7843 1.88058 10.0993 1.75012 10.4277 1.75012C10.7561 1.75012 11.071 1.88058 11.3033 2.1128C11.5355 2.34502 11.6659 2.65998 11.6659 2.98838C11.6659 3.31679 11.5355 3.63175 11.3033 3.86397L4.29742 10.8704C4.15864 11.0092 3.9871 11.1107 3.79867 11.1656L2.12333 11.6544C2.07314 11.669 2.01993 11.6699 1.96928 11.6569C1.91863 11.6439 1.8724 11.6176 1.83543 11.5806C1.79846 11.5437 1.7721 11.4974 1.75913 11.4468C1.74615 11.3961 1.74703 11.3429 1.76167 11.2927L2.2505 9.61738C2.30546 9.42916 2.40698 9.25783 2.54567 9.11922L9.55208 2.1128Z\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/></svg>\n          </button>\n          <button *ngIf=\"branchIndex === 0 || branch.type === 'else-if'\" type=\"button\" (click)=\"onEditFromBranchRow(branchIndex); $event.stopPropagation()\" title=\"Edit\" class=\"cqa-p-0 cqa-text-[#99A1Af] hover:cqa-text-[#1447E6]\">\n            <svg width=\"14\" height=\"14\" viewBox=\"0 0 14 14\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M8.25 8.75C9.2165 8.75 10 7.9665 10 7C10 6.0335 9.2165 5.25 8.25 5.25C7.2835 5.25 6.5 6.0335 6.5 7C6.5 7.9665 7.2835 8.75 8.25 8.75Z\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M8.75033 2.91663H5.25033C2.99516 2.91663 1.16699 4.7448 1.16699 6.99996C1.16699 9.25512 2.99516 11.0833 5.25033 11.0833H8.75033C11.0055 11.0833 12.8337 9.25512 12.8337 6.99996C12.8337 4.7448 11.0055 2.91663 8.75033 2.91663Z\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/></svg>\n          </button>\n          <button type=\"button\" (click)=\"branchIndex === 0 ? onDelete() : onDeleteBranch(branch); $event.stopPropagation()\" title=\"{{ branchIndex === 0 ? 'Delete step' : 'Delete branch' }}\" class=\"cqa-p-0 cqa-text-[#ff6467] hover:cqa-text-[#C63535]\">\n            <svg width=\"14\" height=\"14\" viewBox=\"0 0 14 14\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M1.75 3.5H12.25\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M11.0827 3.5V11.6667C11.0827 12.25 10.4993 12.8333 9.91602 12.8333H4.08268C3.49935 12.8333 2.91602 12.25 2.91602 11.6667V3.5\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M4.66602 3.49996V2.33329C4.66602 1.74996 5.24935 1.16663 5.83268 1.16663H8.16602C8.74935 1.16663 9.33268 1.74996 9.33268 2.33329V3.49996\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M5.83398 6.41663V9.91663\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M8.16602 6.41663V9.91663\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/></svg>\n          </button>\n        </div>\n        <span *ngIf=\"getBranchCreatedDate(branch)\" class=\"step-date cqa-text-[#6B7280] cqa-text-[12px] cqa-leading-[15px] cqa-flex-shrink-0 cqa-ml-auto\">{{ getBranchCreatedDate(branch) | date:'d MMM yyyy' }}</span>\n      </div>\n\n      <!-- START marker per branch: START IF, START ELSE IF, or START ELSE (centered with decorative lines) - only when branch has nested steps -->\n      <div *ngIf=\"branch.nestedSteps?.length > 0\" class=\"cqa-flex cqa-items-center cqa-gap-3 cqa-py-1 cqa-px-4\" style=\"border-top: 1px solid #E5E7EB;\">\n        <span class=\"cqa-flex-1 cqa-self-stretch cqa-border-t cqa-border-dashed cqa-border-[#7B3306] cqa-opacity-40\" style=\"min-width: 20px;\"></span>\n        <span class=\"cqa-text-[#7B3306] cqa-text-[10px] cqa-leading-[15px] cqa-font-medium cqa-whitespace-nowrap\">{{ getStartBranchLabel(branch) }}</span>\n        <span class=\"cqa-flex-1 cqa-self-stretch cqa-border-t cqa-border-dashed cqa-border-[#7B3306] cqa-opacity-40\" style=\"min-width: 20px;\"></span>\n      </div>\n\n      <!-- Branch Content (Nested Steps – renderer dispatches by step type, n-level nesting) -->\n      <div *ngIf=\"!isReorder || isInsideStepGroup\" class=\"cqa-flex cqa-flex-col\">\n        <cqa-test-case-details-renderer\n          *ngFor=\"let step of branch.nestedSteps; let i = index\"\n          [step]=\"step\"\n          [index]=\"i\"\n          [selected]=\"$any(step).selected\"\n          [branch]=\"branch\"\n          [isNested]=\"true\"\n          [isInsideStepGroup]=\"isInsideStepGroup\"\n          [isReorder]=\"isReorder\"\n          [nestingLevel]=\"(nestingLevel || 0) + 1\"\n          [addStepBetween]=\"addStepBetween\"\n          [editable]=\"editable\"\n          [dataProfileOptions]=\"dataProfileOptions\" [hasMoreDataProfiles]=\"hasMoreDataProfiles\" [isLoadingDataProfiles]=\"isLoadingDataProfiles\"\n          [naturalTextActionsOptions]=\"naturalTextActionsOptions\"\n          (branchStepChange)=\"onBranchStepChange($event.branch, $event.step, $event.stepIndex)\"\n          (addStepForBranch)=\"onAddStep($event.branch)\"\n          (addStepForLoop)=\"onAddStepForLoop($event, branch)\"\n          (deleteStepWithBranch)=\"onDeleteStep($event.branch, $event.stepIndex)\"\n          (toggleExpanded)=\"onNestedToggleExpanded($event, branch, step, i)\"\n          (groupNameChange)=\"$any(step).groupName = $event; onBranchStepChange(branch, step, i)\"\n          (descriptionChange)=\"$any(step).description = $event; onBranchStepChange(branch, step, i)\"\n          (reusableChange)=\"$any(step).reusable = $event; onBranchStepChange(branch, step, i)\"\n          (openExternal)=\"onNestedOpenExternal($event)\"\n          (edit)=\"onNestedEdit($event)\"\n          (link)=\"onBranchStepChange(branch, step, i)\"\n          (duplicate)=\"onNestedDuplicate($event, step)\"\n          (viewDetails)=\"viewDetails.emit($event)\"\n          (conditionChange)=\"$any(step).condition = $event; onBranchStepChange(branch, step, i)\"\n          (addBranch)=\"onNestedConditionAddBranch($any(step)); onBranchStepChange(branch, step, i)\"\n          (deleteBranch)=\"onNestedConditionDeleteBranch($any(step), $event); onBranchStepChange(branch, step, i)\"\n          (testDataProfileChange)=\"$any(step).testDataProfile = $event; onBranchStepChange(branch, step, i)\"\n          (startStepChange)=\"$any(step).startStep = $event; onBranchStepChange(branch, step, i)\"\n          (endStepChange)=\"$any(step).endStep = $event; onBranchStepChange(branch, step, i)\"\n          (maxIterationsChange)=\"$any(step).maxIterations = $event; onBranchStepChange(branch, step, i)\"\n          (eventTypeChange)=\"$any(step).eventType = $event; onBranchStepChange(branch, step, i)\"\n          (parameterChange)=\"onBranchStepChange(branch, step, i)\"\n          (selectionChange)=\"$any(step).selected = $event; onBranchStepChange(branch, step, i)\"\n          (loadMoreDataProfiles)=\"loadMoreDataProfiles.emit($event)\"\n          (searchDataProfiles)=\"searchDataProfiles.emit($event)\"\n          (stepUpdate)=\"stepUpdate.emit($event)\"\n          (dndDropInZone)=\"dndDropInZone.emit($event)\"\n          (clickAction)=\"onNestedClickAction($event)\"\n          (editInDepth)=\"editInDepth.emit($event)\"\n          (addStepBetweenClick)=\"addStepBetweenClick.emit($event)\"\n        >\n        </cqa-test-case-details-renderer>\n      </div>\n      <div *ngIf=\"isReorder && !isInsideStepGroup\" class=\"cqa-flex cqa-flex-col nested-step-drop-list\"\n           [style.min-height.px]=\"branch.nestedSteps.length === 0 ? 52 : null\"\n           [dndDropzone]=\"['step']\"\n           dndEffectAllowed=\"move\"\n           dndDragoverClass=\"dndDragover\"\n           (dndDrop)=\"onDndDrop($event, branch)\">\n        <div dndPlaceholderRef class=\"step-drag-placeholder-nested cqa-my-1 cqa-min-h-[50px] cqa-border-2 cqa-border-dashed cqa-border-[#3F43EE] cqa-rounded cqa-bg-[rgba(63,67,238,0.08)] cqa-flex cqa-items-center cqa-justify-center cqa-text-[#3F43EE] cqa-text-xs\">Drop here</div>\n        <div *ngFor=\"let step of branch.nestedSteps; let i = index\" class=\"nested-step-drag-item\"\n             [dndDraggable]=\"step\"\n             dndEffectAllowed=\"move\"\n             dndType=\"step\">\n          <cqa-test-case-details-renderer\n            [step]=\"step\"\n            [index]=\"i\"\n            [selected]=\"$any(step).selected\"\n            [branch]=\"branch\"\n            [isNested]=\"true\"\n            [isInsideStepGroup]=\"isInsideStepGroup\"\n            [isReorder]=\"isReorder\"\n            [nestingLevel]=\"(nestingLevel || 0) + 1\"\n            [addStepBetweenAbove]=\"addStepBetweenAbove\"\n            [addStepBetweenBelow]=\"addStepBetweenBelow\"\n            [addStepBetween]=\"addStepBetween\"\n          [editable]=\"editable\"\n            [dataProfileOptions]=\"dataProfileOptions\" [hasMoreDataProfiles]=\"hasMoreDataProfiles\" [isLoadingDataProfiles]=\"isLoadingDataProfiles\"\n            [naturalTextActionsOptions]=\"naturalTextActionsOptions\"\n            (branchStepChange)=\"onBranchStepChange($event.branch, $event.step, $event.stepIndex)\"\n            (addStepForBranch)=\"onAddStep($event.branch)\"\n            (addStepForLoop)=\"onAddStepForLoop($event, branch)\"\n            (deleteStepWithBranch)=\"onDeleteStep($event.branch, $event.stepIndex)\"\n            (toggleExpanded)=\"onNestedToggleExpanded($event, branch, step, i)\"\n            (groupNameChange)=\"$any(step).groupName = $event; onBranchStepChange(branch, step, i)\"\n            (descriptionChange)=\"$any(step).description = $event; onBranchStepChange(branch, step, i)\"\n            (reusableChange)=\"$any(step).reusable = $event; onBranchStepChange(branch, step, i)\"\n            (openExternal)=\"onNestedOpenExternal($event)\"\n            (edit)=\"onNestedEdit($event)\"\n            (link)=\"onBranchStepChange(branch, step, i)\"\n            (duplicate)=\"onNestedDuplicate($event, step)\"\n            (viewDetails)=\"viewDetails.emit($event)\"\n            (conditionChange)=\"$any(step).condition = $event; onBranchStepChange(branch, step, i)\"\n            (addBranch)=\"onNestedConditionAddBranch($any(step)); onBranchStepChange(branch, step, i)\"\n            (deleteBranch)=\"onNestedConditionDeleteBranch($any(step), $event); onBranchStepChange(branch, step, i)\"\n            (testDataProfileChange)=\"$any(step).testDataProfile = $event; onBranchStepChange(branch, step, i)\"\n            (startStepChange)=\"$any(step).startStep = $event; onBranchStepChange(branch, step, i)\"\n            (endStepChange)=\"$any(step).endStep = $event; onBranchStepChange(branch, step, i)\"\n            (maxIterationsChange)=\"$any(step).maxIterations = $event; onBranchStepChange(branch, step, i)\"\n            (eventTypeChange)=\"$any(step).eventType = $event; onBranchStepChange(branch, step, i)\"\n            (parameterChange)=\"onBranchStepChange(branch, step, i)\"\n            (selectionChange)=\"$any(step).selected = $event; onBranchStepChange(branch, step, i)\"\n            (loadMoreDataProfiles)=\"loadMoreDataProfiles.emit($event)\"\n            (searchDataProfiles)=\"searchDataProfiles.emit($event)\"\n            (stepUpdate)=\"stepUpdate.emit($event)\"\n            (dndDropInZone)=\"dndDropInZone.emit($event)\"\n            (clickAction)=\"onNestedClickAction($event)\"\n            (editInDepth)=\"editInDepth.emit($event)\"\n            (addStepBetweenClick)=\"addStepBetweenClick.emit($event)\"\n          >\n          </cqa-test-case-details-renderer>\n        </div>\n      </div>\n\n      <!-- Empty branch (IF / ELSE IF / ELSE): show plus icon on hover when no steps, same as loop step.\n           When rendered inside a step group or when reordering, hide this Add button entirely. -->\n      <div *ngIf=\"branch.nestedSteps.length === 0 && editable && !isInsideStepGroup && !isReorder\" class=\"condition-branch-empty cqa-min-h-[52px] cqa-flex cqa-items-center cqa-justify-center cqa-pl-4 cqa-pr-4\">\n        <button type=\"button\" (click)=\"onAddStep(branch); $event.stopPropagation()\" (mousedown)=\"$event.stopPropagation()\" [attr.title]=\"'Add step to ' + getBranchLabel(branch)\"\n          class=\"condition-branch-empty-add\">\n          <svg width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n            <rect x=\"1\" y=\"1\" width=\"21.1822\" height=\"22\" rx=\"10.5911\" fill=\"white\" />\n            <rect x=\"1\" y=\"1\" width=\"21.1822\" height=\"22\" rx=\"10.5911\" stroke=\"#3F43EE\" stroke-width=\"2\" />\n            <path d=\"M8.5 12H15.5\" stroke=\"#3F43EE\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n            <path d=\"M12 8.5V15.5\" stroke=\"#3F43EE\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n          </svg>\n        </button>\n      </div>\n\n      <!-- END marker per branch: END IF, END ELSE IF, or END ELSE - only when branch has nested steps -->\n      <div *ngIf=\"branch.nestedSteps?.length > 0\" class=\"cqa-flex cqa-items-center cqa-gap-3 cqa-py-1 cqa-px-4\" style=\"border-top: 1px solid #E5E7EB;\">\n        <span class=\"cqa-flex-1 cqa-self-stretch cqa-border-t cqa-border-dashed cqa-border-[#7B3306] cqa-opacity-40\" style=\"min-width: 20px;\"></span>\n        <span class=\"cqa-text-[#7B3306] cqa-text-[10px] cqa-leading-[15px] cqa-font-medium cqa-whitespace-nowrap\">{{ getEndBranchLabel(branch) }}</span>\n        <span class=\"cqa-flex-1 cqa-self-stretch cqa-border-t cqa-border-dashed cqa-border-[#7B3306] cqa-opacity-40\" style=\"min-width: 20px;\"></span>\n      </div>\n    </div>\n    <!-- END CONDITION: final marker after all branches -->\n    <div class=\"cqa-flex cqa-items-center cqa-gap-3 cqa-py-1 cqa-px-4\" style=\"border-top: 1px solid #E5E7EB;\">\n      <span class=\"cqa-flex-1 cqa-self-stretch cqa-border-t cqa-border-dashed cqa-border-[#7B3306] cqa-opacity-40\" style=\"min-width: 20px;\"></span>\n      <span class=\"cqa-text-[#7B3306] cqa-text-[10px] cqa-leading-[15px] cqa-font-medium cqa-whitespace-nowrap\">END CONDITION</span>\n      <span class=\"cqa-flex-1 cqa-self-stretch cqa-border-t cqa-border-dashed cqa-border-[#7B3306] cqa-opacity-40\" style=\"min-width: 20px;\"></span>\n    </div>\n  </div>\n</div>"]}
1315
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"condition-step.component.js","sourceRoot":"","sources":["../../../../../../src/lib/test-case-details/condition-step/condition-step.component.ts","../../../../../../src/lib/test-case-details/condition-step/condition-step.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, Output, EventEmitter, OnInit, OnChanges, ChangeDetectorRef, ViewChild, ElementRef } from '@angular/core';\nimport { FormBuilder, FormGroup, FormControl } from '@angular/forms';\nimport { DndDropEvent } from 'ngx-drag-drop';\nimport { ConditionStepConfig, ConditionBranch, TestCaseStepConfig, NormalStepConfig, LoopStepConfig, StepGroupConfig, StepTypes } from '../test-case-step.models';\nimport { STEP_ROW_ACTIONS_STYLES } from '../step-row-actions.styles';\nimport { DynamicSelectFieldConfig, SelectOption } from '../../dynamic-select/dynamic-select-field.component';\nimport { CqaAutocompleteOption } from '../../autocomplete/autocomplete.model';\nimport { ViewDetailsPayload } from '../step-details-modal/step-details-modal-data';\n\nconst CONDITION_BRANCH_EMPTY_STYLES = `\n  /* Empty drop zone: ensure min height for drag-drop to work (IF/ELSE IF/ELSE branches) */\n  .nested-step-drop-list:has(.step-drag-placeholder-nested:only-child) {\n    min-height: 52px;\n  }\n  /* Empty IF / ELSE IF / ELSE: always show plus icon when no steps (visible without hover) */\n  .condition-branch-empty {\n    opacity: 1;\n    transition: opacity 0.1s ease;\n  }\n  /* Show edit/delete icons when hovering over branch row header (IF TRUE, ELSE IF, ELSE) */\n  .condition-branch-row:hover .step-actions {\n    opacity: 1;\n  }\n  .condition-branch-empty-add {\n    padding: 0;\n    background: transparent;\n    border: 0;\n    cursor: pointer;\n    color: #3F43EE;\n    transition: opacity 0.15s ease;\n  }\n  .condition-branch-empty-add:hover {\n    opacity: 0.9;\n  }\n`;\n@Component({\n  selector: 'cqa-test-case-condition-step',\n  templateUrl: './condition-step.component.html',\n  host: { class: 'cqa-ui-root' },\n  styles: [\n    STEP_ROW_ACTIONS_STYLES,\n    CONDITION_BRANCH_EMPTY_STYLES,\n  ],\n})\nexport class TestCaseConditionStepComponent implements OnInit, OnChanges {\n  @Input() config!: ConditionStepConfig;\n  @Input() id!: string;\n  @Input() stepNumber!: number | string;\n  /** Array index from parent renderer - use this for editInDepth instead of stepNumber (stepNumber \"10.3\" parses to 10) */\n  @Input() index?: number;\n  @Input() condition!: string;\n  @Input() branches: ConditionBranch[] = [];\n  @Input() expanded: boolean = true;\n  @Input() isNested: boolean = false;\n  @Input() isInsideLoop: boolean = false;\n  @Input() isInsideStepGroup: boolean = false;\n  @Input() isReorder: boolean = false;\n  @Input() editable: boolean = true;\n  /** Visual indentation level for nested structures (passed down from renderer). */\n  @Input() nestingLevel: number = 0;\n  @Input() selected: boolean = false;\n  /** Options for the data profile dropdown */\n  @Input() dataProfileOptions: any[] = [];\n  /** Indicates if more data profiles are available for loading */\n  @Input() hasMoreDataProfiles: boolean = false;\n  /** Loading state for data profiles */\n  @Input() isLoadingDataProfiles: boolean = false;\n  /** Natural text actions options for while loop condition */\n  @Input() naturalTextActionsOptions: any[] = [];\n  /** Function to process template variables (similar to step-builder-condition) */\n  @Input() setConditionTemplateVariables: (template: any) => any[] = () => [];\n  /** Show \"Add Step Between\" button above nested steps */\n  @Input() addStepBetweenAbove: boolean = false;\n  /** Show \"Add Step Between\" button below nested steps */\n  @Input() addStepBetweenBelow: boolean = false;\n  /** @deprecated Use addStepBetweenAbove and addStepBetweenBelow instead. If set, applies to both buttons. */\n  @Input() addStepBetween: boolean = false;\n\n  /** When non-null, edit mode is open: 'stepRow' = edit UI in step row only, 'branchRow' = edit UI in branch row only */\n  editContext: 'stepRow' | 'branchRow' | null = null;\n\n  /** Base left padding for step rows (matches px-4 = 16px) plus 24px per nesting level (matches pl-10 = 40px at level 1). */\n  getRowPaddingLeftPx(): number {\n    const level = Number(this.nestingLevel) || 0;\n    return 16 + (level * 24);\n  }\n\n  /** Which branch index is being edited when editContext === 'branchRow' (0 = IF TRUE, 1+ = ELSE IF) */\n  editingBranchIndex: number = 0;\n\n  /** True when editContext is set (either step row or branch row edit). */\n  get isEditing(): boolean {\n    return this.editContext !== null;\n  }\n\n  /** Array of ELSE IF branches in edit mode */\n  elseIfBranches: Array<{\n    id: string;\n    form: FormGroup;\n    selectedTemplate: any;\n    templateVariables: any[];\n    templateVariablesForm: FormGroup;\n    snapshot: { conditionLeft?: string; conditionOperator?: string; conditionRight?: string };\n  }> = [];\n\n  /** Form for edit mode; bound to cqa-dynamic-select and cqa-custom-input */\n  editForm!: FormGroup;\n\n  /** Operator dropdown config (IS, IS NOT, CONTAINS, etc.) */\n  operatorSelectConfig!: DynamicSelectFieldConfig;\n  /** Condition left operand dropdown config (natural text actions with IF_CONDITION) */\n  conditionLeftSelectConfig!: DynamicSelectFieldConfig;\n\n  /** Snapshot for Cancel revert */\n  private editSnapshot: { conditionLeft?: string; conditionOperator?: string; conditionRight?: string } = {};\n  \n  /** Selected template for IF condition */\n  selectedTemplate: any = null;\n  /** Template variables for IF condition */\n  templateVariables: any[] = [];\n  /** Form group for template variables */\n  templateVariablesForm!: FormGroup;\n\n  @ViewChild('viewDetailsTrigger', { static: false }) viewDetailsTrigger?: ElementRef<HTMLElement>;\n\n  @Output() toggleExpanded = new EventEmitter<{config: ConditionStepConfig, expanded: boolean}>();\n  @Output() conditionChange = new EventEmitter<string>();\n  @Output() branchStepChange = new EventEmitter<{ branch: ConditionBranch; step: TestCaseStepConfig; stepIndex: number }>();\n  @Output() addStep = new EventEmitter<{ branch: ConditionBranch }>();\n  /** Emitted when a nested loop-step emits addStepForLoop (empty state plus button). */\n  @Output() addStepForLoop = new EventEmitter<{ loopStepConfig: LoopStepConfig }>();\n  @Output() deleteStep = new EventEmitter<{ branch: ConditionBranch; stepIndex: number }>();\n  @Output() addBranch = new EventEmitter<void>();\n  /** Emitted when user clicks \"Add Else\" so the parent can call POST test_steps with conditionType CONDITION_ELSE */\n  @Output() addElse = new EventEmitter<{ conditionStepConfig: ConditionStepConfig }>();\n  /** Payload can be branch only (legacy) or { branch, stepNumber } for delete modal label e.g. \"Step 5 ELSE\". */\n  @Output() deleteBranch = new EventEmitter<ConditionBranch | { branch: ConditionBranch; stepNumber?: number | string }>();\n  @Output() duplicate = new EventEmitter<void>();\n  @Output() delete = new EventEmitter<void>();\n  @Output() edit = new EventEmitter<{ step: TestCaseStepConfig; index: number }>();\n  @Output() moreOptions = new EventEmitter<void>();\n  @Output() viewDetails = new EventEmitter<ViewDetailsPayload>();\n  @Output() editInDepth = new EventEmitter<{ step: TestCaseStepConfig; index?: number; templateOverride?: any; isCreateMode?: boolean; createModeBranchData?: any }>();\n  @Output() dndDropInZone = new EventEmitter<{ event: DndDropEvent; targetList: TestCaseStepConfig[] }>();\n  /** Emit when more data profiles need to be loaded */\n  @Output() loadMoreDataProfiles = new EventEmitter<string>();\n  /** Emit when data profile search query changes */\n  @Output() searchDataProfiles = new EventEmitter<string>();\n  /** Emit when a nested step is updated (e.g., Apply button clicked in loop-step edit mode) */\n  @Output() stepUpdate = new EventEmitter<TestCaseStepConfig>();\n  /** Re-emit when a nested step (e.g. normal-step) emits clickAction (e.g. element/label click for popup) */\n  @Output() clickAction = new EventEmitter<{ event: MouseEvent; step: TestCaseStepConfig }>();\n  /** Re-emit addStepBetweenClick from nested renderers */\n  @Output() addStepBetweenClick = new EventEmitter<{step: TestCaseStepConfig, index: number, position: 'ABOVE' | 'BELOW'}>();\n  @Output() selectionChange = new EventEmitter<boolean>();\n  /** Re-emit when nested step group emits openExternal (redirect to step group in new tab) */\n  @Output() openExternal = new EventEmitter<{ step: TestCaseStepConfig }>();\n\n  onDndDrop(event: DndDropEvent, branch: ConditionBranch): void {\n    this.dndDropInZone.emit({ event, targetList: branch.nestedSteps });\n  }\n\n  /** Emit clickAction when user clicks on condition/branch action badges (element, test_data, etc.) so parent can open edit modals */\n  onConditionActionClick(event: MouseEvent, branch?: ConditionBranch): void {\n    if (this.isInsideStepGroup) return;\n    const step: TestCaseStepConfig = branch?.id != null\n      ? { ...this.config, id: String(branch.id) } as TestCaseStepConfig\n      : this.config;\n    this.clickAction.emit({ event, step });\n  }\n\n  /** Forward clickAction from nested steps only when not inside a step-group (Element/Test Data modals disabled there). */\n  onNestedClickAction(payload: { event: MouseEvent; step: TestCaseStepConfig }): void {\n    if (!this.isInsideStepGroup) {\n      this.clickAction.emit(payload);\n    }\n  }\n\n  constructor(\n    private fb: FormBuilder,\n    private cdr: ChangeDetectorRef\n  ) {}\n\n  ngOnInit(): void {\n    if (this.config) {\n      this.id = this.config.id;\n      this.stepNumber = this.config.stepNumber;\n      this.condition = this.config.condition;\n      this.branches = this.config.branches || [];\n      this.expanded = this.config.expanded !== undefined ? this.config.expanded : true;\n      this.selected = (this.config as any).selected || false;\n    }\n    this.buildEditForm();\n    this.buildOperatorSelectConfig();\n    this.updateConditionLeftSelectConfig();\n  }\n\n  ngOnChanges(changes: any): void {\n    if (changes['config'] && this.config) {\n      this.selected = (this.config as any).selected || false;\n      // Update condition and branches when config changes (important for immediate UI updates)\n      // This ensures the UI reflects changes immediately, even if config object reference doesn't change\n      if (this.config.condition !== undefined) {\n        this.condition = this.config.condition;\n      }\n      if (this.config.branches) {\n        this.branches = this.config.branches;\n      }\n      // Trigger change detection to ensure UI updates\n      this.cdr.detectChanges();\n    }\n    if (changes['condition'] && this.condition !== undefined) {\n      // Condition input changed, update from config if available\n      if (this.config && this.config.condition !== undefined) {\n        this.condition = this.config.condition;\n      }\n      // Trigger change detection\n      this.cdr.detectChanges();\n    }\n    if (changes['branches'] && this.branches) {\n      // Branches changed, trigger change detection\n      this.cdr.detectChanges();\n    }\n    if (changes['naturalTextActionsOptions']) {\n      this.updateConditionLeftSelectConfig();\n      // Rebuild form when options are loaded to populate initial value from naturalTextActionId\n      if (this.editForm && this.naturalTextActionsOptions && this.naturalTextActionsOptions.length > 0) {\n        this.rebuildEditFormWithNaturalTextAction();\n      }\n    }\n  }\n\n  /** Rebuild edit form when naturalTextActionsOptions are loaded to populate from naturalTextActionId */\n  private rebuildEditFormWithNaturalTextAction(): void {\n    if (!this.editForm) {\n      return;\n    }\n    const configWithId = this.config as any;\n    if (configWithId.naturalTextActionId && this.naturalTextActionsOptions && this.naturalTextActionsOptions.length > 0) {\n      const matchingOption = this.naturalTextActionsOptions.find(\n        (option: any) => String(option.id) === String(configWithId.naturalTextActionId)\n      );\n      if (matchingOption) {\n        const naturalText = matchingOption.naturalText ?? matchingOption.name ?? matchingOption.value ?? '';\n        if (naturalText) {\n          const currentValue = this.editForm.get('conditionLeft')?.value ?? '';\n          // Only update if current value is empty or doesn't match\n          if (!currentValue || currentValue !== naturalText) {\n            this.editForm.get('conditionLeft')?.setValue(naturalText);\n          }\n        }\n        // Get the full template object (NaturalTextActions) from the option\n        const fullTemplate = matchingOption.template || matchingOption;\n        // Store selected template and get variables\n        this.selectedTemplate = fullTemplate;\n        if (fullTemplate && fullTemplate.variables) {\n          this.templateVariables = this.setConditionTemplateVariables(fullTemplate);\n          this.buildTemplateVariablesForm();\n        }\n      }\n    }\n  }\n\n  private buildEditForm(): void {\n    // If config has naturalTextActionId, find the matching natural text action\n    let conditionLeftValue = '';\n    const configWithId = this.config as any;\n    if (configWithId.naturalTextActionId && this.naturalTextActionsOptions && this.naturalTextActionsOptions.length > 0) {\n      const matchingOption = this.naturalTextActionsOptions.find(\n        (option: any) => String(option.id) === String(configWithId.naturalTextActionId)\n      );\n      if (matchingOption) {\n        // Use naturalText exactly as received from API\n        conditionLeftValue = matchingOption.naturalText ?? matchingOption.name ?? matchingOption.value ?? '';\n        // Get the full template object (NaturalTextActions) from the option\n        const fullTemplate = matchingOption.template || matchingOption;\n        // Store selected template and get variables\n        this.selectedTemplate = fullTemplate;\n        if (fullTemplate && fullTemplate.variables) {\n          this.templateVariables = this.setConditionTemplateVariables(fullTemplate);\n          this.buildTemplateVariablesForm();\n        }\n      }\n    }\n    \n    // If no naturalTextActionId match found, parse from condition string\n    if (!conditionLeftValue) {\n      const { left } = this.parseCondition(this.condition);\n      conditionLeftValue = left;\n    }\n    \n    const { operator, right } = this.parseCondition(this.condition);\n    this.editForm = this.fb.group({\n      conditionLeft: [conditionLeftValue],\n      conditionOperator: [operator],\n      conditionRight: [right],\n    });\n    \n    // Initialize template variables form if not already initialized\n    if (!this.templateVariablesForm) {\n      this.templateVariablesForm = this.fb.group({});\n    }\n  }\n\n  private buildElseIfBranch(index?: number): {\n    id: string;\n    form: FormGroup;\n    selectedTemplate: any;\n    templateVariables: any[];\n    templateVariablesForm: FormGroup;\n    snapshot: { conditionLeft?: string; conditionOperator?: string; conditionRight?: string };\n  } {\n    // Initialize ELSE IF form with empty values or from existing ELSE IF branch if available\n    // Use getAllBranchesFlat to include chained nextBranch ELSE IFs\n    const elseIfBranches = this.getAllBranchesFlat().filter(b => b.type === 'else-if');\n    const branchIndex = index !== undefined ? index : elseIfBranches.length;\n    const elseIfBranch = elseIfBranches[branchIndex];\n    const elseCondition = elseIfBranch?.action || '';\n    const { left, operator, right } = this.parseCondition(elseCondition);\n    \n    const form = this.fb.group({\n      conditionLeft: [left],\n      conditionOperator: [operator],\n      conditionRight: [right],\n    });\n    \n    const templateVariablesForm = this.fb.group({});\n    \n    return {\n      id: `else-if-${Date.now()}-${Math.random()}`,\n      form,\n      selectedTemplate: null,\n      templateVariables: [],\n      templateVariablesForm,\n      snapshot: { conditionLeft: left, conditionOperator: operator, conditionRight: right }\n    };\n  }\n\n  private buildOperatorSelectConfig(): void {\n    const options: SelectOption[] = [\n      { id: 'is', value: 'is', name: 'IS', label: 'IS' },\n      { id: 'is not', value: 'is not', name: 'IS NOT', label: 'IS NOT' },\n      { id: 'contains', value: 'contains', name: 'CONTAINS', label: 'CONTAINS' },\n      { id: 'equals', value: 'equals', name: 'EQUALS', label: 'EQUALS' },\n      { id: 'starts with', value: 'starts with', name: 'STARTS WITH', label: 'STARTS WITH' },\n      { id: 'ends with', value: 'ends with', name: 'ENDS WITH', label: 'ENDS WITH' },\n    ];\n    this.operatorSelectConfig = {\n      key: 'conditionOperator',\n      placeholder: 'Operator',\n      searchable: false,\n      options,\n    };\n  }\n\n  /** Update condition left select config with filtered natural text actions (IF_CONDITION only) */\n  private updateConditionLeftSelectConfig(): void {\n    // Filter natural text actions to only include those with stepActionType === \"IF_CONDITION\"\n    const filteredOptions = (this.naturalTextActionsOptions || []).filter((option: any) => {\n      return option.stepActionType === 'IF_CONDITION';\n    });\n\n    this.conditionLeftSelectConfig = {\n      key: 'conditionLeft',\n      placeholder: 'Select Condition',\n      searchable: true,\n      options: filteredOptions,\n    };\n  }\n\n  /** Options for the condition left autocomplete (IF_CONDITION natural text actions) */\n  get conditionLeftAutocompleteOptions(): CqaAutocompleteOption[] {\n    const opts = this.conditionLeftSelectConfig?.options ?? [];\n    return opts.map((option: any) => {\n      // Use naturalText exactly as received from API, fallback to name/value/id\n      const naturalText = option.naturalText ?? option.name ?? option.value ?? String(option.id ?? '');\n      return {\n        value: naturalText,\n        label: naturalText,\n        // Store the full template object (NaturalTextActions) for template variables processing\n        // Use option.template if available (full NaturalTextActions), otherwise use option itself\n        template: option.template || option,\n      } as CqaAutocompleteOption & { template?: any };\n    });\n  }\n\n  /**\n   * Display value for IF/ELSE IF condition autocomplete.\n   * - For IF (step row / IF branch edit), show naturalText from option matching naturalTextActionId when form is empty.\n   * - For ELSE IF branch edit, always use the form value (so clearing leaves the field empty instead of reverting to IF).\n   */\n  get conditionLeftDisplayValue(): string {\n    const configWithId = this.config as any;\n    const formValue = this.editForm?.get('conditionLeft')?.value ?? '';\n    const isFormHtml = formValue && (String(formValue).includes('<') || String(formValue).includes('>'));\n\n    // When editing an ELSE IF branch, don't fall back to IF's naturalText; just show the current form value.\n    const isEditingElseIfBranch =\n      this.editContext === 'branchRow' &&\n      typeof this.editingBranchIndex === 'number' &&\n      this.editingBranchIndex > 0;\n    if (isEditingElseIfBranch) {\n      if (isFormHtml) return '';\n      return formValue;\n    }\n\n    if (configWithId?.naturalTextActionId != null && this.naturalTextActionsOptions?.length) {\n      const matchingOption = this.naturalTextActionsOptions.find(\n        (option: any) => String(option.id) === String(configWithId.naturalTextActionId)\n      );\n      if (matchingOption) {\n        const naturalText = matchingOption.naturalText ?? matchingOption.name ?? matchingOption.value ?? '';\n        if (naturalText) {\n          const naturalTextStr = String(naturalText);\n          if (!formValue || formValue === naturalTextStr || isFormHtml) return naturalTextStr;\n          return formValue;\n        }\n      }\n    }\n    if (isFormHtml) return '';\n    return formValue;\n  }\n\n  onConditionLeftSelect(option: CqaAutocompleteOption & { template?: any }): void {\n    this.editForm?.get('conditionLeft')?.setValue(option.value);\n    \n    // Get template from option - option.template should contain the full NaturalTextActions object\n    const matchingTemplate = option.template;\n    \n    // If template not in option, try to find from naturalTextActionsOptions by matching naturalText\n    let fullTemplate = matchingTemplate;\n    if (!fullTemplate || !fullTemplate.variables) {\n      const optVal = (option.value ?? '').toString().trim();\n      const matchingOption = this.naturalTextActionsOptions.find(\n        (opt: any) => {\n          const n = (opt.naturalText ?? opt.name ?? opt.value ?? '').toString().trim();\n          return n === optVal || (opt.template && (opt.template as any).naturalText?.toString().trim() === optVal);\n        }\n      );\n      // Use template property from option if available, otherwise use the option itself\n      fullTemplate = matchingOption?.template || matchingOption;\n    }\n    \n    if (fullTemplate && fullTemplate.variables) {\n      // Store the full template for reference\n      this.selectedTemplate = fullTemplate;\n      \n      // Get template variables using the provided function\n      // Pass the full NaturalTextActions object which has the variables property\n      const variables = this.setConditionTemplateVariables(fullTemplate);\n      console.log('Template variables loaded:', variables, 'from template:', fullTemplate);\n      \n      this.templateVariables = variables || [];\n      // Build form for template variables\n      this.buildTemplateVariablesForm();\n      // Trigger change detection to update the template\n      this.cdr.detectChanges();\n    } else {\n      console.log('No matching template found or template has no variables', {\n        fullTemplate,\n        hasVariables: fullTemplate?.variables,\n        optionValue: option.value,\n        optionTemplate: option.template\n      });\n      this.selectedTemplate = null;\n      this.templateVariables = [];\n      if (!this.templateVariablesForm) {\n        this.templateVariablesForm = this.fb.group({});\n      }\n      // Trigger change detection to update the template\n      this.cdr.detectChanges();\n    }\n    // Auto-open Edit In depth when user selects a condition from the autocomplete.\n    // Pass the selected template so the modal shows the newly selected template, not the old step template.\n    // Prefer selectedTemplate (validated), then fullTemplate, then option.template (from autocomplete)\n    const templateToPass = this.selectedTemplate || fullTemplate || option.template;\n    setTimeout(() => this.onEditInDepth(templateToPass), 100);\n  }\n  \n  private buildTemplateVariablesForm(): void {\n    if (!this.templateVariablesForm) {\n      this.templateVariablesForm = this.fb.group({});\n    }\n    \n    // Clear existing form controls\n    Object.keys(this.templateVariablesForm.controls).forEach(key => {\n      this.templateVariablesForm.removeControl(key);\n    });\n    \n    // Get existing template variables data from config if available\n    const configWithData = this.config as any;\n    const existingData = configWithData.templateVariablesData || {};\n    \n    // Add form controls for each variable\n    this.templateVariables.forEach(variable => {\n      // Try to get value from existing data first, then from variable default\n      let defaultValue: any;\n      if (existingData.hasOwnProperty(variable.name)) {\n        defaultValue = existingData[variable.name];\n      } else {\n        defaultValue = variable.type === 'boolean' \n          ? (variable.value === true || variable.value === 'true' || variable.value === 1)\n          : (variable.value || '');\n      }\n      \n      // Convert boolean string to boolean\n      if (variable.type === 'boolean' && typeof defaultValue === 'string') {\n        defaultValue = defaultValue === 'true' || defaultValue === '1';\n      }\n      \n      this.templateVariablesForm.addControl(variable.name, new FormControl(defaultValue));\n    });\n  }\n\n  onElseConditionLeftSelect(option: CqaAutocompleteOption & { template?: any }, branchId: string): void {\n    const branch = this.elseIfBranches.find(b => b.id === branchId);\n    if (!branch) return;\n    \n    branch.form?.get('conditionLeft')?.setValue(option.value);\n    \n    // Get template from option - option.template should contain the full NaturalTextActions object\n    const matchingTemplate = option.template;\n    \n    // If template not in option, try to find from naturalTextActionsOptions by matching naturalText\n    let fullTemplate = matchingTemplate;\n    if (!fullTemplate || !fullTemplate.variables) {\n      const matchingOption = this.naturalTextActionsOptions.find(\n        (opt: any) => opt.naturalText === option.value || opt.name === option.value || opt.value === option.value\n      );\n      // Use template property from option if available, otherwise use the option itself\n      fullTemplate = matchingOption?.template || matchingOption;\n    }\n    \n    if (fullTemplate && fullTemplate.variables) {\n      // Store the full template for reference\n      branch.selectedTemplate = fullTemplate;\n      // Get template variables using the provided function\n      branch.templateVariables = this.setConditionTemplateVariables(fullTemplate);\n      // Build form for template variables\n      this.buildElseTemplateVariablesForm(branch);\n      // Trigger change detection to update the template\n      this.cdr.detectChanges();\n    } else {\n      branch.selectedTemplate = null;\n      branch.templateVariables = [];\n      if (!branch.templateVariablesForm) {\n        branch.templateVariablesForm = this.fb.group({});\n      }\n      // Trigger change detection to update the template\n      this.cdr.detectChanges();\n    }\n    // Auto-open Edit In depth when user selects a condition from the ELSE IF autocomplete.\n    // For existing branch: pass branch and branchIndex so modal shows \"Edit Step N\".\n    // For new branch (id starts with \"else-if-\" = temp UI id): pass isCreateMode so modal shows \"Create Step\" and calls create API on save.\n    const configBranch = this.getBranchById(branchId);\n    const branchIndex = this.getBranchIndexById(branchId);\n    const isNewBranch = typeof branchId === 'string' && branchId.startsWith('else-if-');\n    setTimeout(() => this.onEditInDepth(fullTemplate, configBranch ?? undefined, branchIndex >= 0 ? branchIndex : undefined, isNewBranch, branch), 100);\n  }\n  \n  private buildElseTemplateVariablesForm(branch: {\n    id: string;\n    form: FormGroup;\n    selectedTemplate: any;\n    templateVariables: any[];\n    templateVariablesForm: FormGroup;\n    snapshot: { conditionLeft?: string; conditionOperator?: string; conditionRight?: string };\n  }): void {\n    if (!branch.templateVariablesForm) {\n      branch.templateVariablesForm = this.fb.group({});\n    }\n    \n    // Clear existing form controls\n    Object.keys(branch.templateVariablesForm.controls).forEach(key => {\n      branch.templateVariablesForm.removeControl(key);\n    });\n    \n    // Get existing template variables data from config if available (for ELSE IF branch)\n    const configWithData = this.config as any;\n    const existingData = configWithData.elseTemplateVariablesData || {};\n    \n    // Add form controls for each variable\n    branch.templateVariables.forEach(variable => {\n      // Try to get value from existing data first, then from variable default\n      let defaultValue: any;\n      if (existingData.hasOwnProperty(variable.name)) {\n        defaultValue = existingData[variable.name];\n      } else {\n        defaultValue = variable.type === 'boolean' \n          ? (variable.value === true || variable.value === 'true' || variable.value === 1)\n          : (variable.value || '');\n      }\n      \n      // Convert boolean string to boolean\n      if (variable.type === 'boolean' && typeof defaultValue === 'string') {\n        defaultValue = defaultValue === 'true' || defaultValue === '1';\n      }\n      \n      branch.templateVariablesForm.addControl(variable.name, new FormControl(defaultValue));\n    });\n  }\n\n  onAddElse(): void {\n    // Add a new ELSE IF branch (UI row only; APIs are called when user clicks Apply)\n    const newBranch = this.buildElseIfBranch();\n    this.elseIfBranches.push(newBranch);\n  }\n\n  onAddElseBranch(): void {\n    // Emit so parent can call POST test_steps with conditionType CONDITION_ELSE\n    if (this.config) {\n      this.addElse.emit({ conditionStepConfig: this.config });\n    }\n  }\n\n  onRemoveElse(branchId: string): void {\n    // Remove the ELSE IF branch with the given ID\n    const index = this.elseIfBranches.findIndex(b => b.id === branchId);\n    if (index !== -1) {\n      this.elseIfBranches.splice(index, 1);\n    }\n  }\n\n  /** Strip HTML tags from a string to get plain text */\n  private stripHtmlTags(html: string): string {\n    if (!html || typeof html !== 'string') return html;\n    // Create a temporary div element to parse HTML and extract text\n    const div = document.createElement('div');\n    div.innerHTML = html;\n    return div.textContent || div.innerText || html.replace(/<[^>]*>/g, '');\n  }\n\n  /** Parse condition string into left, operator, right (e.g. \"Usertype is Premium\")\n   * Strips HTML tags before parsing to handle formatted conditions */\n  private parseCondition(c: string): { left: string; operator: string; right: string } {\n    if (!c || typeof c !== 'string') {\n      return { left: '', operator: 'is', right: '' };\n    }\n    // Strip HTML tags before parsing to avoid issues with formatted conditions\n    const plainText = this.stripHtmlTags(c).trim();\n    const operators = [' is not ', ' is ', ' contains ', ' equals ', ' starts with ', ' ends with '];\n    for (const op of operators) {\n      const i = plainText.toLowerCase().indexOf(op);\n      if (i !== -1) {\n        return {\n          left: plainText.slice(0, i).trim(),\n          operator: op.trim(),\n          right: plainText.slice(i + op.length).trim(),\n        };\n      }\n    }\n    return { left: plainText, operator: 'is', right: '' };\n  }\n\n  /** Build condition string from form values */\n  private buildConditionFromForm(): string {\n    let left = this.editForm.get('conditionLeft')?.value ?? '';\n    const op = this.editForm.get('conditionOperator')?.value ?? 'is';\n    const right = this.editForm.get('conditionRight')?.value ?? '';\n    \n    // If left is an ID (number), find the naturalText from options\n    if (left && this.naturalTextActionsOptions && this.naturalTextActionsOptions.length > 0) {\n      const leftValue = String(left);\n      // Check if it's a number (ID) or if we need to find the naturalText\n      const isNumericId = !isNaN(Number(leftValue)) && leftValue.trim() !== '';\n      \n      if (isNumericId) {\n        // Find the option by ID and use its naturalText\n        const selectedAction = this.naturalTextActionsOptions.find(\n          (option: any) => String(option.id) === leftValue\n        );\n        if (selectedAction && selectedAction.naturalText) {\n          left = String(selectedAction.naturalText);\n        }\n      } else {\n        // Check if it's already a naturalText or needs to be found\n        const selectedAction = this.naturalTextActionsOptions.find(\n          (option: any) => option.naturalText === left || option.name === left || option.value === left\n        );\n        if (selectedAction && selectedAction.naturalText) {\n          left = String(selectedAction.naturalText);\n        }\n      }\n    }\n    \n    return [left, op, right].filter(Boolean).join(' ');\n  }\n\n  onEditFormFieldChange(controlName: string, value: string): void {\n    this.editForm.get(controlName)?.setValue(value);\n  }\n\n  /** Count and summarize condition branches using their display step numbers.\n   * Example: IF + 2x ELSE IF + ELSE → \"Steps 6-9 (4 steps)\". */\n  /**\n   * Returns a flat list of all branches including those chained via nextBranch.\n   * Used for counting, badge display, and summary when the condition uses a chained structure.\n   */\n  getAllBranchesFlat(): ConditionBranch[] {\n    const result: ConditionBranch[] = [];\n    const traverse = (branches: ConditionBranch[]) => {\n      for (const b of branches) {\n        result.push(b);\n        if (b.nextBranch) traverse([b.nextBranch]);\n      }\n    };\n    traverse(this.branches || []);\n    return result;\n  }\n\n  getStepsSummary(): string {\n    const allBranches = this.getAllBranchesFlat();\n    const branchCount = allBranches.length;\n    if (branchCount === 0) {\n      return '0 steps';\n    }\n\n    const first = this.getBranchDisplayNumber(0);\n    const last = this.getBranchDisplayNumber(branchCount - 1);\n\n    if (branchCount === 1) {\n      return `Steps ${first} (1 step)`;\n    }\n    return `Steps ${first}-${last} (${branchCount} steps)`;\n  }\n\n  /** Branch type badges for step row: IF, ELSE IF (with count if multiple), ELSE */\n  getBranchTypeBadges(): { label: string; count?: number; type: 'if' | 'else-if' | 'else'; badgeClass: string }[] {\n    const badges: { label: string; count?: number; type: 'if' | 'else-if' | 'else'; badgeClass: string }[] = [];\n    const allBranches = this.getAllBranchesFlat();\n    const elseIfCount = allBranches.filter(b => b.type === 'else-if').length;\n    const hasElse = this.hasElseBranch;\n\n    badges.push({ label: 'IF', type: 'if', badgeClass: 'cqa-bg-[#0DBD7D1A] cqa-text-[#0D542B] cqa-border cqa-border-solid cqa-border-[#0DBD7D]' });\n    if (elseIfCount > 0) {\n      badges.push({\n        label: 'ELSE IF',\n        count: elseIfCount > 1 ? elseIfCount : undefined,\n        type: 'else-if',\n        badgeClass: 'cqa-bg-yellow-50 cqa-text-yellow-700 cqa-border cqa-border-solid cqa-border-yellow-200'\n      });\n    }\n    if (hasElse) {\n      badges.push({ label: 'ELSE', type: 'else', badgeClass: 'cqa-bg-red-50 cqa-text-red-700 cqa-border cqa-border-solid cqa-border-red-200' });\n    }\n    return badges;\n  }\n\n  /** Condition text as plain text (strips HTML), truncated with \"...\" if long */\n  getConditionPlainText(maxLength: number = 60): string {\n    if (!this.condition || typeof this.condition !== 'string') return '';\n    const plain = this.condition.replace(/<[^>]*>/g, '').trim();\n    if (plain.length <= maxLength) return plain;\n    let truncated = plain.slice(0, maxLength);\n    // Trim trailing punctuation to avoid \"....\" when text ends with \".\"\n    truncated = truncated.replace(/[.,;:!?]+$/, '');\n    return truncated + '...';\n  }\n\n  /** Event key-value pairs for display, excluding customEvent */\n  getEventDetailsForDisplay(): { key: string; value: string }[] {\n    const event = this.config?.event;\n    if (!event || typeof event !== 'object') return [];\n    return Object.entries(event)\n      .filter(([key]) => key !== 'customEvent')\n      .map(([key, value]) => ({\n        key,\n        value: value != null ? String(value) : ''\n      }));\n  }\n\n  /** Event key-value pairs for a branch (e.g. selector, element) - for IF uses config.event, for ELSE IF/ELSE uses branch.event */\n  getBranchEventDetailsForDisplay(branch: ConditionBranch): { key: string; value: string }[] {\n    const event = (branch as any).event ?? (branch.type === 'if' ? this.config?.event : undefined);\n    if (!event || typeof event !== 'object') return [];\n    return Object.entries(event)\n      .filter(([key]) => key !== 'customEvent')\n      .map(([key, value]) => ({\n        key,\n        value: value != null ? String(value) : ''\n      }));\n  }\n\n  onToggleExpanded(): void {\n    this.expanded = !this.expanded;\n    this.toggleExpanded.emit({config:this.config, expanded:this.expanded});\n  }\n\n  onConditionChange(value: string): void {\n    this.condition = value;\n    this.conditionChange.emit(value);\n  }\n\n  onBranchStepChange(branch: ConditionBranch, step: TestCaseStepConfig, stepIndex: number): void {\n    this.branchStepChange.emit({ branch, step, stepIndex });\n  }\n\n  /** Re-emit openExternal from nested step group so redirect works for step groups inside condition branches. */\n  onNestedOpenExternal(payload: { step: TestCaseStepConfig }): void {\n    if (payload?.step) {\n      this.openExternal.emit(payload);\n    }\n  }\n\n  onNestedToggleExpanded(event: boolean | {config: TestCaseStepConfig, expanded: boolean}, branch: ConditionBranch, step: TestCaseStepConfig, index: number): void {\n    // Handle both boolean and object formats\n    if (typeof event === 'object' && event !== null && 'expanded' in event) {\n      // Object format from step-group: {config, expanded}\n      (step as any).expanded = event.expanded;\n      // Check if the event's config is a step-group (not the current step)\n      // This ensures nested step-group events bubble up correctly\n      if (this.isStepGroup(event.config)) {\n        // Re-emit the toggleExpanded event with the object format, preserving the original config\n        // Cast to satisfy TypeScript - the renderer accepts TestCaseStepConfig which includes StepGroupConfig\n        this.toggleExpanded.emit({config: event.config as any as ConditionStepConfig, expanded: event.expanded});\n      }\n    } else {\n      // Boolean format from other step types\n      (step as any).expanded = event as boolean;\n    }\n    this.onBranchStepChange(branch, step, index);\n  }\n\n  onAddStep(branch: ConditionBranch): void {\n    this.addStep.emit({ branch });\n  }\n\n  /** Handle addStepForLoop event from nested loop-step (empty state plus button). */\n  onAddStepForLoop(event: { loopStepConfig: LoopStepConfig }, branch: ConditionBranch): void {\n    // Re-emit addStepForLoop so it bubbles up to the portal, which will handle creating the step\n    // with the correct parentId (loop step id) and branch context\n    this.addStepForLoop.emit(event);\n  }\n\n  onDeleteStep(branch: ConditionBranch, stepIndex: number): void {\n    this.deleteStep.emit({ branch, stepIndex });\n  }\n\n  /** Re-emit edit from nested step in a branch so the portal can open edit modal (same as root level). */\n  onNestedEdit(event: { step: TestCaseStepConfig; index: number }): void {\n    if (event?.step != null) this.edit.emit(event as any);\n  }\n\n  /** Re-emit duplicate from nested step in a branch so the portal can duplicate (same as root level). */\n  onNestedDuplicate(event: any, step: TestCaseStepConfig): void {\n    this.duplicate.emit((event && event.step != null) ? event : { step } as any);\n  }\n\n  onAddBranch(): void {\n    this.addBranch.emit();\n  }\n\n  onDeleteBranch(branch: ConditionBranch): void {\n    const branchIndex = this.branches?.indexOf(branch) ?? 0;\n    const displayNumber = this.getBranchDisplayNumber(branchIndex);\n    this.deleteBranch.emit({ branch, stepNumber: displayNumber });\n  }\n\n  onNestedConditionAddBranch(nestedStep: ConditionStepConfig): void {\n    // Add a new branch to the nested condition step\n    if (!nestedStep.branches) {\n      nestedStep.branches = [];\n    }\n    const newBranch: ConditionBranch = {\n      type: nestedStep.branches.length === 0 ? 'if' : 'else',\n      label: nestedStep.branches.length === 0 ? 'IF TRUE' : 'ELSE',\n      stepType: StepTypes.CONDITION_IF,\n      nestedSteps: []\n    };\n    nestedStep.branches.push(newBranch);\n  }\n\n  onNestedConditionDeleteBranch(nestedStep: ConditionStepConfig, payload: ConditionBranch | { branch: ConditionBranch; stepNumber?: number | string }): void {\n    // Re-emit deleteBranch so step-list can open delete modal and call API.\n    const branch = payload && typeof payload === 'object' && 'branch' in payload ? (payload as { branch: ConditionBranch }).branch : (payload as ConditionBranch);\n    const branchIndex = this.branches?.indexOf(branch) ?? 0;\n    const displayNumber = this.getBranchDisplayNumber(branchIndex);\n    const toEmit: { branch: ConditionBranch; stepNumber?: number | string } =\n      payload && typeof payload === 'object' && 'branch' in payload\n        ? { branch: (payload as { branch: ConditionBranch }).branch, stepNumber: (payload as any).stepNumber ?? displayNumber }\n        : { branch: payload as ConditionBranch, stepNumber: displayNumber };\n    this.deleteBranch.emit(toEmit);\n  }\n\n  isNormalStep(step: TestCaseStepConfig): step is NormalStepConfig {\n    return 'eventType' in step;\n  }\n\n  isLoopStep(step: TestCaseStepConfig): step is LoopStepConfig {\n    return 'loopType' in step;\n  }\n\n  isConditionStep(step: TestCaseStepConfig): step is ConditionStepConfig {\n    return 'condition' in step && 'branches' in step;\n  }\n\n  isStepGroup(step: TestCaseStepConfig): step is StepGroupConfig {\n    return 'groupName' in step;\n  }\n\n  getBranchLabel(branch: ConditionBranch): string {\n    return branch.label || (branch.type === 'if' ? 'IF TRUE' : branch.type === 'else-if' ? 'ELSE IF' : 'ELSE');\n  }\n\n  /** Condition text for branch header display: IF uses main condition, ELSE IF/ELSE use branch.action */\n  getBranchConditionDisplay(branch: ConditionBranch): string {\n    if (branch.type === 'if') {\n      return this.condition ?? '';\n    }\n    return branch.action ?? '';\n  }\n\n  /** Start marker label for each branch: START IF, START ELSE IF, or START ELSE */\n  getStartBranchLabel(branch: ConditionBranch): string {\n    return branch.type === 'if' ? 'START IF' : branch.type === 'else-if' ? 'START ELSE IF' : 'START ELSE';\n  }\n\n  /** End marker label for each branch: END IF, END ELSE IF, or END ELSE */\n  getEndBranchLabel(branch: ConditionBranch): string {\n    return branch.type === 'if' ? 'END IF' : branch.type === 'else-if' ? 'END ELSE IF' : 'END ELSE';\n  }\n\n  /** Branch display number: full hierarchical number. IF = stepNumber (e.g. 2.1.50), ELSE IF = 2.1.51, ELSE = 2.1.52. */\n  getBranchDisplayNumber(branchIndex: number): number | string {\n    if (branchIndex === 0) {\n      return this.stepNumber;\n    }\n    const parts = String(this.stepNumber).split('.');\n    const lastNum = parseInt(parts[parts.length - 1], 10) || 0;\n    parts[parts.length - 1] = String(lastNum + branchIndex);\n    return parts.join('.');\n  }\n\n  /** Find branch in branches by id (for elseIfBranches which use same id). */\n  getBranchById(branchId?: string | number): ConditionBranch | undefined {\n    if (branchId == null) return undefined;\n    return this.branches?.find(b => b.id != null && String(b.id) === String(branchId));\n  }\n\n  /** Get branch index in branches by id. */\n  getBranchIndexById(branchId?: string | number): number {\n    const branch = this.getBranchById(branchId);\n    return branch != null ? (this.branches?.indexOf(branch) ?? -1) : -1;\n  }\n\n  getBranchColorClass(branch: ConditionBranch): string {\n    if (branch.type === 'if') {\n      return 'cqa-bg-[#0DBD7D1A]';\n    } else if (branch.type === 'else-if') {\n      return 'cqa-bg-yellow-50 cqa-border-yellow-200';\n    } else {\n      return 'cqa-bg-red-50 cqa-border-red-200';\n    }\n  }\n\n  getBranchTextColor(branch: ConditionBranch): string {\n    if (branch.type === 'if') {\n      return 'cqa-text-[#0D542B]';\n    } else if (branch.type === 'else-if') {\n      return 'cqa-text-yellow-700';\n    } else {\n      return 'cqa-text-red-700';\n    }\n  }\n\n  /** Created date for branch header display: branch-specific or fallback to config. */\n  getBranchCreatedDate(branch: ConditionBranch): number | undefined {\n    return branch.createdDate ?? this.config?.createdDate;\n  }\n\n  /** True when condition already has an ELSE branch (disables Add ELSE IF / Add ELSE). */\n  get hasElseBranch(): boolean {\n    return this.getAllBranchesFlat().some(b => b.type === 'else');\n  }\n\n  onOpenExternal(): void {\n    // Not used in condition step, but needed for recursive step groups\n  }\n\n  /** Shared init for edit mode; then call onEditFromStepRow or onEditFromBranchRow to set context. */\n  private initEditForm(branch?: ConditionBranch | null): void {\n    this.editSnapshot = {\n      conditionLeft: this.editForm?.get('conditionLeft')?.value,\n      conditionOperator: this.editForm?.get('conditionOperator')?.value,\n      conditionRight: this.editForm?.get('conditionRight')?.value,\n    };\n\n    let conditionLeftValue = '';\n    const configWithId = this.config as any;\n    const editingElseIf = !!branch && branch.type === 'else-if';\n    const hasTemplate =\n      !editingElseIf &&\n      configWithId.naturalTextActionId &&\n      this.naturalTextActionsOptions &&\n      this.naturalTextActionsOptions.length > 0;\n\n    if (hasTemplate) {\n      const matchingAction = this.naturalTextActionsOptions.find(\n        (option: any) => String(option.id) === String(configWithId.naturalTextActionId)\n      );\n      if (matchingAction) {\n        // For template-based conditions, use the full naturalText (it's a complete sentence)\n        conditionLeftValue = matchingAction.naturalText ?? matchingAction.name ?? matchingAction.value ?? '';\n      }\n    }\n\n    if (!conditionLeftValue) {\n      // No template or editing ELSE IF: parse from the appropriate condition string\n      const sourceText =\n        editingElseIf && branch?.action ? String(branch.action) : (this.condition ?? '');\n      const { left } = this.parseCondition(sourceText);\n      conditionLeftValue = left;\n    }\n\n    // Only parse operator and right if we don't have a template (templates are complete sentences)\n    if (!hasTemplate) {\n      const sourceText =\n        editingElseIf && branch?.action ? String(branch.action) : (this.condition ?? '');\n      const { operator, right } = this.parseCondition(sourceText);\n      this.editForm?.get('conditionOperator')?.setValue(operator);\n      this.editForm?.get('conditionRight')?.setValue(right);\n    } else {\n      // For templates, clear operator and right (template naturalText is the full condition)\n      this.editForm?.get('conditionOperator')?.setValue('is');\n      this.editForm?.get('conditionRight')?.setValue('');\n    }\n    \n    this.editForm?.get('conditionLeft')?.setValue(conditionLeftValue);\n    this.elseIfBranches = [];\n  }\n\n  /** Edit from step row: edit UI appears in the step row only (first branch stays read-only). */\n  onEditFromStepRow(): void {\n    this.initEditForm();\n    this.editContext = 'stepRow';\n  }\n\n  /** Edit from branch row: edit UI appears in that branch row (IF TRUE or ELSE IF). */\n  onEditFromBranchRow(branchIndex: number = 0): void {\n    const branch = this.branches && this.branches.length > branchIndex\n      ? this.branches[branchIndex]\n      : undefined;\n    this.initEditForm(branch);\n    this.editingBranchIndex = branchIndex;\n    this.editContext = 'branchRow';\n  }\n\n  /** @deprecated Use onEditFromStepRow or onEditFromBranchRow. Kept for compatibility. */\n  onEdit(): void {\n    this.initEditForm();\n    this.editContext = 'branchRow';\n  }\n\n  onEditCancel(): void {\n    this.editForm?.get('conditionLeft')?.setValue(this.editSnapshot.conditionLeft ?? '');\n    this.editForm?.get('conditionOperator')?.setValue(this.editSnapshot.conditionOperator ?? 'is');\n    this.editForm?.get('conditionRight')?.setValue(this.editSnapshot.conditionRight ?? '');\n    \n    // Reset all ELSE IF branches to their snapshots\n    this.elseIfBranches.forEach(branch => {\n      branch.form?.get('conditionLeft')?.setValue(branch.snapshot.conditionLeft ?? '');\n      branch.form?.get('conditionOperator')?.setValue(branch.snapshot.conditionOperator ?? 'is');\n      branch.form?.get('conditionRight')?.setValue(branch.snapshot.conditionRight ?? '');\n    });\n    \n    // Clear all ELSE IF branches\n    this.elseIfBranches = [];\n\n    this.editContext = null;\n    this.editingBranchIndex = 0;\n  }\n\n  /**\n   * Build payload for one ELSE IF branch (action, naturalTextActionId, templateVariablesData, testDataList)\n   * so the parent can create the step via POST then PUT when Apply is clicked.\n   */\n  private buildElseIfBranchPayload(branch: {\n    form: FormGroup;\n    selectedTemplate: any;\n    templateVariables: any[];\n    templateVariablesForm: FormGroup;\n  }): { action: string; naturalTextActionId?: number; templateVariablesData?: any; testDataList?: Array<{ testData: string; testDataType: string }> } {\n    const conditionLeft = branch.form?.get('conditionLeft')?.value ?? '';\n    const conditionOperator = branch.form?.get('conditionOperator')?.value ?? 'is';\n    const conditionRight = branch.form?.get('conditionRight')?.value ?? '';\n    let naturalTextActionId: number | undefined;\n    let naturalTextValue: string = conditionLeft;\n    if (conditionLeft && this.naturalTextActionsOptions && this.naturalTextActionsOptions.length > 0) {\n      const leftValue = String(conditionLeft);\n      const isNumericId = !isNaN(Number(leftValue)) && leftValue.trim() !== '';\n      const selectedAction: any = isNumericId\n        ? this.naturalTextActionsOptions.find((opt: any) => String(opt.id) === leftValue)\n        : this.naturalTextActionsOptions.find(\n            (opt: any) => opt.naturalText === conditionLeft || opt.name === conditionLeft || opt.value === conditionLeft\n          );\n      if (selectedAction) {\n        naturalTextActionId = selectedAction.id;\n        naturalTextValue = selectedAction.naturalText || selectedAction.name || selectedAction.value || conditionLeft;\n      }\n    }\n    const templateVariablesData: any = {};\n    const testDataList: Array<{ testData: string; testDataType: string }> = [];\n    if (branch.templateVariablesForm && branch.templateVariables && branch.templateVariables.length > 0) {\n      branch.templateVariables.forEach((variable: any) => {\n        const value = branch.templateVariablesForm.get(variable.name)?.value;\n        if (value !== undefined && value !== null && value !== '') {\n          templateVariablesData[variable.name] = value;\n          testDataList.push({ testData: String(value), testDataType: 'raw' });\n        }\n      });\n    }\n    const action = [naturalTextValue, conditionOperator, conditionRight].filter(Boolean).join(' ');\n    return {\n      action: action || (branch.selectedTemplate?.naturalText ?? ''),\n      ...(naturalTextActionId !== undefined && { naturalTextActionId }),\n      ...(Object.keys(templateVariablesData).length > 0 && { templateVariablesData }),\n      ...(testDataList.length > 0 && { testDataList }),\n    };\n  }\n\n  onEditApply(): void {\n    const formValues = this.editForm.value;\n    const conditionLeft = formValues.conditionLeft ?? '';\n    const conditionOperator = formValues.conditionOperator ?? 'is';\n    const conditionRight = formValues.conditionRight ?? '';\n\n    // Find the selected natural text action and get naturalText (not ID)\n    let naturalTextActionId: number | undefined;\n    let naturalTextValue: string = conditionLeft; // Default to conditionLeft\n    \n    if (conditionLeft && this.naturalTextActionsOptions && this.naturalTextActionsOptions.length > 0) {\n      const leftValue = String(conditionLeft);\n      const isNumericId = !isNaN(Number(leftValue)) && leftValue.trim() !== '';\n      \n      let selectedAction: any;\n      if (isNumericId) {\n        // Find by ID and get naturalText\n        selectedAction = this.naturalTextActionsOptions.find(\n          (option: any) => String(option.id) === leftValue\n        );\n      } else {\n        // Find by naturalText, name, or value\n        selectedAction = this.naturalTextActionsOptions.find(\n          (option: any) => option.naturalText === conditionLeft || option.name === conditionLeft || option.value === conditionLeft\n        );\n      }\n      \n      if (selectedAction) {\n        naturalTextActionId = selectedAction.id;\n        // Use naturalText if available, otherwise fall back to name or value\n        naturalTextValue = selectedAction.naturalText || selectedAction.name || selectedAction.value || conditionLeft;\n      }\n    }\n    \n    // Collect template variables values for event object\n    const templateVariablesData: any = {};\n    // Build testDataList array in the order of template variables\n    const testDataList: Array<{ testData: string; testDataType: string }> = [];\n    \n    if (this.templateVariablesForm && this.templateVariables.length > 0) {\n      this.templateVariables.forEach(variable => {\n        const value = this.templateVariablesForm.get(variable.name)?.value;\n        if (value !== undefined && value !== null && value !== '') {\n          // Add to event object (e.g., source_value, target_value)\n          templateVariablesData[variable.name] = value;\n          // Add to testDataList array (order matters - maintain template variable order)\n          testDataList.push({\n            testData: String(value),\n            testDataType: 'raw'\n          });\n        }\n      });\n    }\n    \n    // Build condition string\n    // If we have a naturalTextActionId (template), use the full naturalTextValue as-is (it's already a complete sentence)\n    // Otherwise, build from parts: conditionLeft + operator + conditionRight\n    let rawCondition: string;\n    if (naturalTextActionId !== undefined) {\n      // Template-based condition: naturalTextValue is the full template (e.g., \"Check the text #{label} is present on the current page\")\n      rawCondition = naturalTextValue;\n    } else {\n      // Manual condition: build from parts\n      rawCondition = [naturalTextValue, conditionOperator, conditionRight].filter(Boolean).join(' ');\n    }\n\n    const isEditingBranchRow = this.editContext === 'branchRow';\n    const branchForEdit = isEditingBranchRow && this.branches && this.branches.length > this.editingBranchIndex\n      ? this.branches[this.editingBranchIndex]\n      : null;\n    const isEditingElseIfBranch = !!branchForEdit && branchForEdit.type === 'else-if';\n\n    // For display in the header, substitute #{variable} placeholders with HTML badges using templateVariablesData.\n    // This mirrors the renderer behavior so users never see raw #{label} text while editing.\n    // - For IF (step row / IF branch edit), update main condition header.\n    // - For ELSE IF edit, update only that branch's action text; keep IF header unchanged.\n    const formattedForDisplay = this.substituteTemplateVariablesToHtmlForCondition(rawCondition, templateVariablesData);\n    if (isEditingElseIfBranch && branchForEdit) {\n      // Update ELSE IF branch action for immediate UI feedback\n      (branchForEdit as any).action = formattedForDisplay;\n    } else {\n      this.condition = formattedForDisplay;\n    }\n\n    // Build payload for each newly added ELSE IF (so parent can call POST then PUT when Apply is clicked)\n    const newElseIfBranches = this.elseIfBranches.map(b => this.buildElseIfBranchPayload(b));\n    \n    // Update config with new values\n    const updatedConfigBase: ConditionStepConfig & {\n      id?: string;\n      naturalTextActionId?: number;\n      templateVariablesData?: any;\n      testDataList?: Array<{ testData: string; testDataType: string }>;\n      newElseIfBranches?: Array<{ action: string; naturalTextActionId?: number; templateVariablesData?: any; testDataList?: Array<{ testData: string; testDataType: string }> }>;\n      isElseIfBranch?: boolean;\n      parentConditionId?: string;\n    } = {\n      ...this.config,\n      stepType: this.config.stepType || StepTypes.CONDITION_IF, // Ensure stepType is set\n      ...(naturalTextActionId !== undefined && { naturalTextActionId } as any),\n      ...(Object.keys(templateVariablesData).length > 0 && { templateVariablesData } as any),\n      ...(testDataList.length > 0 && { testDataList } as any),\n      ...(newElseIfBranches.length > 0 && { newElseIfBranches } as any),\n    };\n\n    let updatedConfig: typeof updatedConfigBase;\n    if (isEditingElseIfBranch && branchForEdit && branchForEdit.id != null) {\n      // Editing existing ELSE IF branch: target that branch's step ID and send raw condition so backend updates the branch only.\n      // Any new ELSE IF added here chains off this specific ELSE IF (handled by step-list since updatedConfig.id = this branch's id).\n      updatedConfig = {\n        ...updatedConfigBase,\n        id: String(branchForEdit.id),\n        condition: rawCondition,\n        isElseIfBranch: true,\n        parentConditionId: String(this.config.id),\n      } as any;\n    } else {\n      // IF condition edit (step row or IF branch row): use formatted condition for display.\n      // When editing from the IF TRUE branch row (branchIndex === 0), any new ELSE IFs must be\n      // inserted directly after the IF branch — not at the end of the chain.\n      // Pass insertAfterBranchId so step-list knows the exact insertion point.\n      const isEditingIfBranchRow = isEditingBranchRow && branchForEdit?.type === 'if' && branchForEdit.id != null;\n      updatedConfig = {\n        ...updatedConfigBase,\n        condition: this.condition,\n        ...(isEditingIfBranchRow && { insertAfterBranchId: String(branchForEdit!.id) } as any),\n      } as any;\n    }\n    \n    // Emit individual change event\n    this.conditionChange.emit(this.condition);\n    \n    // Emit step update event with full config (includes newElseIfBranches so parent can create steps on Apply)\n    console.log('Condition-step: Emitting stepUpdate event', updatedConfig);\n    this.stepUpdate.emit(updatedConfig);\n\n    this.editContext = null;\n  }\n\n  /**\n   * Local helper to substitute #{variable} placeholders in the condition text with HTML badge spans.\n   * Mirrors the portal renderer's substituteTemplateVariablesToHtml so inline edit mode never shows raw #{label}.\n   */\n  private substituteTemplateVariablesToHtmlForCondition(\n    text: string,\n    variables: Record<string, unknown> | null | undefined\n  ): string {\n    if (!text || typeof text !== 'string') return text;\n    const data = variables && typeof variables === 'object' ? variables : {};\n    const escape = (v: string) => {\n      const div = document.createElement('div');\n      div.textContent = v;\n      return div.innerHTML;\n    };\n    const elementVars = ['label', 'description', 'element', 'selector', 'ai_task', 'query', 'custom_code'];\n    const attributeVars = ['attribute'];\n\n    return text.replace(/\\#\\{([^}]+)\\}/g, (_, key: string) => {\n      const val = (data as any)[key];\n      const displayVal = val != null && val !== '' ? String(val) : key;\n      const escaped = escape(displayVal);\n      if (elementVars.includes(key)) {\n        return `<span data-key=\"${key}\" data-event-key=\"${key}\" class=\"element\">${escaped}</span>`;\n      }\n      if (attributeVars.includes(key)) {\n        return `<span data-key=\"${key}\" data-event-key=\"${key}\" class=\"attribute\">${escaped}</span>`;\n      }\n      return `<span data-key=\"${key}\" data-event-key=\"${key}\" class=\"test_data\">${escaped}</span>`;\n    });\n  }\n\n  /**\n   * Emit editInDepth. When branch is provided (ELSE IF/ELSE branch row), use branch's nested condition step\n   * and branch display number for correct \"Edit Step N\" title. When isCreateMode (new ELSE IF), modal shows \"Create In depth\" and calls create API on save.\n   */\n  onEditInDepth(templateOverride?: any, branch?: ConditionBranch, branchIndex?: number, isCreateMode?: boolean, elseIfBranch?: any): void {\n    this.moreOptions.emit();\n    let step: TestCaseStepConfig;\n    let index: number | undefined;\n    if (branch != null && branchIndex != null && branchIndex >= 0 && !isCreateMode) {\n      // Branch row (ELSE IF/ELSE) - existing branch: use nested condition step if present, else main config with branch id\n      const nestedCondition = branch.nestedSteps?.[0] as ConditionStepConfig | undefined;\n      step = (nestedCondition && this.isConditionStep(nestedCondition))\n        ? nestedCondition\n        : ({ ...this.config, id: branch.id != null ? String(branch.id) : this.config.id } as TestCaseStepConfig);\n      // Display index: getBranchDisplayNumber(1)=93 -> index 92 for \"Edit Step 93\"\n      const displayNum = this.getBranchDisplayNumber(branchIndex);\n      index = typeof displayNum === 'number' ? displayNum - 1 : (typeof displayNum === 'string' ? parseInt(String(displayNum), 10) - 1 : 0);\n    } else if (isCreateMode) {\n      // Create mode (new ELSE IF branch) - don't set index so modal shows \"Create Step\"\n      step = this.config as TestCaseStepConfig;\n      index = undefined;\n    } else {\n      // Main step row, IF branch\n      index = typeof this.index === 'number'\n        ? this.index\n        : (typeof this.stepNumber === 'number' ? this.stepNumber : (typeof this.stepNumber === 'string' ? parseInt(this.stepNumber, 10) : 0));\n      step = this.config as TestCaseStepConfig;\n    }\n    const payload: { step: TestCaseStepConfig; index?: number; templateOverride?: any; isCreateMode?: boolean; createModeBranchData?: any } = {\n      step,\n      index: index !== undefined ? (isNaN(index) ? 0 : Math.max(0, index)) : undefined,\n    };\n    if (templateOverride) {\n      payload.templateOverride = templateOverride;\n    }\n    if (isCreateMode && elseIfBranch) {\n      payload.isCreateMode = true;\n      // Pass template variables form data for create mode\n      if (elseIfBranch.templateVariablesForm && elseIfBranch.selectedTemplate) {\n        payload.createModeBranchData = {\n          templateVariablesForm: elseIfBranch.templateVariablesForm,\n          selectedTemplate: elseIfBranch.selectedTemplate\n        };\n      }\n    }\n    this.editInDepth.emit(payload);\n  }\n\n  onLink(): void {\n    // Not used in condition step, but needed for recursive step groups\n  }\n\n  onDuplicate(): void {\n    this.duplicate.emit();\n  }\n\n  onDelete(): void {\n    this.delete.emit();\n  }\n\n  onSelectionChange(checked: boolean): void {\n    this.selected = checked;\n    this.selectionChange.emit(checked);\n  }\n\n  onMoreOptions(): void {\n    this.moreOptions.emit();\n  }\n\n  onViewDetails(event?: MouseEvent): void {\n    if (event) {\n      event.preventDefault();\n      event.stopPropagation();\n    }\n    \n    if (!this.config.description || this.config.description.trim() === '') {\n      return;\n    }\n\n    if (event) {\n      this.viewDetails.emit({\n        event,\n        title: 'IF / ELSE Step Details',\n        description: this.config.description,\n      });\n    }\n  }\n  \n  /** Get select config for a template variable */\n  getSelectConfigForVariable(variable: any, branchIdOrIsElse: string | boolean = false): DynamicSelectFieldConfig {\n    const options: SelectOption[] = (variable.options || []).map((opt: string) => ({\n      id: opt,\n      value: opt,\n      name: opt,\n      label: opt\n    }));\n\n    // If branchIdOrIsElse is a string, it's a branch ID; otherwise it's a boolean for backward compatibility\n    let form: FormGroup;\n    if (typeof branchIdOrIsElse === 'string') {\n      const branch = this.elseIfBranches.find(b => b.id === branchIdOrIsElse);\n      form = branch?.templateVariablesForm || this.fb.group({});\n    } else {\n      form = branchIdOrIsElse ? (this.elseIfBranches[0]?.templateVariablesForm || this.fb.group({})) : this.templateVariablesForm;\n    }\n\n    return {\n      key: variable.name,\n      placeholder: `Select ${variable.label}`,\n      multiple: false,\n      searchable: false,\n      options: options,\n      onChange: (value: any) => {\n        if (form && form.get(variable.name)) {\n          form.get(variable.name)?.setValue(value);\n        }\n      }\n    };\n  }\n}\n","<div [class]=\"'cqa-flex cqa-flex-col cqa-border cqa-border-solid cqa-border-[#E5E7EB] ' + (isNested ? ' cqa-pl-[24px]' : '')\" style=\"min-height: 50px\">\n  <!-- Inline Edit Mode: shown in first branch row below when user clicks Edit from branch row (top block hidden) -->\n  <div *ngIf=\"false && isEditing\" class=\"cqa-py-2.5 cqa-px-4 cqa-flex cqa-flex-col cqa-gap-3\" (click)=\"$event.stopPropagation()\" (mousedown)=\"$event.stopPropagation()\" style=\"min-height: 50px\">\n    <!-- First Row: CONDITION tag, autocomplete, IF/ELSE indicators, Edit In depth, Cancel/Apply -->\n    <div class=\"cqa-flex cqa-items-center cqa-gap-3 cqa-justify-between\">\n      <div class=\"cqa-flex cqa-items-center cqa-gap-3 cqa-flex-grow\">\n        <!-- CONDITION Tag (orange) -->\n        <span class=\"cqa-px-1.5 cqa-rounded-md cqa-text-[#EA580C] cqa-text-[10px] cqa-leading-[15px] cqa-font-medium cqa-bg-[#FFEDD5]\">\n          CONDITION\n        </span>\n\n        <!-- First field: left operand (e.g. Usertype) - autocomplete with IF_CONDITION natural text actions -->\n        <cqa-autocomplete\n          *ngIf=\"editForm\"\n          [options]=\"conditionLeftAutocompleteOptions\"\n          [value]=\"conditionLeftDisplayValue\"\n          (valueChange)=\"onEditFormFieldChange('conditionLeft', $event)\"\n          (optionSelect)=\"onConditionLeftSelect($event)\"\n          placeholder=\"Select Condition\"\n          [fullWidth]=\"true\"\n          class=\"cqa-w-full cqa-max-w-[216px]\"></cqa-autocomplete>\n\n        <!-- Second Row: Template Variables Section (shown when template is selected, inline before Edit In depth) -->\n        <div *ngIf=\"selectedTemplate && templateVariables && templateVariables.length > 0\" class=\"cqa-flex cqa-flex-row cqa-flex-wrap cqa-gap-3\">\n          <ng-container *ngFor=\"let variable of templateVariables\">\n            <!-- Boolean variables with mat-slide-toggle -->\n            <ng-container *ngIf=\"variable.type === 'boolean'\">\n              <div class=\"cqa-flex cqa-items-center cqa-gap-2\">\n                <label class=\"cqa-text-[12px] cqa-font-medium cqa-text-gray-700\">\n                  {{ variable.label }}\n                </label>\n                <mat-slide-toggle\n                  [checked]=\"templateVariablesForm.get(variable.name)?.value || variable.value || false\"\n                  (change)=\"templateVariablesForm.get(variable.name)?.setValue($event.checked)\"\n                  color=\"primary\">\n                </mat-slide-toggle>\n              </div>\n            </ng-container>\n            \n            <!-- Non-boolean variables -->\n            <ng-container *ngIf=\"variable.type !== 'boolean' && variable.name !== 'custom_code'\">\n              <!-- Dropdown for select variables -->\n              <ng-container *ngIf=\"variable.name === 'type' || variable.name === 'scrollTo' || variable.options\">\n                <div class=\"cqa-flex cqa-flex-col\" style=\"min-width: 150px;\">\n                  <!-- <label class=\"cqa-text-[12px] cqa-font-medium cqa-text-gray-700 cqa-mb-1\">\n                    {{ variable.label }}\n                  </label> -->\n                  <cqa-dynamic-select \n                    [form]=\"templateVariablesForm\"\n                    [config]=\"getSelectConfigForVariable(variable, false)\">\n                  </cqa-dynamic-select>\n                </div>\n              </ng-container>\n              <!-- Text Input for other variables -->\n              <ng-container *ngIf=\"variable.name !== 'type' && variable.name !== 'scrollTo' && !variable.options\">\n                <div class=\"cqa-flex cqa-flex-col\" style=\"min-width: 150px;\">\n                  <!-- <label class=\"cqa-text-[12px] cqa-font-medium cqa-text-gray-700 cqa-mb-1\">\n                    {{ variable.label }}\n                  </label> -->\n                  <cqa-custom-input\n                    [placeholder]=\"'Enter ' + variable.label\"\n                    [value]=\"templateVariablesForm.get(variable.name)?.value || variable.value || ''\"\n                    [fullWidth]=\"true\"\n                    (valueChange)=\"templateVariablesForm.get(variable.name)?.setValue($event)\">\n                  </cqa-custom-input>\n                </div>\n              </ng-container>\n            </ng-container>\n          </ng-container>\n        </div>\n\n        <!-- IF / ELSE indicators -->\n        <span class=\"cqa-px-2 cqa-py-[2px] cqa-rounded-[4px] cqa-text-[8px] cqa-leading-[12px] cqa-bg-[#DCFCE7] cqa-text-[#008236] cqa-border cqa-border-solid cqa-border-[#B9F8CF] cqa-flex cqa-items-center cqa-gap-1.5\">\n          <svg width=\"8\" height=\"8\" viewBox=\"0 0 8 8\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M6.66634 2L2.99967 5.66667L1.33301 4\" stroke=\"#008236\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/></svg>\n          IF\n        </span>\n        <!-- Add ELSE IF button - disabled when ELSE already exists -->\n        <button\n          type=\"button\"\n          (click)=\"onAddElse()\"\n          [disabled]=\"hasElseBranch\"\n          class=\"cqa-px-2 cqa-py-[2px] cqa-rounded-[4px] cqa-text-[8px] cqa-leading-[12px] cqa-bg-[#fff9e9] cqa-text-[#E65100] cqa-border cqa-border-solid cqa-border-[#feecbd] cqa-flex cqa-items-center cqa-gap-1.5 cqa-transition-colors\"\n          [class.cqa-cursor-pointer]=\"!hasElseBranch\"\n          [class.cqa-cursor-not-allowed]=\"hasElseBranch\"\n          [class.cqa-opacity-60]=\"hasElseBranch\">\n          Add ELSE IF\n        </button>\n        <!-- Add Else button - disabled when ELSE already exists -->\n        <button\n          type=\"button\"\n          (click)=\"onAddElseBranch()\"\n          [disabled]=\"hasElseBranch\"\n          class=\"cqa-px-2 cqa-py-[2px] cqa-rounded-[4px] cqa-text-[8px] cqa-leading-[12px] cqa-bg-[#fff9e9] cqa-text-[#E65100] cqa-border cqa-border-solid cqa-border-[#feecbd] cqa-flex cqa-items-center cqa-gap-1.5 cqa-transition-colors\"\n          [class.cqa-cursor-pointer]=\"!hasElseBranch\"\n          [class.cqa-cursor-not-allowed]=\"hasElseBranch\"\n          [class.cqa-opacity-60]=\"hasElseBranch\">\n          Add ELSE\n        </button>\n\n        <!-- Edit In depth link -->\n        <a href=\"#\" (click)=\"onEditInDepth(); $event.preventDefault()\"\n          class=\"cqa-text-[#3F43EE] cqa-text-[10px] cqa-leading-[15px] cqa-font-medium cqa-flex cqa-items-center cqa-gap-[2px] cqa-no-underline\">\n          Edit In depth\n          <svg width=\"8\" height=\"8\" viewBox=\"0 0 8 8\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M2.03809 6.74329L2.62809 7.33329L5.96142 3.99996L2.62809 0.666626L2.03809 1.25663L4.78142 3.99996L2.03809 6.74329Z\" fill=\"#3F43EE\"/></svg>\n        </a>      \n      </div>\n      <!-- Cancel / Apply buttons - shown on IF row when no ELSE IF branches are present -->\n      <div *ngIf=\"elseIfBranches.length === 0\" class=\"cqa-flex cqa-items-center cqa-gap-2\">\n        <cqa-button variant=\"outlined\" btnSize=\"lg\" [customClass]=\"'cqa-text-[14px] cqa-py-[9px]'\" [text]=\"'Cancel'\" (clicked)=\"onEditCancel()\"></cqa-button>\n        <cqa-button variant=\"filled\" btnSize=\"lg\" [customClass]=\"'cqa-text-[14px] cqa-py-[9px]'\" [text]=\"'Apply'\" (clicked)=\"onEditApply()\"></cqa-button>\n      </div>\n    </div>\n    \n    \n  </div>\n\n  <!-- Step row: always visible (no template edit here; template edit only in branch row below). Has edit/delete. -->\n  <div\n    [class]=\"'step-row cqa-flex cqa-items-center cqa-gap-3 cqa-py-2 cqa-pr-4' + (config?.shouldSkip ? ' cqa-step-skipped' : '')\"\n    [style.opacity]=\"config?.shouldSkip ? '0.6' : null\"\n    [style.padding-left.px]=\"getRowPaddingLeftPx()\"\n    style=\"border-bottom: 1px solid #E5E7EB; min-height: 50px\">\n    <!-- Checkbox/Drag Handle column - same structure as normal-step for alignment -->\n    <div class=\"cqa-inline-flex cqa-items-center\">\n    <div *ngIf=\"isReorder && !isInsideStepGroup\" class=\"cqa-mr-2 cqa-cursor-move cqa-text-[#6B7280] hover:cqa-text-[#111827]\">\n      <svg width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n        <circle cx=\"3\" cy=\"3\" r=\"1.5\" fill=\"currentColor\"/>\n        <circle cx=\"8\" cy=\"3\" r=\"1.5\" fill=\"currentColor\"/>\n        <circle cx=\"13\" cy=\"3\" r=\"1.5\" fill=\"currentColor\"/>\n        <circle cx=\"3\" cy=\"8\" r=\"1.5\" fill=\"currentColor\"/>\n        <circle cx=\"8\" cy=\"8\" r=\"1.5\" fill=\"currentColor\"/>\n        <circle cx=\"13\" cy=\"8\" r=\"1.5\" fill=\"currentColor\"/>\n        <circle cx=\"3\" cy=\"13\" r=\"1.5\" fill=\"currentColor\"/>\n        <circle cx=\"8\" cy=\"13\" r=\"1.5\" fill=\"currentColor\"/>\n        <circle cx=\"13\" cy=\"13\" r=\"1.5\" fill=\"currentColor\"/>\n      </svg>\n    </div>\n    <!-- Checkbox (when isReorder is false and not inside step group - hide for steps inside step groups) -->\n    <label *ngIf=\"editable && !isReorder && !isInsideStepGroup\" class=\"cqa-flex cqa-items-center cqa-cursor-pointer cqa-relative cqa-mr-2\">\n      <input type=\"checkbox\"\n        [ngModel]=\"selected\"\n        (ngModelChange)=\"onSelectionChange($event)\"\n        class=\"cqa-h-4 cqa-w-4 cqa-cursor-pointer cqa-transition-all cqa-appearance-none cqa-rounded shadow hover:cqa-shadow-md cqa-border cqa-border-solid cqa-border-slate-300 cqa-flex-shrink-0\"\n        [class.cqa-bg-[#3F43EE]]=\"selected\"\n        [class.cqa-border-[#3F43EE]]=\"selected\"\n        id=\"check-condition\" />\n      <span class=\"cqa-absolute cqa-text-white cqa-top-1/2 cqa-left-1/2 cqa--translate-x-1/2 cqa--translate-y-1/2 cqa-pointer-events-none cqa-flex cqa-items-center cqa-justify-center\"\n        [class.cqa-opacity-0]=\"!selected\"\n        [class.cqa-opacity-100]=\"selected\">\n        <svg width=\"12\" height=\"13\" viewBox=\"0 0 12 13\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M10 3.125L4.5 8.625L2 6.125\" stroke=\"white\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/></svg>\n      </span>\n    </label>\n    </div>\n    <div *ngIf=\"isInsideStepGroup\" class=\"cqa-ml-1 cqa-mr-1 cqa-text-[#9CA3AF]\">\n      <svg width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n        <path d=\"M11.9998 5.66667H11.3332V4.33333C11.3332 2.49333 9.83984 1 7.99984 1C6.15984 1 4.6665 2.49333 4.6665 4.33333V5.66667H3.99984C3.2665 5.66667 2.6665 6.26667 2.6665 7V13.6667C2.6665 14.4 3.2665 15 3.99984 15H11.9998C12.7332 15 13.3332 14.4 13.3332 13.6667V7C13.3332 6.26667 12.7332 5.66667 11.9998 5.66667ZM5.99984 4.33333C5.99984 3.22667 6.89317 2.33333 7.99984 2.33333C9.1065 2.33333 9.99984 3.22667 9.99984 4.33333V5.66667H5.99984V4.33333ZM11.9998 13.6667H3.99984V7H11.9998V13.6667ZM7.99984 11.6667C8.73317 11.6667 9.33317 11.0667 9.33317 10.3333C9.33317 9.6 8.73317 9 7.99984 9C7.2665 9 6.6665 9.6 6.6665 10.3333C6.6665 11.0667 7.2665 11.6667 7.99984 11.6667Z\" fill=\"currentColor\"/>\n      </svg>\n    </div>\n    <span class=\"cqa-text-[#6B7280] cqa-text-[14px] cqa-leading-[18px] cqa-min-w-[32px]\">{{ stepNumber }}</span>\n    <!-- Expand/Collapse Icon -->\n    <button type=\"button\" (click)=\"onToggleExpanded()\" class=\"cqa-p-0\">\n      <svg [class.cqa-rotate-180]=\"!expanded\" class=\"cqa-transition-transform\" width=\"16\" height=\"16\"\n        viewBox=\"0 0 16 16\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n        <path d=\"M12 10L8 6L4 10\" stroke=\"#6B7280\" stroke-width=\"1.33333\" stroke-linecap=\"round\"\n          stroke-linejoin=\"round\" />\n      </svg>\n    </button>\n\n    <!-- IF/ELSE Icon -->\n    <div><svg width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n        <path d=\"M4 2V10\" stroke=\"#7B3306\" stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n        <path\n          d=\"M12 6C13.1046 6 14 5.10457 14 4C14 2.89543 13.1046 2 12 2C10.8954 2 10 2.89543 10 4C10 5.10457 10.8954 6 12 6Z\"\n          stroke=\"#7B3306\" stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n        <path\n          d=\"M4 14C5.10457 14 6 13.1046 6 12C6 10.8954 5.10457 10 4 10C2.89543 10 2 10.8954 2 12C2 13.1046 2.89543 14 4 14Z\"\n          stroke=\"#7B3306\" stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n        <path d=\"M12 6C12 7.5913 11.3679 9.11742 10.2426 10.2426C9.11742 11.3679 7.5913 12 6 12\" stroke=\"#7B3306\"\n          stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n      </svg></div>\n\n    <!-- IF/ELSE Label -->\n    <span class=\"cqa-font-semibold cqa-text-[#7B3306] cqa-text-[12px] cqa-leading-none\">\n      CONDITION\n    </span>\n\n    <!-- Step row: read-only (condition, summary, actions) when not editing step row -->\n    <ng-container *ngIf=\"editContext !== 'stepRow'\">\n      <!-- First condition text as plain text (no HTML) -->\n      <div *ngIf=\"getConditionPlainText()\" class=\"cqa-flex cqa-items-center cqa-gap-3 cqa-ml-2 cqa-flex-1 cqa-flex-wrap cqa-px-1 cqa-min-w-0\">\n        <span class=\"cqa-text-[#111827] cqa-text-[14px] cqa-leading-[18px] cqa-truncate\">{{ getConditionPlainText() }}</span>\n      </div>\n\n      <div class=\"cqa-flex cqa-items-center cqa-gap-2 cqa-ml-auto cqa-flex-wrap cqa-px-1 cqa-self-center\">\n        <span *ngIf=\"config?.shouldSkip\" class=\"cqa-border cqa-border-solid cqa-border-[#E5E5E5] cqa-rounded-lg cqa-py-0.5 cqa-px-2 cqa-text-[#0A0A0A] cqa-text-[12px] cqa-leading-[15px] cqa-flex-shrink-0\">Skipped</span>\n        <!-- Branch type badges: IF, ELSE IF (with count), ELSE -->\n        <div class=\"cqa-flex cqa-items-center cqa-gap-1.5 cqa-flex-shrink-0\">\n          <span *ngFor=\"let badge of getBranchTypeBadges()\"\n            [class]=\"'cqa-inline-flex cqa-items-center cqa-gap-1 cqa-px-2 cqa-py-0.5 cqa-rounded cqa-text-[10px] cqa-leading-[15px] cqa-font-medium ' + badge.badgeClass\">\n            {{ badge.label }}\n            <ng-container *ngIf=\"badge.count\">+{{ badge.count }}</ng-container>\n          </span>\n        </div>\n        <div\n          class=\"cqa-border cqa-border-solid cqa-border-[#E5E5E5] cqa-rounded-lg cqa-py-0.5 cqa-px-2 cqa-text-[#0A0A0A] cqa-text-[12px] cqa-leading-[15px]\">\n          {{ getStepsSummary() }}\n        </div>\n        <a *ngIf=\"config.description && config.description.trim() !== ''\" #viewDetailsTrigger href=\"#\" (click)=\"onViewDetails($event)\" class=\"cqa-text-[#3F43EE] cqa-text-[10px] cqa-leading-[15px] cqa-font-medium cqa-flex cqa-items-center cqa-gap-1 cqa-no-underline\">View Details<svg width=\"8\" height=\"8\" viewBox=\"0 0 8 8\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M2.03809 6.74329L2.62809 7.33329L5.96142 3.99996L2.62809 0.666626L2.03809 1.25663L4.78142 3.99996L2.03809 6.74329Z\" fill=\"#3F43EE\"/></svg></a>\n        <a href=\"#\" (click)=\"onEditInDepth(); $event.preventDefault()\" class=\"cqa-text-[#3F43EE] cqa-text-[10px] cqa-leading-[15px] cqa-font-medium cqa-flex cqa-items-center cqa-gap-1 cqa-no-underline\">Edit In depth<svg width=\"8\" height=\"8\" viewBox=\"0 0 8 8\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M2.03809 6.74329L2.62809 7.33329L5.96142 3.99996L2.62809 0.666626L2.03809 1.25663L4.78142 3.99996L2.03809 6.74329Z\" fill=\"#3F43EE\"/></svg></a>\n        <!-- Created Date (from API) - last so aligned across all steps, format: 25 Feb 2026 -->\n        <span *ngIf=\"config.createdDate\" class=\"step-date cqa-text-[#6B7280] cqa-text-[12px] cqa-leading-[15px] cqa-ml-auto cqa-flex-shrink-0\">\n          {{ config.createdDate | date:'d MMM yyyy' }}\n        </span>\n      </div>\n    </ng-container>\n\n    <!-- Step row: edit mode (CONDITION, autocomplete, IF, Add ELSE IF, Add ELSE, Edit In depth, Cancel, Apply) when editContext === 'stepRow' -->\n    <ng-container *ngIf=\"editContext === 'stepRow'\">\n      <div class=\"cqa-flex cqa-items-center cqa-gap-3 cqa-ml-2 cqa-flex-1 cqa-flex-wrap cqa-min-w-0\">\n        <span class=\"cqa-px-1.5 cqa-rounded-md cqa-text-[#EA580C] cqa-text-[10px] cqa-leading-[15px] cqa-font-medium cqa-bg-[#FFEDD5]\">CONDITION</span>\n        <cqa-autocomplete\n          *ngIf=\"editForm\"\n          [options]=\"conditionLeftAutocompleteOptions\"\n          [value]=\"conditionLeftDisplayValue\"\n          (valueChange)=\"onEditFormFieldChange('conditionLeft', $event)\"\n          (optionSelect)=\"onConditionLeftSelect($event)\"\n          placeholder=\"Select Condition\"\n          [fullWidth]=\"true\"\n          class=\"cqa-w-full cqa-max-w-[216px]\"></cqa-autocomplete>\n        <span class=\"cqa-px-2 cqa-py-[2px] cqa-rounded-[4px] cqa-text-[8px] cqa-leading-[12px] cqa-bg-[#DCFCE7] cqa-text-[#008236] cqa-border cqa-border-solid cqa-border-[#B9F8CF] cqa-flex cqa-items-center cqa-gap-1.5\">IF</span>\n        <button type=\"button\" (click)=\"onAddElse()\" class=\"cqa-px-2 cqa-py-[2px] cqa-rounded-[4px] cqa-text-[8px] cqa-leading-[12px] cqa-bg-[#fff9e9] cqa-text-[#E65100] cqa-border cqa-border-solid cqa-border-[#feecbd] cqa-flex cqa-items-center cqa-gap-1.5 cqa-transition-colors cqa-cursor-pointer\">Add ELSE IF</button>\n        <button type=\"button\" (click)=\"onAddElseBranch()\" [disabled]=\"hasElseBranch\" [attr.aria-disabled]=\"hasElseBranch\" class=\"cqa-px-2 cqa-py-[2px] cqa-rounded-[4px] cqa-text-[8px] cqa-leading-[12px] cqa-bg-[#fff9e9] cqa-text-[#E65100] cqa-border cqa-border-solid cqa-border-[#feecbd] cqa-flex cqa-items-center cqa-gap-1.5 cqa-transition-colors\" [class.cqa-cursor-pointer]=\"!hasElseBranch\" [class.cqa-cursor-not-allowed]=\"hasElseBranch\" [class.cqa-opacity-60]=\"hasElseBranch\">Add ELSE</button>\n        <a href=\"#\" (click)=\"onEditInDepth(); $event.preventDefault()\" class=\"cqa-text-[#3F43EE] cqa-text-[10px] cqa-leading-[15px] cqa-font-medium cqa-flex cqa-items-center cqa-gap-[2px] cqa-no-underline\">Edit In depth<svg width=\"8\" height=\"8\" viewBox=\"0 0 8 8\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M2.03809 6.74329L2.62809 7.33329L5.96142 3.99996L2.62809 0.666626L2.03809 1.25663L4.78142 3.99996L2.03809 6.74329Z\" fill=\"#3F43EE\"/></svg></a>\n      </div>\n      <div class=\"cqa-flex cqa-items-center cqa-gap-2 cqa-flex-shrink-0\">\n        <cqa-button variant=\"outlined\" btnSize=\"lg\" [customClass]=\"'cqa-text-[14px] cqa-py-[9px]'\" [text]=\"'Cancel'\" (clicked)=\"onEditCancel()\"></cqa-button>\n        <cqa-button variant=\"filled\" btnSize=\"lg\" [customClass]=\"'cqa-text-[14px] cqa-py-[9px]'\" [text]=\"'Apply'\" (clicked)=\"onEditApply()\"></cqa-button>\n      </div>\n    </ng-container>\n  </div>\n\n  <!-- ELSE IF Sections in Edit Mode - shown below step row when editing and has ELSE IF branches -->\n  <ng-container *ngFor=\"let branch of elseIfBranches; let i = index\">\n    <div *ngIf=\"isEditing\" class=\"cqa-py-2.5 cqa-px-1 cqa-flex cqa-flex-col cqa-gap-3 cqa-border-t cqa-border-solid cqa-border-[#E5E7EB]\">\n      <!-- First Row: Remove ELSE IF button, autocomplete, Edit In depth, Cancel/Apply -->\n      <div class=\"cqa-flex cqa-items-center cqa-gap-3 cqa-justify-between\">\n        <div class=\"cqa-flex cqa-items-center cqa-gap-3 cqa-flex-grow\">\n          <!-- Remove ELSE IF button -->\n          <button\n            type=\"button\"\n            (click)=\"onRemoveElse(branch.id)\"\n            class=\"cqa-px-2 cqa-py-[2px] cqa-rounded-[4px] cqa-text-[8px] cqa-leading-[12px] cqa-bg-[#F3F4F6] cqa-text-[#99A1AF] cqa-border cqa-border-solid cqa-border-[#E5E7EB] cqa-cursor-pointer hover:cqa-bg-[#E5E7EB] cqa-transition-colors\">\n            Remove ELSE IF\n          </button>\n\n          <!-- ELSE IF autocomplete field: same as IF condition -->\n          <cqa-autocomplete\n            *ngIf=\"branch.form\"\n            [options]=\"conditionLeftAutocompleteOptions\"\n            [value]=\"branch.form.get('conditionLeft')?.value ?? ''\"\n            (valueChange)=\"branch.form.get('conditionLeft')?.setValue($event)\"\n            (optionSelect)=\"onElseConditionLeftSelect($event, branch.id)\"\n            placeholder=\"Select Condition\"\n            [fullWidth]=\"true\"\n            [compact]=\"true\"\n            class=\"cqa-w-full cqa-max-w-[216px]\"></cqa-autocomplete>\n          \n          <!-- Second Row: ELSE IF Template Variables Section (shown when template is selected, inline before Edit In depth) -->\n          <div *ngIf=\"branch.selectedTemplate && branch.templateVariables && branch.templateVariables.length > 0\" class=\"cqa-flex cqa-flex-row cqa-flex-wrap cqa-gap-3\">\n            <ng-container *ngFor=\"let variable of branch.templateVariables\">\n              <!-- Boolean variables with mat-slide-toggle -->\n              <ng-container *ngIf=\"variable.type === 'boolean'\">\n                <div class=\"cqa-flex cqa-items-center cqa-gap-2\">\n                  <mat-slide-toggle\n                    [checked]=\"branch.templateVariablesForm.get(variable.name)?.value || variable.value || false\"\n                    (change)=\"branch.templateVariablesForm.get(variable.name)?.setValue($event.checked)\"\n                    color=\"primary\">\n                  </mat-slide-toggle>\n                </div>\n              </ng-container>\n              \n              <!-- Non-boolean variables -->\n              <ng-container *ngIf=\"variable.type !== 'boolean' && variable.name !== 'custom_code'\">\n                <ng-container *ngIf=\"variable.name === 'type' || variable.name === 'scrollTo' || variable.options\">\n                  <div class=\"cqa-flex cqa-flex-col\" style=\"min-width: 150px;\">\n                    <cqa-dynamic-select \n                      [form]=\"branch.templateVariablesForm\"\n                      [config]=\"getSelectConfigForVariable(variable, branch.id)\">\n                    </cqa-dynamic-select>\n                  </div>\n                </ng-container>\n                \n                <ng-container *ngIf=\"variable.name !== 'type' && variable.name !== 'scrollTo' && !variable.options\">\n                  <div class=\"cqa-flex cqa-flex-col\" style=\"min-width: 150px;\">\n                    <cqa-custom-input\n                      [value]=\"branch.templateVariablesForm.get(variable.name)?.value || variable.value || ''\"\n                      (valueChange)=\"branch.templateVariablesForm.get(variable.name)?.setValue($event)\"\n                      [placeholder]=\"variable.label\">\n                    </cqa-custom-input>\n                  </div>\n                </ng-container>\n              </ng-container>\n            </ng-container>\n          </div>\n\n          <!-- Edit In depth link -->\n          <a href=\"#\" (click)=\"onEditInDepth(undefined, getBranchById(branch.id), getBranchIndexById(branch.id)); $event.preventDefault()\"\n            class=\"cqa-text-[#3F43EE] cqa-text-[10px] cqa-leading-[15px] cqa-font-medium cqa-flex cqa-items-center cqa-gap-[2px] cqa-no-underline\">\n            Edit In depth\n            <svg width=\"8\" height=\"8\" viewBox=\"0 0 8 8\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M2.03809 6.74329L2.62809 7.33329L5.96142 3.99996L2.62809 0.666626L2.03809 1.25663L4.78142 3.99996L2.03809 6.74329Z\" fill=\"#3F43EE\"/></svg>\n          </a>\n        </div>\n        <!-- Cancel / Apply buttons - shown in last ELSE IF row -->\n        <div *ngIf=\"i === elseIfBranches.length - 1\" class=\"cqa-flex cqa-items-center cqa-gap-2\">\n          <cqa-button variant=\"outlined\" btnSize=\"lg\" [customClass]=\"'cqa-text-[14px] cqa-py-[9px]'\" [text]=\"'Cancel'\" (clicked)=\"onEditCancel()\"></cqa-button>\n          <cqa-button variant=\"filled\" btnSize=\"lg\" [customClass]=\"'cqa-text-[14px] cqa-py-[9px]'\" [text]=\"'Apply'\" (clicked)=\"onEditApply()\"></cqa-button>\n        </div>\n      </div>\n    </div>\n  </ng-container>\n\n  <!-- Expanded Content with Branches (shown when expanded or when editing so edit UI appears in first branch row) -->\n  <div *ngIf=\"expanded || isEditing\" class=\"cqa-flex cqa-flex-col\">\n    <!-- Branches (IF TRUE, ELSE IF, ELSE) -->\n    <div *ngFor=\"let branch of branches; let branchIndex = index\" class=\"condition-branch-row cqa-flex cqa-flex-col\" [attr.data-branch-id]=\"branch?.id\">\n      <!-- Edit mode (IF TRUE branch): shows CONDITION, autocomplete, IF, Add ELSE IF, Add ELSE, Edit In depth, Edit/Delete, Cancel/Apply -->\n      <div\n        *ngIf=\"editContext === 'branchRow' && branchIndex === 0 && editingBranchIndex === 0\"\n        (click)=\"$event.stopPropagation()\"\n        (mousedown)=\"$event.stopPropagation()\"\n        [class]=\"'cqa-px-1 cqa-py-2.5 cqa-text-[12px] cqa-leading-[15px] cqa-flex cqa-items-center cqa-gap-3 cqa-justify-between cqa-flex-wrap ' + getBranchTextColor(branch) + ' ' + getBranchColorClass(branch)\">\n        <div class=\"cqa-flex cqa-items-center cqa-gap-3 cqa-flex-grow cqa-flex-wrap cqa-min-w-0\">\n          <span class=\"cqa-text-[#6B7280] cqa-text-[14px] cqa-leading-[18px] cqa-min-w-[32px] cqa-flex-shrink-0\">{{ getBranchDisplayNumber(branchIndex) }}</span>\n          <span>{{ getBranchLabel(branch) }}</span>\n          <span class=\"cqa-px-1.5 cqa-rounded-md cqa-text-[#EA580C] cqa-text-[10px] cqa-leading-[15px] cqa-font-medium cqa-bg-[#FFEDD5]\">CONDITION</span>\n          <cqa-autocomplete\n            *ngIf=\"editForm\"\n            [options]=\"conditionLeftAutocompleteOptions\"\n            [value]=\"conditionLeftDisplayValue\"\n            (valueChange)=\"onEditFormFieldChange('conditionLeft', $event)\"\n            (optionSelect)=\"onConditionLeftSelect($event)\"\n            placeholder=\"Select Condition\"\n            [fullWidth]=\"true\"\n            class=\"cqa-w-full cqa-max-w-[216px]\"></cqa-autocomplete>\n          <span class=\"cqa-px-2 cqa-py-[2px] cqa-rounded-[4px] cqa-text-[8px] cqa-leading-[12px] cqa-bg-[#DCFCE7] cqa-text-[#008236] cqa-border cqa-border-solid cqa-border-[#B9F8CF] cqa-flex cqa-items-center cqa-gap-1.5\">IF</span>\n          <button type=\"button\" (click)=\"onAddElse(); $event.stopPropagation()\" class=\"cqa-px-2 cqa-py-[2px] cqa-rounded-[4px] cqa-text-[8px] cqa-leading-[12px] cqa-bg-[#fff9e9] cqa-text-[#E65100] cqa-border cqa-border-solid cqa-border-[#feecbd] cqa-flex cqa-items-center cqa-gap-1.5 cqa-transition-colors cqa-cursor-pointer\">Add ELSE IF</button>\n          <button type=\"button\" (click)=\"onAddElseBranch(); $event.stopPropagation()\" [disabled]=\"hasElseBranch\" [attr.aria-disabled]=\"hasElseBranch\" class=\"cqa-px-2 cqa-py-[2px] cqa-rounded-[4px] cqa-text-[8px] cqa-leading-[12px] cqa-bg-[#fff9e9] cqa-text-[#E65100] cqa-border cqa-border-solid cqa-border-[#feecbd] cqa-flex cqa-items-center cqa-gap-1.5 cqa-transition-colors\" [class.cqa-cursor-pointer]=\"!hasElseBranch\" [class.cqa-cursor-not-allowed]=\"hasElseBranch\" [class.cqa-opacity-60]=\"hasElseBranch\">Add ELSE</button>\n          <a href=\"#\" (click)=\"onEditInDepth(undefined, branch, 0); $event.preventDefault()\" class=\"cqa-text-[#3F43EE] cqa-text-[10px] cqa-leading-[15px] cqa-font-medium cqa-flex cqa-items-center cqa-gap-[2px] cqa-no-underline\">Edit In depth<svg width=\"8\" height=\"8\" viewBox=\"0 0 8 8\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M2.03809 6.74329L2.62809 7.33329L5.96142 3.99996L2.62809 0.666626L2.03809 1.25663L4.78142 3.99996L2.03809 6.74329Z\" fill=\"#3F43EE\"/></svg></a>\n        </div>\n        <div class=\"cqa-flex cqa-items-center cqa-gap-2 cqa-flex-shrink-0\">\n          <cqa-button variant=\"outlined\" btnSize=\"lg\" [customClass]=\"'cqa-text-[14px] cqa-py-[9px]'\" [text]=\"'Cancel'\" (clicked)=\"onEditCancel()\"></cqa-button>\n          <cqa-button variant=\"filled\" btnSize=\"lg\" [customClass]=\"'cqa-text-[14px] cqa-py-[9px]'\" [text]=\"'Apply'\" (clicked)=\"onEditApply()\"></cqa-button>\n        </div>\n      </div>\n      <!-- Edit mode (ELSE IF branch): shows CONDITION, autocomplete, Add ELSE IF / Add ELSE, Edit In depth, Cancel/Apply -->\n      <div\n        *ngIf=\"editContext === 'branchRow' && branchIndex === editingBranchIndex && branch.type === 'else-if'\"\n        (click)=\"$event.stopPropagation()\"\n        (mousedown)=\"$event.stopPropagation()\"\n        [class]=\"'cqa-px-1 cqa-py-2.5 cqa-text-[12px] cqa-leading-[15px] cqa-flex cqa-items-center cqa-gap-3 cqa-justify-between cqa-flex-wrap ' + getBranchTextColor(branch) + ' ' + getBranchColorClass(branch)\">\n        <div class=\"cqa-flex cqa-items-center cqa-gap-3 cqa-flex-grow cqa-flex-wrap cqa-min-w-0\">\n          <span class=\"cqa-text-[#6B7280] cqa-text-[14px] cqa-leading-[18px] cqa-min-w-[32px] cqa-flex-shrink-0\">{{ getBranchDisplayNumber(branchIndex) }}</span>\n          <span>{{ getBranchLabel(branch) }}</span>\n          <span class=\"cqa-px-1.5 cqa-rounded-md cqa-text-[#EA580C] cqa-text-[10px] cqa-leading-[15px] cqa-font-medium cqa-bg-[#FFEDD5]\">CONDITION</span>\n          <!-- ELSE IF condition autocomplete: same options and value model as IF, but initialized from this branch's condition -->\n          <cqa-autocomplete\n            *ngIf=\"editForm\"\n            [options]=\"conditionLeftAutocompleteOptions\"\n            [value]=\"conditionLeftDisplayValue\"\n            (valueChange)=\"onEditFormFieldChange('conditionLeft', $event)\"\n            (optionSelect)=\"onConditionLeftSelect($event)\"\n            placeholder=\"Select Condition\"\n            [fullWidth]=\"true\"\n            class=\"cqa-w-full cqa-max-w-[216px]\"></cqa-autocomplete>\n          <button type=\"button\" (click)=\"onAddElse(); $event.stopPropagation()\" class=\"cqa-px-2 cqa-py-[2px] cqa-rounded-[4px] cqa-text-[8px] cqa-leading-[12px] cqa-bg-[#fff9e9] cqa-text-[#E65100] cqa-border cqa-border-solid cqa-border-[#feecbd] cqa-flex cqa-items-center cqa-gap-1.5 cqa-transition-colors cqa-cursor-pointer\">Add ELSE IF</button>\n          <button type=\"button\" (click)=\"onAddElseBranch(); $event.stopPropagation()\" [disabled]=\"hasElseBranch\" [attr.aria-disabled]=\"hasElseBranch\" class=\"cqa-px-2 cqa-py-[2px] cqa-rounded-[4px] cqa-text-[8px] cqa-leading-[12px] cqa-bg-[#fff9e9] cqa-text-[#E65100] cqa-border cqa-border-solid cqa-border-[#feecbd] cqa-flex cqa-items-center cqa-gap-1.5 cqa-transition-colors\" [class.cqa-cursor-pointer]=\"!hasElseBranch\" [class.cqa-cursor-not-allowed]=\"hasElseBranch\" [class.cqa-opacity-60]=\"hasElseBranch\">Add ELSE</button>\n          <a href=\"#\" (click)=\"onEditInDepth(undefined, branch, branchIndex); $event.preventDefault()\" class=\"cqa-text-[#3F43EE] cqa-text-[10px] cqa-leading-[15px] cqa-font-medium cqa-flex cqa-items-center cqa-gap-[2px] cqa-no-underline\">Edit In depth<svg width=\"8\" height=\"8\" viewBox=\"0 0 8 8\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M2.03809 6.74329L2.62809 7.33329L5.96142 3.99996L2.62809 0.666626L2.03809 1.25663L4.78142 3.99996L2.03809 6.74329Z\" fill=\"#3F43EE\"/></svg></a>\n        </div>\n        <div class=\"cqa-flex cqa-items-center cqa-gap-2 cqa-flex-shrink-0\">\n          <cqa-button variant=\"outlined\" btnSize=\"lg\" [customClass]=\"'cqa-text-[14px] cqa-py-[9px]'\" [text]=\"'Cancel'\" (clicked)=\"onEditCancel()\"></cqa-button>\n          <cqa-button variant=\"filled\" btnSize=\"lg\" [customClass]=\"'cqa-text-[14px] cqa-py-[9px]'\" [text]=\"'Apply'\" (clicked)=\"onEditApply()\"></cqa-button>\n        </div>\n      </div>\n      <!-- Branch Header (read-only): display when not editing this branch row. Order: branch content (left), then step-actions, then date (right, same as other steps). -->\n      <div\n        *ngIf=\"editContext !== 'branchRow' || branchIndex !== editingBranchIndex\"\n        [class]=\"'cqa-px-4 cqa-py-2 cqa-text-[12px] cqa-leading-[15px] cqa-flex cqa-items-center cqa-gap-2 cqa-justify-between ' + getBranchTextColor(branch) + ' ' + getBranchColorClass(branch)\">\n        <div class=\"cqa-flex cqa-items-center cqa-gap-2 cqa-flex-grow cqa-flex-wrap cqa-min-w-0\">\n          <span class=\"cqa-text-[#6B7280] cqa-text-[14px] cqa-leading-[18px] cqa-min-w-[32px] cqa-flex-shrink-0\">{{ getBranchDisplayNumber(branchIndex) }}</span>\n          <span>{{ getBranchLabel(branch) }}</span>\n          <span\n            *ngIf=\"getBranchConditionDisplay(branch)\"\n            [innerHTML]=\"getBranchConditionDisplay(branch) | cqaSafeHtml\"\n            (click)=\"onConditionActionClick($event, branch)\"\n            class=\"cqa-text-[#111827] cqa-text-[14px] cqa-leading-[18px] cqa-action-format\"></span>\n          <ng-container *ngIf=\"getBranchEventDetailsForDisplay(branch).length > 0\">\n            <span *ngFor=\"let item of getBranchEventDetailsForDisplay(branch)\" class=\"cqa-inline-flex cqa-items-center cqa-gap-1 cqa-py-0.5 cqa-px-2 cqa-rounded cqa-text-[12px] cqa-leading-[15px] cqa-bg-[#F3F4F6] cqa-text-[#374151] cqa-border cqa-border-solid cqa-border-[#E5E7EB]\" (click)=\"onConditionActionClick($event, branch)\">\n              <span class=\"cqa-font-medium cqa-text-[#6B7280]\">{{ item.key }}:</span>\n              <span class=\"cqa-text-[#111827]\">{{ item.value }}</span>\n            </span>\n          </ng-container>\n        </div>\n        <!-- Right section: step-actions then date (same order as other step types) -->\n        <div *ngIf=\"editable && !isInsideStepGroup && !isReorder\" class=\"step-actions cqa-flex cqa-items-center cqa-gap-1.5 cqa-pr-2 cqa-flex-shrink-0\">\n          <button *ngIf=\"branchIndex === 0 || branch.type === 'else-if'\" type=\"button\" (click)=\"onEditFromBranchRow(branchIndex); $event.stopPropagation()\" title=\"Edit\" class=\"cqa-p-0 cqa-text-[#99A1Af] hover:cqa-text-[#1447E6]\">\n            <svg width=\"14\" height=\"14\" viewBox=\"0 0 14 14\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M7 11.6666H12.25\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M9.55208 2.1128C9.7843 1.88058 10.0993 1.75012 10.4277 1.75012C10.7561 1.75012 11.071 1.88058 11.3033 2.1128C11.5355 2.34502 11.6659 2.65998 11.6659 2.98838C11.6659 3.31679 11.5355 3.63175 11.3033 3.86397L4.29742 10.8704C4.15864 11.0092 3.9871 11.1107 3.79867 11.1656L2.12333 11.6544C2.07314 11.669 2.01993 11.6699 1.96928 11.6569C1.91863 11.6439 1.8724 11.6176 1.83543 11.5806C1.79846 11.5437 1.7721 11.4974 1.75913 11.4468C1.74615 11.3961 1.74703 11.3429 1.76167 11.2927L2.2505 9.61738C2.30546 9.42916 2.40698 9.25783 2.54567 9.11922L9.55208 2.1128Z\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/></svg>\n          </button>\n          <button *ngIf=\"branchIndex === 0 || branch.type === 'else-if'\" type=\"button\" (click)=\"onEditFromBranchRow(branchIndex); $event.stopPropagation()\" title=\"Edit\" class=\"cqa-p-0 cqa-text-[#99A1Af] hover:cqa-text-[#1447E6]\">\n            <svg width=\"14\" height=\"14\" viewBox=\"0 0 14 14\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M8.25 8.75C9.2165 8.75 10 7.9665 10 7C10 6.0335 9.2165 5.25 8.25 5.25C7.2835 5.25 6.5 6.0335 6.5 7C6.5 7.9665 7.2835 8.75 8.25 8.75Z\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M8.75033 2.91663H5.25033C2.99516 2.91663 1.16699 4.7448 1.16699 6.99996C1.16699 9.25512 2.99516 11.0833 5.25033 11.0833H8.75033C11.0055 11.0833 12.8337 9.25512 12.8337 6.99996C12.8337 4.7448 11.0055 2.91663 8.75033 2.91663Z\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/></svg>\n          </button>\n          <button type=\"button\" (click)=\"branchIndex === 0 ? onDelete() : onDeleteBranch(branch); $event.stopPropagation()\" title=\"{{ branchIndex === 0 ? 'Delete step' : 'Delete branch' }}\" class=\"cqa-p-0 cqa-text-[#ff6467] hover:cqa-text-[#C63535]\">\n            <svg width=\"14\" height=\"14\" viewBox=\"0 0 14 14\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M1.75 3.5H12.25\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M11.0827 3.5V11.6667C11.0827 12.25 10.4993 12.8333 9.91602 12.8333H4.08268C3.49935 12.8333 2.91602 12.25 2.91602 11.6667V3.5\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M4.66602 3.49996V2.33329C4.66602 1.74996 5.24935 1.16663 5.83268 1.16663H8.16602C8.74935 1.16663 9.33268 1.74996 9.33268 2.33329V3.49996\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M5.83398 6.41663V9.91663\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M8.16602 6.41663V9.91663\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/></svg>\n          </button>\n        </div>\n        <span *ngIf=\"getBranchCreatedDate(branch)\" class=\"step-date cqa-text-[#6B7280] cqa-text-[12px] cqa-leading-[15px] cqa-flex-shrink-0 cqa-ml-auto\">{{ getBranchCreatedDate(branch) | date:'d MMM yyyy' }}</span>\n      </div>\n\n      <!-- START marker per branch: START IF, START ELSE IF, or START ELSE (centered with decorative lines) - only when branch has nested steps -->\n      <div *ngIf=\"branch.nestedSteps?.length > 0\" class=\"cqa-flex cqa-items-center cqa-gap-3 cqa-py-1 cqa-px-4\" style=\"border-top: 1px solid #E5E7EB;\">\n        <span class=\"cqa-flex-1 cqa-self-stretch cqa-border-t cqa-border-dashed cqa-border-[#7B3306] cqa-opacity-40\" style=\"min-width: 20px;\"></span>\n        <span class=\"cqa-text-[#7B3306] cqa-text-[10px] cqa-leading-[15px] cqa-font-medium cqa-whitespace-nowrap\">{{ getStartBranchLabel(branch) }}</span>\n        <span class=\"cqa-flex-1 cqa-self-stretch cqa-border-t cqa-border-dashed cqa-border-[#7B3306] cqa-opacity-40\" style=\"min-width: 20px;\"></span>\n      </div>\n\n      <!-- Branch Content (Nested Steps – renderer dispatches by step type, n-level nesting) -->\n      <div *ngIf=\"!isReorder || isInsideStepGroup\" class=\"cqa-flex cqa-flex-col\">\n        <cqa-test-case-details-renderer\n          *ngFor=\"let step of branch.nestedSteps; let i = index\"\n          [step]=\"step\"\n          [index]=\"i\"\n          [selected]=\"$any(step).selected\"\n          [branch]=\"branch\"\n          [isNested]=\"true\"\n          [isInsideStepGroup]=\"isInsideStepGroup\"\n          [isReorder]=\"isReorder\"\n          [nestingLevel]=\"(nestingLevel || 0) + 1\"\n          [addStepBetween]=\"addStepBetween\"\n          [editable]=\"editable\"\n          [dataProfileOptions]=\"dataProfileOptions\" [hasMoreDataProfiles]=\"hasMoreDataProfiles\" [isLoadingDataProfiles]=\"isLoadingDataProfiles\"\n          [naturalTextActionsOptions]=\"naturalTextActionsOptions\"\n          (branchStepChange)=\"onBranchStepChange($event.branch, $event.step, $event.stepIndex)\"\n          (addStepForBranch)=\"onAddStep($event.branch)\"\n          (addStepForLoop)=\"onAddStepForLoop($event, branch)\"\n          (deleteStepWithBranch)=\"onDeleteStep($event.branch, $event.stepIndex)\"\n          (toggleExpanded)=\"onNestedToggleExpanded($event, branch, step, i)\"\n          (groupNameChange)=\"$any(step).groupName = $event; onBranchStepChange(branch, step, i)\"\n          (descriptionChange)=\"$any(step).description = $event; onBranchStepChange(branch, step, i)\"\n          (reusableChange)=\"$any(step).reusable = $event; onBranchStepChange(branch, step, i)\"\n          (openExternal)=\"onNestedOpenExternal($event)\"\n          (edit)=\"onNestedEdit($event)\"\n          (link)=\"onBranchStepChange(branch, step, i)\"\n          (duplicate)=\"onNestedDuplicate($event, step)\"\n          (viewDetails)=\"viewDetails.emit($event)\"\n          (conditionChange)=\"$any(step).condition = $event; onBranchStepChange(branch, step, i)\"\n          (addBranch)=\"onNestedConditionAddBranch($any(step)); onBranchStepChange(branch, step, i)\"\n          (deleteBranch)=\"onNestedConditionDeleteBranch($any(step), $event); onBranchStepChange(branch, step, i)\"\n          (testDataProfileChange)=\"$any(step).testDataProfile = $event; onBranchStepChange(branch, step, i)\"\n          (startStepChange)=\"$any(step).startStep = $event; onBranchStepChange(branch, step, i)\"\n          (endStepChange)=\"$any(step).endStep = $event; onBranchStepChange(branch, step, i)\"\n          (maxIterationsChange)=\"$any(step).maxIterations = $event; onBranchStepChange(branch, step, i)\"\n          (eventTypeChange)=\"$any(step).eventType = $event; onBranchStepChange(branch, step, i)\"\n          (parameterChange)=\"onBranchStepChange(branch, step, i)\"\n          (selectionChange)=\"$any(step).selected = $event; onBranchStepChange(branch, step, i)\"\n          (loadMoreDataProfiles)=\"loadMoreDataProfiles.emit($event)\"\n          (searchDataProfiles)=\"searchDataProfiles.emit($event)\"\n          (stepUpdate)=\"stepUpdate.emit($event)\"\n          (dndDropInZone)=\"dndDropInZone.emit($event)\"\n          (clickAction)=\"onNestedClickAction($event)\"\n          (editInDepth)=\"editInDepth.emit($event)\"\n          (addStepBetweenClick)=\"addStepBetweenClick.emit($event)\"\n        >\n        </cqa-test-case-details-renderer>\n      </div>\n      <div *ngIf=\"isReorder && !isInsideStepGroup\" class=\"cqa-flex cqa-flex-col nested-step-drop-list\"\n           [style.min-height.px]=\"branch.nestedSteps.length === 0 ? 52 : null\"\n           [dndDropzone]=\"['step']\"\n           dndEffectAllowed=\"move\"\n           dndDragoverClass=\"dndDragover\"\n           (dndDrop)=\"onDndDrop($event, branch)\">\n        <div dndPlaceholderRef class=\"step-drag-placeholder-nested cqa-my-1 cqa-min-h-[50px] cqa-border-2 cqa-border-dashed cqa-border-[#3F43EE] cqa-rounded cqa-bg-[rgba(63,67,238,0.08)] cqa-flex cqa-items-center cqa-justify-center cqa-text-[#3F43EE] cqa-text-xs\">Drop here</div>\n        <div *ngFor=\"let step of branch.nestedSteps; let i = index\" class=\"nested-step-drag-item\"\n             [dndDraggable]=\"step\"\n             dndEffectAllowed=\"move\"\n             dndType=\"step\">\n          <cqa-test-case-details-renderer\n            [step]=\"step\"\n            [index]=\"i\"\n            [selected]=\"$any(step).selected\"\n            [branch]=\"branch\"\n            [isNested]=\"true\"\n            [isInsideStepGroup]=\"isInsideStepGroup\"\n            [isReorder]=\"isReorder\"\n            [nestingLevel]=\"(nestingLevel || 0) + 1\"\n            [addStepBetweenAbove]=\"addStepBetweenAbove\"\n            [addStepBetweenBelow]=\"addStepBetweenBelow\"\n            [addStepBetween]=\"addStepBetween\"\n          [editable]=\"editable\"\n            [dataProfileOptions]=\"dataProfileOptions\" [hasMoreDataProfiles]=\"hasMoreDataProfiles\" [isLoadingDataProfiles]=\"isLoadingDataProfiles\"\n            [naturalTextActionsOptions]=\"naturalTextActionsOptions\"\n            (branchStepChange)=\"onBranchStepChange($event.branch, $event.step, $event.stepIndex)\"\n            (addStepForBranch)=\"onAddStep($event.branch)\"\n            (addStepForLoop)=\"onAddStepForLoop($event, branch)\"\n            (deleteStepWithBranch)=\"onDeleteStep($event.branch, $event.stepIndex)\"\n            (toggleExpanded)=\"onNestedToggleExpanded($event, branch, step, i)\"\n            (groupNameChange)=\"$any(step).groupName = $event; onBranchStepChange(branch, step, i)\"\n            (descriptionChange)=\"$any(step).description = $event; onBranchStepChange(branch, step, i)\"\n            (reusableChange)=\"$any(step).reusable = $event; onBranchStepChange(branch, step, i)\"\n            (openExternal)=\"onNestedOpenExternal($event)\"\n            (edit)=\"onNestedEdit($event)\"\n            (link)=\"onBranchStepChange(branch, step, i)\"\n            (duplicate)=\"onNestedDuplicate($event, step)\"\n            (viewDetails)=\"viewDetails.emit($event)\"\n            (conditionChange)=\"$any(step).condition = $event; onBranchStepChange(branch, step, i)\"\n            (addBranch)=\"onNestedConditionAddBranch($any(step)); onBranchStepChange(branch, step, i)\"\n            (deleteBranch)=\"onNestedConditionDeleteBranch($any(step), $event); onBranchStepChange(branch, step, i)\"\n            (testDataProfileChange)=\"$any(step).testDataProfile = $event; onBranchStepChange(branch, step, i)\"\n            (startStepChange)=\"$any(step).startStep = $event; onBranchStepChange(branch, step, i)\"\n            (endStepChange)=\"$any(step).endStep = $event; onBranchStepChange(branch, step, i)\"\n            (maxIterationsChange)=\"$any(step).maxIterations = $event; onBranchStepChange(branch, step, i)\"\n            (eventTypeChange)=\"$any(step).eventType = $event; onBranchStepChange(branch, step, i)\"\n            (parameterChange)=\"onBranchStepChange(branch, step, i)\"\n            (selectionChange)=\"$any(step).selected = $event; onBranchStepChange(branch, step, i)\"\n            (loadMoreDataProfiles)=\"loadMoreDataProfiles.emit($event)\"\n            (searchDataProfiles)=\"searchDataProfiles.emit($event)\"\n            (stepUpdate)=\"stepUpdate.emit($event)\"\n            (dndDropInZone)=\"dndDropInZone.emit($event)\"\n            (clickAction)=\"onNestedClickAction($event)\"\n            (editInDepth)=\"editInDepth.emit($event)\"\n            (addStepBetweenClick)=\"addStepBetweenClick.emit($event)\"\n          >\n          </cqa-test-case-details-renderer>\n        </div>\n      </div>\n\n      <!-- Empty branch (IF / ELSE IF / ELSE): show plus icon on hover when no steps, same as loop step.\n           When rendered inside a step group or when reordering, hide this Add button entirely. -->\n      <div *ngIf=\"branch.nestedSteps.length === 0 && editable && !isInsideStepGroup && !isReorder\" class=\"condition-branch-empty cqa-min-h-[52px] cqa-flex cqa-items-center cqa-justify-center cqa-pl-4 cqa-pr-4\">\n        <button type=\"button\" (click)=\"onAddStep(branch); $event.stopPropagation()\" (mousedown)=\"$event.stopPropagation()\" [attr.title]=\"'Add step to ' + getBranchLabel(branch)\"\n          class=\"condition-branch-empty-add\">\n          <svg width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n            <rect x=\"1\" y=\"1\" width=\"21.1822\" height=\"22\" rx=\"10.5911\" fill=\"white\" />\n            <rect x=\"1\" y=\"1\" width=\"21.1822\" height=\"22\" rx=\"10.5911\" stroke=\"#3F43EE\" stroke-width=\"2\" />\n            <path d=\"M8.5 12H15.5\" stroke=\"#3F43EE\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n            <path d=\"M12 8.5V15.5\" stroke=\"#3F43EE\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n          </svg>\n        </button>\n      </div>\n\n      <!-- END marker per branch: END IF, END ELSE IF, or END ELSE - only when branch has nested steps -->\n      <div *ngIf=\"branch.nestedSteps?.length > 0\" class=\"cqa-flex cqa-items-center cqa-gap-3 cqa-py-1 cqa-px-4\" style=\"border-top: 1px solid #E5E7EB;\">\n        <span class=\"cqa-flex-1 cqa-self-stretch cqa-border-t cqa-border-dashed cqa-border-[#7B3306] cqa-opacity-40\" style=\"min-width: 20px;\"></span>\n        <span class=\"cqa-text-[#7B3306] cqa-text-[10px] cqa-leading-[15px] cqa-font-medium cqa-whitespace-nowrap\">{{ getEndBranchLabel(branch) }}</span>\n        <span class=\"cqa-flex-1 cqa-self-stretch cqa-border-t cqa-border-dashed cqa-border-[#7B3306] cqa-opacity-40\" style=\"min-width: 20px;\"></span>\n      </div>\n    </div>\n    <!-- END CONDITION: final marker after all branches -->\n    <div class=\"cqa-flex cqa-items-center cqa-gap-3 cqa-py-1 cqa-px-4\" style=\"border-top: 1px solid #E5E7EB;\">\n      <span class=\"cqa-flex-1 cqa-self-stretch cqa-border-t cqa-border-dashed cqa-border-[#7B3306] cqa-opacity-40\" style=\"min-width: 20px;\"></span>\n      <span class=\"cqa-text-[#7B3306] cqa-text-[10px] cqa-leading-[15px] cqa-font-medium cqa-whitespace-nowrap\">END CONDITION</span>\n      <span class=\"cqa-flex-1 cqa-self-stretch cqa-border-t cqa-border-dashed cqa-border-[#7B3306] cqa-opacity-40\" style=\"min-width: 20px;\"></span>\n    </div>\n  </div>\n</div>"]}