@cqa-lib/cqa-ui 1.1.359 → 1.1.361
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2020/lib/test-case-details/condition-step/condition-step.component.mjs +12 -3
- package/esm2020/lib/test-case-details/loop-step/loop-step.component.mjs +11 -3
- package/esm2020/lib/test-case-details/normal-step/normal-step.component.mjs +6 -2
- package/esm2020/lib/test-case-details/scroll-step/scroll-step.component.mjs +3 -1
- package/fesm2015/cqa-lib-cqa-ui.mjs +27 -5
- package/fesm2015/cqa-lib-cqa-ui.mjs.map +1 -1
- package/fesm2020/cqa-lib-cqa-ui.mjs +27 -5
- package/fesm2020/cqa-lib-cqa-ui.mjs.map +1 -1
- package/lib/test-case-details/condition-step/condition-step.component.d.ts +5 -0
- package/lib/test-case-details/loop-step/loop-step.component.d.ts +5 -0
- package/package.json +1 -1
|
@@ -139,7 +139,7 @@ export class TestCaseNormalStepComponent {
|
|
|
139
139
|
}
|
|
140
140
|
/** Opens Test Data modal below the given trigger; used when eventType === 'navigate'. */
|
|
141
141
|
openTestDataModal(origin) {
|
|
142
|
-
if (this.eventType !== 'navigate') {
|
|
142
|
+
if (this.isInsideStepGroup || this.eventType !== 'navigate') {
|
|
143
143
|
return;
|
|
144
144
|
}
|
|
145
145
|
const el = origin instanceof MouseEvent
|
|
@@ -225,6 +225,8 @@ export class TestCaseNormalStepComponent {
|
|
|
225
225
|
});
|
|
226
226
|
}
|
|
227
227
|
openElementPopup(origin) {
|
|
228
|
+
if (this.isInsideStepGroup)
|
|
229
|
+
return;
|
|
228
230
|
const elementParam = this.parameters.find(p => p.name === 'element');
|
|
229
231
|
const elementData = this.config.elementData;
|
|
230
232
|
let el;
|
|
@@ -368,6 +370,8 @@ export class TestCaseNormalStepComponent {
|
|
|
368
370
|
clickOnAction(event) {
|
|
369
371
|
event.preventDefault();
|
|
370
372
|
event.stopPropagation();
|
|
373
|
+
if (this.isInsideStepGroup)
|
|
374
|
+
return;
|
|
371
375
|
this.clickAction.emit(event);
|
|
372
376
|
}
|
|
373
377
|
}
|
|
@@ -453,4 +457,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImpor
|
|
|
453
457
|
type: HostListener,
|
|
454
458
|
args: ['document:click', ['$event']]
|
|
455
459
|
}] } });
|
|
456
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"normal-step.component.js","sourceRoot":"","sources":["../../../../../../src/lib/test-case-details/normal-step/normal-step.component.ts","../../../../../../src/lib/test-case-details/normal-step/normal-step.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  Input,\n  Output,\n  EventEmitter,\n  OnInit,\n  HostListener,\n  ElementRef,\n  ViewChild,\n  ChangeDetectorRef,\n  NgZone,\n} from '@angular/core';\nimport { NormalStepConfig, TestCaseEventType, EventTypeConfig, StepParameter, TestCaseStepConfig } from '../test-case-step.models';\nimport { STEP_ROW_ACTIONS_STYLES } from '../step-row-actions.styles';\nimport {\n  CustomEditStepResult,\n  CustomEditStepService,\n} from '../custom-edit-step/custom-edit-step.service';\nimport { CUSTOM_EDIT_STEP_EDIT_IN_DEPTH } from '../custom-edit-step/custom-edit-step-data';\nimport { ElementPopupResult, ElementPopupService } from '../element-popup/element-popup.service';\nimport {\n  TestDataModalResult,\n  TestDataModalService,\n} from '../test-data-modal/test-data-modal.service';\nimport {\n  TEST_DATA_MODAL_EDIT_IN_DEPTH,\n  TestDataModalData,\n} from '../test-data-modal/test-data-modal-data';\nimport { DomSanitizer } from '@angular/platform-browser';\nimport { ViewDetailsPayload } from '../step-details-modal/step-details-modal-data';\n\n@Component({\n  selector: 'cqa-test-case-normal-step',\n  templateUrl: './normal-step.component.html',\n  host: { class: 'cqa-ui-root' },\n  styles: [STEP_ROW_ACTIONS_STYLES],\n})\nexport class TestCaseNormalStepComponent implements OnInit {\n  @ViewChild('dropdownContainer', { static: false }) dropdownContainer?: ElementRef;\n  @ViewChild('descriptionTrigger', { static: false }) descriptionTrigger?: ElementRef<HTMLElement>;\n  @ViewChild('testDataTrigger', { static: false }) testDataTrigger?: ElementRef<HTMLElement>;\n  @ViewChild('editTrigger', { static: false }) editTrigger?: ElementRef<HTMLElement>;\n  @ViewChild('elementTrigger', { static: false }) elementTrigger?: ElementRef<HTMLElement>;\n  @ViewChild('clickElementTrigger', { static: false }) clickElementTrigger?: ElementRef<HTMLElement>;\n  @ViewChild('viewDetailsTrigger', { static: false }) viewDetailsTrigger?: ElementRef<HTMLElement>;\n  @Input() config!: NormalStepConfig;\n  @Input() stepNumber!: number | string;\n  /** Array index from parent renderer - use for editInDepth (stepNumber \"10.3\" parses wrong) */\n  @Input() index?: number;\n  @Input() action!: string;\n  @Input() eventType!: TestCaseEventType;\n  @Input() parameters: StepParameter[] = [];\n  @Input() selected: boolean = false;\n  @Input() disabled: boolean = false;\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  @Input() stepIndex?: number;\n  @Input() isDuplicating: boolean = false;\n\n  @Output() eventTypeChange = new EventEmitter<TestCaseEventType>();\n  @Output() parameterChange = new EventEmitter<{ parameter: StepParameter; value: string }>();\n  @Output() edit = new EventEmitter<void>();\n  @Output() editInDepth = new EventEmitter<{ step: TestCaseStepConfig; index: number }>();\n  @Output() link = new EventEmitter<void>();\n  @Output() duplicate = new EventEmitter<void>();\n  @Output() delete = new EventEmitter<void>();\n  @Output() moreOptions = new EventEmitter<void>();\n  @Output() viewDetails = new EventEmitter<ViewDetailsPayload>();\n  @Output() selectionChange = new EventEmitter<boolean>();\n  @Output() clickAction = new EventEmitter<MouseEvent>();\n\n  eventTypeDropdownOpen: boolean = false;\n  /** Stored test data modal state for reopening with same selections. */\n  private testDataModalState: TestDataModalData | null = null;\n\n  constructor(\n    private readonly customEditStep: CustomEditStepService,\n    private readonly elementPopup: ElementPopupService,\n    private readonly testDataModal: TestDataModalService,\n    private readonly cdr: ChangeDetectorRef,\n    private readonly ngZone: NgZone,\n    private readonly sanitizer: DomSanitizer\n  ) {}\n\n  /** Unique colors per event type; badge uses consistent size (w-8 h-8 rounded-lg). */\n  eventTypeConfigs: EventTypeConfig[] = [\n    { type: 'navigate', label: 'Navigate', icon: 'paper_plane', color: '#4338CA', backgroundColor: '#E0E7FF' },\n    { type: 'custom', label: 'Custom', icon: 'settings', color: '#475569', backgroundColor: '#F1F5F9' },\n    { type: 'ai-agent', label: 'AI Agent', icon: 'star', color: '#7C3AED', backgroundColor: '#EDE9FE' },\n    { type: 'type', label: 'Type', icon: 'T', color: '#A21CAF', backgroundColor: '#FAE8FF' },\n    { type: 'click', label: 'Click', icon: 'cursor', color: '#0284C7', backgroundColor: '#E0F2FE' },\n    { type: 'doubleClick', label: 'Double Click', icon: 'cursor-double', color: '#0891B2', backgroundColor: '#CFFAFE' },\n    { type: 'pressEnter', label: 'Press Enter', icon: 'enter', color: '#0D9488', backgroundColor: '#CCFBF1' },\n    { type: 'enter', label: 'Enter', icon: 'T', color: '#059669', backgroundColor: '#D1FAE5' },\n    { type: 'verify', label: 'Verify', icon: 'check', color: '#16A34A', backgroundColor: '#DCFCE7' },\n    { type: 'wait', label: 'Wait', icon: 'clock', color: '#6B7280', backgroundColor: '#F3F4F6' }\n  ];\n\n  ngOnInit(): void {\n    if (this.config) {\n      this.action = this.config.action || '';\n      this.stepNumber = this.config.stepNumber;\n      this.eventType = this.config.eventType;\n      this.parameters = this.config.parameters || [];\n      this.selected = this.config.selected || false;\n      this.disabled = this.config.disabled || false;\n    }\n  }\n\n  getCurrentEventTypeConfig(): EventTypeConfig {\n    return this.eventTypeConfigs.find(etc => etc.type === this.eventType) || this.eventTypeConfigs[0];\n  }\n\n  getActionDescription(): string {\n    // const config = this.getCurrentEventTypeConfig();\n    // switch (this.eventType) {\n    //   case 'navigate':\n    //     return 'Navigate to';\n    //   case 'type':\n    //     return 'Type';\n    //   case 'click':\n    //     return 'Click on';\n    //   case 'doubleClick':\n    //     return 'Double click on';\n    //   case 'pressEnter':\n    //     return 'Press Enter on';\n    //   case 'enter':\n    //     return 'Enter';\n    //   case 'wait':\n    //     return 'Wait';\n    //   case 'verify':\n    //     return 'Verify';\n    //   case 'custom':\n    //     return 'Custom step';\n    //   case 'ai-agent':\n    //     return 'AI Agent';\n    //   default:\n    //     return '';\n    // }\n      if (this.action) {\n        return this.action ? this.sanitizer.bypassSecurityTrustHtml(this.action) as string : '';\n      }\n      return '';\n  }\n\n  getActionSuffix(): string {\n    switch (this.eventType) {\n      case 'type':\n        return 'into';\n      case 'wait':\n        if (this.parameters.length > 0 && this.parameters[0].name === 'duration') {\n          return 'seconds';\n        }\n        return 'for element';\n      default:\n        return '';\n    }\n  }\n\n  /** Current description for custom event type (first parameter value). */\n  getCustomDescription(): string {\n    if (this.eventType !== 'custom' || !this.parameters?.length) {\n      return '';\n    }\n    const first = this.parameters[0];\n    return first?.value ?? first?.displayValue ?? '';\n  }\n\n  /**\n   * Get the URL parameter for navigate steps (old UI style - show only URL)\n   * Returns the first parameter with name 'url' or 'URL', or the first parameter if none found\n   */\n  getNavigateUrlParameter(): StepParameter | null {\n    if (this.eventType !== 'navigate' || !this.parameters || this.parameters.length === 0) {\n      return null;\n    }\n    // Try to find parameter with name 'url' or 'URL'\n    const urlParam = this.parameters.find(p => p.name?.toLowerCase() === 'url');\n    // If not found, return the first parameter (likely the URL)\n    return urlParam || this.parameters[0] || null;\n  }\n\n  /** Current URL value for navigate step (for Test Data modal). */\n  getNavigateUrlValue(): string {\n    const param = this.getNavigateUrlParameter();\n    return param?.value ?? param?.displayValue ?? '';\n  }\n\n  /** Opens Test Data modal below the given trigger; used when eventType === 'navigate'. */\n  openTestDataModal(origin: ElementRef<HTMLElement> | HTMLElement | MouseEvent): void {\n    if (this.eventType !== 'navigate') {\n      return;\n    }\n    const el =\n      origin instanceof MouseEvent\n        ? (origin.currentTarget as HTMLElement)\n        : origin instanceof ElementRef\n          ? origin.nativeElement\n          : (origin as HTMLElement);\n    const originRef = new ElementRef(el);\n    \n    // Use stored state if available, otherwise use current URL value\n    const modalData: TestDataModalData = this.testDataModalState ?? {\n      value: this.getNavigateUrlValue(),\n    };\n    \n    const ref = this.testDataModal.open(originRef, modalData);\n    ref.afterClosed().subscribe((result: TestDataModalResult) => {\n      this.ngZone.run(() => {\n        if (result === TEST_DATA_MODAL_EDIT_IN_DEPTH) {\n          this.moreOptions.emit();\n          this.cdr.markForCheck();\n          return;\n        }\n        \n        // Handle TestDataModalData object (full state)\n        if (result !== undefined && typeof result === 'object' && 'value' in result) {\n          const modalDataResult = result as TestDataModalData;\n          this.testDataModalState = modalDataResult; // Store state for reopening\n          const urlParam = this.getNavigateUrlParameter();\n          if (urlParam && modalDataResult.value) {\n            urlParam.value = modalDataResult.value;\n            urlParam.displayValue = modalDataResult.value;\n            this.parameterChange.emit({ parameter: urlParam, value: modalDataResult.value });\n            this.cdr.markForCheck();\n            this.cdr.detectChanges();\n          }\n          return;\n        }\n        \n        // Handle string result (backward compatibility)\n        if (typeof result === 'string') {\n          const urlParam = this.getNavigateUrlParameter();\n          if (urlParam) {\n            urlParam.value = result;\n            urlParam.displayValue = result;\n            this.parameterChange.emit({ parameter: urlParam, value: result });\n            // Clear stored state when using string result\n            this.testDataModalState = null;\n            this.cdr.markForCheck();\n            this.cdr.detectChanges();\n          }\n        }\n      });\n    });\n  }\n\n  /** Opens Step Description modal below the given trigger; used when eventType === 'custom'. */\n  openStepDescriptionModal(origin: ElementRef<HTMLElement> | HTMLElement | MouseEvent): void {\n    if (this.eventType !== 'custom') {\n      return;\n    }\n    const el =\n      origin instanceof MouseEvent\n        ? (origin.currentTarget as HTMLElement)\n        : origin instanceof ElementRef\n          ? origin.nativeElement\n          : (origin as HTMLElement);\n    const originRef = new ElementRef(el);\n    const ref = this.customEditStep.open(originRef, {\n      description: this.getCustomDescription(),\n    });\n    ref.afterClosed().subscribe((result: CustomEditStepResult) => {\n      this.ngZone.run(() => {\n        if (result === CUSTOM_EDIT_STEP_EDIT_IN_DEPTH) {\n          this.moreOptions.emit();\n          this.cdr.markForCheck();\n          return;\n        }\n        if (typeof result === 'string' && this.parameters?.length) {\n          const first = this.parameters[0];\n          if (first) {\n            first.value = result;\n            first.displayValue = result;\n            this.parameterChange.emit({ parameter: first, value: result });\n            this.cdr.markForCheck();\n            this.cdr.detectChanges();\n          }\n        }\n      });\n    });\n  }\n\n  openElementPopup(origin: ElementRef<HTMLElement> | HTMLElement | MouseEvent): void {\n    const elementParam = this.parameters.find(p => p.name === 'element');\n    const elementData = this.config.elementData;\n\n    let el: HTMLElement;\n    if (this.elementTrigger?.nativeElement) {\n      el = this.elementTrigger.nativeElement;\n    } else if (this.clickElementTrigger?.nativeElement) {\n      el = this.clickElementTrigger.nativeElement;\n    } else {\n      el =\n        origin instanceof MouseEvent\n          ? (origin.currentTarget as HTMLElement)\n          : origin instanceof ElementRef\n            ? origin.nativeElement\n            : (origin as HTMLElement);\n    }\n    const originRef = new ElementRef(el);\n    const elementTitle = elementData?.label || elementParam?.value || 'Element';\n    const elementSelector = elementData?.selector || elementParam?.value || '';\n    const elementLabels = elementData?.labels || (elementData?.label ? [elementData.label] : []);\n    const allLabels = elementLabels.length > 0 ? elementLabels : ['css', 'xpath', 'id'];\n    \n    const elementPopupRef = this.elementPopup.open(originRef, {\n      element: {\n        title: elementTitle,\n        selector: elementSelector,\n        labels: elementLabels\n      },\n      labels: allLabels,\n      description: this.config.description || 'Element details',\n      helpUrl: '',\n      elements: elementData ? [\n        {\n          title: elementTitle,\n          selector: elementSelector,\n          labels: elementLabels\n        }\n      ] : []\n    });\n    elementPopupRef.afterClosed().subscribe((result: ElementPopupResult) => {\n      if (result !== undefined && typeof result === 'string') {\n        this.parameterChange.emit({ parameter: { name: 'element', value: result, displayValue: result }, value: result });\n      }\n    });\n  }\n\n  onEventTypeSelect(eventType: TestCaseEventType): void {\n    this.eventType = eventType;\n    this.eventTypeDropdownOpen = false;\n    this.eventTypeChange.emit(eventType);\n  }\n\n  onParameterChange(parameter: StepParameter, value: string): void {\n    parameter.value = value;\n    this.parameterChange.emit({ parameter, value });\n  }\n\n  onEdit(): void {\n    if (this.eventType === 'custom' && this.descriptionTrigger?.nativeElement) {\n      this.openStepDescriptionModal(new ElementRef(this.descriptionTrigger.nativeElement));\n      return;\n    }\n    if (this.eventType === 'navigate' && this.testDataTrigger?.nativeElement) {\n      this.openTestDataModal(new ElementRef(this.testDataTrigger.nativeElement));\n      return;\n    }\n    // Emit editInDepth - prefer renderer index (correct); stepNumber \"10.3\" parses to 10 - wrong\n    const idx = typeof this.index === 'number' ? this.index : (typeof this.stepNumber === 'number' ? this.stepNumber - 1 : (typeof this.stepNumber === 'string' ? parseInt(this.stepNumber, 10) - 1 : (this.stepIndex ?? 0)));\n    this.editInDepth.emit({ step: this.config as TestCaseStepConfig, index: isNaN(idx as number) ? 0 : (idx as number) });\n    this.edit.emit();\n  }\n\n  onLink(): void {\n    this.link.emit();\n  }\n\n  onDuplicate(): void {\n    if (this.isDuplicating) return;\n    this.duplicate.emit();\n  }\n\n  onDelete(): void {\n    this.delete.emit();\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      const title = this.getStepTitle();\n      this.viewDetails.emit({\n        event,\n        title,\n        description: this.config.description,\n      });\n    }\n  }\n\n  private getStepTitle(): string {\n    switch (this.eventType) {\n      case 'ai-agent':\n        return 'Agent Instructions';\n      case 'custom':\n        return 'Step Description';\n      case 'navigate':\n        return 'Navigate Step';\n      case 'type':\n        return 'Type Step';\n      case 'click':\n        return 'Click Step';\n      case 'doubleClick':\n        return 'Double Click Step';\n      case 'pressEnter':\n        return 'Press Enter Step';\n      case 'enter':\n        return 'Enter Step';\n      case 'verify':\n        return 'Verify Step';\n      case 'wait':\n        return 'Wait Step';\n      default:\n        return 'Step Details';\n    }\n  }\n\n  onSelectionChange(checked: boolean): void {\n    this.selected = checked;\n    this.selectionChange.emit(checked);\n  }\n\n  toggleEventTypeDropdown(): void {\n    this.eventTypeDropdownOpen = !this.eventTypeDropdownOpen;\n  }\n\n  closeEventTypeDropdown(): void {\n    this.eventTypeDropdownOpen = false;\n  }\n\n  @HostListener('document:click', ['$event'])\n  onDocumentClick(event: MouseEvent): void {\n    if (this.dropdownContainer && !this.dropdownContainer.nativeElement.contains(event.target)) {\n      this.closeEventTypeDropdown();\n    }\n  }\n\n  clickOnAction(event: MouseEvent): void {\n    event.preventDefault();\n    event.stopPropagation();\n    this.clickAction.emit(event);\n  }\n}\n","<div [class]=\"'step-row cqa-flex cqa-items-center cqa-gap-3 cqa-py-2 cqa-px-4 ' + (isInsideLoop && isInsideStepGroup ? 'cqa-pl-20 cqa-pr-4' : (isInsideLoop || isInsideStepGroup) ? 'cqa-pl-10 cqa-pr-4' : '')\" style=\"border-top: 1px solid #E5E7EB; border-bottom: 1px solid #E5E7EB;\">\n\n  <div class=\"cqa-inline-flex cqa-items-center\">\n    <!-- Drag Handle Icon (when isReorder is true and not inside step group - steps inside step groups cannot be reordered) -->\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, editable, 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        [disabled]=\"disabled\"\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\" />\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\n  <!-- Step Number -->\n  <span class=\"cqa-text-[#6B7280] cqa-text-[14px] cqa-leading-[18px] cqa-min-w-[32px]\">\n    {{ stepNumber }}\n  </span>\n\n  <!-- Event Type Selector (Pill Button) #### (click)=\"toggleEventTypeDropdown(); $event.stopPropagation()\" -->\n  <div class=\"cqa-relative\" #dropdownContainer>\n    <button type=\"button\" \n      [attr.title]=\"getCurrentEventTypeConfig().label\"\n      [style.background-color]=\"getCurrentEventTypeConfig().backgroundColor\"\n      [style.color]=\"getCurrentEventTypeConfig().color\"\n      class=\"cqa-w-8 cqa-h-8 cqa-rounded-lg cqa-flex cqa-items-center cqa-justify-center cqa-flex-shrink-0 cqa-cursor-pointer\">\n      <!-- Icon -->\n      <span *ngIf=\"getCurrentEventTypeConfig().icon === 'paper_plane'\">\n        <svg width=\"14\" height=\"14\" viewBox=\"0 0 14 14\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n          <path d=\"M1.75 6.41663L12.8333 1.16663L7.58333 12.25L6.41667 7.58329L1.75 6.41663Z\" stroke=\"currentColor\"\n            stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n        </svg>\n      </span>\n      <span *ngIf=\"getCurrentEventTypeConfig().icon === 'star'\">\n        <svg width=\"14\" height=\"14\" viewBox=\"0 0 14 14\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n          <path\n            d=\"M5.797 9.04165C5.74492 8.83977 5.63969 8.65554 5.49227 8.50812C5.34485 8.3607 5.16062 8.25548 4.95875 8.2034L1.38 7.28057C1.31894 7.26324 1.2652 7.22646 1.22694 7.17583C1.18867 7.12519 1.16797 7.06345 1.16797 6.99998C1.16797 6.93651 1.18867 6.87478 1.22694 6.82414C1.2652 6.7735 1.31894 6.73673 1.38 6.7194L4.95875 5.79598C5.16055 5.74395 5.34473 5.63882 5.49215 5.49151C5.63956 5.34419 5.74483 5.16008 5.797 4.95832L6.71983 1.37957C6.73698 1.31827 6.77372 1.26427 6.82443 1.2258C6.87515 1.18733 6.93705 1.1665 7.0007 1.1665C7.06436 1.1665 7.12626 1.18733 7.17698 1.2258C7.22769 1.26427 7.26442 1.31827 7.28158 1.37957L8.20383 4.95832C8.25591 5.16019 8.36113 5.34442 8.50855 5.49184C8.65597 5.63926 8.8402 5.74449 9.04208 5.79657L12.6208 6.71882C12.6824 6.73579 12.7366 6.77249 12.7753 6.82328C12.814 6.87407 12.8349 6.93614 12.8349 6.99998C12.8349 7.06382 12.814 7.1259 12.7753 7.17669C12.7366 7.22748 12.6824 7.26417 12.6208 7.28115L9.04208 8.2034C8.8402 8.25548 8.65597 8.3607 8.50855 8.50812C8.36113 8.65554 8.25591 8.83977 8.20383 9.04165L7.281 12.6204C7.26384 12.6817 7.22711 12.7357 7.17639 12.7742C7.12568 12.8126 7.06377 12.8335 7.00012 12.8335C6.93647 12.8335 6.87456 12.8126 6.82385 12.7742C6.77314 12.7357 6.7364 12.6817 6.71925 12.6204L5.797 9.04165Z\"\n            stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n          <path d=\"M11.666 1.75V4.08333\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\"\n            stroke-linejoin=\"round\" />\n          <path d=\"M12.8333 2.91663H10.5\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\"\n            stroke-linejoin=\"round\" />\n          <path d=\"M2.33398 9.91663V11.0833\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\"\n            stroke-linejoin=\"round\" />\n          <path d=\"M2.91667 10.5H1.75\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\"\n            stroke-linejoin=\"round\" />\n        </svg>\n      </span>\n      <span *ngIf=\"getCurrentEventTypeConfig().icon === 'T'\">\n        <svg width=\"14\" height=\"14\" viewBox=\"0 0 14 14\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n          <path d=\"M2.33398 4.08325V2.33325H11.6673V4.08325\" stroke=\"currentColor\" stroke-width=\"1.16667\"\n            stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n          <path d=\"M5.25 11.6667H8.75\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\"\n            stroke-linejoin=\"round\" />\n          <path d=\"M7 2.33325V11.6666\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\"\n            stroke-linejoin=\"round\" />\n        </svg>\n      </span>\n      <span *ngIf=\"getCurrentEventTypeConfig().icon === 'cursor'\">\n        <svg width=\"14\" height=\"14\" viewBox=\"0 0 14 14\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n          <path d=\"M1.75 1.75L5.87417 11.6492L7.33833 7.33833L11.6492 5.87417L1.75 1.75Z\" stroke=\"currentColor\"\n            stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n          <path d=\"M7.58398 7.58325L11.084 11.0833\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\"\n            stroke-linejoin=\"round\" />\n        </svg>\n      </span>\n      <span *ngIf=\"getCurrentEventTypeConfig().icon === 'cursor-double'\">\n        <svg width=\"14\" height=\"14\" viewBox=\"0 0 14 14\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M8.16667 2.3916L7 3.49993\" stroke=\"currentColor\" stroke-width=\"1.25\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M2.97487 4.66662L1.2832 4.19995\" stroke=\"currentColor\" stroke-width=\"1.25\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M3.50091 7L2.39258 8.16667\" stroke=\"currentColor\" stroke-width=\"1.25\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M4.19922 1.28345L4.66589 2.97511\" stroke=\"currentColor\" stroke-width=\"1.25\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M5.27114 5.65255C5.24852 5.59926 5.24234 5.54043 5.25338 5.48361C5.26443 5.42678 5.2922 5.37455 5.33313 5.33362C5.37407 5.29269 5.4263 5.26492 5.48312 5.25387C5.53994 5.24283 5.59877 5.24901 5.65206 5.27163L12.0687 7.89663C12.1258 7.92006 12.174 7.961 12.2064 8.01357C12.2388 8.06613 12.2536 8.12761 12.2488 8.18915C12.244 8.25069 12.2198 8.30912 12.1797 8.35603C12.1396 8.40295 12.0856 8.43592 12.0256 8.45021L9.48864 9.05746C9.38391 9.08248 9.28815 9.13599 9.21196 9.21208C9.13578 9.28816 9.08213 9.38385 9.05698 9.48855L8.45031 12.026C8.43617 12.0863 8.40323 12.1405 8.35626 12.1808C8.30928 12.2211 8.25071 12.2454 8.189 12.2502C8.1273 12.255 8.06567 12.2401 8.01302 12.2075C7.96037 12.175 7.91944 12.1266 7.89614 12.0692L5.27114 5.65255Z\" stroke=\"currentColor\" stroke-width=\"1.25\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n        </svg>\n      </span>\n      <span *ngIf=\"getCurrentEventTypeConfig().icon === 'enter'\" class=\"cqa-enter-key-icon cqa-inline-flex cqa-flex-shrink-0\" style=\"width: 20px; height: 20px;\">\n        <svg width=\"20\" height=\"20\" viewBox=\"0 0 32 32\" xmlns=\"http://www.w3.org/2000/svg\" class=\"cqa-w-full cqa-h-full\">\n          <path fill=\"#6B7280\" transform=\"translate(14,5)\" d=\"M0 0 C4.29 0 8.58 0 13 0 C13 7.26 13 14.52 13 22 C5.74 22 -1.52 22 -9 22 C-9 16.72 -9 11.44 -9 6 C-6.03 6 -3.06 6 0 6 C0 4.02 0 2.04 0 0 Z M2 2 C2 3.98 2 5.96 2 8 C-0.97 8 -3.94 8 -7 8 C-7 11.96 -7 15.92 -7 20 C-1.06 20 4.88 20 11 20 C11 14.06 11 8.12 11 2 C8.03 2 5.06 2 2 2 Z\"/>\n          <path fill=\"#6B7280\" transform=\"translate(19,13)\" d=\"M0 0 C0.66 0 1.32 0 2 0 C2 2.31 2 4.62 2 7 C0.02 7 -1.96 7 -4 7 C-4.33 8.32 -4.66 9.64 -5 11 C-6.65 9.68 -8.3 8.36 -10 7 C-8.63016497 3.83884224 -8.0109362 3.0072908 -5 1 C-4.67 2.32 -4.34 3.64 -4 5 C-2.68 5 -1.36 5 0 5 C0 3.35 0 1.7 0 0 Z\"/>\n        </svg>\n      </span>\n      <span *ngIf=\"getCurrentEventTypeConfig().icon === 'clock'\">\n        <svg width=\"14\" height=\"14\" viewBox=\"0 0 14 14\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n          <path\n            d=\"M6.99935 12.8334C10.221 12.8334 12.8327 10.2217 12.8327 7.00008C12.8327 3.77842 10.221 1.16675 6.99935 1.16675C3.77769 1.16675 1.16602 3.77842 1.16602 7.00008C1.16602 10.2217 3.77769 12.8334 6.99935 12.8334Z\"\n            stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n          <path d=\"M7 3.5V7L9.33333 8.16667\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\"\n            stroke-linejoin=\"round\" />\n        </svg>\n      </span>\n      <span *ngIf=\"getCurrentEventTypeConfig().icon === 'settings'\">\n        <svg width=\"14\" height=\"14\" viewBox=\"0 0 14 14\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n          <path d=\"M7 4.66667C5.71133 4.66667 4.66667 5.71133 4.66667 7C4.66667 8.28867 5.71133 9.33333 7 9.33333C8.28867 9.33333 9.33333 8.28867 9.33333 7C9.33333 5.71133 8.28867 4.66667 7 4.66667Z\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n          <path d=\"M11.0833 7.58333C11.1417 7.29167 11.1417 6.70833 11.0833 6.41667L12.25 5.83333C12.4167 5.70833 12.4833 5.48333 12.4167 5.25L11.6667 3.41667C11.6 3.18333 11.3917 3.04167 11.1417 3.04167L9.91667 3.5C9.56667 3.20833 9.19167 2.95833 8.75 2.79167L8.4 1.45833C8.34167 1.225 8.14167 1.16667 7.93333 1.16667H6.06667C5.85833 1.16667 5.65833 1.225 5.6 1.45833L5.25 2.79167C4.80833 2.95833 4.43333 3.20833 4.08333 3.5L2.85833 3.04167C2.60833 3.04167 2.4 3.18333 2.33333 3.41667L1.58333 5.25C1.51667 5.48333 1.58333 5.70833 1.75 5.83333L2.91667 6.41667C2.85833 6.70833 2.85833 7.29167 2.91667 7.58333L1.75 8.16667C1.58333 8.29167 1.51667 8.51667 1.58333 8.75L2.33333 10.5833C2.4 10.8167 2.60833 10.9583 2.85833 10.9583L4.08333 10.5C4.43333 10.7917 4.80833 11.0417 5.25 11.2083L5.6 12.5417C5.65833 12.775 5.85833 12.8333 6.06667 12.8333H7.93333C8.14167 12.8333 8.34167 12.775 8.4 12.5417L8.75 11.2083C9.19167 11.0417 9.56667 10.7917 9.91667 10.5L11.1417 10.9583C11.3917 10.9583 11.6 10.8167 11.6667 10.5833L12.4167 8.75C12.4833 8.51667 12.4167 8.29167 12.25 8.16667L11.0833 7.58333Z\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n        </svg>\n      </span>\n      <span *ngIf=\"getCurrentEventTypeConfig().icon === 'check'\">\n        <svg width=\"14\" height=\"14\" viewBox=\"0 0 14 14\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n          <path d=\"M11.6667 3.5L5.25 10.5L2.33333 7.58333\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n        </svg>\n      </span>\n\n      <!-- Label (show only when no icon; all types have icon now – tooltip on button) -->\n      <span *ngIf=\"!getCurrentEventTypeConfig().icon\" class=\"cqa-text-[#432DD7] cqa-text-[10px] cqa-leading-[15px] cqa-font-medium\">{{\n        getCurrentEventTypeConfig().label }}</span>\n    </button>\n\n    <!-- Dropdown Menu -->\n    <div *ngIf=\"eventTypeDropdownOpen\" (click)=\"$event.stopPropagation()\"\n      class=\"cqa-absolute cqa-top-full cqa-left-0 cqa-mt-1 cqa-bg-white cqa-rounded-lg cqa-shadow-lg cqa-border cqa-border-gray-200 cqa-z-50 cqa-min-w-[150px] cqa-py-1\">\n      <button *ngFor=\"let etc of eventTypeConfigs\" type=\"button\" (click)=\"onEventTypeSelect(etc.type)\"\n        [class.cqa-bg-primary-50]=\"eventType === etc.type\"\n        class=\"cqa-w-full cqa-px-3 cqa-py-2 cqa-text-left cqa-flex cqa-items-center cqa-gap-2 hover:cqa-bg-gray-50 cqa-transition-colors\">\n        <span *ngIf=\"etc.icon === 'paper_plane'\">\n          <svg width=\"12\" height=\"12\" viewBox=\"0 0 12 12\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n            <path d=\"M1 5.5L11 1M11 1L7.5 11L6 6.5L1 5.5M11 1L1 5.5\" stroke=\"currentColor\" stroke-width=\"1.5\"\n              stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n          </svg>\n        </span>\n        <span *ngIf=\"etc.icon === 'star'\">\n          <svg width=\"12\" height=\"12\" viewBox=\"0 0 12 12\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n            <path d=\"M6 1L7.5 4.5L11 5L7.5 5.5L6 9L4.5 5.5L1 5L4.5 4.5L6 1Z\" fill=\"currentColor\" />\n          </svg>\n        </span>\n        <span *ngIf=\"etc.icon === 'T'\">\n          <svg width=\"12\" height=\"12\" viewBox=\"0 0 14 14\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n            <path d=\"M2.33398 4.08325V2.33325H11.6673V4.08325\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n            <path d=\"M5.25 11.6667H8.75\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n            <path d=\"M7 2.33325V11.6666\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n          </svg>\n        </span>\n        <span *ngIf=\"etc.icon === 'cursor'\">\n          <svg width=\"12\" height=\"12\" viewBox=\"0 0 12 12\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n            <path d=\"M2 2L9 1L10 8L7 7L5 9L4 7L2 2Z\" stroke=\"currentColor\" stroke-width=\"1.5\" stroke-linecap=\"round\"\n              stroke-linejoin=\"round\" />\n          </svg>\n        </span>\n        <span *ngIf=\"etc.icon === 'cursor-double'\">\n          <svg width=\"14\" height=\"14\" viewBox=\"0 0 14 14\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M8.16667 2.3916L7 3.49993\" stroke=\"currentColor\" stroke-width=\"1.25\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M2.97487 4.66662L1.2832 4.19995\" stroke=\"currentColor\" stroke-width=\"1.25\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M3.50091 7L2.39258 8.16667\" stroke=\"currentColor\" stroke-width=\"1.25\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M4.19922 1.28345L4.66589 2.97511\" stroke=\"currentColor\" stroke-width=\"1.25\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M5.27114 5.65255C5.24852 5.59926 5.24234 5.54043 5.25338 5.48361C5.26443 5.42678 5.2922 5.37455 5.33313 5.33362C5.37407 5.29269 5.4263 5.26492 5.48312 5.25387C5.53994 5.24283 5.59877 5.24901 5.65206 5.27163L12.0687 7.89663C12.1258 7.92006 12.174 7.961 12.2064 8.01357C12.2388 8.06613 12.2536 8.12761 12.2488 8.18915C12.244 8.25069 12.2198 8.30912 12.1797 8.35603C12.1396 8.40295 12.0856 8.43592 12.0256 8.45021L9.48864 9.05746C9.38391 9.08248 9.28815 9.13599 9.21196 9.21208C9.13578 9.28816 9.08213 9.38385 9.05698 9.48855L8.45031 12.026C8.43617 12.0863 8.40323 12.1405 8.35626 12.1808C8.30928 12.2211 8.25071 12.2454 8.189 12.2502C8.1273 12.255 8.06567 12.2401 8.01302 12.2075C7.96037 12.175 7.91944 12.1266 7.89614 12.0692L5.27114 5.65255Z\" stroke=\"currentColor\" stroke-width=\"1.25\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n          </svg>  \n        </span>\n        <span *ngIf=\"etc.icon === 'enter'\" class=\"cqa-enter-key-icon cqa-inline-flex cqa-flex-shrink-0\" style=\"width: 16px; height: 16px;\">\n          <svg width=\"16\" height=\"16\" viewBox=\"0 0 32 32\" xmlns=\"http://www.w3.org/2000/svg\" class=\"cqa-w-full cqa-h-full\">\n            <path fill=\"#6B7280\" transform=\"translate(14,5)\" d=\"M0 0 C4.29 0 8.58 0 13 0 C13 7.26 13 14.52 13 22 C5.74 22 -1.52 22 -9 22 C-9 16.72 -9 11.44 -9 6 C-6.03 6 -3.06 6 0 6 C0 4.02 0 2.04 0 0 Z M2 2 C2 3.98 2 5.96 2 8 C-0.97 8 -3.94 8 -7 8 C-7 11.96 -7 15.92 -7 20 C-1.06 20 4.88 20 11 20 C11 14.06 11 8.12 11 2 C8.03 2 5.06 2 2 2 Z\"/>\n            <path fill=\"#6B7280\" transform=\"translate(19,13)\" d=\"M0 0 C0.66 0 1.32 0 2 0 C2 2.31 2 4.62 2 7 C0.02 7 -1.96 7 -4 7 C-4.33 8.32 -4.66 9.64 -5 11 C-6.65 9.68 -8.3 8.36 -10 7 C-8.63016497 3.83884224 -8.0109362 3.0072908 -5 1 C-4.67 2.32 -4.34 3.64 -4 5 C-2.68 5 -1.36 5 0 5 C0 3.35 0 1.7 0 0 Z\"/>\n          </svg>\n        </span>\n        <span *ngIf=\"etc.icon === 'clock'\">\n          <svg width=\"12\" height=\"12\" viewBox=\"0 0 12 12\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n            <circle cx=\"6\" cy=\"6\" r=\"5\" stroke=\"currentColor\" stroke-width=\"1.5\" />\n            <path d=\"M6 3V6L8 7\" stroke=\"currentColor\" stroke-width=\"1.5\" stroke-linecap=\"round\" />\n          </svg>\n        </span>\n        <span *ngIf=\"etc.icon === 'settings'\">\n          <svg width=\"12\" height=\"12\" viewBox=\"0 0 14 14\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n            <path d=\"M7 4.66667C5.71133 4.66667 4.66667 5.71133 4.66667 7C4.66667 8.28867 5.71133 9.33333 7 9.33333C8.28867 9.33333 9.33333 8.28867 9.33333 7C9.33333 5.71133 8.28867 4.66667 7 4.66667Z\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n            <path d=\"M11.0833 7.58333C11.1417 7.29167 11.1417 6.70833 11.0833 6.41667L12.25 5.83333C12.4167 5.70833 12.4833 5.48333 12.4167 5.25L11.6667 3.41667C11.6 3.18333 11.3917 3.04167 11.1417 3.04167L9.91667 3.5C9.56667 3.20833 9.19167 2.95833 8.75 2.79167L8.4 1.45833C8.34167 1.225 8.14167 1.16667 7.93333 1.16667H6.06667C5.85833 1.16667 5.65833 1.225 5.6 1.45833L5.25 2.79167C4.80833 2.95833 4.43333 3.20833 4.08333 3.5L2.85833 3.04167C2.60833 3.04167 2.4 3.18333 2.33333 3.41667L1.58333 5.25C1.51667 5.48333 1.58333 5.70833 1.75 5.83333L2.91667 6.41667C2.85833 6.70833 2.85833 7.29167 2.91667 7.58333L1.75 8.16667C1.58333 8.29167 1.51667 8.51667 1.58333 8.75L2.33333 10.5833C2.4 10.8167 2.60833 10.9583 2.85833 10.9583L4.08333 10.5C4.43333 10.7917 4.80833 11.0417 5.25 11.2083L5.6 12.5417C5.65833 12.775 5.85833 12.8333 6.06667 12.8333H7.93333C8.14167 12.8333 8.34167 12.775 8.4 12.5417L8.75 11.2083C9.19167 11.0417 9.56667 10.7917 9.91667 10.5L11.1417 10.9583C11.3917 10.9583 11.6 10.8167 11.6667 10.5833L12.4167 8.75C12.4833 8.51667 12.4167 8.29167 12.25 8.16667L11.0833 7.58333Z\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n          </svg>\n        </span>\n        <span *ngIf=\"etc.icon === 'check'\">\n          <svg width=\"12\" height=\"12\" viewBox=\"0 0 14 14\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n            <path d=\"M11.6667 3.5L5.25 10.5L2.33333 7.58333\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n          </svg>\n        </span>\n        <span>{{ etc.label }}</span>\n      </button>\n    </div>\n  </div>\n\n  <!-- Action Description: flex-1 + min-w-0 so row can shrink; block flow in step-list SCSS avoids flex breaking innerHTML badges -->\n  <span class=\"cqa-text-[#111827] cqa-text-[14px] cqa-leading-[18px] cqa-action-format cqa-align-middle cqa-min-w-0 cqa-flex-1\" *ngIf=\"getActionDescription()\"\n   [innerHTML]=\"getActionDescription()\" (click)=\"clickOnAction($event)\">\n  </span>\n  <!-- <span class=\"cqa-text-[#111827] cqa-text-[14px] cqa-leading-[18px]\" *ngIf=\"getActionDescription()\">\n    {{ getActionDescription() }}\n  </span> -->\n\n  <!-- Parameters -->\n  <div class=\"cqa-flex cqa-items-center cqa-gap-3\" *ngIf=\"false\">\n    <!-- Navigate: URL as clickable trigger for Test Data modal -->\n    <span *ngIf=\"eventType === 'navigate' && getNavigateUrlParameter()\" #testDataTrigger\n      (click)=\"openTestDataModal($event)\"\n      class=\"cqa-py-0.5 cqa-px-2 cqa-text-[#3F43EE] cqa-text-[14px] cqa-leading-[17px] cqa-font-semibold cqa-border cqa-border-solid cqa-border-[#8A8CF4] cqa-rounded cqa-bg-[#D8D9FC] cqa-cursor-pointer hover:cqa-opacity-90\">\n      {{ getNavigateUrlParameter()?.value || getNavigateUrlParameter()?.displayValue }}\n    </span>\n    \n    <!-- Other event types: loop through parameters (navigate excluded) -->\n    <ng-container *ngFor=\"let param of parameters; let i = index\">\n      <!-- Skip navigate parameters in the loop (already shown above) -->\n      <ng-container *ngIf=\"eventType !== 'navigate'\">\n\n      <!-- Type: First param (text value like {{username}}) -->\n      <span *ngIf=\"eventType === 'type' && i === 0\" class=\"cqa-text-gray-900 cqa-text-sm\">\n        {{ param.value }}\n      </span>\n\n      <!-- Type: \"into\" text -->\n      <span *ngIf=\"eventType === 'type' && i === 0\" class=\"cqa-text-gray-900 cqa-text-sm\">\n        into\n      </span>\n\n      <!-- Type: Second param (selector) -->\n      <span *ngIf=\"eventType === 'type' && i === 1\"\n        class=\"cqa-py-0.5 cqa-px-2 cqa-text-[#3F43EE] cqa-text-[14px] cqa-leading-[17px] cqa-font-semibold cqa-border cqa-border-solid cqa-border-[#8A8CF4] cqa-rounded cqa-bg-[#D8D9FC]\">\n        {{ param.displayValue || param.value }}\n      </span>\n\n      <!-- Click: Selector input/display -->\n      <span *ngIf=\"eventType === 'click' && param.name === 'element'\"\n       #clickElementTrigger\n       (click)=\"openElementPopup($event)\"\n        class=\"cqa-py-0.5 cqa-px-2 cqa-text-[#3F43EE] cqa-text-[14px] cqa-leading-[17px] cqa-font-semibold cqa-border cqa-border-solid cqa-border-[#8A8CF4] cqa-rounded cqa-cursor-pointer cqa-bg-[#D8D9FC]\">\n        {{ param.displayValue || param.value }}\n      </span>\n\n      <!-- Click: Suffix text (like \"if Present\") -->\n      <span *ngIf=\"eventType === 'click' && param.name === 'suffix'\" class=\"cqa-text-gray-900 cqa-text-sm\">\n        {{ param.value }}\n      </span>\n\n      <!-- Double Click: Selector input/display -->\n      <span *ngIf=\"eventType === 'doubleClick' && i === 0\"\n        class=\"cqa-py-0.5 cqa-px-2 cqa-text-[#3F43EE] cqa-text-[14px] cqa-leading-[17px] cqa-font-semibold cqa-border cqa-border-solid cqa-border-[#8A8CF4] cqa-rounded cqa-bg-[#D8D9FC]\">\n        {{ param.displayValue || param.value }}\n      </span>\n\n      <!-- Press Enter: Selector input/display with HTML support -->\n      <span *ngIf=\"eventType === 'pressEnter' && i === 0\"\n        class=\"cqa-py-0.5 cqa-px-2 cqa-text-[#3F43EE] cqa-text-[14px] cqa-leading-[17px] cqa-font-semibold cqa-border cqa-border-solid cqa-border-[#8A8CF4] cqa-rounded cqa-bg-[#D8D9FC]\"\n        [innerHTML]=\"param.displayValue || param.value\">\n      </span>\n\n      <!-- Enter: Value display with quotes (like click action) -->\n      <span *ngIf=\"eventType === 'enter' && param.name === 'value'\"\n        class=\"cqa-py-0.5 cqa-px-2 cqa-text-[#3F43EE] cqa-text-[14px] cqa-leading-[17px] cqa-font-semibold cqa-border cqa-border-solid cqa-border-[#8A8CF4] cqa-rounded cqa-bg-[#D8D9FC]\">\n        {{ param.displayValue || param.value }}\n      </span>\n\n      <!-- Enter: \"in the\" text -->\n      <span *ngIf=\"eventType === 'enter' && param.name === 'value'\" class=\"cqa-text-gray-900 cqa-text-sm\">\n        in the\n      </span>\n\n      <!-- Enter: Label display with quotes (like click action) -->\n      <span *ngIf=\"eventType === 'enter' && param.name === 'label'\"\n        class=\"cqa-py-0.5 cqa-px-2 cqa-text-[#3F43EE] cqa-text-[14px] cqa-leading-[17px] cqa-font-semibold cqa-border cqa-border-solid cqa-border-[#8A8CF4] cqa-rounded cqa-bg-[#D8D9FC]\">\n        {{ param.displayValue || param.value }}\n      </span>\n\n      <!-- Enter: \"field\" text -->\n      <span *ngIf=\"eventType === 'enter' && param.name === 'label'\" class=\"cqa-text-gray-900 cqa-text-sm\">\n        field\n      </span>\n\n      <!-- Wait: Duration input -->\n      <input *ngIf=\"eventType === 'wait' && param.name === 'duration'\" type=\"number\" [value]=\"param.value\"\n        (input)=\"onParameterChange(param, $any($event.target).value)\" placeholder=\"2\"\n        class=\"cqa-w-16 cqa-px-2 cqa-py-1.5 cqa-rounded-lg cqa-border cqa-border-solid cqa-border-[#9E9EE3] cqa-bg-[#D1C4E9] cqa-text-[#3F43EE] cqa-text-sm cqa-font-medium cqa-outline-none focus:cqa-ring-2 focus:cqa-ring-[#3F43EE] focus:cqa-ring-opacity-50\" />\n      <span *ngIf=\"eventType === 'wait' && param.name === 'duration'\" class=\"cqa-text-gray-900 cqa-text-sm\">\n        seconds\n      </span>\n\n      <!-- Wait: Element selector -->\n      <span *ngIf=\"eventType === 'wait' && param.name === 'element'\" class=\"cqa-text-gray-900 cqa-text-sm\">\n        for element\n      </span>\n      <span *ngIf=\"eventType === 'wait' && param.name === 'element'\" \n       #elementTrigger\n       (click)=\"openElementPopup($event)\"\n        class=\"cqa-py-0.5 cqa-px-2 cqa-text-[#3F43EE] cqa-text-[14px] cqa-leading-[17px] cqa-font-semibold cqa-border cqa-border-solid cqa-border-[#8A8CF4] cqa-rounded cqa-cursor-pointer cqa-bg-[#D8D9FC]\">\n        {{ param.displayValue || param.value }}\n      </span>\n      <span *ngIf=\"eventType === 'wait' && param.name === 'element'\" class=\"cqa-text-gray-900 cqa-text-sm\">\n        to be visible\n      </span>\n\n      <!-- Custom: Description (clickable to open Step Description modal; pass $event so modal opens below this trigger) -->\n      <span *ngIf=\"eventType === 'custom'\" #descriptionTrigger\n        (click)=\"openStepDescriptionModal($event)\"\n        class=\"cqa-py-0.5 cqa-px-2 cqa-text-[#3F43EE] cqa-text-[14px] cqa-leading-[17px] cqa-font-semibold cqa-border cqa-border-solid cqa-border-[#8A8CF4] cqa-rounded cqa-bg-[#D8D9FC] cqa-cursor-pointer hover:cqa-opacity-90\"\n        [innerHTML]=\"param.displayValue || param.value\">\n      </span>\n\n      <!-- AI Agent: Instructions -->\n      <span *ngIf=\"eventType === 'ai-agent'\"\n        class=\"cqa-py-0.5 cqa-px-2 cqa-text-[#3F43EE] cqa-text-[14px] cqa-leading-[17px] cqa-font-semibold cqa-border cqa-border-solid cqa-border-[#8A8CF4] cqa-rounded cqa-bg-[#D8D9FC]\">\n        {{ param.displayValue || param.value }}\n      </span>\n      </ng-container>\n    </ng-container>\n  </div>\n\n  <div class=\"cqa-flex cqa-items-center cqa-gap-3 cqa-ml-auto\">\n    <div class=\"cqa-flex cqa-items-center cqa-gap-3\">\n      <!-- View Details Link (show only if description is not empty) -->\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-2 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\n      <!-- Action Icons: Edit, Link, Duplicate, Delete (show on hover; hidden when step is inside step-group) -->\n      <div *ngIf=\"editable && !isInsideStepGroup && !isReorder\" class=\"step-actions cqa-flex cqa-items-center cqa-gap-3 cqa-px-[7px]\">\n      <button type=\"button\" #editTrigger (click)=\"onEdit(); $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\">\n          <path d=\"M7 11.6666H12.25\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n          <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\"/>\n        </svg>\n      </button>\n      <!-- <button type=\"button\" (click)=\"onLink(); $event.stopPropagation()\" title=\"Link\" 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\">\n          <path d=\"M5.00065 9.91671H3.66732C2.78326 9.91671 1.93542 9.60942 1.3103 9.06244C0.685174 8.51545 0.333984 7.77359 0.333984 7.00004C0.333984 6.22649 0.685174 5.48463 1.3103 4.93765C1.93542 4.39066 2.78326 4.08337 3.66732 4.08337H5.00065\" stroke=\"currentColor\" stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n          <path d=\"M9 4.08337H10.3333C11.2174 4.08337 12.0652 4.39066 12.6904 4.93765C13.3155 5.48463 13.6667 6.22649 13.6667 7.00004C13.6667 7.77359 13.3155 8.51545 12.6904 9.06244C12.0652 9.60942 11.2174 9.91671 10.3333 9.91671H9\" stroke=\"currentColor\" stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n          <path d=\"M4.33398 7H9.66732\" stroke=\"currentColor\" stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n        </svg>\n      </button> -->\n      <button\n        type=\"button\"\n        (click)=\"onDuplicate(); $event.stopPropagation()\"\n        [disabled]=\"isDuplicating\"\n        [attr.title]=\"isDuplicating ? 'Duplicating...' : 'Duplicate'\"\n        class=\"cqa-p-0 cqa-text-[#99A1Af] hover:cqa-text-[#1447E6] disabled:cqa-opacity-60 disabled:cqa-cursor-not-allowed\"\n      >\n        <svg *ngIf=\"!isDuplicating\" width=\"14\" height=\"14\" viewBox=\"0 0 14 14\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n          <path d=\"M11.666 4.66663H5.83268C5.18835 4.66663 4.66602 5.18896 4.66602 5.83329V11.6666C4.66602 12.311 5.18835 12.8333 5.83268 12.8333H11.666C12.3103 12.8333 12.8327 12.311 12.8327 11.6666V5.83329C12.8327 5.18896 12.3103 4.66663 11.666 4.66663Z\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n          <path d=\"M2.33268 9.33329C1.69102 9.33329 1.16602 8.80829 1.16602 8.16663V2.33329C1.16602 1.69163 1.69102 1.16663 2.33268 1.16663H8.16602C8.80768 1.16663 9.33268 1.69163 9.33268 2.33329\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n        </svg>\n        <svg *ngIf=\"isDuplicating\" width=\"14\" height=\"14\" viewBox=\"0 0 16 16\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\" aria-label=\"Duplicating\">\n          <circle cx=\"8\" cy=\"8\" r=\"6\" stroke=\"currentColor\" stroke-opacity=\"0.2\" stroke-width=\"2\"></circle>\n          <path d=\"M14 8A6 6 0 0 0 8 2\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\">\n            <animateTransform attributeName=\"transform\" type=\"rotate\" from=\"0 8 8\" to=\"360 8 8\" dur=\"0.8s\" repeatCount=\"indefinite\"/>\n          </path>\n        </svg>\n      </button>\n      <button type=\"button\" (click)=\"onDelete(); $event.stopPropagation()\" title=\"Delete\" 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\">\n          <path d=\"M1.75 3.5H12.25\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n          <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\"/>\n          <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\"/>\n          <path d=\"M5.83398 6.41663V9.91663\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n          <path d=\"M8.16602 6.41663V9.91663\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n        </svg>\n      </button>\n    </div>\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  </div>\n</div>"]}
|
|
460
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"normal-step.component.js","sourceRoot":"","sources":["../../../../../../src/lib/test-case-details/normal-step/normal-step.component.ts","../../../../../../src/lib/test-case-details/normal-step/normal-step.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  Input,\n  Output,\n  EventEmitter,\n  OnInit,\n  HostListener,\n  ElementRef,\n  ViewChild,\n  ChangeDetectorRef,\n  NgZone,\n} from '@angular/core';\nimport { NormalStepConfig, TestCaseEventType, EventTypeConfig, StepParameter, TestCaseStepConfig } from '../test-case-step.models';\nimport { STEP_ROW_ACTIONS_STYLES } from '../step-row-actions.styles';\nimport {\n  CustomEditStepResult,\n  CustomEditStepService,\n} from '../custom-edit-step/custom-edit-step.service';\nimport { CUSTOM_EDIT_STEP_EDIT_IN_DEPTH } from '../custom-edit-step/custom-edit-step-data';\nimport { ElementPopupResult, ElementPopupService } from '../element-popup/element-popup.service';\nimport {\n  TestDataModalResult,\n  TestDataModalService,\n} from '../test-data-modal/test-data-modal.service';\nimport {\n  TEST_DATA_MODAL_EDIT_IN_DEPTH,\n  TestDataModalData,\n} from '../test-data-modal/test-data-modal-data';\nimport { DomSanitizer } from '@angular/platform-browser';\nimport { ViewDetailsPayload } from '../step-details-modal/step-details-modal-data';\n\n@Component({\n  selector: 'cqa-test-case-normal-step',\n  templateUrl: './normal-step.component.html',\n  host: { class: 'cqa-ui-root' },\n  styles: [STEP_ROW_ACTIONS_STYLES],\n})\nexport class TestCaseNormalStepComponent implements OnInit {\n  @ViewChild('dropdownContainer', { static: false }) dropdownContainer?: ElementRef;\n  @ViewChild('descriptionTrigger', { static: false }) descriptionTrigger?: ElementRef<HTMLElement>;\n  @ViewChild('testDataTrigger', { static: false }) testDataTrigger?: ElementRef<HTMLElement>;\n  @ViewChild('editTrigger', { static: false }) editTrigger?: ElementRef<HTMLElement>;\n  @ViewChild('elementTrigger', { static: false }) elementTrigger?: ElementRef<HTMLElement>;\n  @ViewChild('clickElementTrigger', { static: false }) clickElementTrigger?: ElementRef<HTMLElement>;\n  @ViewChild('viewDetailsTrigger', { static: false }) viewDetailsTrigger?: ElementRef<HTMLElement>;\n  @Input() config!: NormalStepConfig;\n  @Input() stepNumber!: number | string;\n  /** Array index from parent renderer - use for editInDepth (stepNumber \"10.3\" parses wrong) */\n  @Input() index?: number;\n  @Input() action!: string;\n  @Input() eventType!: TestCaseEventType;\n  @Input() parameters: StepParameter[] = [];\n  @Input() selected: boolean = false;\n  @Input() disabled: boolean = false;\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  @Input() stepIndex?: number;\n  @Input() isDuplicating: boolean = false;\n\n  @Output() eventTypeChange = new EventEmitter<TestCaseEventType>();\n  @Output() parameterChange = new EventEmitter<{ parameter: StepParameter; value: string }>();\n  @Output() edit = new EventEmitter<void>();\n  @Output() editInDepth = new EventEmitter<{ step: TestCaseStepConfig; index: number }>();\n  @Output() link = new EventEmitter<void>();\n  @Output() duplicate = new EventEmitter<void>();\n  @Output() delete = new EventEmitter<void>();\n  @Output() moreOptions = new EventEmitter<void>();\n  @Output() viewDetails = new EventEmitter<ViewDetailsPayload>();\n  @Output() selectionChange = new EventEmitter<boolean>();\n  @Output() clickAction = new EventEmitter<MouseEvent>();\n\n  eventTypeDropdownOpen: boolean = false;\n  /** Stored test data modal state for reopening with same selections. */\n  private testDataModalState: TestDataModalData | null = null;\n\n  constructor(\n    private readonly customEditStep: CustomEditStepService,\n    private readonly elementPopup: ElementPopupService,\n    private readonly testDataModal: TestDataModalService,\n    private readonly cdr: ChangeDetectorRef,\n    private readonly ngZone: NgZone,\n    private readonly sanitizer: DomSanitizer\n  ) {}\n\n  /** Unique colors per event type; badge uses consistent size (w-8 h-8 rounded-lg). */\n  eventTypeConfigs: EventTypeConfig[] = [\n    { type: 'navigate', label: 'Navigate', icon: 'paper_plane', color: '#4338CA', backgroundColor: '#E0E7FF' },\n    { type: 'custom', label: 'Custom', icon: 'settings', color: '#475569', backgroundColor: '#F1F5F9' },\n    { type: 'ai-agent', label: 'AI Agent', icon: 'star', color: '#7C3AED', backgroundColor: '#EDE9FE' },\n    { type: 'type', label: 'Type', icon: 'T', color: '#A21CAF', backgroundColor: '#FAE8FF' },\n    { type: 'click', label: 'Click', icon: 'cursor', color: '#0284C7', backgroundColor: '#E0F2FE' },\n    { type: 'doubleClick', label: 'Double Click', icon: 'cursor-double', color: '#0891B2', backgroundColor: '#CFFAFE' },\n    { type: 'pressEnter', label: 'Press Enter', icon: 'enter', color: '#0D9488', backgroundColor: '#CCFBF1' },\n    { type: 'enter', label: 'Enter', icon: 'T', color: '#059669', backgroundColor: '#D1FAE5' },\n    { type: 'verify', label: 'Verify', icon: 'check', color: '#16A34A', backgroundColor: '#DCFCE7' },\n    { type: 'wait', label: 'Wait', icon: 'clock', color: '#6B7280', backgroundColor: '#F3F4F6' }\n  ];\n\n  ngOnInit(): void {\n    if (this.config) {\n      this.action = this.config.action || '';\n      this.stepNumber = this.config.stepNumber;\n      this.eventType = this.config.eventType;\n      this.parameters = this.config.parameters || [];\n      this.selected = this.config.selected || false;\n      this.disabled = this.config.disabled || false;\n    }\n  }\n\n  getCurrentEventTypeConfig(): EventTypeConfig {\n    return this.eventTypeConfigs.find(etc => etc.type === this.eventType) || this.eventTypeConfigs[0];\n  }\n\n  getActionDescription(): string {\n    // const config = this.getCurrentEventTypeConfig();\n    // switch (this.eventType) {\n    //   case 'navigate':\n    //     return 'Navigate to';\n    //   case 'type':\n    //     return 'Type';\n    //   case 'click':\n    //     return 'Click on';\n    //   case 'doubleClick':\n    //     return 'Double click on';\n    //   case 'pressEnter':\n    //     return 'Press Enter on';\n    //   case 'enter':\n    //     return 'Enter';\n    //   case 'wait':\n    //     return 'Wait';\n    //   case 'verify':\n    //     return 'Verify';\n    //   case 'custom':\n    //     return 'Custom step';\n    //   case 'ai-agent':\n    //     return 'AI Agent';\n    //   default:\n    //     return '';\n    // }\n      if (this.action) {\n        return this.action ? this.sanitizer.bypassSecurityTrustHtml(this.action) as string : '';\n      }\n      return '';\n  }\n\n  getActionSuffix(): string {\n    switch (this.eventType) {\n      case 'type':\n        return 'into';\n      case 'wait':\n        if (this.parameters.length > 0 && this.parameters[0].name === 'duration') {\n          return 'seconds';\n        }\n        return 'for element';\n      default:\n        return '';\n    }\n  }\n\n  /** Current description for custom event type (first parameter value). */\n  getCustomDescription(): string {\n    if (this.eventType !== 'custom' || !this.parameters?.length) {\n      return '';\n    }\n    const first = this.parameters[0];\n    return first?.value ?? first?.displayValue ?? '';\n  }\n\n  /**\n   * Get the URL parameter for navigate steps (old UI style - show only URL)\n   * Returns the first parameter with name 'url' or 'URL', or the first parameter if none found\n   */\n  getNavigateUrlParameter(): StepParameter | null {\n    if (this.eventType !== 'navigate' || !this.parameters || this.parameters.length === 0) {\n      return null;\n    }\n    // Try to find parameter with name 'url' or 'URL'\n    const urlParam = this.parameters.find(p => p.name?.toLowerCase() === 'url');\n    // If not found, return the first parameter (likely the URL)\n    return urlParam || this.parameters[0] || null;\n  }\n\n  /** Current URL value for navigate step (for Test Data modal). */\n  getNavigateUrlValue(): string {\n    const param = this.getNavigateUrlParameter();\n    return param?.value ?? param?.displayValue ?? '';\n  }\n\n  /** Opens Test Data modal below the given trigger; used when eventType === 'navigate'. */\n  openTestDataModal(origin: ElementRef<HTMLElement> | HTMLElement | MouseEvent): void {\n    if (this.isInsideStepGroup || this.eventType !== 'navigate') {\n      return;\n    }\n    const el =\n      origin instanceof MouseEvent\n        ? (origin.currentTarget as HTMLElement)\n        : origin instanceof ElementRef\n          ? origin.nativeElement\n          : (origin as HTMLElement);\n    const originRef = new ElementRef(el);\n    \n    // Use stored state if available, otherwise use current URL value\n    const modalData: TestDataModalData = this.testDataModalState ?? {\n      value: this.getNavigateUrlValue(),\n    };\n    \n    const ref = this.testDataModal.open(originRef, modalData);\n    ref.afterClosed().subscribe((result: TestDataModalResult) => {\n      this.ngZone.run(() => {\n        if (result === TEST_DATA_MODAL_EDIT_IN_DEPTH) {\n          this.moreOptions.emit();\n          this.cdr.markForCheck();\n          return;\n        }\n        \n        // Handle TestDataModalData object (full state)\n        if (result !== undefined && typeof result === 'object' && 'value' in result) {\n          const modalDataResult = result as TestDataModalData;\n          this.testDataModalState = modalDataResult; // Store state for reopening\n          const urlParam = this.getNavigateUrlParameter();\n          if (urlParam && modalDataResult.value) {\n            urlParam.value = modalDataResult.value;\n            urlParam.displayValue = modalDataResult.value;\n            this.parameterChange.emit({ parameter: urlParam, value: modalDataResult.value });\n            this.cdr.markForCheck();\n            this.cdr.detectChanges();\n          }\n          return;\n        }\n        \n        // Handle string result (backward compatibility)\n        if (typeof result === 'string') {\n          const urlParam = this.getNavigateUrlParameter();\n          if (urlParam) {\n            urlParam.value = result;\n            urlParam.displayValue = result;\n            this.parameterChange.emit({ parameter: urlParam, value: result });\n            // Clear stored state when using string result\n            this.testDataModalState = null;\n            this.cdr.markForCheck();\n            this.cdr.detectChanges();\n          }\n        }\n      });\n    });\n  }\n\n  /** Opens Step Description modal below the given trigger; used when eventType === 'custom'. */\n  openStepDescriptionModal(origin: ElementRef<HTMLElement> | HTMLElement | MouseEvent): void {\n    if (this.eventType !== 'custom') {\n      return;\n    }\n    const el =\n      origin instanceof MouseEvent\n        ? (origin.currentTarget as HTMLElement)\n        : origin instanceof ElementRef\n          ? origin.nativeElement\n          : (origin as HTMLElement);\n    const originRef = new ElementRef(el);\n    const ref = this.customEditStep.open(originRef, {\n      description: this.getCustomDescription(),\n    });\n    ref.afterClosed().subscribe((result: CustomEditStepResult) => {\n      this.ngZone.run(() => {\n        if (result === CUSTOM_EDIT_STEP_EDIT_IN_DEPTH) {\n          this.moreOptions.emit();\n          this.cdr.markForCheck();\n          return;\n        }\n        if (typeof result === 'string' && this.parameters?.length) {\n          const first = this.parameters[0];\n          if (first) {\n            first.value = result;\n            first.displayValue = result;\n            this.parameterChange.emit({ parameter: first, value: result });\n            this.cdr.markForCheck();\n            this.cdr.detectChanges();\n          }\n        }\n      });\n    });\n  }\n\n  openElementPopup(origin: ElementRef<HTMLElement> | HTMLElement | MouseEvent): void {\n    if (this.isInsideStepGroup) return;\n    const elementParam = this.parameters.find(p => p.name === 'element');\n    const elementData = this.config.elementData;\n\n    let el: HTMLElement;\n    if (this.elementTrigger?.nativeElement) {\n      el = this.elementTrigger.nativeElement;\n    } else if (this.clickElementTrigger?.nativeElement) {\n      el = this.clickElementTrigger.nativeElement;\n    } else {\n      el =\n        origin instanceof MouseEvent\n          ? (origin.currentTarget as HTMLElement)\n          : origin instanceof ElementRef\n            ? origin.nativeElement\n            : (origin as HTMLElement);\n    }\n    const originRef = new ElementRef(el);\n    const elementTitle = elementData?.label || elementParam?.value || 'Element';\n    const elementSelector = elementData?.selector || elementParam?.value || '';\n    const elementLabels = elementData?.labels || (elementData?.label ? [elementData.label] : []);\n    const allLabels = elementLabels.length > 0 ? elementLabels : ['css', 'xpath', 'id'];\n    \n    const elementPopupRef = this.elementPopup.open(originRef, {\n      element: {\n        title: elementTitle,\n        selector: elementSelector,\n        labels: elementLabels\n      },\n      labels: allLabels,\n      description: this.config.description || 'Element details',\n      helpUrl: '',\n      elements: elementData ? [\n        {\n          title: elementTitle,\n          selector: elementSelector,\n          labels: elementLabels\n        }\n      ] : []\n    });\n    elementPopupRef.afterClosed().subscribe((result: ElementPopupResult) => {\n      if (result !== undefined && typeof result === 'string') {\n        this.parameterChange.emit({ parameter: { name: 'element', value: result, displayValue: result }, value: result });\n      }\n    });\n  }\n\n  onEventTypeSelect(eventType: TestCaseEventType): void {\n    this.eventType = eventType;\n    this.eventTypeDropdownOpen = false;\n    this.eventTypeChange.emit(eventType);\n  }\n\n  onParameterChange(parameter: StepParameter, value: string): void {\n    parameter.value = value;\n    this.parameterChange.emit({ parameter, value });\n  }\n\n  onEdit(): void {\n    if (this.eventType === 'custom' && this.descriptionTrigger?.nativeElement) {\n      this.openStepDescriptionModal(new ElementRef(this.descriptionTrigger.nativeElement));\n      return;\n    }\n    if (this.eventType === 'navigate' && this.testDataTrigger?.nativeElement) {\n      this.openTestDataModal(new ElementRef(this.testDataTrigger.nativeElement));\n      return;\n    }\n    // Emit editInDepth - prefer renderer index (correct); stepNumber \"10.3\" parses to 10 - wrong\n    const idx = typeof this.index === 'number' ? this.index : (typeof this.stepNumber === 'number' ? this.stepNumber - 1 : (typeof this.stepNumber === 'string' ? parseInt(this.stepNumber, 10) - 1 : (this.stepIndex ?? 0)));\n    this.editInDepth.emit({ step: this.config as TestCaseStepConfig, index: isNaN(idx as number) ? 0 : (idx as number) });\n    this.edit.emit();\n  }\n\n  onLink(): void {\n    this.link.emit();\n  }\n\n  onDuplicate(): void {\n    if (this.isDuplicating) return;\n    this.duplicate.emit();\n  }\n\n  onDelete(): void {\n    this.delete.emit();\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      const title = this.getStepTitle();\n      this.viewDetails.emit({\n        event,\n        title,\n        description: this.config.description,\n      });\n    }\n  }\n\n  private getStepTitle(): string {\n    switch (this.eventType) {\n      case 'ai-agent':\n        return 'Agent Instructions';\n      case 'custom':\n        return 'Step Description';\n      case 'navigate':\n        return 'Navigate Step';\n      case 'type':\n        return 'Type Step';\n      case 'click':\n        return 'Click Step';\n      case 'doubleClick':\n        return 'Double Click Step';\n      case 'pressEnter':\n        return 'Press Enter Step';\n      case 'enter':\n        return 'Enter Step';\n      case 'verify':\n        return 'Verify Step';\n      case 'wait':\n        return 'Wait Step';\n      default:\n        return 'Step Details';\n    }\n  }\n\n  onSelectionChange(checked: boolean): void {\n    this.selected = checked;\n    this.selectionChange.emit(checked);\n  }\n\n  toggleEventTypeDropdown(): void {\n    this.eventTypeDropdownOpen = !this.eventTypeDropdownOpen;\n  }\n\n  closeEventTypeDropdown(): void {\n    this.eventTypeDropdownOpen = false;\n  }\n\n  @HostListener('document:click', ['$event'])\n  onDocumentClick(event: MouseEvent): void {\n    if (this.dropdownContainer && !this.dropdownContainer.nativeElement.contains(event.target)) {\n      this.closeEventTypeDropdown();\n    }\n  }\n\n  clickOnAction(event: MouseEvent): void {\n    event.preventDefault();\n    event.stopPropagation();\n    if (this.isInsideStepGroup) return;\n    this.clickAction.emit(event);\n  }\n}\n","<div [class]=\"'step-row cqa-flex cqa-items-center cqa-gap-3 cqa-py-2 cqa-px-4 ' + (isInsideLoop && isInsideStepGroup ? 'cqa-pl-20 cqa-pr-4' : (isInsideLoop || isInsideStepGroup) ? 'cqa-pl-10 cqa-pr-4' : '')\" style=\"border-top: 1px solid #E5E7EB; border-bottom: 1px solid #E5E7EB;\">\n\n  <div class=\"cqa-inline-flex cqa-items-center\">\n    <!-- Drag Handle Icon (when isReorder is true and not inside step group - steps inside step groups cannot be reordered) -->\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, editable, 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        [disabled]=\"disabled\"\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\" />\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\n  <!-- Step Number -->\n  <span class=\"cqa-text-[#6B7280] cqa-text-[14px] cqa-leading-[18px] cqa-min-w-[32px]\">\n    {{ stepNumber }}\n  </span>\n\n  <!-- Event Type Selector (Pill Button) #### (click)=\"toggleEventTypeDropdown(); $event.stopPropagation()\" -->\n  <div class=\"cqa-relative\" #dropdownContainer>\n    <button type=\"button\" \n      [attr.title]=\"getCurrentEventTypeConfig().label\"\n      [style.background-color]=\"getCurrentEventTypeConfig().backgroundColor\"\n      [style.color]=\"getCurrentEventTypeConfig().color\"\n      class=\"cqa-w-8 cqa-h-8 cqa-rounded-lg cqa-flex cqa-items-center cqa-justify-center cqa-flex-shrink-0 cqa-cursor-pointer\">\n      <!-- Icon -->\n      <span *ngIf=\"getCurrentEventTypeConfig().icon === 'paper_plane'\">\n        <svg width=\"14\" height=\"14\" viewBox=\"0 0 14 14\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n          <path d=\"M1.75 6.41663L12.8333 1.16663L7.58333 12.25L6.41667 7.58329L1.75 6.41663Z\" stroke=\"currentColor\"\n            stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n        </svg>\n      </span>\n      <span *ngIf=\"getCurrentEventTypeConfig().icon === 'star'\">\n        <svg width=\"14\" height=\"14\" viewBox=\"0 0 14 14\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n          <path\n            d=\"M5.797 9.04165C5.74492 8.83977 5.63969 8.65554 5.49227 8.50812C5.34485 8.3607 5.16062 8.25548 4.95875 8.2034L1.38 7.28057C1.31894 7.26324 1.2652 7.22646 1.22694 7.17583C1.18867 7.12519 1.16797 7.06345 1.16797 6.99998C1.16797 6.93651 1.18867 6.87478 1.22694 6.82414C1.2652 6.7735 1.31894 6.73673 1.38 6.7194L4.95875 5.79598C5.16055 5.74395 5.34473 5.63882 5.49215 5.49151C5.63956 5.34419 5.74483 5.16008 5.797 4.95832L6.71983 1.37957C6.73698 1.31827 6.77372 1.26427 6.82443 1.2258C6.87515 1.18733 6.93705 1.1665 7.0007 1.1665C7.06436 1.1665 7.12626 1.18733 7.17698 1.2258C7.22769 1.26427 7.26442 1.31827 7.28158 1.37957L8.20383 4.95832C8.25591 5.16019 8.36113 5.34442 8.50855 5.49184C8.65597 5.63926 8.8402 5.74449 9.04208 5.79657L12.6208 6.71882C12.6824 6.73579 12.7366 6.77249 12.7753 6.82328C12.814 6.87407 12.8349 6.93614 12.8349 6.99998C12.8349 7.06382 12.814 7.1259 12.7753 7.17669C12.7366 7.22748 12.6824 7.26417 12.6208 7.28115L9.04208 8.2034C8.8402 8.25548 8.65597 8.3607 8.50855 8.50812C8.36113 8.65554 8.25591 8.83977 8.20383 9.04165L7.281 12.6204C7.26384 12.6817 7.22711 12.7357 7.17639 12.7742C7.12568 12.8126 7.06377 12.8335 7.00012 12.8335C6.93647 12.8335 6.87456 12.8126 6.82385 12.7742C6.77314 12.7357 6.7364 12.6817 6.71925 12.6204L5.797 9.04165Z\"\n            stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n          <path d=\"M11.666 1.75V4.08333\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\"\n            stroke-linejoin=\"round\" />\n          <path d=\"M12.8333 2.91663H10.5\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\"\n            stroke-linejoin=\"round\" />\n          <path d=\"M2.33398 9.91663V11.0833\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\"\n            stroke-linejoin=\"round\" />\n          <path d=\"M2.91667 10.5H1.75\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\"\n            stroke-linejoin=\"round\" />\n        </svg>\n      </span>\n      <span *ngIf=\"getCurrentEventTypeConfig().icon === 'T'\">\n        <svg width=\"14\" height=\"14\" viewBox=\"0 0 14 14\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n          <path d=\"M2.33398 4.08325V2.33325H11.6673V4.08325\" stroke=\"currentColor\" stroke-width=\"1.16667\"\n            stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n          <path d=\"M5.25 11.6667H8.75\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\"\n            stroke-linejoin=\"round\" />\n          <path d=\"M7 2.33325V11.6666\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\"\n            stroke-linejoin=\"round\" />\n        </svg>\n      </span>\n      <span *ngIf=\"getCurrentEventTypeConfig().icon === 'cursor'\">\n        <svg width=\"14\" height=\"14\" viewBox=\"0 0 14 14\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n          <path d=\"M1.75 1.75L5.87417 11.6492L7.33833 7.33833L11.6492 5.87417L1.75 1.75Z\" stroke=\"currentColor\"\n            stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n          <path d=\"M7.58398 7.58325L11.084 11.0833\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\"\n            stroke-linejoin=\"round\" />\n        </svg>\n      </span>\n      <span *ngIf=\"getCurrentEventTypeConfig().icon === 'cursor-double'\">\n        <svg width=\"14\" height=\"14\" viewBox=\"0 0 14 14\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M8.16667 2.3916L7 3.49993\" stroke=\"currentColor\" stroke-width=\"1.25\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M2.97487 4.66662L1.2832 4.19995\" stroke=\"currentColor\" stroke-width=\"1.25\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M3.50091 7L2.39258 8.16667\" stroke=\"currentColor\" stroke-width=\"1.25\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M4.19922 1.28345L4.66589 2.97511\" stroke=\"currentColor\" stroke-width=\"1.25\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M5.27114 5.65255C5.24852 5.59926 5.24234 5.54043 5.25338 5.48361C5.26443 5.42678 5.2922 5.37455 5.33313 5.33362C5.37407 5.29269 5.4263 5.26492 5.48312 5.25387C5.53994 5.24283 5.59877 5.24901 5.65206 5.27163L12.0687 7.89663C12.1258 7.92006 12.174 7.961 12.2064 8.01357C12.2388 8.06613 12.2536 8.12761 12.2488 8.18915C12.244 8.25069 12.2198 8.30912 12.1797 8.35603C12.1396 8.40295 12.0856 8.43592 12.0256 8.45021L9.48864 9.05746C9.38391 9.08248 9.28815 9.13599 9.21196 9.21208C9.13578 9.28816 9.08213 9.38385 9.05698 9.48855L8.45031 12.026C8.43617 12.0863 8.40323 12.1405 8.35626 12.1808C8.30928 12.2211 8.25071 12.2454 8.189 12.2502C8.1273 12.255 8.06567 12.2401 8.01302 12.2075C7.96037 12.175 7.91944 12.1266 7.89614 12.0692L5.27114 5.65255Z\" stroke=\"currentColor\" stroke-width=\"1.25\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n        </svg>\n      </span>\n      <span *ngIf=\"getCurrentEventTypeConfig().icon === 'enter'\" class=\"cqa-enter-key-icon cqa-inline-flex cqa-flex-shrink-0\" style=\"width: 20px; height: 20px;\">\n        <svg width=\"20\" height=\"20\" viewBox=\"0 0 32 32\" xmlns=\"http://www.w3.org/2000/svg\" class=\"cqa-w-full cqa-h-full\">\n          <path fill=\"#6B7280\" transform=\"translate(14,5)\" d=\"M0 0 C4.29 0 8.58 0 13 0 C13 7.26 13 14.52 13 22 C5.74 22 -1.52 22 -9 22 C-9 16.72 -9 11.44 -9 6 C-6.03 6 -3.06 6 0 6 C0 4.02 0 2.04 0 0 Z M2 2 C2 3.98 2 5.96 2 8 C-0.97 8 -3.94 8 -7 8 C-7 11.96 -7 15.92 -7 20 C-1.06 20 4.88 20 11 20 C11 14.06 11 8.12 11 2 C8.03 2 5.06 2 2 2 Z\"/>\n          <path fill=\"#6B7280\" transform=\"translate(19,13)\" d=\"M0 0 C0.66 0 1.32 0 2 0 C2 2.31 2 4.62 2 7 C0.02 7 -1.96 7 -4 7 C-4.33 8.32 -4.66 9.64 -5 11 C-6.65 9.68 -8.3 8.36 -10 7 C-8.63016497 3.83884224 -8.0109362 3.0072908 -5 1 C-4.67 2.32 -4.34 3.64 -4 5 C-2.68 5 -1.36 5 0 5 C0 3.35 0 1.7 0 0 Z\"/>\n        </svg>\n      </span>\n      <span *ngIf=\"getCurrentEventTypeConfig().icon === 'clock'\">\n        <svg width=\"14\" height=\"14\" viewBox=\"0 0 14 14\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n          <path\n            d=\"M6.99935 12.8334C10.221 12.8334 12.8327 10.2217 12.8327 7.00008C12.8327 3.77842 10.221 1.16675 6.99935 1.16675C3.77769 1.16675 1.16602 3.77842 1.16602 7.00008C1.16602 10.2217 3.77769 12.8334 6.99935 12.8334Z\"\n            stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n          <path d=\"M7 3.5V7L9.33333 8.16667\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\"\n            stroke-linejoin=\"round\" />\n        </svg>\n      </span>\n      <span *ngIf=\"getCurrentEventTypeConfig().icon === 'settings'\">\n        <svg width=\"14\" height=\"14\" viewBox=\"0 0 14 14\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n          <path d=\"M7 4.66667C5.71133 4.66667 4.66667 5.71133 4.66667 7C4.66667 8.28867 5.71133 9.33333 7 9.33333C8.28867 9.33333 9.33333 8.28867 9.33333 7C9.33333 5.71133 8.28867 4.66667 7 4.66667Z\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n          <path d=\"M11.0833 7.58333C11.1417 7.29167 11.1417 6.70833 11.0833 6.41667L12.25 5.83333C12.4167 5.70833 12.4833 5.48333 12.4167 5.25L11.6667 3.41667C11.6 3.18333 11.3917 3.04167 11.1417 3.04167L9.91667 3.5C9.56667 3.20833 9.19167 2.95833 8.75 2.79167L8.4 1.45833C8.34167 1.225 8.14167 1.16667 7.93333 1.16667H6.06667C5.85833 1.16667 5.65833 1.225 5.6 1.45833L5.25 2.79167C4.80833 2.95833 4.43333 3.20833 4.08333 3.5L2.85833 3.04167C2.60833 3.04167 2.4 3.18333 2.33333 3.41667L1.58333 5.25C1.51667 5.48333 1.58333 5.70833 1.75 5.83333L2.91667 6.41667C2.85833 6.70833 2.85833 7.29167 2.91667 7.58333L1.75 8.16667C1.58333 8.29167 1.51667 8.51667 1.58333 8.75L2.33333 10.5833C2.4 10.8167 2.60833 10.9583 2.85833 10.9583L4.08333 10.5C4.43333 10.7917 4.80833 11.0417 5.25 11.2083L5.6 12.5417C5.65833 12.775 5.85833 12.8333 6.06667 12.8333H7.93333C8.14167 12.8333 8.34167 12.775 8.4 12.5417L8.75 11.2083C9.19167 11.0417 9.56667 10.7917 9.91667 10.5L11.1417 10.9583C11.3917 10.9583 11.6 10.8167 11.6667 10.5833L12.4167 8.75C12.4833 8.51667 12.4167 8.29167 12.25 8.16667L11.0833 7.58333Z\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n        </svg>\n      </span>\n      <span *ngIf=\"getCurrentEventTypeConfig().icon === 'check'\">\n        <svg width=\"14\" height=\"14\" viewBox=\"0 0 14 14\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n          <path d=\"M11.6667 3.5L5.25 10.5L2.33333 7.58333\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n        </svg>\n      </span>\n\n      <!-- Label (show only when no icon; all types have icon now – tooltip on button) -->\n      <span *ngIf=\"!getCurrentEventTypeConfig().icon\" class=\"cqa-text-[#432DD7] cqa-text-[10px] cqa-leading-[15px] cqa-font-medium\">{{\n        getCurrentEventTypeConfig().label }}</span>\n    </button>\n\n    <!-- Dropdown Menu -->\n    <div *ngIf=\"eventTypeDropdownOpen\" (click)=\"$event.stopPropagation()\"\n      class=\"cqa-absolute cqa-top-full cqa-left-0 cqa-mt-1 cqa-bg-white cqa-rounded-lg cqa-shadow-lg cqa-border cqa-border-gray-200 cqa-z-50 cqa-min-w-[150px] cqa-py-1\">\n      <button *ngFor=\"let etc of eventTypeConfigs\" type=\"button\" (click)=\"onEventTypeSelect(etc.type)\"\n        [class.cqa-bg-primary-50]=\"eventType === etc.type\"\n        class=\"cqa-w-full cqa-px-3 cqa-py-2 cqa-text-left cqa-flex cqa-items-center cqa-gap-2 hover:cqa-bg-gray-50 cqa-transition-colors\">\n        <span *ngIf=\"etc.icon === 'paper_plane'\">\n          <svg width=\"12\" height=\"12\" viewBox=\"0 0 12 12\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n            <path d=\"M1 5.5L11 1M11 1L7.5 11L6 6.5L1 5.5M11 1L1 5.5\" stroke=\"currentColor\" stroke-width=\"1.5\"\n              stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n          </svg>\n        </span>\n        <span *ngIf=\"etc.icon === 'star'\">\n          <svg width=\"12\" height=\"12\" viewBox=\"0 0 12 12\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n            <path d=\"M6 1L7.5 4.5L11 5L7.5 5.5L6 9L4.5 5.5L1 5L4.5 4.5L6 1Z\" fill=\"currentColor\" />\n          </svg>\n        </span>\n        <span *ngIf=\"etc.icon === 'T'\">\n          <svg width=\"12\" height=\"12\" viewBox=\"0 0 14 14\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n            <path d=\"M2.33398 4.08325V2.33325H11.6673V4.08325\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n            <path d=\"M5.25 11.6667H8.75\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n            <path d=\"M7 2.33325V11.6666\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n          </svg>\n        </span>\n        <span *ngIf=\"etc.icon === 'cursor'\">\n          <svg width=\"12\" height=\"12\" viewBox=\"0 0 12 12\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n            <path d=\"M2 2L9 1L10 8L7 7L5 9L4 7L2 2Z\" stroke=\"currentColor\" stroke-width=\"1.5\" stroke-linecap=\"round\"\n              stroke-linejoin=\"round\" />\n          </svg>\n        </span>\n        <span *ngIf=\"etc.icon === 'cursor-double'\">\n          <svg width=\"14\" height=\"14\" viewBox=\"0 0 14 14\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M8.16667 2.3916L7 3.49993\" stroke=\"currentColor\" stroke-width=\"1.25\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M2.97487 4.66662L1.2832 4.19995\" stroke=\"currentColor\" stroke-width=\"1.25\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M3.50091 7L2.39258 8.16667\" stroke=\"currentColor\" stroke-width=\"1.25\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M4.19922 1.28345L4.66589 2.97511\" stroke=\"currentColor\" stroke-width=\"1.25\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M5.27114 5.65255C5.24852 5.59926 5.24234 5.54043 5.25338 5.48361C5.26443 5.42678 5.2922 5.37455 5.33313 5.33362C5.37407 5.29269 5.4263 5.26492 5.48312 5.25387C5.53994 5.24283 5.59877 5.24901 5.65206 5.27163L12.0687 7.89663C12.1258 7.92006 12.174 7.961 12.2064 8.01357C12.2388 8.06613 12.2536 8.12761 12.2488 8.18915C12.244 8.25069 12.2198 8.30912 12.1797 8.35603C12.1396 8.40295 12.0856 8.43592 12.0256 8.45021L9.48864 9.05746C9.38391 9.08248 9.28815 9.13599 9.21196 9.21208C9.13578 9.28816 9.08213 9.38385 9.05698 9.48855L8.45031 12.026C8.43617 12.0863 8.40323 12.1405 8.35626 12.1808C8.30928 12.2211 8.25071 12.2454 8.189 12.2502C8.1273 12.255 8.06567 12.2401 8.01302 12.2075C7.96037 12.175 7.91944 12.1266 7.89614 12.0692L5.27114 5.65255Z\" stroke=\"currentColor\" stroke-width=\"1.25\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n          </svg>  \n        </span>\n        <span *ngIf=\"etc.icon === 'enter'\" class=\"cqa-enter-key-icon cqa-inline-flex cqa-flex-shrink-0\" style=\"width: 16px; height: 16px;\">\n          <svg width=\"16\" height=\"16\" viewBox=\"0 0 32 32\" xmlns=\"http://www.w3.org/2000/svg\" class=\"cqa-w-full cqa-h-full\">\n            <path fill=\"#6B7280\" transform=\"translate(14,5)\" d=\"M0 0 C4.29 0 8.58 0 13 0 C13 7.26 13 14.52 13 22 C5.74 22 -1.52 22 -9 22 C-9 16.72 -9 11.44 -9 6 C-6.03 6 -3.06 6 0 6 C0 4.02 0 2.04 0 0 Z M2 2 C2 3.98 2 5.96 2 8 C-0.97 8 -3.94 8 -7 8 C-7 11.96 -7 15.92 -7 20 C-1.06 20 4.88 20 11 20 C11 14.06 11 8.12 11 2 C8.03 2 5.06 2 2 2 Z\"/>\n            <path fill=\"#6B7280\" transform=\"translate(19,13)\" d=\"M0 0 C0.66 0 1.32 0 2 0 C2 2.31 2 4.62 2 7 C0.02 7 -1.96 7 -4 7 C-4.33 8.32 -4.66 9.64 -5 11 C-6.65 9.68 -8.3 8.36 -10 7 C-8.63016497 3.83884224 -8.0109362 3.0072908 -5 1 C-4.67 2.32 -4.34 3.64 -4 5 C-2.68 5 -1.36 5 0 5 C0 3.35 0 1.7 0 0 Z\"/>\n          </svg>\n        </span>\n        <span *ngIf=\"etc.icon === 'clock'\">\n          <svg width=\"12\" height=\"12\" viewBox=\"0 0 12 12\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n            <circle cx=\"6\" cy=\"6\" r=\"5\" stroke=\"currentColor\" stroke-width=\"1.5\" />\n            <path d=\"M6 3V6L8 7\" stroke=\"currentColor\" stroke-width=\"1.5\" stroke-linecap=\"round\" />\n          </svg>\n        </span>\n        <span *ngIf=\"etc.icon === 'settings'\">\n          <svg width=\"12\" height=\"12\" viewBox=\"0 0 14 14\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n            <path d=\"M7 4.66667C5.71133 4.66667 4.66667 5.71133 4.66667 7C4.66667 8.28867 5.71133 9.33333 7 9.33333C8.28867 9.33333 9.33333 8.28867 9.33333 7C9.33333 5.71133 8.28867 4.66667 7 4.66667Z\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n            <path d=\"M11.0833 7.58333C11.1417 7.29167 11.1417 6.70833 11.0833 6.41667L12.25 5.83333C12.4167 5.70833 12.4833 5.48333 12.4167 5.25L11.6667 3.41667C11.6 3.18333 11.3917 3.04167 11.1417 3.04167L9.91667 3.5C9.56667 3.20833 9.19167 2.95833 8.75 2.79167L8.4 1.45833C8.34167 1.225 8.14167 1.16667 7.93333 1.16667H6.06667C5.85833 1.16667 5.65833 1.225 5.6 1.45833L5.25 2.79167C4.80833 2.95833 4.43333 3.20833 4.08333 3.5L2.85833 3.04167C2.60833 3.04167 2.4 3.18333 2.33333 3.41667L1.58333 5.25C1.51667 5.48333 1.58333 5.70833 1.75 5.83333L2.91667 6.41667C2.85833 6.70833 2.85833 7.29167 2.91667 7.58333L1.75 8.16667C1.58333 8.29167 1.51667 8.51667 1.58333 8.75L2.33333 10.5833C2.4 10.8167 2.60833 10.9583 2.85833 10.9583L4.08333 10.5C4.43333 10.7917 4.80833 11.0417 5.25 11.2083L5.6 12.5417C5.65833 12.775 5.85833 12.8333 6.06667 12.8333H7.93333C8.14167 12.8333 8.34167 12.775 8.4 12.5417L8.75 11.2083C9.19167 11.0417 9.56667 10.7917 9.91667 10.5L11.1417 10.9583C11.3917 10.9583 11.6 10.8167 11.6667 10.5833L12.4167 8.75C12.4833 8.51667 12.4167 8.29167 12.25 8.16667L11.0833 7.58333Z\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n          </svg>\n        </span>\n        <span *ngIf=\"etc.icon === 'check'\">\n          <svg width=\"12\" height=\"12\" viewBox=\"0 0 14 14\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n            <path d=\"M11.6667 3.5L5.25 10.5L2.33333 7.58333\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n          </svg>\n        </span>\n        <span>{{ etc.label }}</span>\n      </button>\n    </div>\n  </div>\n\n  <!-- Action Description: flex-1 + min-w-0 so row can shrink; block flow in step-list SCSS avoids flex breaking innerHTML badges -->\n  <span class=\"cqa-text-[#111827] cqa-text-[14px] cqa-leading-[18px] cqa-action-format cqa-align-middle cqa-min-w-0 cqa-flex-1\" *ngIf=\"getActionDescription()\"\n   [innerHTML]=\"getActionDescription()\" (click)=\"clickOnAction($event)\">\n  </span>\n  <!-- <span class=\"cqa-text-[#111827] cqa-text-[14px] cqa-leading-[18px]\" *ngIf=\"getActionDescription()\">\n    {{ getActionDescription() }}\n  </span> -->\n\n  <!-- Parameters -->\n  <div class=\"cqa-flex cqa-items-center cqa-gap-3\" *ngIf=\"false\">\n    <!-- Navigate: URL as clickable trigger for Test Data modal -->\n    <span *ngIf=\"eventType === 'navigate' && getNavigateUrlParameter()\" #testDataTrigger\n      (click)=\"openTestDataModal($event)\"\n      class=\"cqa-py-0.5 cqa-px-2 cqa-text-[#3F43EE] cqa-text-[14px] cqa-leading-[17px] cqa-font-semibold cqa-border cqa-border-solid cqa-border-[#8A8CF4] cqa-rounded cqa-bg-[#D8D9FC] cqa-cursor-pointer hover:cqa-opacity-90\">\n      {{ getNavigateUrlParameter()?.value || getNavigateUrlParameter()?.displayValue }}\n    </span>\n    \n    <!-- Other event types: loop through parameters (navigate excluded) -->\n    <ng-container *ngFor=\"let param of parameters; let i = index\">\n      <!-- Skip navigate parameters in the loop (already shown above) -->\n      <ng-container *ngIf=\"eventType !== 'navigate'\">\n\n      <!-- Type: First param (text value like {{username}}) -->\n      <span *ngIf=\"eventType === 'type' && i === 0\" class=\"cqa-text-gray-900 cqa-text-sm\">\n        {{ param.value }}\n      </span>\n\n      <!-- Type: \"into\" text -->\n      <span *ngIf=\"eventType === 'type' && i === 0\" class=\"cqa-text-gray-900 cqa-text-sm\">\n        into\n      </span>\n\n      <!-- Type: Second param (selector) -->\n      <span *ngIf=\"eventType === 'type' && i === 1\"\n        class=\"cqa-py-0.5 cqa-px-2 cqa-text-[#3F43EE] cqa-text-[14px] cqa-leading-[17px] cqa-font-semibold cqa-border cqa-border-solid cqa-border-[#8A8CF4] cqa-rounded cqa-bg-[#D8D9FC]\">\n        {{ param.displayValue || param.value }}\n      </span>\n\n      <!-- Click: Selector input/display -->\n      <span *ngIf=\"eventType === 'click' && param.name === 'element'\"\n       #clickElementTrigger\n       (click)=\"openElementPopup($event)\"\n        class=\"cqa-py-0.5 cqa-px-2 cqa-text-[#3F43EE] cqa-text-[14px] cqa-leading-[17px] cqa-font-semibold cqa-border cqa-border-solid cqa-border-[#8A8CF4] cqa-rounded cqa-cursor-pointer cqa-bg-[#D8D9FC]\">\n        {{ param.displayValue || param.value }}\n      </span>\n\n      <!-- Click: Suffix text (like \"if Present\") -->\n      <span *ngIf=\"eventType === 'click' && param.name === 'suffix'\" class=\"cqa-text-gray-900 cqa-text-sm\">\n        {{ param.value }}\n      </span>\n\n      <!-- Double Click: Selector input/display -->\n      <span *ngIf=\"eventType === 'doubleClick' && i === 0\"\n        class=\"cqa-py-0.5 cqa-px-2 cqa-text-[#3F43EE] cqa-text-[14px] cqa-leading-[17px] cqa-font-semibold cqa-border cqa-border-solid cqa-border-[#8A8CF4] cqa-rounded cqa-bg-[#D8D9FC]\">\n        {{ param.displayValue || param.value }}\n      </span>\n\n      <!-- Press Enter: Selector input/display with HTML support -->\n      <span *ngIf=\"eventType === 'pressEnter' && i === 0\"\n        class=\"cqa-py-0.5 cqa-px-2 cqa-text-[#3F43EE] cqa-text-[14px] cqa-leading-[17px] cqa-font-semibold cqa-border cqa-border-solid cqa-border-[#8A8CF4] cqa-rounded cqa-bg-[#D8D9FC]\"\n        [innerHTML]=\"param.displayValue || param.value\">\n      </span>\n\n      <!-- Enter: Value display with quotes (like click action) -->\n      <span *ngIf=\"eventType === 'enter' && param.name === 'value'\"\n        class=\"cqa-py-0.5 cqa-px-2 cqa-text-[#3F43EE] cqa-text-[14px] cqa-leading-[17px] cqa-font-semibold cqa-border cqa-border-solid cqa-border-[#8A8CF4] cqa-rounded cqa-bg-[#D8D9FC]\">\n        {{ param.displayValue || param.value }}\n      </span>\n\n      <!-- Enter: \"in the\" text -->\n      <span *ngIf=\"eventType === 'enter' && param.name === 'value'\" class=\"cqa-text-gray-900 cqa-text-sm\">\n        in the\n      </span>\n\n      <!-- Enter: Label display with quotes (like click action) -->\n      <span *ngIf=\"eventType === 'enter' && param.name === 'label'\"\n        class=\"cqa-py-0.5 cqa-px-2 cqa-text-[#3F43EE] cqa-text-[14px] cqa-leading-[17px] cqa-font-semibold cqa-border cqa-border-solid cqa-border-[#8A8CF4] cqa-rounded cqa-bg-[#D8D9FC]\">\n        {{ param.displayValue || param.value }}\n      </span>\n\n      <!-- Enter: \"field\" text -->\n      <span *ngIf=\"eventType === 'enter' && param.name === 'label'\" class=\"cqa-text-gray-900 cqa-text-sm\">\n        field\n      </span>\n\n      <!-- Wait: Duration input -->\n      <input *ngIf=\"eventType === 'wait' && param.name === 'duration'\" type=\"number\" [value]=\"param.value\"\n        (input)=\"onParameterChange(param, $any($event.target).value)\" placeholder=\"2\"\n        class=\"cqa-w-16 cqa-px-2 cqa-py-1.5 cqa-rounded-lg cqa-border cqa-border-solid cqa-border-[#9E9EE3] cqa-bg-[#D1C4E9] cqa-text-[#3F43EE] cqa-text-sm cqa-font-medium cqa-outline-none focus:cqa-ring-2 focus:cqa-ring-[#3F43EE] focus:cqa-ring-opacity-50\" />\n      <span *ngIf=\"eventType === 'wait' && param.name === 'duration'\" class=\"cqa-text-gray-900 cqa-text-sm\">\n        seconds\n      </span>\n\n      <!-- Wait: Element selector -->\n      <span *ngIf=\"eventType === 'wait' && param.name === 'element'\" class=\"cqa-text-gray-900 cqa-text-sm\">\n        for element\n      </span>\n      <span *ngIf=\"eventType === 'wait' && param.name === 'element'\" \n       #elementTrigger\n       (click)=\"openElementPopup($event)\"\n        class=\"cqa-py-0.5 cqa-px-2 cqa-text-[#3F43EE] cqa-text-[14px] cqa-leading-[17px] cqa-font-semibold cqa-border cqa-border-solid cqa-border-[#8A8CF4] cqa-rounded cqa-cursor-pointer cqa-bg-[#D8D9FC]\">\n        {{ param.displayValue || param.value }}\n      </span>\n      <span *ngIf=\"eventType === 'wait' && param.name === 'element'\" class=\"cqa-text-gray-900 cqa-text-sm\">\n        to be visible\n      </span>\n\n      <!-- Custom: Description (clickable to open Step Description modal; pass $event so modal opens below this trigger) -->\n      <span *ngIf=\"eventType === 'custom'\" #descriptionTrigger\n        (click)=\"openStepDescriptionModal($event)\"\n        class=\"cqa-py-0.5 cqa-px-2 cqa-text-[#3F43EE] cqa-text-[14px] cqa-leading-[17px] cqa-font-semibold cqa-border cqa-border-solid cqa-border-[#8A8CF4] cqa-rounded cqa-bg-[#D8D9FC] cqa-cursor-pointer hover:cqa-opacity-90\"\n        [innerHTML]=\"param.displayValue || param.value\">\n      </span>\n\n      <!-- AI Agent: Instructions -->\n      <span *ngIf=\"eventType === 'ai-agent'\"\n        class=\"cqa-py-0.5 cqa-px-2 cqa-text-[#3F43EE] cqa-text-[14px] cqa-leading-[17px] cqa-font-semibold cqa-border cqa-border-solid cqa-border-[#8A8CF4] cqa-rounded cqa-bg-[#D8D9FC]\">\n        {{ param.displayValue || param.value }}\n      </span>\n      </ng-container>\n    </ng-container>\n  </div>\n\n  <div class=\"cqa-flex cqa-items-center cqa-gap-3 cqa-ml-auto\">\n    <div class=\"cqa-flex cqa-items-center cqa-gap-3\">\n      <!-- View Details Link (show only if description is not empty) -->\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-2 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\n      <!-- Action Icons: Edit, Link, Duplicate, Delete (show on hover; hidden when step is inside step-group) -->\n      <div *ngIf=\"editable && !isInsideStepGroup && !isReorder\" class=\"step-actions cqa-flex cqa-items-center cqa-gap-3 cqa-px-[7px]\">\n      <button type=\"button\" #editTrigger (click)=\"onEdit(); $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\">\n          <path d=\"M7 11.6666H12.25\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n          <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\"/>\n        </svg>\n      </button>\n      <!-- <button type=\"button\" (click)=\"onLink(); $event.stopPropagation()\" title=\"Link\" 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\">\n          <path d=\"M5.00065 9.91671H3.66732C2.78326 9.91671 1.93542 9.60942 1.3103 9.06244C0.685174 8.51545 0.333984 7.77359 0.333984 7.00004C0.333984 6.22649 0.685174 5.48463 1.3103 4.93765C1.93542 4.39066 2.78326 4.08337 3.66732 4.08337H5.00065\" stroke=\"currentColor\" stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n          <path d=\"M9 4.08337H10.3333C11.2174 4.08337 12.0652 4.39066 12.6904 4.93765C13.3155 5.48463 13.6667 6.22649 13.6667 7.00004C13.6667 7.77359 13.3155 8.51545 12.6904 9.06244C12.0652 9.60942 11.2174 9.91671 10.3333 9.91671H9\" stroke=\"currentColor\" stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n          <path d=\"M4.33398 7H9.66732\" stroke=\"currentColor\" stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n        </svg>\n      </button> -->\n      <button\n        type=\"button\"\n        (click)=\"onDuplicate(); $event.stopPropagation()\"\n        [disabled]=\"isDuplicating\"\n        [attr.title]=\"isDuplicating ? 'Duplicating...' : 'Duplicate'\"\n        class=\"cqa-p-0 cqa-text-[#99A1Af] hover:cqa-text-[#1447E6] disabled:cqa-opacity-60 disabled:cqa-cursor-not-allowed\"\n      >\n        <svg *ngIf=\"!isDuplicating\" width=\"14\" height=\"14\" viewBox=\"0 0 14 14\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n          <path d=\"M11.666 4.66663H5.83268C5.18835 4.66663 4.66602 5.18896 4.66602 5.83329V11.6666C4.66602 12.311 5.18835 12.8333 5.83268 12.8333H11.666C12.3103 12.8333 12.8327 12.311 12.8327 11.6666V5.83329C12.8327 5.18896 12.3103 4.66663 11.666 4.66663Z\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n          <path d=\"M2.33268 9.33329C1.69102 9.33329 1.16602 8.80829 1.16602 8.16663V2.33329C1.16602 1.69163 1.69102 1.16663 2.33268 1.16663H8.16602C8.80768 1.16663 9.33268 1.69163 9.33268 2.33329\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n        </svg>\n        <svg *ngIf=\"isDuplicating\" width=\"14\" height=\"14\" viewBox=\"0 0 16 16\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\" aria-label=\"Duplicating\">\n          <circle cx=\"8\" cy=\"8\" r=\"6\" stroke=\"currentColor\" stroke-opacity=\"0.2\" stroke-width=\"2\"></circle>\n          <path d=\"M14 8A6 6 0 0 0 8 2\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\">\n            <animateTransform attributeName=\"transform\" type=\"rotate\" from=\"0 8 8\" to=\"360 8 8\" dur=\"0.8s\" repeatCount=\"indefinite\"/>\n          </path>\n        </svg>\n      </button>\n      <button type=\"button\" (click)=\"onDelete(); $event.stopPropagation()\" title=\"Delete\" 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\">\n          <path d=\"M1.75 3.5H12.25\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n          <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\"/>\n          <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\"/>\n          <path d=\"M5.83398 6.41663V9.91663\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n          <path d=\"M8.16602 6.41663V9.91663\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\n        </svg>\n      </button>\n    </div>\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  </div>\n</div>"]}
|
|
@@ -82,6 +82,8 @@ export class TestCaseScrollStepComponent {
|
|
|
82
82
|
clickOnAction(event) {
|
|
83
83
|
event.preventDefault();
|
|
84
84
|
event.stopPropagation();
|
|
85
|
+
if (this.isInsideStepGroup)
|
|
86
|
+
return;
|
|
85
87
|
this.clickAction.emit(event);
|
|
86
88
|
}
|
|
87
89
|
getDisplayText() {
|
|
@@ -192,4 +194,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImpor
|
|
|
192
194
|
}], clickAction: [{
|
|
193
195
|
type: Output
|
|
194
196
|
}] } });
|
|
195
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"scroll-step.component.js","sourceRoot":"","sources":["../../../../../../src/lib/test-case-details/scroll-step/scroll-step.component.ts","../../../../../../src/lib/test-case-details/scroll-step/scroll-step.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, Output, EventEmitter, OnInit, ViewChild, ElementRef } from '@angular/core';\nimport { DomSanitizer } from '@angular/platform-browser';\nimport { ScrollStepConfig, TestCaseStepConfig } from '../test-case-step.models';\nimport { STEP_ROW_ACTIONS_STYLES } from '../step-row-actions.styles';\nimport { ViewDetailsPayload } from '../step-details-modal/step-details-modal-data';\n\n@Component({\n  selector: 'cqa-test-case-scroll-step',\n  templateUrl: './scroll-step.component.html',\n  host: { class: 'cqa-ui-root' },\n  styles: [STEP_ROW_ACTIONS_STYLES],\n})\nexport class TestCaseScrollStepComponent implements OnInit {\n  @Input() config!: ScrollStepConfig;\n  @Input() stepNumber!: number | string;\n  @Input() index?: number;\n  @Input() selector: string = '';\n  @Input() direction?: 'top' | 'bottom' | 'up' | 'down' | 'left' | 'right';\n  @Input() description?: string;\n  @Input() selected: boolean = false;\n  @Input() disabled: boolean = false;\n  @Input() isNested: boolean = false;\n  @Input() isInsideStepGroup: boolean = false;\n  @Input() isInsideLoop: boolean = false;\n  @Input() expanded: boolean = false;\n  @Input() isReorder: boolean = false;\n  @Input() editable: boolean = true;\n  /** Saved action HTML from API — when set, row shows same text as edit modal and badges are clickable */\n  @Input() action: string = '';\n\n  @ViewChild('viewDetailsTrigger', { static: false }) viewDetailsTrigger?: ElementRef<HTMLElement>;\n\n  @Output() edit = new EventEmitter<void>();\n  @Output() editInDepth = new EventEmitter<{ step: TestCaseStepConfig; index: number }>();\n  @Output() link = new EventEmitter<void>();\n  @Output() duplicate = new EventEmitter<void>();\n  @Output() delete = new EventEmitter<void>();\n  @Output() viewDetails = new EventEmitter<ViewDetailsPayload>();\n  @Output() selectionChange = new EventEmitter<boolean>();\n  @Output() toggleExpanded = new EventEmitter<{config: ScrollStepConfig, expanded: boolean}>();\n  @Output() selectorChange = new EventEmitter<string>();\n  @Output() directionChange = new EventEmitter<'top' | 'bottom' | 'up' | 'down' | 'left' | 'right'>();\n  /** Same as normal-step: click on element/test_data badge opens popup */\n  @Output() clickAction = new EventEmitter<MouseEvent>();\n\n  constructor(private readonly sanitizer: DomSanitizer) {}\n\n  ngOnInit(): void {\n    if (this.config) {\n      this.stepNumber = this.config.stepNumber;\n      this.selector = this.config.selector;\n      this.direction = this.config.direction;\n      if ((this.config as any).action && !this.action) {\n        this.action = String((this.config as any).action);\n      }\n      this.description = this.config.description;\n      this.selected = this.config.selected || false;\n      this.disabled = this.config.disabled || false;\n      this.expanded = this.config.expanded || false;\n    }\n  }\n\n  /**\n   * Maps stored direction values to the same natural language used in template htmlGrammar\n   * (e.g. \"Scroll one screen up\") so the step row matches the edit modal.\n   */\n  /** Public for template: expanded panel shows same label as main row. */\n  getDirectionLabel(): string {\n    if (!this.direction) return '';\n    return this.directionToNaturalPhrase(this.direction);\n  }\n\n  private directionToNaturalPhrase(direction: string): string {\n    // Align with template htmlGrammar in edit modal (e.g. \"Scroll one screen up/bottom\").\n    // Same step must show identical wording in the list row and Selected Template.\n    const map: Record<string, string> = {\n      up: 'one screen up',\n      down: 'one screen down',\n      top: 'one screen top',\n      bottom: 'one screen bottom',\n      // Horizontal directions: keep unless templates use \"one screen left/right\"\n      left: 'to the left',\n      right: 'to the right',\n    };\n    const phrase = map[direction.toLowerCase()];\n    return phrase ?? direction;\n  }\n\n  /** When action HTML exists, render it (mirrors normal-step / edit modal). */\n  hasActionHtml(): boolean {\n    return !!(this.action && String(this.action).trim());\n  }\n\n  getActionHtml(): string {\n    if (!this.action) return '';\n    return this.sanitizer.bypassSecurityTrustHtml(this.action) as unknown as string;\n  }\n\n  clickOnAction(event: MouseEvent): void {\n    event.preventDefault();\n    event.stopPropagation();\n    this.clickAction.emit(event);\n  }\n\n  getDisplayText(): string {\n    if (!this.direction) {\n      return this.selector ? `Scroll ${this.selector}` : 'Scroll';\n    }\n    const phrase = this.directionToNaturalPhrase(this.direction);\n    // Match template wording: \"Scroll one screen up\" etc.; append selector when present.\n    if (this.selector && String(this.selector).trim() !== '') {\n      return `Scroll ${phrase} — ${this.selector}`;\n    }\n    return `Scroll ${phrase}`;\n  }\n\n  onToggleExpanded(): void {\n    this.expanded = !this.expanded;\n    this.toggleExpanded.emit({config: this.config, expanded: this.expanded});\n  }\n\n  onEdit(): void {\n    const idx = typeof this.index === 'number' ? this.index : (typeof this.stepNumber === 'number' ? this.stepNumber - 1 : (typeof this.stepNumber === 'string' ? parseInt(this.stepNumber, 10) - 1 : 0));\n    this.editInDepth.emit({ step: this.config as TestCaseStepConfig, index: isNaN(idx as number) ? 0 : (idx as number) });\n    this.edit.emit();\n  }\n  onLink(): void { this.link.emit(); }\n  onDuplicate(): void { this.duplicate.emit(); }\n  onDelete(): void { this.delete.emit(); }\n  onViewDetails(event?: MouseEvent): void {\n    if (event) {\n      event.preventDefault();\n      event.stopPropagation();\n    }\n    \n    if (!this.description || this.description.trim() === '') {\n      return;\n    }\n\n    if (event) {\n      this.onToggleExpanded();\n      this.viewDetails.emit({\n        event,\n        title: 'Scroll Step Details',\n        description: this.description,\n      });\n    }\n  }\n  onSelectionChange(checked: boolean): void { this.selected = checked; this.selectionChange.emit(checked); }\n  onSelectorChange(value: string): void { this.selector = value; this.selectorChange.emit(value); }\n  onDirectionChange(value: 'top' | 'bottom' | 'up' | 'down' | 'left' | 'right'): void {\n    this.direction = value;\n    this.directionChange.emit(value);\n  }\n}\n","<div class=\"cqa-flex cqa-flex-col\" style=\"border-bottom: 1px solid #E5E7EB;\">\n  <div\n    [class]=\"'step-row cqa-flex cqa-items-center cqa-gap-3 cqa-py-2 ' + (isInsideLoop && isInsideStepGroup ? 'cqa-pl-20 cqa-pr-4' : (isInsideLoop || isInsideStepGroup) ? 'cqa-pl-10 cqa-pr-4' : 'cqa-px-4')\">\n    <div class=\"cqa-inline-flex cqa-items-center\">\n      <!-- Drag Handle Icon (when isReorder is true and not inside step group - steps inside step groups cannot be reordered) -->\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\" [ngModel]=\"selected\" [disabled]=\"disabled\" (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\" [class.cqa-border-[#3F43EE]]=\"selected\" id=\"check\" />\n        <span\n          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\" [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\">\n            <path d=\"M10 3.125L4.5 8.625L2 6.125\" stroke=\"white\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n          </svg>\n        </span>\n      </label>\n    </div>\n    <span class=\"cqa-text-[#6B7280] cqa-text-[14px] cqa-leading-[18px] cqa-min-w-[32px]\">{{ stepNumber }}</span>\n    <span title=\"Scroll\"\n      class=\"cqa-w-8 cqa-h-8 cqa-rounded-lg cqa-flex cqa-items-center cqa-justify-center cqa-flex-shrink-0 cqa-bg-[#E0F2FE] cqa-text-[#0EA5E9]\">\n      <svg width=\"14\" height=\"14\" viewBox=\"0 0 14 14\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n        <path d=\"M5.24935 1.75L2.91602 4.0775H4.66602V8.16667H5.83268V4.0775H7.58268L5.24935 1.75ZM9.33268 9.9225V5.83333H8.16602V9.9225H6.41602L8.74935 12.25L11.0827 9.9225H9.33268Z\" fill=\"currentColor\"/>\n      </svg>\n    </span>\n    <div class=\"cqa-flex-grow cqa-flex cqa-flex-col cqa-gap-1\">\n      <div class=\"cqa-flex cqa-items-center cqa-gap-2 cqa-min-w-0\">\n        <!-- Same action HTML as edit modal so wording matches; badges delegate to step-list clickAction (element/test-data modals) -->\n        <span *ngIf=\"hasActionHtml()\"\n          class=\"cqa-text-[#111827] cqa-text-[14px] cqa-leading-[18px] cqa-action-format cqa-align-middle cqa-min-w-0 cqa-flex-1\"\n          [innerHTML]=\"getActionHtml()\"\n          (click)=\"clickOnAction($event)\">\n        </span>\n        <span *ngIf=\"!hasActionHtml()\"\n          class=\"cqa-text-[#111827] cqa-text-[14px] cqa-leading-[18px]\">\n          {{ getDisplayText() }}\n        </span>\n      </div>\n      <!-- Expanded details: light blue panel with Selector, Direction -->\n      <div *ngIf=\"expanded\"\n        [class]=\"'cqa-py-1 cqa-px-3 cqa-rounded-lg cqa-border cqa-border-solid cqa-bg-[#E3F2FD] cqa-border-[#90CAF9]' + (isInsideLoop && isInsideStepGroup ? ' cqa-ml-20' : (isInsideLoop || isInsideStepGroup) ? ' cqa-ml-10' : '')\">\n        <div class=\"cqa-flex cqa-flex-wrap cqa-items-center cqa-gap-2 cqa-text-[12px] cqa-leading-[16px]\">\n          <span class=\"cqa-text-[#0D47A1] cqa-font-semibold\">Selector:</span>\n          <span class=\"cqa-py-1 cqa-px-2 cqa-rounded-[4px] cqa-border cqa-border-solid cqa-bg-[#fff] cqa-border-[#90CAF9] cqa-text-[#111827] cqa-text-[10px] cqa-leading-[15px] cqa-font-medium\">{{selector}}</span>\n          <span *ngIf=\"direction\" class=\"cqa-text-[#6B7280]\">Direction: {{ getDirectionLabel() }}</span>\n        </div>\n      </div>\n    </div>\n    <div class=\"cqa-flex cqa-items-center cqa-gap-3\">\n      <!-- View Details Link (show only if description is not empty) -->\n      <a *ngIf=\"description && description.trim() !== ''\" #viewDetailsTrigger href=\"#\" (click)=\"onViewDetails($event)\"\n        class=\"cqa-text-[#3F43EE] cqa-text-[10px] cqa-leading-[15px] cqa-font-medium cqa-flex cqa-items-center cqa-gap-2 cqa-no-underline\">{{\n        expanded ? 'Hide Details' : 'View Details' }}<svg [class.cqa-rotate-90]=\"expanded\" width=\"8\" height=\"8\"\n          viewBox=\"0 0 8 8\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n          <path\n            d=\"M2.03809 6.74329L2.62809 7.33329L5.96142 3.99996L2.62809 0.666626L2.03809 1.25663L4.78142 3.99996L2.03809 6.74329Z\"\n            fill=\"#3F43EE\" />\n        </svg></a>\n      <div *ngIf=\"editable && !isInsideStepGroup && !isReorder\" class=\"step-actions cqa-flex cqa-items-center cqa-gap-3 cqa-px-[7px]\">\n      <button type=\"button\" (click)=\"onEdit(); $event.stopPropagation()\" title=\"Edit\"\n        class=\"cqa-p-0 cqa-text-[#99A1Af] hover:cqa-text-[#1447E6]\"><svg width=\"14\" height=\"14\" viewBox=\"0 0 14 14\"\n          fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n          <path d=\"M7 11.6666H12.25\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\"\n            stroke-linejoin=\"round\" />\n          <path\n            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\"\n            stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n        </svg></button>\n      <!-- <button type=\"button\" (click)=\"onLink(); $event.stopPropagation()\" title=\"Link\"\n        class=\"cqa-p-0 cqa-text-[#99A1Af] hover:cqa-text-[#1447E6]\"><svg width=\"14\" height=\"14\" viewBox=\"0 0 14 14\"\n          fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n          <path\n            d=\"M5.00065 9.91671H3.66732C2.78326 9.91671 1.93542 9.60942 1.3103 9.06244C0.685174 8.51545 0.333984 7.77359 0.333984 7.00004C0.333984 6.22649 0.685174 5.48463 1.3103 4.93765C1.93542 4.39066 2.78326 4.08337 3.66732 4.08337H5.00065\"\n            stroke=\"currentColor\" stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n          <path\n            d=\"M9 4.08337H10.3333C11.2174 4.08337 12.0652 4.39066 12.6904 4.93765C13.3155 5.48463 13.6667 6.22649 13.6667 7.00004C13.6667 7.77359 13.3155 8.51545 12.6904 9.06244C12.0652 9.60942 11.2174 9.91671 10.3333 9.91671H9\"\n            stroke=\"currentColor\" stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n          <path d=\"M4.33398 7H9.66732\" stroke=\"currentColor\" stroke-width=\"1.33333\" stroke-linecap=\"round\"\n            stroke-linejoin=\"round\" />\n        </svg></button> -->\n      <button type=\"button\" (click)=\"onDuplicate(); $event.stopPropagation()\" title=\"Duplicate\"\n        class=\"cqa-p-0 cqa-text-[#99A1Af] hover:cqa-text-[#1447E6]\"><svg width=\"14\" height=\"14\" viewBox=\"0 0 14 14\"\n          fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n          <path\n            d=\"M11.666 4.66663H5.83268C5.18835 4.66663 4.66602 5.18896 4.66602 5.83329V11.6666C4.66602 12.311 5.18835 12.8333 5.83268 12.8333H11.666C12.3103 12.8333 12.8327 12.311 12.8327 11.6666V5.83329C12.8327 5.18896 12.3103 4.66663 11.666 4.66663Z\"\n            stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n          <path\n            d=\"M2.33268 9.33329C1.69102 9.33329 1.16602 8.80829 1.16602 8.16663V2.33329C1.16602 1.69163 1.69102 1.16663 2.33268 1.16663H8.16602C8.80768 1.16663 9.33268 1.69163 9.33268 2.33329\"\n            stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n        </svg></button>\n      <button type=\"button\" (click)=\"onDelete(); $event.stopPropagation()\" title=\"Delete\"\n        class=\"cqa-p-0 cqa-text-[#ff6467] hover:cqa-text-[#C63535]\"><svg width=\"14\" height=\"14\" viewBox=\"0 0 14 14\"\n          fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n          <path d=\"M1.75 3.5H12.25\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\"\n            stroke-linejoin=\"round\" />\n          <path\n            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\"\n            stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n          <path\n            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\"\n            stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n          <path d=\"M5.83398 6.41663V9.91663\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\"\n            stroke-linejoin=\"round\" />\n          <path d=\"M8.16602 6.41663V9.91663\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\"\n            stroke-linejoin=\"round\" />\n        </svg></button>\n      </div>\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  </div>\n</div>\n"]}
|
|
197
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"scroll-step.component.js","sourceRoot":"","sources":["../../../../../../src/lib/test-case-details/scroll-step/scroll-step.component.ts","../../../../../../src/lib/test-case-details/scroll-step/scroll-step.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, Output, EventEmitter, OnInit, ViewChild, ElementRef } from '@angular/core';\nimport { DomSanitizer } from '@angular/platform-browser';\nimport { ScrollStepConfig, TestCaseStepConfig } from '../test-case-step.models';\nimport { STEP_ROW_ACTIONS_STYLES } from '../step-row-actions.styles';\nimport { ViewDetailsPayload } from '../step-details-modal/step-details-modal-data';\n\n@Component({\n  selector: 'cqa-test-case-scroll-step',\n  templateUrl: './scroll-step.component.html',\n  host: { class: 'cqa-ui-root' },\n  styles: [STEP_ROW_ACTIONS_STYLES],\n})\nexport class TestCaseScrollStepComponent implements OnInit {\n  @Input() config!: ScrollStepConfig;\n  @Input() stepNumber!: number | string;\n  @Input() index?: number;\n  @Input() selector: string = '';\n  @Input() direction?: 'top' | 'bottom' | 'up' | 'down' | 'left' | 'right';\n  @Input() description?: string;\n  @Input() selected: boolean = false;\n  @Input() disabled: boolean = false;\n  @Input() isNested: boolean = false;\n  @Input() isInsideStepGroup: boolean = false;\n  @Input() isInsideLoop: boolean = false;\n  @Input() expanded: boolean = false;\n  @Input() isReorder: boolean = false;\n  @Input() editable: boolean = true;\n  /** Saved action HTML from API — when set, row shows same text as edit modal and badges are clickable */\n  @Input() action: string = '';\n\n  @ViewChild('viewDetailsTrigger', { static: false }) viewDetailsTrigger?: ElementRef<HTMLElement>;\n\n  @Output() edit = new EventEmitter<void>();\n  @Output() editInDepth = new EventEmitter<{ step: TestCaseStepConfig; index: number }>();\n  @Output() link = new EventEmitter<void>();\n  @Output() duplicate = new EventEmitter<void>();\n  @Output() delete = new EventEmitter<void>();\n  @Output() viewDetails = new EventEmitter<ViewDetailsPayload>();\n  @Output() selectionChange = new EventEmitter<boolean>();\n  @Output() toggleExpanded = new EventEmitter<{config: ScrollStepConfig, expanded: boolean}>();\n  @Output() selectorChange = new EventEmitter<string>();\n  @Output() directionChange = new EventEmitter<'top' | 'bottom' | 'up' | 'down' | 'left' | 'right'>();\n  /** Same as normal-step: click on element/test_data badge opens popup */\n  @Output() clickAction = new EventEmitter<MouseEvent>();\n\n  constructor(private readonly sanitizer: DomSanitizer) {}\n\n  ngOnInit(): void {\n    if (this.config) {\n      this.stepNumber = this.config.stepNumber;\n      this.selector = this.config.selector;\n      this.direction = this.config.direction;\n      if ((this.config as any).action && !this.action) {\n        this.action = String((this.config as any).action);\n      }\n      this.description = this.config.description;\n      this.selected = this.config.selected || false;\n      this.disabled = this.config.disabled || false;\n      this.expanded = this.config.expanded || false;\n    }\n  }\n\n  /**\n   * Maps stored direction values to the same natural language used in template htmlGrammar\n   * (e.g. \"Scroll one screen up\") so the step row matches the edit modal.\n   */\n  /** Public for template: expanded panel shows same label as main row. */\n  getDirectionLabel(): string {\n    if (!this.direction) return '';\n    return this.directionToNaturalPhrase(this.direction);\n  }\n\n  private directionToNaturalPhrase(direction: string): string {\n    // Align with template htmlGrammar in edit modal (e.g. \"Scroll one screen up/bottom\").\n    // Same step must show identical wording in the list row and Selected Template.\n    const map: Record<string, string> = {\n      up: 'one screen up',\n      down: 'one screen down',\n      top: 'one screen top',\n      bottom: 'one screen bottom',\n      // Horizontal directions: keep unless templates use \"one screen left/right\"\n      left: 'to the left',\n      right: 'to the right',\n    };\n    const phrase = map[direction.toLowerCase()];\n    return phrase ?? direction;\n  }\n\n  /** When action HTML exists, render it (mirrors normal-step / edit modal). */\n  hasActionHtml(): boolean {\n    return !!(this.action && String(this.action).trim());\n  }\n\n  getActionHtml(): string {\n    if (!this.action) return '';\n    return this.sanitizer.bypassSecurityTrustHtml(this.action) as unknown as string;\n  }\n\n  clickOnAction(event: MouseEvent): void {\n    event.preventDefault();\n    event.stopPropagation();\n    if (this.isInsideStepGroup) return;\n    this.clickAction.emit(event);\n  }\n\n  getDisplayText(): string {\n    if (!this.direction) {\n      return this.selector ? `Scroll ${this.selector}` : 'Scroll';\n    }\n    const phrase = this.directionToNaturalPhrase(this.direction);\n    // Match template wording: \"Scroll one screen up\" etc.; append selector when present.\n    if (this.selector && String(this.selector).trim() !== '') {\n      return `Scroll ${phrase} — ${this.selector}`;\n    }\n    return `Scroll ${phrase}`;\n  }\n\n  onToggleExpanded(): void {\n    this.expanded = !this.expanded;\n    this.toggleExpanded.emit({config: this.config, expanded: this.expanded});\n  }\n\n  onEdit(): void {\n    const idx = typeof this.index === 'number' ? this.index : (typeof this.stepNumber === 'number' ? this.stepNumber - 1 : (typeof this.stepNumber === 'string' ? parseInt(this.stepNumber, 10) - 1 : 0));\n    this.editInDepth.emit({ step: this.config as TestCaseStepConfig, index: isNaN(idx as number) ? 0 : (idx as number) });\n    this.edit.emit();\n  }\n  onLink(): void { this.link.emit(); }\n  onDuplicate(): void { this.duplicate.emit(); }\n  onDelete(): void { this.delete.emit(); }\n  onViewDetails(event?: MouseEvent): void {\n    if (event) {\n      event.preventDefault();\n      event.stopPropagation();\n    }\n    \n    if (!this.description || this.description.trim() === '') {\n      return;\n    }\n\n    if (event) {\n      this.onToggleExpanded();\n      this.viewDetails.emit({\n        event,\n        title: 'Scroll Step Details',\n        description: this.description,\n      });\n    }\n  }\n  onSelectionChange(checked: boolean): void { this.selected = checked; this.selectionChange.emit(checked); }\n  onSelectorChange(value: string): void { this.selector = value; this.selectorChange.emit(value); }\n  onDirectionChange(value: 'top' | 'bottom' | 'up' | 'down' | 'left' | 'right'): void {\n    this.direction = value;\n    this.directionChange.emit(value);\n  }\n}\n","<div class=\"cqa-flex cqa-flex-col\" style=\"border-bottom: 1px solid #E5E7EB;\">\n  <div\n    [class]=\"'step-row cqa-flex cqa-items-center cqa-gap-3 cqa-py-2 ' + (isInsideLoop && isInsideStepGroup ? 'cqa-pl-20 cqa-pr-4' : (isInsideLoop || isInsideStepGroup) ? 'cqa-pl-10 cqa-pr-4' : 'cqa-px-4')\">\n    <div class=\"cqa-inline-flex cqa-items-center\">\n      <!-- Drag Handle Icon (when isReorder is true and not inside step group - steps inside step groups cannot be reordered) -->\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\" [ngModel]=\"selected\" [disabled]=\"disabled\" (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\" [class.cqa-border-[#3F43EE]]=\"selected\" id=\"check\" />\n        <span\n          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\" [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\">\n            <path d=\"M10 3.125L4.5 8.625L2 6.125\" stroke=\"white\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n          </svg>\n        </span>\n      </label>\n    </div>\n    <span class=\"cqa-text-[#6B7280] cqa-text-[14px] cqa-leading-[18px] cqa-min-w-[32px]\">{{ stepNumber }}</span>\n    <span title=\"Scroll\"\n      class=\"cqa-w-8 cqa-h-8 cqa-rounded-lg cqa-flex cqa-items-center cqa-justify-center cqa-flex-shrink-0 cqa-bg-[#E0F2FE] cqa-text-[#0EA5E9]\">\n      <svg width=\"14\" height=\"14\" viewBox=\"0 0 14 14\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n        <path d=\"M5.24935 1.75L2.91602 4.0775H4.66602V8.16667H5.83268V4.0775H7.58268L5.24935 1.75ZM9.33268 9.9225V5.83333H8.16602V9.9225H6.41602L8.74935 12.25L11.0827 9.9225H9.33268Z\" fill=\"currentColor\"/>\n      </svg>\n    </span>\n    <div class=\"cqa-flex-grow cqa-flex cqa-flex-col cqa-gap-1\">\n      <div class=\"cqa-flex cqa-items-center cqa-gap-2 cqa-min-w-0\">\n        <!-- Same action HTML as edit modal so wording matches; badges delegate to step-list clickAction (element/test-data modals) -->\n        <span *ngIf=\"hasActionHtml()\"\n          class=\"cqa-text-[#111827] cqa-text-[14px] cqa-leading-[18px] cqa-action-format cqa-align-middle cqa-min-w-0 cqa-flex-1\"\n          [innerHTML]=\"getActionHtml()\"\n          (click)=\"clickOnAction($event)\">\n        </span>\n        <span *ngIf=\"!hasActionHtml()\"\n          class=\"cqa-text-[#111827] cqa-text-[14px] cqa-leading-[18px]\">\n          {{ getDisplayText() }}\n        </span>\n      </div>\n      <!-- Expanded details: light blue panel with Selector, Direction -->\n      <div *ngIf=\"expanded\"\n        [class]=\"'cqa-py-1 cqa-px-3 cqa-rounded-lg cqa-border cqa-border-solid cqa-bg-[#E3F2FD] cqa-border-[#90CAF9]' + (isInsideLoop && isInsideStepGroup ? ' cqa-ml-20' : (isInsideLoop || isInsideStepGroup) ? ' cqa-ml-10' : '')\">\n        <div class=\"cqa-flex cqa-flex-wrap cqa-items-center cqa-gap-2 cqa-text-[12px] cqa-leading-[16px]\">\n          <span class=\"cqa-text-[#0D47A1] cqa-font-semibold\">Selector:</span>\n          <span class=\"cqa-py-1 cqa-px-2 cqa-rounded-[4px] cqa-border cqa-border-solid cqa-bg-[#fff] cqa-border-[#90CAF9] cqa-text-[#111827] cqa-text-[10px] cqa-leading-[15px] cqa-font-medium\">{{selector}}</span>\n          <span *ngIf=\"direction\" class=\"cqa-text-[#6B7280]\">Direction: {{ getDirectionLabel() }}</span>\n        </div>\n      </div>\n    </div>\n    <div class=\"cqa-flex cqa-items-center cqa-gap-3\">\n      <!-- View Details Link (show only if description is not empty) -->\n      <a *ngIf=\"description && description.trim() !== ''\" #viewDetailsTrigger href=\"#\" (click)=\"onViewDetails($event)\"\n        class=\"cqa-text-[#3F43EE] cqa-text-[10px] cqa-leading-[15px] cqa-font-medium cqa-flex cqa-items-center cqa-gap-2 cqa-no-underline\">{{\n        expanded ? 'Hide Details' : 'View Details' }}<svg [class.cqa-rotate-90]=\"expanded\" width=\"8\" height=\"8\"\n          viewBox=\"0 0 8 8\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n          <path\n            d=\"M2.03809 6.74329L2.62809 7.33329L5.96142 3.99996L2.62809 0.666626L2.03809 1.25663L4.78142 3.99996L2.03809 6.74329Z\"\n            fill=\"#3F43EE\" />\n        </svg></a>\n      <div *ngIf=\"editable && !isInsideStepGroup && !isReorder\" class=\"step-actions cqa-flex cqa-items-center cqa-gap-3 cqa-px-[7px]\">\n      <button type=\"button\" (click)=\"onEdit(); $event.stopPropagation()\" title=\"Edit\"\n        class=\"cqa-p-0 cqa-text-[#99A1Af] hover:cqa-text-[#1447E6]\"><svg width=\"14\" height=\"14\" viewBox=\"0 0 14 14\"\n          fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n          <path d=\"M7 11.6666H12.25\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\"\n            stroke-linejoin=\"round\" />\n          <path\n            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\"\n            stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n        </svg></button>\n      <!-- <button type=\"button\" (click)=\"onLink(); $event.stopPropagation()\" title=\"Link\"\n        class=\"cqa-p-0 cqa-text-[#99A1Af] hover:cqa-text-[#1447E6]\"><svg width=\"14\" height=\"14\" viewBox=\"0 0 14 14\"\n          fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n          <path\n            d=\"M5.00065 9.91671H3.66732C2.78326 9.91671 1.93542 9.60942 1.3103 9.06244C0.685174 8.51545 0.333984 7.77359 0.333984 7.00004C0.333984 6.22649 0.685174 5.48463 1.3103 4.93765C1.93542 4.39066 2.78326 4.08337 3.66732 4.08337H5.00065\"\n            stroke=\"currentColor\" stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n          <path\n            d=\"M9 4.08337H10.3333C11.2174 4.08337 12.0652 4.39066 12.6904 4.93765C13.3155 5.48463 13.6667 6.22649 13.6667 7.00004C13.6667 7.77359 13.3155 8.51545 12.6904 9.06244C12.0652 9.60942 11.2174 9.91671 10.3333 9.91671H9\"\n            stroke=\"currentColor\" stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n          <path d=\"M4.33398 7H9.66732\" stroke=\"currentColor\" stroke-width=\"1.33333\" stroke-linecap=\"round\"\n            stroke-linejoin=\"round\" />\n        </svg></button> -->\n      <button type=\"button\" (click)=\"onDuplicate(); $event.stopPropagation()\" title=\"Duplicate\"\n        class=\"cqa-p-0 cqa-text-[#99A1Af] hover:cqa-text-[#1447E6]\"><svg width=\"14\" height=\"14\" viewBox=\"0 0 14 14\"\n          fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n          <path\n            d=\"M11.666 4.66663H5.83268C5.18835 4.66663 4.66602 5.18896 4.66602 5.83329V11.6666C4.66602 12.311 5.18835 12.8333 5.83268 12.8333H11.666C12.3103 12.8333 12.8327 12.311 12.8327 11.6666V5.83329C12.8327 5.18896 12.3103 4.66663 11.666 4.66663Z\"\n            stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n          <path\n            d=\"M2.33268 9.33329C1.69102 9.33329 1.16602 8.80829 1.16602 8.16663V2.33329C1.16602 1.69163 1.69102 1.16663 2.33268 1.16663H8.16602C8.80768 1.16663 9.33268 1.69163 9.33268 2.33329\"\n            stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n        </svg></button>\n      <button type=\"button\" (click)=\"onDelete(); $event.stopPropagation()\" title=\"Delete\"\n        class=\"cqa-p-0 cqa-text-[#ff6467] hover:cqa-text-[#C63535]\"><svg width=\"14\" height=\"14\" viewBox=\"0 0 14 14\"\n          fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n          <path d=\"M1.75 3.5H12.25\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\"\n            stroke-linejoin=\"round\" />\n          <path\n            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\"\n            stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n          <path\n            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\"\n            stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n          <path d=\"M5.83398 6.41663V9.91663\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\"\n            stroke-linejoin=\"round\" />\n          <path d=\"M8.16602 6.41663V9.91663\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\"\n            stroke-linejoin=\"round\" />\n        </svg></button>\n      </div>\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  </div>\n</div>\n"]}
|