@cqa-lib/cqa-ui 1.1.266 → 1.1.267
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/step-builder/step-builder-group/step-builder-group.component.mjs +3 -3
- package/esm2020/lib/step-builder/template-variables-form/template-variables-form.component.mjs +9 -5
- package/esm2020/lib/test-case-details/condition-step/condition-step.component.mjs +13 -3
- package/esm2020/lib/test-case-details/loop-step/loop-step.component.mjs +3 -3
- package/esm2020/lib/test-case-details/test-case-details-renderer/test-case-details-renderer.component.mjs +2 -1
- package/esm2020/lib/test-case-details/test-case-details.component.mjs +3 -3
- package/fesm2015/cqa-lib-cqa-ui.mjs +27 -12
- package/fesm2015/cqa-lib-cqa-ui.mjs.map +1 -1
- package/fesm2020/cqa-lib-cqa-ui.mjs +27 -12
- package/fesm2020/cqa-lib-cqa-ui.mjs.map +1 -1
- package/lib/test-case-details/condition-step/condition-step.component.d.ts +9 -1
- package/package.json +1 -1
- package/styles.css +1 -1
|
@@ -291,6 +291,7 @@ export class TestCaseDetailsRendererComponent {
|
|
|
291
291
|
wire('addBranch', this.addBranch);
|
|
292
292
|
wire('addElse', this.addElse);
|
|
293
293
|
wire('deleteBranch', this.deleteBranch);
|
|
294
|
+
wire('addStepForLoop', this.addStepForLoop);
|
|
294
295
|
wire('testDataProfileChange', this.testDataProfileChange);
|
|
295
296
|
wire('startStepChange', this.startStepChange);
|
|
296
297
|
wire('endStepChange', this.endStepChange);
|
|
@@ -478,4 +479,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImpor
|
|
|
478
479
|
}], editInDepth: [{
|
|
479
480
|
type: Output
|
|
480
481
|
}] } });
|
|
481
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"test-case-details-renderer.component.js","sourceRoot":"","sources":["../../../../../../src/lib/test-case-details/test-case-details-renderer/test-case-details-renderer.component.ts","../../../../../../src/lib/test-case-details/test-case-details-renderer/test-case-details-renderer.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  Input,\n  Output,\n  EventEmitter,\n  ViewChild,\n  ViewContainerRef,\n  OnChanges,\n  SimpleChanges,\n  Inject,\n  AfterViewInit,\n  OnDestroy,\n  ChangeDetectorRef,\n  ComponentRef,\n} from '@angular/core';\nimport { TEST_CASE_STEP_COMPONENT_MAP, TestCaseStepComponentMap } from '../test-case-step-components.token';\nimport {\n  TestCaseStepConfig,\n  isStepGroupConfig,\n  isConditionStepConfig,\n  isLoopStepConfig,\n  isNormalStepConfig,\n  isApiStepConfig,\n  isDatabaseStepConfig,\n  isAiAgentStepConfig,\n  isAiVerifyStepConfig,\n  isUploadStepConfig,\n  isScreenshotStepConfig,\n  isScrollStepConfig,\n  isVerifyUrlStepConfig,\n  isRestoreSessionStepConfig,\n  isCustomCodeStepConfig,\n  ConditionBranch,\n  LoopStepConfig,\n} from '../test-case-step.models';\n\n@Component({\n  selector: 'cqa-test-case-details-renderer',\n  templateUrl: './test-case-details-renderer.component.html',\n  host: { class: 'cqa-ui-root' },\n})\nexport class TestCaseDetailsRendererComponent implements OnChanges, AfterViewInit, OnDestroy {\n  @ViewChild('stepHost', { read: ViewContainerRef }) stepHost!: ViewContainerRef;\n\n  @Input() step!: TestCaseStepConfig;\n  @Input() index!: number;\n  @Input() isNested: boolean = false;\n  @Input() isInsideLoop: boolean = false;\n  /** When true, step is rendered inside a step-group; row actions (Edit/Duplicate/Delete) are hidden. */\n  @Input() isInsideStepGroup: boolean = false;\n  /** When rendering a step inside a condition branch, the branch context (for addStepForBranch / deleteStepWithBranch). */\n  @Input() branch?: ConditionBranch;\n  /** When true, enables drag-and-drop reordering and shows drag handle icon instead of checkbox */\n  @Input() isReorder: boolean = false;\n  /** Current selection state; when changed (e.g. from Select all), the created step component is updated so the checkbox reflects it */\n  @Input() selected?: boolean;\n  /** Show \"Add Step Between\" button above the step */\n  @Input() addStepBetweenAbove: boolean = true;\n  /** Show \"Add Step Between\" button below the step */\n  @Input() addStepBetweenBelow: boolean = true;\n  /** @deprecated Use addStepBetweenAbove and addStepBetweenBelow instead. If set, applies to both buttons. */\n  @Input() addStepBetween: boolean = false;\n\n  @Output() nestedStepChange = new EventEmitter<{ step: TestCaseStepConfig; index: number }>();\n  @Output() addStep = new EventEmitter<void>();\n  @Output() deleteStep = new EventEmitter<number>();\n  @Output() toggleExpanded = new EventEmitter<boolean | {config: TestCaseStepConfig, expanded: boolean}>();\n  @Output() groupNameChange = new EventEmitter<string>();\n  @Output() descriptionChange = new EventEmitter<string>();\n  @Output() reusableChange = new EventEmitter<boolean>();\n  @Output() openExternal = new EventEmitter<{step: TestCaseStepConfig}>();\n  @Output() edit = new EventEmitter<{step: TestCaseStepConfig, index: number}>();\n  @Output() link = new EventEmitter<void>();\n  @Output() duplicate = new EventEmitter<void>();\n  @Output() delete = new EventEmitter<{ step: TestCaseStepConfig } | void>();\n  @Output() viewDetails = new EventEmitter<import('../step-details-modal/step-details-modal-data').ViewDetailsPayload>();\n  @Output() selectionChange = new EventEmitter<boolean>();\n  @Output() conditionChange = new EventEmitter<string>();\n  @Output() branchStepChange = new EventEmitter<{ branch: ConditionBranch; step: TestCaseStepConfig; stepIndex: number }>();\n  @Output() addStepForBranch = new EventEmitter<{ branch: ConditionBranch }>();\n  /** Emitted when empty loop step plus is clicked; same behaviour as add-step-between (parentId = loop step id). */\n  @Output() addStepForLoop = new EventEmitter<{ loopStepConfig: LoopStepConfig }>();\n  @Output() deleteStepWithBranch = new EventEmitter<{ branch: ConditionBranch; stepIndex: number }>();\n  @Output() addBranch = new EventEmitter<void>();\n  /** Emitted when user clicks \"Add Else\" in a condition step; parent should call POST test_steps with conditionType CONDITION_ELSE */\n  @Output() addElse = new EventEmitter<{ conditionStepConfig: TestCaseStepConfig }>();\n  @Output() deleteBranch = new EventEmitter<ConditionBranch>();\n  @Output() testDataProfileChange = new EventEmitter<string>();\n  @Output() startStepChange = new EventEmitter<number>();\n  @Output() endStepChange = new EventEmitter<number>();\n  @Output() maxIterationsChange = new EventEmitter<number>();\n  @Output() eventTypeChange = new EventEmitter<any>();\n  @Output() parameterChange = new EventEmitter<any>();\n  @Output() clickAction = new EventEmitter<{ event: MouseEvent; step: TestCaseStepConfig }>();\n  /** Emitted when a step is dropped in a nested dropzone (step-group, loop, condition). Payload: { event, targetList }. */\n  @Output() dndDropInZone = new EventEmitter<{ event: any; targetList: TestCaseStepConfig[] }>();\n  /** Data profile options for loop steps */\n  @Input() dataProfileOptions: any[] = [];\n  /** Indicates if more data profiles are available for loading */\n  @Input() hasMoreDataProfiles: boolean = false;\n  /** Loading state for data profiles */\n  @Input() isLoadingDataProfiles: boolean = false;\n  /** Natural text actions options for while loop condition */\n  @Input() naturalTextActionsOptions: any[] = [];\n  /** Function to process template variables for condition steps */\n  @Input() setConditionTemplateVariables: (template: any) => any[] = () => [];\n  /** Emit when more data profiles need to be loaded */\n  @Output() loadMoreDataProfiles = new EventEmitter<string>();\n  /** Emit when data profile search query changes */\n  @Output() searchDataProfiles = new EventEmitter<string>();\n  /** Emit when a step is updated (e.g., Apply button clicked in loop-step edit mode) */\n  @Output() stepUpdate = new EventEmitter<TestCaseStepConfig>();\n  @Output() addStepBetweenClick = new EventEmitter<{step: TestCaseStepConfig, index: number, position: 'ABOVE' | 'BELOW'}>();\n  /** Emit when user clicks \"Edit In depth\" in condition-step (or other steps that support it) */\n  @Output() editInDepth = new EventEmitter<{ step: TestCaseStepConfig; index: number }>();\n\n  private componentRef: ComponentRef<any> | null = null;\n\n  constructor(\n    @Inject(TEST_CASE_STEP_COMPONENT_MAP) private componentMap: TestCaseStepComponentMap,\n    private cdr: ChangeDetectorRef\n  ) {}\n\n  ngAfterViewInit(): void {\n    this.renderStep();\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    const structuralChange = changes['step'] || changes['index'] || changes['isNested'] || changes['isInsideLoop'] ||\n        changes['isInsideStepGroup'] || changes['isReorder'];\n    const optionsOnlyChange = (changes['dataProfileOptions'] || changes['hasMoreDataProfiles'] || changes['isLoadingDataProfiles'] ||\n        changes['naturalTextActionsOptions'] || changes['setConditionTemplateVariables']) && !structuralChange;\n\n    if (structuralChange) {\n      this.renderStep();\n    } else if (optionsOnlyChange && this.componentRef?.instance != null && this.step != null) {\n      // Update only profile/options inputs so we don't destroy the step (e.g. opening data profile dropdown\n      // loads options and would otherwise recreate the component and collapse inline edit)\n      this.updateOptionsInputs(this.componentRef.instance);\n      this.cdr.detectChanges();\n    } else if (changes['selected'] && this.componentRef?.instance != null) {\n      (this.componentRef.instance as any).selected = this.selected;\n      this.cdr.detectChanges();\n    }\n  }\n\n  /** Update only data profile / options inputs on existing instance (avoids full recreate and losing isEditing). */\n  private updateOptionsInputs(instance: any): void {\n    if (isLoopStepConfig(this.step!) || isConditionStepConfig(this.step!) || isStepGroupConfig(this.step!)) {\n      (instance as any).dataProfileOptions = this.dataProfileOptions;\n      (instance as any).hasMoreDataProfiles = this.hasMoreDataProfiles;\n      (instance as any).isLoadingDataProfiles = this.isLoadingDataProfiles;\n      (instance as any).naturalTextActionsOptions = this.naturalTextActionsOptions;\n      (instance as any).addStepBetweenAbove = this.addStepBetweenAbove;\n      (instance as any).addStepBetweenBelow = this.addStepBetweenBelow;\n      (instance as any).addStepBetween = this.addStepBetween;\n    }\n    if (isLoopStepConfig(this.step!)) {\n      (instance as any).naturalTextActionsOptions = this.naturalTextActionsOptions;\n      (instance as any).setConditionTemplateVariables = this.setConditionTemplateVariables;\n    }\n    if (isConditionStepConfig(this.step!)) {\n      (instance as any).naturalTextActionsOptions = this.naturalTextActionsOptions;\n      (instance as any).setConditionTemplateVariables = this.setConditionTemplateVariables;\n    }\n  }\n\n  private getComponentType(step: TestCaseStepConfig): any {\n    if (isStepGroupConfig(step)) return this.componentMap.stepGroup;\n    if (isConditionStepConfig(step)) return this.componentMap.conditionStep;\n    if (isLoopStepConfig(step)) return this.componentMap.loopStep;\n    if (isApiStepConfig(step)) return this.componentMap.apiStep;\n    if (isDatabaseStepConfig(step)) return this.componentMap.databaseStep;\n    if (isAiAgentStepConfig(step)) return this.componentMap.aiAgentStep;\n    if (isAiVerifyStepConfig(step)) return this.componentMap.aiVerifyStep;\n    if (isUploadStepConfig(step)) return this.componentMap.uploadStep;\n    if (isScreenshotStepConfig(step)) return this.componentMap.screenshotStep;\n    if (isScrollStepConfig(step)) return this.componentMap.scrollStep;\n    if (isVerifyUrlStepConfig(step)) return this.componentMap.verifyUrlStep;\n    if (isRestoreSessionStepConfig(step)) return this.componentMap.restoreSessionStep;\n    if (isCustomCodeStepConfig(step)) return this.componentMap.customCodeStep;\n    if (isNormalStepConfig(step)) return this.componentMap.normalStep;\n    return null;\n  }\n\n  private renderStep(): void {\n    if (!this.stepHost || !this.step) return;\n\n    const componentType = this.getComponentType(this.step);\n    if (!componentType) return;\n\n    this.stepHost.clear();\n    this.componentRef = this.stepHost.createComponent(componentType);\n    const instance = this.componentRef.instance;\n\n    instance.config = this.step;\n    instance.stepNumber = (this.step as any).stepNumber;\n    instance.isNested = this.isNested;\n    instance.isInsideLoop = this.isInsideLoop;\n    instance.isInsideStepGroup = this.isInsideStepGroup;\n    instance.isReorder = this.isReorder;\n    Object.keys(this.step).forEach((key) => {\n      if (key !== 'stepType' && key !== 'nestedSteps' && key !== 'branches') {\n        (instance as any)[key] = (this.step as any)[key];\n      }\n    });\n    if ((this.step as any).nestedSteps) (instance as any).nestedSteps = (this.step as any).nestedSteps;\n    if ((this.step as any).branches) (instance as any).branches = (this.step as any).branches;\n\n    // Pass data profile inputs to step instances that can contain nested loop steps\n    if (isLoopStepConfig(this.step) || isConditionStepConfig(this.step) || isStepGroupConfig(this.step)) {\n      (instance as any).dataProfileOptions = this.dataProfileOptions;\n      (instance as any).hasMoreDataProfiles = this.hasMoreDataProfiles;\n      (instance as any).isLoadingDataProfiles = this.isLoadingDataProfiles;\n      // Also pass natural text actions options (for nested loop steps with while loop and condition steps)\n      (instance as any).naturalTextActionsOptions = this.naturalTextActionsOptions;\n      // Pass addStepBetween inputs to nested step components\n      (instance as any).addStepBetweenAbove = this.addStepBetweenAbove;\n      (instance as any).addStepBetweenBelow = this.addStepBetweenBelow;\n      // Keep backward compatibility with deprecated addStepBetween\n      (instance as any).addStepBetween = this.addStepBetween;\n    }\n    \n    // Pass natural text actions options and template variables function to loop steps (for while loop condition, same as condition-step)\n    if (isLoopStepConfig(this.step)) {\n      (instance as any).naturalTextActionsOptions = this.naturalTextActionsOptions;\n      (instance as any).setConditionTemplateVariables = this.setConditionTemplateVariables;\n    }\n    \n    // Pass natural text actions options and template variables function to condition steps\n    if (isConditionStepConfig(this.step)) {\n      (instance as any).naturalTextActionsOptions = this.naturalTextActionsOptions;\n      (instance as any).setConditionTemplateVariables = this.setConditionTemplateVariables;\n    }\n\n    this.wireOutputs(instance);\n    this.cdr.detectChanges();\n  }\n\n  private wireOutputs(instance: any): void {\n    // Store subscriptions on the instance to prevent duplicates\n    if (!(instance as any)._cqaSubscriptions) {\n      (instance as any)._cqaSubscriptions = new Map<string, any>();\n    }\n    const subscriptions = (instance as any)._cqaSubscriptions;\n    \n    const wire = (key: string, emitter: EventEmitter<any>) => {\n      if (instance[key] && typeof instance[key].subscribe === 'function') {\n        // Unsubscribe from previous subscription if exists\n        const existingSub = subscriptions.get(key);\n        if (existingSub) {\n          existingSub.unsubscribe();\n        }\n        \n        // Create new subscription\n        const subscription = instance[key].subscribe((v: any) => {\n          emitter.emit(v);\n        });\n        subscriptions.set(key, subscription);\n      }\n    };\n    wire('nestedStepChange', this.nestedStepChange as any);\n    wire('addStep', {\n      emit: (v: any) => {\n        if (v != null && typeof v === 'object' && 'branch' in v) this.addStepForBranch.emit(v);\n        else if (v != null && typeof v === 'object' && 'loopStepConfig' in v) this.addStepForLoop.emit(v);\n        else this.addStep.emit(v);\n      },\n    } as any);\n    wire('deleteStep', {\n      emit: (v: any) => {\n        if (v != null && typeof v === 'object' && 'branch' in v && 'stepIndex' in v) this.deleteStepWithBranch.emit(v);\n        else this.deleteStep.emit(v);\n      },\n    } as any);\n    wire('toggleExpanded', {\n      emit: (v: any) => {\n        // Handle both boolean and object formats\n        // If it's an object with config and expanded, emit it as-is\n        // If it's just a boolean, emit it as-is\n        this.toggleExpanded.emit(v);\n      },\n    } as any);\n    wire('groupNameChange', this.groupNameChange as any);\n    wire('descriptionChange', this.descriptionChange as any);\n    wire('reusableChange', this.reusableChange as any);\n    wire('openExternal', this.openExternal as any);\n    wire('edit', {\n      emit: (v: any) => {\n        // If child component emits void or nothing, use current step and index\n        // If child component already emits an object, merge it with step and index\n        if (v != null && typeof v === 'object' && 'step' in v && 'index' in v) {\n          // Already has step and index, emit as-is\n          this.edit.emit(v);\n        } else {\n          // Emit with current step and index\n          this.edit.emit({ step: this.step, index: this.index });\n        }\n      },\n    } as any);\n    wire('link', this.link as any);\n    wire('duplicate', this.duplicate as any);\n    // Wire delete event - intercept and emit with step data (forward payload when child emits { step } for nested deletes)\n    if (instance.delete && typeof instance.delete.subscribe === 'function') {\n      const existingSub = subscriptions.get('delete');\n      if (existingSub) {\n        existingSub.unsubscribe();\n      }\n      const deleteSub = instance.delete.subscribe((v: any) => {\n        if (this.branch != null && this.index != null) {\n          this.deleteStepWithBranch.emit({ branch: this.branch, stepIndex: this.index });\n        } else if (v != null && typeof v === 'object' && v.step) {\n          this.delete.emit(v);\n        } else {\n          this.delete.emit({ step: this.step });\n        }\n      });\n      subscriptions.set('delete', deleteSub);\n    }\n    wire('viewDetails', this.viewDetails as any);\n    wire('selectionChange', this.selectionChange as any);\n    wire('conditionChange', this.conditionChange as any);\n    wire('branchStepChange', this.branchStepChange as any);\n    wire('addStepForBranch', this.addStepForBranch as any);\n    wire('deleteStepWithBranch', this.deleteStepWithBranch as any);\n    wire('addBranch', this.addBranch as any);\n    wire('addElse', this.addElse as any);\n    wire('deleteBranch', this.deleteBranch as any);\n    wire('testDataProfileChange', this.testDataProfileChange as any);\n    wire('startStepChange', this.startStepChange as any);\n    wire('endStepChange', this.endStepChange as any);\n    wire('maxIterationsChange', this.maxIterationsChange as any);\n    wire('eventTypeChange', this.eventTypeChange as any);\n    wire('parameterChange', this.parameterChange as any);\n    // Wire clickAction - wrap MouseEvent with step data\n    if (instance.clickAction && typeof instance.clickAction.subscribe === 'function') {\n      const existingSub = subscriptions.get('clickAction');\n      if (existingSub) {\n        existingSub.unsubscribe();\n      }\n      const clickActionSub = instance.clickAction.subscribe((v: any) => {\n        // If child component emits an object with event and step, use it; otherwise wrap MouseEvent with current step\n        if (v != null && typeof v === 'object' && 'event' in v && 'step' in v) {\n          this.clickAction.emit(v);\n        } else {\n          // Assume v is a MouseEvent, wrap it with current step\n          this.clickAction.emit({ event: v as MouseEvent, step: this.step });\n        }\n      });\n      subscriptions.set('clickAction', clickActionSub);\n    }\n    wire('dndDropInZone', this.dndDropInZone as any);\n    wire('loadMoreDataProfiles', this.loadMoreDataProfiles as any);\n    wire('searchDataProfiles', this.searchDataProfiles as any);\n    wire('addStepBetweenClick', this.addStepBetweenClick as any);\n    // Wire editInDepth - check if it exists on instance\n    if (instance.editInDepth && typeof instance.editInDepth.subscribe === 'function') {\n      const existingSub = subscriptions.get('editInDepth');\n      if (existingSub) {\n        existingSub.unsubscribe();\n      }\n      const editInDepthSub = instance.editInDepth.subscribe((v: any) => {\n        // If child component emits an object with step, use it; otherwise use current step and index\n        if (v != null && typeof v === 'object' && 'step' in v) {\n          this.editInDepth.emit({ step: v.step, index: v.index ?? this.index });\n        } else {\n          this.editInDepth.emit({ step: this.step, index: this.index });\n        }\n      });\n      subscriptions.set('editInDepth', editInDepthSub);\n    }\n    // Wire stepUpdate - check if it exists on instance\n    if (instance.stepUpdate) {\n      console.log('Renderer: Found stepUpdate EventEmitter, wiring it');\n      wire('stepUpdate', this.stepUpdate as any);\n    } else {\n      console.warn('Renderer: stepUpdate EventEmitter not found on instance during wireOutputs', {\n        stepId: this.step?.id,\n        stepType: this.step?.stepType,\n        instanceKeys: Object.keys(instance)\n      });\n    }\n  }\n\n  ngOnDestroy(): void {\n    // Clean up subscriptions when component is destroyed\n    if (this.componentRef?.instance) {\n      const subscriptions = (this.componentRef.instance as any)._cqaSubscriptions;\n      if (subscriptions) {\n        subscriptions.forEach((sub: any) => {\n          if (sub && typeof sub.unsubscribe === 'function') {\n            sub.unsubscribe();\n          }\n        });\n        subscriptions.clear();\n      }\n    }\n  }\n}\n\n","<div class=\"cqa-relative cqa-step-renderer-hover-container\">\n    <button *ngIf=\"!isReorder && (addStepBetweenAbove && addStepBetween)\"\n        class=\"cqa-absolute cqa-top-[calc(0 - 12px)] cqa-left-[50%] cqa-translate-x-[-50%] cqa-p-0 cqa-z-[1] cqa-add-step-between-btn\"\n        style=\"top: -12px;\" (click)=\"addStepBetweenClick.emit({step: step, index: index, position: 'ABOVE'})\">\n        <svg width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n            <rect x=\"1\" y=\"1\" width=\"21.1822\" height=\"22\" rx=\"10.5911\" fill=\"white\" />\n            <rect x=\"1\" y=\"1\" width=\"21.1822\" height=\"22\" rx=\"10.5911\" stroke=\"#3F43EE\" stroke-width=\"2\" />\n            <path d=\"M8.5 12H15.5\" stroke=\"#3F43EE\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n            <path d=\"M12 8.5V15.5\" stroke=\"#3F43EE\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n        </svg>\n    </button>\n    <div class=\"cqa-step-host-wrapper\">\n        <ng-container #stepHost></ng-container>\n    </div>\n    <button *ngIf=\"!isReorder && (addStepBetweenBelow && addStepBetween)\"\n        class=\"cqa-absolute cqa-top-[calc(100%-12px)] cqa-left-[50%] cqa-translate-x-[-50%] cqa-p-0 cqa-z-[1] cqa-add-step-between-btn\"\n        (click)=\"addStepBetweenClick.emit({step: step, index: index, position: 'BELOW'})\">\n        <svg width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n            <rect x=\"1\" y=\"1\" width=\"21.1822\" height=\"22\" rx=\"10.5911\" fill=\"white\" />\n            <rect x=\"1\" y=\"1\" width=\"21.1822\" height=\"22\" rx=\"10.5911\" stroke=\"#3F43EE\" stroke-width=\"2\" />\n            <path d=\"M8.5 12H15.5\" stroke=\"#3F43EE\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n            <path d=\"M12 8.5V15.5\" stroke=\"#3F43EE\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n        </svg>\n    </button>\n</div>"]}
|
|
482
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"test-case-details-renderer.component.js","sourceRoot":"","sources":["../../../../../../src/lib/test-case-details/test-case-details-renderer/test-case-details-renderer.component.ts","../../../../../../src/lib/test-case-details/test-case-details-renderer/test-case-details-renderer.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  Input,\n  Output,\n  EventEmitter,\n  ViewChild,\n  ViewContainerRef,\n  OnChanges,\n  SimpleChanges,\n  Inject,\n  AfterViewInit,\n  OnDestroy,\n  ChangeDetectorRef,\n  ComponentRef,\n} from '@angular/core';\nimport { TEST_CASE_STEP_COMPONENT_MAP, TestCaseStepComponentMap } from '../test-case-step-components.token';\nimport {\n  TestCaseStepConfig,\n  isStepGroupConfig,\n  isConditionStepConfig,\n  isLoopStepConfig,\n  isNormalStepConfig,\n  isApiStepConfig,\n  isDatabaseStepConfig,\n  isAiAgentStepConfig,\n  isAiVerifyStepConfig,\n  isUploadStepConfig,\n  isScreenshotStepConfig,\n  isScrollStepConfig,\n  isVerifyUrlStepConfig,\n  isRestoreSessionStepConfig,\n  isCustomCodeStepConfig,\n  ConditionBranch,\n  LoopStepConfig,\n} from '../test-case-step.models';\n\n@Component({\n  selector: 'cqa-test-case-details-renderer',\n  templateUrl: './test-case-details-renderer.component.html',\n  host: { class: 'cqa-ui-root' },\n})\nexport class TestCaseDetailsRendererComponent implements OnChanges, AfterViewInit, OnDestroy {\n  @ViewChild('stepHost', { read: ViewContainerRef }) stepHost!: ViewContainerRef;\n\n  @Input() step!: TestCaseStepConfig;\n  @Input() index!: number;\n  @Input() isNested: boolean = false;\n  @Input() isInsideLoop: boolean = false;\n  /** When true, step is rendered inside a step-group; row actions (Edit/Duplicate/Delete) are hidden. */\n  @Input() isInsideStepGroup: boolean = false;\n  /** When rendering a step inside a condition branch, the branch context (for addStepForBranch / deleteStepWithBranch). */\n  @Input() branch?: ConditionBranch;\n  /** When true, enables drag-and-drop reordering and shows drag handle icon instead of checkbox */\n  @Input() isReorder: boolean = false;\n  /** Current selection state; when changed (e.g. from Select all), the created step component is updated so the checkbox reflects it */\n  @Input() selected?: boolean;\n  /** Show \"Add Step Between\" button above the step */\n  @Input() addStepBetweenAbove: boolean = true;\n  /** Show \"Add Step Between\" button below the step */\n  @Input() addStepBetweenBelow: boolean = true;\n  /** @deprecated Use addStepBetweenAbove and addStepBetweenBelow instead. If set, applies to both buttons. */\n  @Input() addStepBetween: boolean = false;\n\n  @Output() nestedStepChange = new EventEmitter<{ step: TestCaseStepConfig; index: number }>();\n  @Output() addStep = new EventEmitter<void>();\n  @Output() deleteStep = new EventEmitter<number>();\n  @Output() toggleExpanded = new EventEmitter<boolean | {config: TestCaseStepConfig, expanded: boolean}>();\n  @Output() groupNameChange = new EventEmitter<string>();\n  @Output() descriptionChange = new EventEmitter<string>();\n  @Output() reusableChange = new EventEmitter<boolean>();\n  @Output() openExternal = new EventEmitter<{step: TestCaseStepConfig}>();\n  @Output() edit = new EventEmitter<{step: TestCaseStepConfig, index: number}>();\n  @Output() link = new EventEmitter<void>();\n  @Output() duplicate = new EventEmitter<void>();\n  @Output() delete = new EventEmitter<{ step: TestCaseStepConfig } | void>();\n  @Output() viewDetails = new EventEmitter<import('../step-details-modal/step-details-modal-data').ViewDetailsPayload>();\n  @Output() selectionChange = new EventEmitter<boolean>();\n  @Output() conditionChange = new EventEmitter<string>();\n  @Output() branchStepChange = new EventEmitter<{ branch: ConditionBranch; step: TestCaseStepConfig; stepIndex: number }>();\n  @Output() addStepForBranch = new EventEmitter<{ branch: ConditionBranch }>();\n  /** Emitted when empty loop step plus is clicked; same behaviour as add-step-between (parentId = loop step id). */\n  @Output() addStepForLoop = new EventEmitter<{ loopStepConfig: LoopStepConfig }>();\n  @Output() deleteStepWithBranch = new EventEmitter<{ branch: ConditionBranch; stepIndex: number }>();\n  @Output() addBranch = new EventEmitter<void>();\n  /** Emitted when user clicks \"Add Else\" in a condition step; parent should call POST test_steps with conditionType CONDITION_ELSE */\n  @Output() addElse = new EventEmitter<{ conditionStepConfig: TestCaseStepConfig }>();\n  @Output() deleteBranch = new EventEmitter<ConditionBranch>();\n  @Output() testDataProfileChange = new EventEmitter<string>();\n  @Output() startStepChange = new EventEmitter<number>();\n  @Output() endStepChange = new EventEmitter<number>();\n  @Output() maxIterationsChange = new EventEmitter<number>();\n  @Output() eventTypeChange = new EventEmitter<any>();\n  @Output() parameterChange = new EventEmitter<any>();\n  @Output() clickAction = new EventEmitter<{ event: MouseEvent; step: TestCaseStepConfig }>();\n  /** Emitted when a step is dropped in a nested dropzone (step-group, loop, condition). Payload: { event, targetList }. */\n  @Output() dndDropInZone = new EventEmitter<{ event: any; targetList: TestCaseStepConfig[] }>();\n  /** Data profile options for loop steps */\n  @Input() dataProfileOptions: any[] = [];\n  /** Indicates if more data profiles are available for loading */\n  @Input() hasMoreDataProfiles: boolean = false;\n  /** Loading state for data profiles */\n  @Input() isLoadingDataProfiles: boolean = false;\n  /** Natural text actions options for while loop condition */\n  @Input() naturalTextActionsOptions: any[] = [];\n  /** Function to process template variables for condition steps */\n  @Input() setConditionTemplateVariables: (template: any) => any[] = () => [];\n  /** Emit when more data profiles need to be loaded */\n  @Output() loadMoreDataProfiles = new EventEmitter<string>();\n  /** Emit when data profile search query changes */\n  @Output() searchDataProfiles = new EventEmitter<string>();\n  /** Emit when a step is updated (e.g., Apply button clicked in loop-step edit mode) */\n  @Output() stepUpdate = new EventEmitter<TestCaseStepConfig>();\n  @Output() addStepBetweenClick = new EventEmitter<{step: TestCaseStepConfig, index: number, position: 'ABOVE' | 'BELOW'}>();\n  /** Emit when user clicks \"Edit In depth\" in condition-step (or other steps that support it) */\n  @Output() editInDepth = new EventEmitter<{ step: TestCaseStepConfig; index: number }>();\n\n  private componentRef: ComponentRef<any> | null = null;\n\n  constructor(\n    @Inject(TEST_CASE_STEP_COMPONENT_MAP) private componentMap: TestCaseStepComponentMap,\n    private cdr: ChangeDetectorRef\n  ) {}\n\n  ngAfterViewInit(): void {\n    this.renderStep();\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    const structuralChange = changes['step'] || changes['index'] || changes['isNested'] || changes['isInsideLoop'] ||\n        changes['isInsideStepGroup'] || changes['isReorder'];\n    const optionsOnlyChange = (changes['dataProfileOptions'] || changes['hasMoreDataProfiles'] || changes['isLoadingDataProfiles'] ||\n        changes['naturalTextActionsOptions'] || changes['setConditionTemplateVariables']) && !structuralChange;\n\n    if (structuralChange) {\n      this.renderStep();\n    } else if (optionsOnlyChange && this.componentRef?.instance != null && this.step != null) {\n      // Update only profile/options inputs so we don't destroy the step (e.g. opening data profile dropdown\n      // loads options and would otherwise recreate the component and collapse inline edit)\n      this.updateOptionsInputs(this.componentRef.instance);\n      this.cdr.detectChanges();\n    } else if (changes['selected'] && this.componentRef?.instance != null) {\n      (this.componentRef.instance as any).selected = this.selected;\n      this.cdr.detectChanges();\n    }\n  }\n\n  /** Update only data profile / options inputs on existing instance (avoids full recreate and losing isEditing). */\n  private updateOptionsInputs(instance: any): void {\n    if (isLoopStepConfig(this.step!) || isConditionStepConfig(this.step!) || isStepGroupConfig(this.step!)) {\n      (instance as any).dataProfileOptions = this.dataProfileOptions;\n      (instance as any).hasMoreDataProfiles = this.hasMoreDataProfiles;\n      (instance as any).isLoadingDataProfiles = this.isLoadingDataProfiles;\n      (instance as any).naturalTextActionsOptions = this.naturalTextActionsOptions;\n      (instance as any).addStepBetweenAbove = this.addStepBetweenAbove;\n      (instance as any).addStepBetweenBelow = this.addStepBetweenBelow;\n      (instance as any).addStepBetween = this.addStepBetween;\n    }\n    if (isLoopStepConfig(this.step!)) {\n      (instance as any).naturalTextActionsOptions = this.naturalTextActionsOptions;\n      (instance as any).setConditionTemplateVariables = this.setConditionTemplateVariables;\n    }\n    if (isConditionStepConfig(this.step!)) {\n      (instance as any).naturalTextActionsOptions = this.naturalTextActionsOptions;\n      (instance as any).setConditionTemplateVariables = this.setConditionTemplateVariables;\n    }\n  }\n\n  private getComponentType(step: TestCaseStepConfig): any {\n    if (isStepGroupConfig(step)) return this.componentMap.stepGroup;\n    if (isConditionStepConfig(step)) return this.componentMap.conditionStep;\n    if (isLoopStepConfig(step)) return this.componentMap.loopStep;\n    if (isApiStepConfig(step)) return this.componentMap.apiStep;\n    if (isDatabaseStepConfig(step)) return this.componentMap.databaseStep;\n    if (isAiAgentStepConfig(step)) return this.componentMap.aiAgentStep;\n    if (isAiVerifyStepConfig(step)) return this.componentMap.aiVerifyStep;\n    if (isUploadStepConfig(step)) return this.componentMap.uploadStep;\n    if (isScreenshotStepConfig(step)) return this.componentMap.screenshotStep;\n    if (isScrollStepConfig(step)) return this.componentMap.scrollStep;\n    if (isVerifyUrlStepConfig(step)) return this.componentMap.verifyUrlStep;\n    if (isRestoreSessionStepConfig(step)) return this.componentMap.restoreSessionStep;\n    if (isCustomCodeStepConfig(step)) return this.componentMap.customCodeStep;\n    if (isNormalStepConfig(step)) return this.componentMap.normalStep;\n    return null;\n  }\n\n  private renderStep(): void {\n    if (!this.stepHost || !this.step) return;\n\n    const componentType = this.getComponentType(this.step);\n    if (!componentType) return;\n\n    this.stepHost.clear();\n    this.componentRef = this.stepHost.createComponent(componentType);\n    const instance = this.componentRef.instance;\n\n    instance.config = this.step;\n    instance.stepNumber = (this.step as any).stepNumber;\n    instance.isNested = this.isNested;\n    instance.isInsideLoop = this.isInsideLoop;\n    instance.isInsideStepGroup = this.isInsideStepGroup;\n    instance.isReorder = this.isReorder;\n    Object.keys(this.step).forEach((key) => {\n      if (key !== 'stepType' && key !== 'nestedSteps' && key !== 'branches') {\n        (instance as any)[key] = (this.step as any)[key];\n      }\n    });\n    if ((this.step as any).nestedSteps) (instance as any).nestedSteps = (this.step as any).nestedSteps;\n    if ((this.step as any).branches) (instance as any).branches = (this.step as any).branches;\n\n    // Pass data profile inputs to step instances that can contain nested loop steps\n    if (isLoopStepConfig(this.step) || isConditionStepConfig(this.step) || isStepGroupConfig(this.step)) {\n      (instance as any).dataProfileOptions = this.dataProfileOptions;\n      (instance as any).hasMoreDataProfiles = this.hasMoreDataProfiles;\n      (instance as any).isLoadingDataProfiles = this.isLoadingDataProfiles;\n      // Also pass natural text actions options (for nested loop steps with while loop and condition steps)\n      (instance as any).naturalTextActionsOptions = this.naturalTextActionsOptions;\n      // Pass addStepBetween inputs to nested step components\n      (instance as any).addStepBetweenAbove = this.addStepBetweenAbove;\n      (instance as any).addStepBetweenBelow = this.addStepBetweenBelow;\n      // Keep backward compatibility with deprecated addStepBetween\n      (instance as any).addStepBetween = this.addStepBetween;\n    }\n    \n    // Pass natural text actions options and template variables function to loop steps (for while loop condition, same as condition-step)\n    if (isLoopStepConfig(this.step)) {\n      (instance as any).naturalTextActionsOptions = this.naturalTextActionsOptions;\n      (instance as any).setConditionTemplateVariables = this.setConditionTemplateVariables;\n    }\n    \n    // Pass natural text actions options and template variables function to condition steps\n    if (isConditionStepConfig(this.step)) {\n      (instance as any).naturalTextActionsOptions = this.naturalTextActionsOptions;\n      (instance as any).setConditionTemplateVariables = this.setConditionTemplateVariables;\n    }\n\n    this.wireOutputs(instance);\n    this.cdr.detectChanges();\n  }\n\n  private wireOutputs(instance: any): void {\n    // Store subscriptions on the instance to prevent duplicates\n    if (!(instance as any)._cqaSubscriptions) {\n      (instance as any)._cqaSubscriptions = new Map<string, any>();\n    }\n    const subscriptions = (instance as any)._cqaSubscriptions;\n    \n    const wire = (key: string, emitter: EventEmitter<any>) => {\n      if (instance[key] && typeof instance[key].subscribe === 'function') {\n        // Unsubscribe from previous subscription if exists\n        const existingSub = subscriptions.get(key);\n        if (existingSub) {\n          existingSub.unsubscribe();\n        }\n        \n        // Create new subscription\n        const subscription = instance[key].subscribe((v: any) => {\n          emitter.emit(v);\n        });\n        subscriptions.set(key, subscription);\n      }\n    };\n    wire('nestedStepChange', this.nestedStepChange as any);\n    wire('addStep', {\n      emit: (v: any) => {\n        if (v != null && typeof v === 'object' && 'branch' in v) this.addStepForBranch.emit(v);\n        else if (v != null && typeof v === 'object' && 'loopStepConfig' in v) this.addStepForLoop.emit(v);\n        else this.addStep.emit(v);\n      },\n    } as any);\n    wire('deleteStep', {\n      emit: (v: any) => {\n        if (v != null && typeof v === 'object' && 'branch' in v && 'stepIndex' in v) this.deleteStepWithBranch.emit(v);\n        else this.deleteStep.emit(v);\n      },\n    } as any);\n    wire('toggleExpanded', {\n      emit: (v: any) => {\n        // Handle both boolean and object formats\n        // If it's an object with config and expanded, emit it as-is\n        // If it's just a boolean, emit it as-is\n        this.toggleExpanded.emit(v);\n      },\n    } as any);\n    wire('groupNameChange', this.groupNameChange as any);\n    wire('descriptionChange', this.descriptionChange as any);\n    wire('reusableChange', this.reusableChange as any);\n    wire('openExternal', this.openExternal as any);\n    wire('edit', {\n      emit: (v: any) => {\n        // If child component emits void or nothing, use current step and index\n        // If child component already emits an object, merge it with step and index\n        if (v != null && typeof v === 'object' && 'step' in v && 'index' in v) {\n          // Already has step and index, emit as-is\n          this.edit.emit(v);\n        } else {\n          // Emit with current step and index\n          this.edit.emit({ step: this.step, index: this.index });\n        }\n      },\n    } as any);\n    wire('link', this.link as any);\n    wire('duplicate', this.duplicate as any);\n    // Wire delete event - intercept and emit with step data (forward payload when child emits { step } for nested deletes)\n    if (instance.delete && typeof instance.delete.subscribe === 'function') {\n      const existingSub = subscriptions.get('delete');\n      if (existingSub) {\n        existingSub.unsubscribe();\n      }\n      const deleteSub = instance.delete.subscribe((v: any) => {\n        if (this.branch != null && this.index != null) {\n          this.deleteStepWithBranch.emit({ branch: this.branch, stepIndex: this.index });\n        } else if (v != null && typeof v === 'object' && v.step) {\n          this.delete.emit(v);\n        } else {\n          this.delete.emit({ step: this.step });\n        }\n      });\n      subscriptions.set('delete', deleteSub);\n    }\n    wire('viewDetails', this.viewDetails as any);\n    wire('selectionChange', this.selectionChange as any);\n    wire('conditionChange', this.conditionChange as any);\n    wire('branchStepChange', this.branchStepChange as any);\n    wire('addStepForBranch', this.addStepForBranch as any);\n    wire('deleteStepWithBranch', this.deleteStepWithBranch as any);\n    wire('addBranch', this.addBranch as any);\n    wire('addElse', this.addElse as any);\n    wire('deleteBranch', this.deleteBranch as any);\n    wire('addStepForLoop', this.addStepForLoop as any);\n    wire('testDataProfileChange', this.testDataProfileChange as any);\n    wire('startStepChange', this.startStepChange as any);\n    wire('endStepChange', this.endStepChange as any);\n    wire('maxIterationsChange', this.maxIterationsChange as any);\n    wire('eventTypeChange', this.eventTypeChange as any);\n    wire('parameterChange', this.parameterChange as any);\n    // Wire clickAction - wrap MouseEvent with step data\n    if (instance.clickAction && typeof instance.clickAction.subscribe === 'function') {\n      const existingSub = subscriptions.get('clickAction');\n      if (existingSub) {\n        existingSub.unsubscribe();\n      }\n      const clickActionSub = instance.clickAction.subscribe((v: any) => {\n        // If child component emits an object with event and step, use it; otherwise wrap MouseEvent with current step\n        if (v != null && typeof v === 'object' && 'event' in v && 'step' in v) {\n          this.clickAction.emit(v);\n        } else {\n          // Assume v is a MouseEvent, wrap it with current step\n          this.clickAction.emit({ event: v as MouseEvent, step: this.step });\n        }\n      });\n      subscriptions.set('clickAction', clickActionSub);\n    }\n    wire('dndDropInZone', this.dndDropInZone as any);\n    wire('loadMoreDataProfiles', this.loadMoreDataProfiles as any);\n    wire('searchDataProfiles', this.searchDataProfiles as any);\n    wire('addStepBetweenClick', this.addStepBetweenClick as any);\n    // Wire editInDepth - check if it exists on instance\n    if (instance.editInDepth && typeof instance.editInDepth.subscribe === 'function') {\n      const existingSub = subscriptions.get('editInDepth');\n      if (existingSub) {\n        existingSub.unsubscribe();\n      }\n      const editInDepthSub = instance.editInDepth.subscribe((v: any) => {\n        // If child component emits an object with step, use it; otherwise use current step and index\n        if (v != null && typeof v === 'object' && 'step' in v) {\n          this.editInDepth.emit({ step: v.step, index: v.index ?? this.index });\n        } else {\n          this.editInDepth.emit({ step: this.step, index: this.index });\n        }\n      });\n      subscriptions.set('editInDepth', editInDepthSub);\n    }\n    // Wire stepUpdate - check if it exists on instance\n    if (instance.stepUpdate) {\n      console.log('Renderer: Found stepUpdate EventEmitter, wiring it');\n      wire('stepUpdate', this.stepUpdate as any);\n    } else {\n      console.warn('Renderer: stepUpdate EventEmitter not found on instance during wireOutputs', {\n        stepId: this.step?.id,\n        stepType: this.step?.stepType,\n        instanceKeys: Object.keys(instance)\n      });\n    }\n  }\n\n  ngOnDestroy(): void {\n    // Clean up subscriptions when component is destroyed\n    if (this.componentRef?.instance) {\n      const subscriptions = (this.componentRef.instance as any)._cqaSubscriptions;\n      if (subscriptions) {\n        subscriptions.forEach((sub: any) => {\n          if (sub && typeof sub.unsubscribe === 'function') {\n            sub.unsubscribe();\n          }\n        });\n        subscriptions.clear();\n      }\n    }\n  }\n}\n\n","<div class=\"cqa-relative cqa-step-renderer-hover-container\">\n    <button *ngIf=\"!isReorder && (addStepBetweenAbove && addStepBetween)\"\n        class=\"cqa-absolute cqa-top-[calc(0 - 12px)] cqa-left-[50%] cqa-translate-x-[-50%] cqa-p-0 cqa-z-[1] cqa-add-step-between-btn\"\n        style=\"top: -12px;\" (click)=\"addStepBetweenClick.emit({step: step, index: index, position: 'ABOVE'})\">\n        <svg width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n            <rect x=\"1\" y=\"1\" width=\"21.1822\" height=\"22\" rx=\"10.5911\" fill=\"white\" />\n            <rect x=\"1\" y=\"1\" width=\"21.1822\" height=\"22\" rx=\"10.5911\" stroke=\"#3F43EE\" stroke-width=\"2\" />\n            <path d=\"M8.5 12H15.5\" stroke=\"#3F43EE\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n            <path d=\"M12 8.5V15.5\" stroke=\"#3F43EE\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n        </svg>\n    </button>\n    <div class=\"cqa-step-host-wrapper\">\n        <ng-container #stepHost></ng-container>\n    </div>\n    <button *ngIf=\"!isReorder && (addStepBetweenBelow && addStepBetween)\"\n        class=\"cqa-absolute cqa-top-[calc(100%-12px)] cqa-left-[50%] cqa-translate-x-[-50%] cqa-p-0 cqa-z-[1] cqa-add-step-between-btn\"\n        (click)=\"addStepBetweenClick.emit({step: step, index: index, position: 'BELOW'})\">\n        <svg width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n            <rect x=\"1\" y=\"1\" width=\"21.1822\" height=\"22\" rx=\"10.5911\" fill=\"white\" />\n            <rect x=\"1\" y=\"1\" width=\"21.1822\" height=\"22\" rx=\"10.5911\" stroke=\"#3F43EE\" stroke-width=\"2\" />\n            <path d=\"M8.5 12H15.5\" stroke=\"#3F43EE\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n            <path d=\"M12 8.5V15.5\" stroke=\"#3F43EE\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n        </svg>\n    </button>\n</div>"]}
|
|
@@ -120,10 +120,10 @@ export class TestCaseDetailsComponent {
|
|
|
120
120
|
}
|
|
121
121
|
}
|
|
122
122
|
TestCaseDetailsComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: TestCaseDetailsComponent, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
123
|
-
TestCaseDetailsComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.4.0", type: TestCaseDetailsComponent, selector: "cqa-test-case-details", inputs: { editing: "editing", startInEditMode: "startInEditMode", descriptionTitle: "descriptionTitle", descriptionContent: "descriptionContent", enableMarkdown: "enableMarkdown", showEditButton: "showEditButton", metadataItems: "metadataItems", labels: "labels", configTitle: "configTitle", configSections: "configSections", configSectionsRow2: "configSectionsRow2", platform: "platform", isStepGroup: "isStepGroup", selectConfigOverrides: "selectConfigOverrides" }, outputs: { editDescription: "editDescription", cancel: "cancel", saveChanges: "saveChanges", metadataLinkClick: "metadataLinkClick", selectSearch: "selectSearch", selectLoadMore: "selectLoadMore", selectOpened: "selectOpened", selectionChange: "selectionChange", labelAdded: "labelAdded" }, ngImport: i0, template: "<!-- Edit mode: show edit form (Figma design) -->\n<cqa-test-case-details-edit\n *ngIf=\"isEditing\"\n [descriptionTitle]=\"descriptionTitle\"\n [descriptionContent]=\"descriptionContent\"\n [enableMarkdown]=\"enableMarkdown\"\n [metadataItems]=\"metadataItems\"\n [labels]=\"labels\"\n [configTitle]=\"configTitle\"\n [configSections]=\"configSections\"\n [configSectionsRow2]=\"configSectionsRow2\"\n [platform]=\"platform\"\n [isStepGroup]=\"isStepGroup\"\n [selectConfigOverrides]=\"selectConfigOverrides\"\n (save)=\"onSaveChanges($event)\"\n (cancel)=\"onCancelEdit()\"\n (selectSearch)=\"selectSearch.emit($event)\"\n (selectLoadMore)=\"selectLoadMore.emit($event)\"\n (selectOpened)=\"selectOpened.emit($event)\"\n (selectionChange)=\"selectionChange.emit($event)\"\n (labelAdded)=\"labelAdded.emit($event)\">\n</cqa-test-case-details-edit>\n\n<!-- View mode: read-only details -->\n<div *ngIf=\"!isEditing\" class=\"cqa-self-stretch cqa-py-4 cqa-px-0 cqa-flex cqa-flex-col cqa-justify-start cqa-items-start cqa-gap-4 cqa-text-sm cqa-leading-[19.6px]\">\n <div class=\"cqa-self-stretch cqa-flex cqa-flex-col cqa-justify-start cqa-items-start cqa-gap-4 cqa-text-sm cqa-leading-[19.6px]\">\n <!-- Description Section -->\n <div class=\"cqa-self-stretch cqa-flex cqa-flex-col cqa-justify-start cqa-items-start cqa-gap-2.5\">\n <div class=\"cqa-self-stretch cqa-inline-flex cqa-justify-between cqa-items-center\">\n <div class=\"cqa-flex cqa-items-center cqa-gap-2\">\n <div class=\"cqa-w-5 cqa-h-5 cqa-p-1 cqa-flex-shrink-0 cqa-bg-[#3F43EE1A] cqa-rounded-md cqa-inline-flex cqa-justify-center cqa-items-center\">\n <mat-icon class=\"cqa-text-[#1B1FEB] cqa-text-[12px] cqa-w-3 cqa-h-3 cqa-leading-none cqa-block\">description</mat-icon>\n </div>\n <span class=\"cqa-text-[#374151] cqa-text-sm cqa-font-semibold cqa-leading-[19.6px]\">{{ descriptionTitle }}</span>\n </div>\n <button\n *ngIf=\"showEditButton\"\n type=\"button\"\n class=\"cqa-flex cqa-justify-end cqa-items-center cqa-gap-2 cqa-text-[#A3A3A3] cqa-text-xs cqa-font-semibold hover:cqa-text-[#737373] cqa-transition-colors focus:cqa-outline-none focus-visible:cqa-ring-2 focus-visible:cqa-ring-[#3F43EE] focus-visible:cqa-ring-offset-2\"\n (click)=\"onEditClick()\">\n <mat-icon class=\"cqa-text-[14px] cqa-w-4 cqa-h-4\">edit</mat-icon>\n Edit\n </button>\n </div>\n <div *ngIf=\"descriptionContent\" class=\"cqa-self-stretch cqa-flex cqa-flex-col cqa-justify-start cqa-items-start\">\n <div *ngIf=\"enableMarkdown\" class=\"cqa-self-stretch cqa-text-[#111827] cqa-text-sm cqa-leading-[19.6px] cqa-font-normal cqa-prose cqa-prose-sm cqa-max-w-none\" [innerHTML]=\"descriptionContent\"></div>\n <div *ngIf=\"!enableMarkdown\" class=\"cqa-self-stretch cqa-text-[#111827] cqa-text-sm cqa-leading-[19.6px] cqa-font-normal\">{{ descriptionContent }}</div>\n </div>\n </div>\n\n <!-- Metadata Section -->\n <div *ngIf=\"filteredMetadataItems.length\" class=\"cqa-self-stretch cqa-flex cqa-flex-col cqa-justify-start cqa-items-start cqa-gap-2.5\">\n <div class=\"cqa-self-stretch cqa-grid cqa-grid-cols-2 cqa-gap-x-0 cqa-gap-y-4\">\n <ng-container *ngFor=\"let item of filteredMetadataItems; trackBy: trackByMetadataLabel\">\n <div class=\"cqa-flex cqa-flex-col cqa-justify-start cqa-items-start cqa-gap-0.5\">\n <div class=\"cqa-text-[#6B7280] cqa-text-xs cqa-leading-[15px] cqa-font-medium\">{{ item.label }}</div>\n <div\n class=\"cqa-flex cqa-justify-start cqa-items-center cqa-gap-[5px] cqa-min-w-0 cqa-w-full cqa-text-left cqa-text-[#0A0A0A] cqa-border cqa-border-[#F5F5F5]\">\n <mat-icon *ngIf=\"item.icon && (!item.iconLibrary || item.iconLibrary === 'mat')\" class=\"cqa-text-[#6B7280] cqa-text-sm cqa-w-4 cqa-h-4\">\n {{ item.icon }}\n </mat-icon>\n <span *ngIf=\"item.statusColor\" class=\"cqa-w-
|
|
123
|
+
TestCaseDetailsComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.4.0", type: TestCaseDetailsComponent, selector: "cqa-test-case-details", inputs: { editing: "editing", startInEditMode: "startInEditMode", descriptionTitle: "descriptionTitle", descriptionContent: "descriptionContent", enableMarkdown: "enableMarkdown", showEditButton: "showEditButton", metadataItems: "metadataItems", labels: "labels", configTitle: "configTitle", configSections: "configSections", configSectionsRow2: "configSectionsRow2", platform: "platform", isStepGroup: "isStepGroup", selectConfigOverrides: "selectConfigOverrides" }, outputs: { editDescription: "editDescription", cancel: "cancel", saveChanges: "saveChanges", metadataLinkClick: "metadataLinkClick", selectSearch: "selectSearch", selectLoadMore: "selectLoadMore", selectOpened: "selectOpened", selectionChange: "selectionChange", labelAdded: "labelAdded" }, ngImport: i0, template: "<!-- Edit mode: show edit form (Figma design) -->\n<cqa-test-case-details-edit\n *ngIf=\"isEditing\"\n [descriptionTitle]=\"descriptionTitle\"\n [descriptionContent]=\"descriptionContent\"\n [enableMarkdown]=\"enableMarkdown\"\n [metadataItems]=\"metadataItems\"\n [labels]=\"labels\"\n [configTitle]=\"configTitle\"\n [configSections]=\"configSections\"\n [configSectionsRow2]=\"configSectionsRow2\"\n [platform]=\"platform\"\n [isStepGroup]=\"isStepGroup\"\n [selectConfigOverrides]=\"selectConfigOverrides\"\n (save)=\"onSaveChanges($event)\"\n (cancel)=\"onCancelEdit()\"\n (selectSearch)=\"selectSearch.emit($event)\"\n (selectLoadMore)=\"selectLoadMore.emit($event)\"\n (selectOpened)=\"selectOpened.emit($event)\"\n (selectionChange)=\"selectionChange.emit($event)\"\n (labelAdded)=\"labelAdded.emit($event)\">\n</cqa-test-case-details-edit>\n\n<!-- View mode: read-only details -->\n<div *ngIf=\"!isEditing\" class=\"cqa-self-stretch cqa-py-4 cqa-px-0 cqa-flex cqa-flex-col cqa-justify-start cqa-items-start cqa-gap-4 cqa-text-sm cqa-leading-[19.6px]\">\n <div class=\"cqa-self-stretch cqa-flex cqa-flex-col cqa-justify-start cqa-items-start cqa-gap-4 cqa-text-sm cqa-leading-[19.6px]\">\n <!-- Description Section -->\n <div class=\"cqa-self-stretch cqa-flex cqa-flex-col cqa-justify-start cqa-items-start cqa-gap-2.5\">\n <div class=\"cqa-self-stretch cqa-inline-flex cqa-justify-between cqa-items-center\">\n <div class=\"cqa-flex cqa-items-center cqa-gap-2\">\n <div class=\"cqa-w-5 cqa-h-5 cqa-p-1 cqa-flex-shrink-0 cqa-bg-[#3F43EE1A] cqa-rounded-md cqa-inline-flex cqa-justify-center cqa-items-center\">\n <mat-icon class=\"cqa-text-[#1B1FEB] cqa-text-[12px] cqa-w-3 cqa-h-3 cqa-leading-none cqa-block\">description</mat-icon>\n </div>\n <span class=\"cqa-text-[#374151] cqa-text-sm cqa-font-semibold cqa-leading-[19.6px]\">{{ descriptionTitle }}</span>\n </div>\n <button\n *ngIf=\"showEditButton\"\n type=\"button\"\n class=\"cqa-flex cqa-justify-end cqa-items-center cqa-gap-2 cqa-text-[#A3A3A3] cqa-text-xs cqa-font-semibold hover:cqa-text-[#737373] cqa-transition-colors focus:cqa-outline-none focus-visible:cqa-ring-2 focus-visible:cqa-ring-[#3F43EE] focus-visible:cqa-ring-offset-2\"\n (click)=\"onEditClick()\">\n <mat-icon class=\"cqa-text-[14px] cqa-w-4 cqa-h-4\">edit</mat-icon>\n Edit\n </button>\n </div>\n <div *ngIf=\"descriptionContent\" class=\"cqa-self-stretch cqa-flex cqa-flex-col cqa-justify-start cqa-items-start\">\n <div *ngIf=\"enableMarkdown\" class=\"cqa-self-stretch cqa-text-[#111827] cqa-text-sm cqa-leading-[19.6px] cqa-font-normal cqa-prose cqa-prose-sm cqa-max-w-none\" [innerHTML]=\"descriptionContent\"></div>\n <div *ngIf=\"!enableMarkdown\" class=\"cqa-self-stretch cqa-text-[#111827] cqa-text-sm cqa-leading-[19.6px] cqa-font-normal\">{{ descriptionContent }}</div>\n </div>\n </div>\n\n <!-- Metadata Section -->\n <div *ngIf=\"filteredMetadataItems.length\" class=\"cqa-self-stretch cqa-flex cqa-flex-col cqa-justify-start cqa-items-start cqa-gap-2.5\">\n <div class=\"cqa-self-stretch cqa-grid cqa-grid-cols-2 cqa-gap-x-0 cqa-gap-y-4\">\n <ng-container *ngFor=\"let item of filteredMetadataItems; trackBy: trackByMetadataLabel\">\n <div class=\"cqa-flex cqa-flex-col cqa-justify-start cqa-items-start cqa-gap-0.5\">\n <div class=\"cqa-text-[#6B7280] cqa-text-xs cqa-leading-[15px] cqa-font-medium\">{{ item.label }}</div>\n <div\n class=\"cqa-flex cqa-justify-start cqa-items-center cqa-gap-[5px] cqa-min-w-0 cqa-w-full cqa-text-left cqa-text-[#0A0A0A] cqa-border cqa-border-[#F5F5F5]\">\n <mat-icon *ngIf=\"item.icon && (!item.iconLibrary || item.iconLibrary === 'mat')\" class=\"cqa-text-[#6B7280] cqa-text-sm cqa-w-4 cqa-h-4\">\n {{ item.icon }}\n </mat-icon>\n <span *ngIf=\"item.statusColor\" class=\"cqa-w-[10px] cqa-h-[10px] cqa-rounded-full cqa-flex-shrink-0\" [ngClass]=\"getStatusDotClass(item)\"></span>\n <a\n *ngIf=\"item.link\"\n href=\"javascript:void(0)\"\n class=\"cqa-text-[#2563EB] cqa-text-xs cqa-leading-[12px] cqa-font-normal hover:cqa-underline cqa-cursor-pointer cqa-block cqa-truncate cqa-min-w-0\"\n (click)=\"onMetadataLinkClick(item); $event.preventDefault()\">\n {{ item.value }}\n </a>\n <span *ngIf=\"!item.link\" class=\"cqa-text-xs cqa-leading-[12px] cqa-font-normal cqa-align-middle\" [ngClass]=\"getValueTextClass(item)\">\n {{ item.value }}\n </span>\n </div>\n </div>\n </ng-container>\n </div>\n </div>\n\n <!-- Labels (Figma: Labels title, cqa-badge chips with tag icon) -->\n <div *ngIf=\"labels.length\" class=\"cqa-self-stretch cqa-flex cqa-flex-col cqa-justify-start cqa-items-start cqa-gap-2 cqa-text-sm cqa-leading-[19.6px]\">\n <span class=\"cqa-text-[#111827] cqa-text-sm cqa-font-medium cqa-leading-5\">Labels</span>\n <div class=\"cqa-flex cqa-flex-wrap cqa-gap-2\">\n <cqa-badge\n *ngFor=\"let label of labels\"\n [label]=\"label\"\n icon=\"label\"\n variant=\"outline\"\n size=\"small\"\n backgroundColor=\"#ffffff\"\n textColor=\"#475569\"\n borderColor=\"#E2E8F0\"\n iconColor=\"#94A3B8\">\n </cqa-badge>\n </div>\n </div>\n\n <!-- Configuration Section -->\n <div *ngIf=\"configSections.length || configSectionsRow2.length\" class=\"cqa-self-stretch cqa-flex cqa-flex-col cqa-justify-start cqa-items-start cqa-gap-2.5\">\n <div class=\"cqa-self-stretch cqa-inline-flex cqa-justify-start cqa-items-center\">\n <div class=\"cqa-flex cqa-items-center cqa-gap-2\">\n <div class=\"cqa-w-5 cqa-h-5 cqa-p-1 cqa-flex-shrink-0 cqa-bg-[#3F43EE1A] cqa-rounded-md cqa-inline-flex cqa-justify-center cqa-items-center\">\n <mat-icon class=\"cqa-text-[#1B1FEB] cqa-text-[12px] cqa-w-3 cqa-h-3 cqa-leading-none cqa-block\">settings</mat-icon>\n </div>\n <span class=\"cqa-text-[#374151] cqa-text-sm cqa-font-semibold cqa-leading-[19.6px]\">{{ configTitle }}</span>\n </div>\n </div>\n <div class=\"cqa-self-stretch cqa-flex cqa-flex-col cqa-justify-start cqa-items-start cqa-gap-2.5\">\n <div class=\"cqa-self-stretch cqa-grid cqa-grid-cols-1 cqa-gap-2.5\">\n <ng-container *ngFor=\"let section of configSections; trackBy: trackByConfigTitle\">\n <cqa-configuration-card\n [icon]=\"section.icon || 'tune'\"\n [title]=\"section.title\"\n [data]=\"section.items\">\n </cqa-configuration-card>\n </ng-container>\n </div>\n <div *ngIf=\"configSectionsRow2.length\" class=\"cqa-self-stretch cqa-flex cqa-flex-col cqa-gap-4 cqa-text-sm cqa-leading-[19.6px]\">\n <cqa-configuration-card\n *ngFor=\"let section of configSectionsRow2; trackBy: trackByConfigTitle\"\n [icon]=\"section.icon || 'tune'\"\n [title]=\"section.title\"\n [data]=\"section.items\">\n </cqa-configuration-card>\n </div>\n </div>\n </div>\n </div>\n</div>\n", components: [{ type: i1.TestCaseDetailsEditComponent, selector: "cqa-test-case-details-edit", inputs: ["descriptionTitle", "descriptionContent", "enableMarkdown", "metadataItems", "labels", "configTitle", "configSections", "configSectionsRow2", "prerequisiteCaseOptions", "platform", "isStepGroup", "selectConfigOverrides"], outputs: ["save", "cancel", "selectSearch", "selectLoadMore", "selectOpened", "selectionChange", "labelAdded"] }, { type: i2.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { type: i3.BadgeComponent, selector: "cqa-badge", inputs: ["type", "label", "icon", "iconLibrary", "variant", "size", "backgroundColor", "textColor", "borderColor", "iconBackgroundColor", "iconColor", "iconSize", "inlineStyles", "key", "value", "keyTextColor", "valueTextColor", "isLoading"] }, { type: i4.ConfigurationCardComponent, selector: "cqa-configuration-card", inputs: ["icon", "title", "data"] }], directives: [{ type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i5.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i5.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
124
124
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: TestCaseDetailsComponent, decorators: [{
|
|
125
125
|
type: Component,
|
|
126
|
-
args: [{ selector: 'cqa-test-case-details', changeDetection: ChangeDetectionStrategy.OnPush, template: "<!-- Edit mode: show edit form (Figma design) -->\n<cqa-test-case-details-edit\n *ngIf=\"isEditing\"\n [descriptionTitle]=\"descriptionTitle\"\n [descriptionContent]=\"descriptionContent\"\n [enableMarkdown]=\"enableMarkdown\"\n [metadataItems]=\"metadataItems\"\n [labels]=\"labels\"\n [configTitle]=\"configTitle\"\n [configSections]=\"configSections\"\n [configSectionsRow2]=\"configSectionsRow2\"\n [platform]=\"platform\"\n [isStepGroup]=\"isStepGroup\"\n [selectConfigOverrides]=\"selectConfigOverrides\"\n (save)=\"onSaveChanges($event)\"\n (cancel)=\"onCancelEdit()\"\n (selectSearch)=\"selectSearch.emit($event)\"\n (selectLoadMore)=\"selectLoadMore.emit($event)\"\n (selectOpened)=\"selectOpened.emit($event)\"\n (selectionChange)=\"selectionChange.emit($event)\"\n (labelAdded)=\"labelAdded.emit($event)\">\n</cqa-test-case-details-edit>\n\n<!-- View mode: read-only details -->\n<div *ngIf=\"!isEditing\" class=\"cqa-self-stretch cqa-py-4 cqa-px-0 cqa-flex cqa-flex-col cqa-justify-start cqa-items-start cqa-gap-4 cqa-text-sm cqa-leading-[19.6px]\">\n <div class=\"cqa-self-stretch cqa-flex cqa-flex-col cqa-justify-start cqa-items-start cqa-gap-4 cqa-text-sm cqa-leading-[19.6px]\">\n <!-- Description Section -->\n <div class=\"cqa-self-stretch cqa-flex cqa-flex-col cqa-justify-start cqa-items-start cqa-gap-2.5\">\n <div class=\"cqa-self-stretch cqa-inline-flex cqa-justify-between cqa-items-center\">\n <div class=\"cqa-flex cqa-items-center cqa-gap-2\">\n <div class=\"cqa-w-5 cqa-h-5 cqa-p-1 cqa-flex-shrink-0 cqa-bg-[#3F43EE1A] cqa-rounded-md cqa-inline-flex cqa-justify-center cqa-items-center\">\n <mat-icon class=\"cqa-text-[#1B1FEB] cqa-text-[12px] cqa-w-3 cqa-h-3 cqa-leading-none cqa-block\">description</mat-icon>\n </div>\n <span class=\"cqa-text-[#374151] cqa-text-sm cqa-font-semibold cqa-leading-[19.6px]\">{{ descriptionTitle }}</span>\n </div>\n <button\n *ngIf=\"showEditButton\"\n type=\"button\"\n class=\"cqa-flex cqa-justify-end cqa-items-center cqa-gap-2 cqa-text-[#A3A3A3] cqa-text-xs cqa-font-semibold hover:cqa-text-[#737373] cqa-transition-colors focus:cqa-outline-none focus-visible:cqa-ring-2 focus-visible:cqa-ring-[#3F43EE] focus-visible:cqa-ring-offset-2\"\n (click)=\"onEditClick()\">\n <mat-icon class=\"cqa-text-[14px] cqa-w-4 cqa-h-4\">edit</mat-icon>\n Edit\n </button>\n </div>\n <div *ngIf=\"descriptionContent\" class=\"cqa-self-stretch cqa-flex cqa-flex-col cqa-justify-start cqa-items-start\">\n <div *ngIf=\"enableMarkdown\" class=\"cqa-self-stretch cqa-text-[#111827] cqa-text-sm cqa-leading-[19.6px] cqa-font-normal cqa-prose cqa-prose-sm cqa-max-w-none\" [innerHTML]=\"descriptionContent\"></div>\n <div *ngIf=\"!enableMarkdown\" class=\"cqa-self-stretch cqa-text-[#111827] cqa-text-sm cqa-leading-[19.6px] cqa-font-normal\">{{ descriptionContent }}</div>\n </div>\n </div>\n\n <!-- Metadata Section -->\n <div *ngIf=\"filteredMetadataItems.length\" class=\"cqa-self-stretch cqa-flex cqa-flex-col cqa-justify-start cqa-items-start cqa-gap-2.5\">\n <div class=\"cqa-self-stretch cqa-grid cqa-grid-cols-2 cqa-gap-x-0 cqa-gap-y-4\">\n <ng-container *ngFor=\"let item of filteredMetadataItems; trackBy: trackByMetadataLabel\">\n <div class=\"cqa-flex cqa-flex-col cqa-justify-start cqa-items-start cqa-gap-0.5\">\n <div class=\"cqa-text-[#6B7280] cqa-text-xs cqa-leading-[15px] cqa-font-medium\">{{ item.label }}</div>\n <div\n class=\"cqa-flex cqa-justify-start cqa-items-center cqa-gap-[5px] cqa-min-w-0 cqa-w-full cqa-text-left cqa-text-[#0A0A0A] cqa-border cqa-border-[#F5F5F5]\">\n <mat-icon *ngIf=\"item.icon && (!item.iconLibrary || item.iconLibrary === 'mat')\" class=\"cqa-text-[#6B7280] cqa-text-sm cqa-w-4 cqa-h-4\">\n {{ item.icon }}\n </mat-icon>\n <span *ngIf=\"item.statusColor\" class=\"cqa-w-
|
|
126
|
+
args: [{ selector: 'cqa-test-case-details', changeDetection: ChangeDetectionStrategy.OnPush, template: "<!-- Edit mode: show edit form (Figma design) -->\n<cqa-test-case-details-edit\n *ngIf=\"isEditing\"\n [descriptionTitle]=\"descriptionTitle\"\n [descriptionContent]=\"descriptionContent\"\n [enableMarkdown]=\"enableMarkdown\"\n [metadataItems]=\"metadataItems\"\n [labels]=\"labels\"\n [configTitle]=\"configTitle\"\n [configSections]=\"configSections\"\n [configSectionsRow2]=\"configSectionsRow2\"\n [platform]=\"platform\"\n [isStepGroup]=\"isStepGroup\"\n [selectConfigOverrides]=\"selectConfigOverrides\"\n (save)=\"onSaveChanges($event)\"\n (cancel)=\"onCancelEdit()\"\n (selectSearch)=\"selectSearch.emit($event)\"\n (selectLoadMore)=\"selectLoadMore.emit($event)\"\n (selectOpened)=\"selectOpened.emit($event)\"\n (selectionChange)=\"selectionChange.emit($event)\"\n (labelAdded)=\"labelAdded.emit($event)\">\n</cqa-test-case-details-edit>\n\n<!-- View mode: read-only details -->\n<div *ngIf=\"!isEditing\" class=\"cqa-self-stretch cqa-py-4 cqa-px-0 cqa-flex cqa-flex-col cqa-justify-start cqa-items-start cqa-gap-4 cqa-text-sm cqa-leading-[19.6px]\">\n <div class=\"cqa-self-stretch cqa-flex cqa-flex-col cqa-justify-start cqa-items-start cqa-gap-4 cqa-text-sm cqa-leading-[19.6px]\">\n <!-- Description Section -->\n <div class=\"cqa-self-stretch cqa-flex cqa-flex-col cqa-justify-start cqa-items-start cqa-gap-2.5\">\n <div class=\"cqa-self-stretch cqa-inline-flex cqa-justify-between cqa-items-center\">\n <div class=\"cqa-flex cqa-items-center cqa-gap-2\">\n <div class=\"cqa-w-5 cqa-h-5 cqa-p-1 cqa-flex-shrink-0 cqa-bg-[#3F43EE1A] cqa-rounded-md cqa-inline-flex cqa-justify-center cqa-items-center\">\n <mat-icon class=\"cqa-text-[#1B1FEB] cqa-text-[12px] cqa-w-3 cqa-h-3 cqa-leading-none cqa-block\">description</mat-icon>\n </div>\n <span class=\"cqa-text-[#374151] cqa-text-sm cqa-font-semibold cqa-leading-[19.6px]\">{{ descriptionTitle }}</span>\n </div>\n <button\n *ngIf=\"showEditButton\"\n type=\"button\"\n class=\"cqa-flex cqa-justify-end cqa-items-center cqa-gap-2 cqa-text-[#A3A3A3] cqa-text-xs cqa-font-semibold hover:cqa-text-[#737373] cqa-transition-colors focus:cqa-outline-none focus-visible:cqa-ring-2 focus-visible:cqa-ring-[#3F43EE] focus-visible:cqa-ring-offset-2\"\n (click)=\"onEditClick()\">\n <mat-icon class=\"cqa-text-[14px] cqa-w-4 cqa-h-4\">edit</mat-icon>\n Edit\n </button>\n </div>\n <div *ngIf=\"descriptionContent\" class=\"cqa-self-stretch cqa-flex cqa-flex-col cqa-justify-start cqa-items-start\">\n <div *ngIf=\"enableMarkdown\" class=\"cqa-self-stretch cqa-text-[#111827] cqa-text-sm cqa-leading-[19.6px] cqa-font-normal cqa-prose cqa-prose-sm cqa-max-w-none\" [innerHTML]=\"descriptionContent\"></div>\n <div *ngIf=\"!enableMarkdown\" class=\"cqa-self-stretch cqa-text-[#111827] cqa-text-sm cqa-leading-[19.6px] cqa-font-normal\">{{ descriptionContent }}</div>\n </div>\n </div>\n\n <!-- Metadata Section -->\n <div *ngIf=\"filteredMetadataItems.length\" class=\"cqa-self-stretch cqa-flex cqa-flex-col cqa-justify-start cqa-items-start cqa-gap-2.5\">\n <div class=\"cqa-self-stretch cqa-grid cqa-grid-cols-2 cqa-gap-x-0 cqa-gap-y-4\">\n <ng-container *ngFor=\"let item of filteredMetadataItems; trackBy: trackByMetadataLabel\">\n <div class=\"cqa-flex cqa-flex-col cqa-justify-start cqa-items-start cqa-gap-0.5\">\n <div class=\"cqa-text-[#6B7280] cqa-text-xs cqa-leading-[15px] cqa-font-medium\">{{ item.label }}</div>\n <div\n class=\"cqa-flex cqa-justify-start cqa-items-center cqa-gap-[5px] cqa-min-w-0 cqa-w-full cqa-text-left cqa-text-[#0A0A0A] cqa-border cqa-border-[#F5F5F5]\">\n <mat-icon *ngIf=\"item.icon && (!item.iconLibrary || item.iconLibrary === 'mat')\" class=\"cqa-text-[#6B7280] cqa-text-sm cqa-w-4 cqa-h-4\">\n {{ item.icon }}\n </mat-icon>\n <span *ngIf=\"item.statusColor\" class=\"cqa-w-[10px] cqa-h-[10px] cqa-rounded-full cqa-flex-shrink-0\" [ngClass]=\"getStatusDotClass(item)\"></span>\n <a\n *ngIf=\"item.link\"\n href=\"javascript:void(0)\"\n class=\"cqa-text-[#2563EB] cqa-text-xs cqa-leading-[12px] cqa-font-normal hover:cqa-underline cqa-cursor-pointer cqa-block cqa-truncate cqa-min-w-0\"\n (click)=\"onMetadataLinkClick(item); $event.preventDefault()\">\n {{ item.value }}\n </a>\n <span *ngIf=\"!item.link\" class=\"cqa-text-xs cqa-leading-[12px] cqa-font-normal cqa-align-middle\" [ngClass]=\"getValueTextClass(item)\">\n {{ item.value }}\n </span>\n </div>\n </div>\n </ng-container>\n </div>\n </div>\n\n <!-- Labels (Figma: Labels title, cqa-badge chips with tag icon) -->\n <div *ngIf=\"labels.length\" class=\"cqa-self-stretch cqa-flex cqa-flex-col cqa-justify-start cqa-items-start cqa-gap-2 cqa-text-sm cqa-leading-[19.6px]\">\n <span class=\"cqa-text-[#111827] cqa-text-sm cqa-font-medium cqa-leading-5\">Labels</span>\n <div class=\"cqa-flex cqa-flex-wrap cqa-gap-2\">\n <cqa-badge\n *ngFor=\"let label of labels\"\n [label]=\"label\"\n icon=\"label\"\n variant=\"outline\"\n size=\"small\"\n backgroundColor=\"#ffffff\"\n textColor=\"#475569\"\n borderColor=\"#E2E8F0\"\n iconColor=\"#94A3B8\">\n </cqa-badge>\n </div>\n </div>\n\n <!-- Configuration Section -->\n <div *ngIf=\"configSections.length || configSectionsRow2.length\" class=\"cqa-self-stretch cqa-flex cqa-flex-col cqa-justify-start cqa-items-start cqa-gap-2.5\">\n <div class=\"cqa-self-stretch cqa-inline-flex cqa-justify-start cqa-items-center\">\n <div class=\"cqa-flex cqa-items-center cqa-gap-2\">\n <div class=\"cqa-w-5 cqa-h-5 cqa-p-1 cqa-flex-shrink-0 cqa-bg-[#3F43EE1A] cqa-rounded-md cqa-inline-flex cqa-justify-center cqa-items-center\">\n <mat-icon class=\"cqa-text-[#1B1FEB] cqa-text-[12px] cqa-w-3 cqa-h-3 cqa-leading-none cqa-block\">settings</mat-icon>\n </div>\n <span class=\"cqa-text-[#374151] cqa-text-sm cqa-font-semibold cqa-leading-[19.6px]\">{{ configTitle }}</span>\n </div>\n </div>\n <div class=\"cqa-self-stretch cqa-flex cqa-flex-col cqa-justify-start cqa-items-start cqa-gap-2.5\">\n <div class=\"cqa-self-stretch cqa-grid cqa-grid-cols-1 cqa-gap-2.5\">\n <ng-container *ngFor=\"let section of configSections; trackBy: trackByConfigTitle\">\n <cqa-configuration-card\n [icon]=\"section.icon || 'tune'\"\n [title]=\"section.title\"\n [data]=\"section.items\">\n </cqa-configuration-card>\n </ng-container>\n </div>\n <div *ngIf=\"configSectionsRow2.length\" class=\"cqa-self-stretch cqa-flex cqa-flex-col cqa-gap-4 cqa-text-sm cqa-leading-[19.6px]\">\n <cqa-configuration-card\n *ngFor=\"let section of configSectionsRow2; trackBy: trackByConfigTitle\"\n [icon]=\"section.icon || 'tune'\"\n [title]=\"section.title\"\n [data]=\"section.items\">\n </cqa-configuration-card>\n </div>\n </div>\n </div>\n </div>\n</div>\n", styles: [] }]
|
|
127
127
|
}], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }]; }, propDecorators: { editing: [{
|
|
128
128
|
type: Input
|
|
129
129
|
}], startInEditMode: [{
|
|
@@ -171,4 +171,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImpor
|
|
|
171
171
|
}], labelAdded: [{
|
|
172
172
|
type: Output
|
|
173
173
|
}] } });
|
|
174
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"test-case-details.component.js","sourceRoot":"","sources":["../../../../../src/lib/test-case-details/test-case-details.component.ts","../../../../../src/lib/test-case-details/test-case-details.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  Input,\n  Output,\n  EventEmitter,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  OnInit,\n} from '@angular/core';\nimport {\n  TestCaseDetailsConfigSection,\n  TestCaseDetailsMetadataItem,\n} from './test-case-details.models';\nimport {\n  TestCaseDetailsEditFormData,\n  SelectConfigOverrides,\n} from './test-case-details-edit/test-case-details-edit.component';\n\n@Component({\n  selector: 'cqa-test-case-details',\n  templateUrl: './test-case-details.component.html',\n  styleUrls: [],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class TestCaseDetailsComponent implements OnInit {\n  /** Internal editing state when not controlled by parent */\n  private _editing = false;\n\n  /** When provided by parent, use this instead of internal state (fixes Storybook event flow). */\n  @Input() editing?: boolean;\n\n  /** When true, start in edit mode (useful for Storybook). */\n  @Input() startInEditMode = false;\n\n  /** Resolved editing state: parent-controlled or internal */\n  get isEditing(): boolean {\n    return this.editing !== undefined ? this.editing : this._editing;\n  }\n\n  constructor(private cdr: ChangeDetectorRef) {}\n\n  ngOnInit(): void {\n    if (this.startInEditMode) {\n      this._editing = true;\n    }\n  }\n  /** Description section title */\n  @Input() descriptionTitle = 'Description';\n\n  /** Description text content */\n  @Input() descriptionContent = '';\n\n  /** When true, description supports rich text (HTML). Renders as HTML in view mode. */\n  @Input() enableMarkdown = false;\n\n  /** Whether to show the Edit button in the Description header */\n  @Input() showEditButton = false;\n\n  /** Metadata items (createdOn, status, priority, environment, version, testPlanName, etc.) */\n  @Input() metadataItems: TestCaseDetailsMetadataItem[] = [];\n\n  /** Labels/tags (e.g. Automation, API, SDK, UI/UX) */\n  @Input() labels: string[] = [];\n\n  /** Configuration section title */\n  @Input() configTitle = 'Configuration';\n\n  /** Configuration sections (e.g. Execution, AI Configuration) */\n  @Input() configSections: TestCaseDetailsConfigSection[] = [];\n\n  /** Optional config sections displayed in a 2-column row (e.g. Waits & Retries, Device) */\n  @Input() configSectionsRow2: TestCaseDetailsConfigSection[] = [];\n  /** Platform: 'web' or 'mobile'. Defaults to 'web'. Used for Device Settings fields. */\n  @Input() platform: 'web' | 'mobile' = 'web';\n\n  /** When true, filters out Priority and Type from metadata (step groups don't have these). Defaults to false. */\n  @Input() isStepGroup = false;\n\n  /** Override config per select for API-driven options, server search, load more. */\n  @Input() selectConfigOverrides: SelectConfigOverrides = {};\n\n  /** Labels to filter out from metadata for step groups */\n  private readonly stepGroupExcludedMetadataLabels = ['priority', 'type'];\n\n  /** Filtered metadata items - excludes Priority and Type for step groups */\n  get filteredMetadataItems(): TestCaseDetailsMetadataItem[] {\n    if (!this.isStepGroup) {\n      return this.metadataItems;\n    }\n    return this.metadataItems.filter(\n      (item) => !this.stepGroupExcludedMetadataLabels.includes(item.label?.toLowerCase() ?? '')\n    );\n  }\n\n  @Output() editDescription = new EventEmitter<void>();\n  @Output() cancel = new EventEmitter<void>();\n  @Output() saveChanges = new EventEmitter<TestCaseDetailsEditFormData>();\n  @Output() metadataLinkClick = new EventEmitter<TestCaseDetailsMetadataItem>();\n  @Output() selectSearch = new EventEmitter<{ key: string; query: string }>();\n  @Output() selectLoadMore = new EventEmitter<{ key: string; query: string }>();\n  @Output() selectOpened = new EventEmitter<{ key: string }>();\n  @Output() selectionChange = new EventEmitter<{ key: string; value: unknown }>();\n  @Output() labelAdded = new EventEmitter<string>();\n\n  onEditClick(): void {\n    if (this.editing === undefined) {\n      this._editing = true;\n      this.cdr.detectChanges();\n    }\n    this.editDescription.emit();\n  }\n\n  onSaveChanges(data: TestCaseDetailsEditFormData): void {\n    if (this.editing === undefined) {\n      this._editing = false;\n    }\n    this.cdr.detectChanges();\n    this.saveChanges.emit(data);\n  }\n\n  onCancelEdit(): void {\n    this.cancel.emit();\n    if (this.editing === undefined) {\n      this._editing = false;\n    }\n    this.cdr.detectChanges();\n  }\n\n  trackByConfigTitle(_i: number, section: TestCaseDetailsConfigSection): string {\n    return section.title;\n  }\n\n  trackByMetadataLabel(_i: number, item: TestCaseDetailsMetadataItem): string {\n    return item.label;\n  }\n\n\n  onMetadataLinkClick(item: TestCaseDetailsMetadataItem): void {\n    if (item.link) {\n      this.metadataLinkClick.emit(item);\n    }\n  }\n\n  getStatusDotClass(item: TestCaseDetailsMetadataItem): string {\n    if (!item.statusColor) return '';\n    switch (item.statusColor) {\n      case 'yellow':\n        return 'cqa-bg-[#EAB308]';\n      case 'red':\n        return 'cqa-bg-[#DC2626]';\n      case 'green':\n        return 'cqa-bg-[#16A34A]';\n      case 'gray':\n      default:\n        return 'cqa-bg-[#94A3B8]';\n    }\n  }\n\n  /** Text color for metadata value (e.g. red for critical priority) */\n  getValueTextClass(item: TestCaseDetailsMetadataItem): string {\n    if (item.statusColor === 'red') {\n      return 'cqa-text-[#DC2626]';\n    }\n    return 'cqa-text-[#111827]';\n  }\n}\n","<!-- Edit mode: show edit form (Figma design) -->\n<cqa-test-case-details-edit\n  *ngIf=\"isEditing\"\n  [descriptionTitle]=\"descriptionTitle\"\n  [descriptionContent]=\"descriptionContent\"\n  [enableMarkdown]=\"enableMarkdown\"\n  [metadataItems]=\"metadataItems\"\n  [labels]=\"labels\"\n  [configTitle]=\"configTitle\"\n  [configSections]=\"configSections\"\n  [configSectionsRow2]=\"configSectionsRow2\"\n  [platform]=\"platform\"\n  [isStepGroup]=\"isStepGroup\"\n  [selectConfigOverrides]=\"selectConfigOverrides\"\n  (save)=\"onSaveChanges($event)\"\n  (cancel)=\"onCancelEdit()\"\n  (selectSearch)=\"selectSearch.emit($event)\"\n  (selectLoadMore)=\"selectLoadMore.emit($event)\"\n  (selectOpened)=\"selectOpened.emit($event)\"\n  (selectionChange)=\"selectionChange.emit($event)\"\n  (labelAdded)=\"labelAdded.emit($event)\">\n</cqa-test-case-details-edit>\n\n<!-- View mode: read-only details -->\n<div *ngIf=\"!isEditing\" class=\"cqa-self-stretch cqa-py-4 cqa-px-0 cqa-flex cqa-flex-col cqa-justify-start cqa-items-start cqa-gap-4 cqa-text-sm cqa-leading-[19.6px]\">\n  <div class=\"cqa-self-stretch cqa-flex cqa-flex-col cqa-justify-start cqa-items-start cqa-gap-4 cqa-text-sm cqa-leading-[19.6px]\">\n    <!-- Description Section -->\n    <div class=\"cqa-self-stretch cqa-flex cqa-flex-col cqa-justify-start cqa-items-start cqa-gap-2.5\">\n      <div class=\"cqa-self-stretch cqa-inline-flex cqa-justify-between cqa-items-center\">\n        <div class=\"cqa-flex cqa-items-center cqa-gap-2\">\n          <div class=\"cqa-w-5 cqa-h-5 cqa-p-1 cqa-flex-shrink-0 cqa-bg-[#3F43EE1A] cqa-rounded-md cqa-inline-flex cqa-justify-center cqa-items-center\">\n            <mat-icon class=\"cqa-text-[#1B1FEB] cqa-text-[12px] cqa-w-3 cqa-h-3 cqa-leading-none cqa-block\">description</mat-icon>\n          </div>\n          <span class=\"cqa-text-[#374151] cqa-text-sm cqa-font-semibold cqa-leading-[19.6px]\">{{ descriptionTitle }}</span>\n        </div>\n        <button\n          *ngIf=\"showEditButton\"\n          type=\"button\"\n          class=\"cqa-flex cqa-justify-end cqa-items-center cqa-gap-2 cqa-text-[#A3A3A3] cqa-text-xs cqa-font-semibold hover:cqa-text-[#737373] cqa-transition-colors focus:cqa-outline-none focus-visible:cqa-ring-2 focus-visible:cqa-ring-[#3F43EE] focus-visible:cqa-ring-offset-2\"\n          (click)=\"onEditClick()\">\n          <mat-icon class=\"cqa-text-[14px] cqa-w-4 cqa-h-4\">edit</mat-icon>\n          Edit\n        </button>\n      </div>\n      <div *ngIf=\"descriptionContent\" class=\"cqa-self-stretch cqa-flex cqa-flex-col cqa-justify-start cqa-items-start\">\n        <div *ngIf=\"enableMarkdown\" class=\"cqa-self-stretch cqa-text-[#111827] cqa-text-sm cqa-leading-[19.6px] cqa-font-normal cqa-prose cqa-prose-sm cqa-max-w-none\" [innerHTML]=\"descriptionContent\"></div>\n        <div *ngIf=\"!enableMarkdown\" class=\"cqa-self-stretch cqa-text-[#111827] cqa-text-sm cqa-leading-[19.6px] cqa-font-normal\">{{ descriptionContent }}</div>\n      </div>\n    </div>\n\n    <!-- Metadata Section -->\n    <div *ngIf=\"filteredMetadataItems.length\" class=\"cqa-self-stretch cqa-flex cqa-flex-col cqa-justify-start cqa-items-start cqa-gap-2.5\">\n      <div class=\"cqa-self-stretch cqa-grid cqa-grid-cols-2 cqa-gap-x-0 cqa-gap-y-4\">\n        <ng-container *ngFor=\"let item of filteredMetadataItems; trackBy: trackByMetadataLabel\">\n          <div class=\"cqa-flex cqa-flex-col cqa-justify-start cqa-items-start cqa-gap-0.5\">\n            <div class=\"cqa-text-[#6B7280] cqa-text-xs cqa-leading-[15px] cqa-font-medium\">{{ item.label }}</div>\n            <div\n              class=\"cqa-flex cqa-justify-start cqa-items-center cqa-gap-[5px] cqa-min-w-0 cqa-w-full cqa-text-left cqa-text-[#0A0A0A] cqa-border cqa-border-[#F5F5F5]\">\n              <mat-icon *ngIf=\"item.icon && (!item.iconLibrary || item.iconLibrary === 'mat')\" class=\"cqa-text-[#6B7280] cqa-text-sm cqa-w-4 cqa-h-4\">\n                {{ item.icon }}\n              </mat-icon>\n              <span *ngIf=\"item.statusColor\" class=\"cqa-w-3.5 cqa-h-3.5 cqa-rounded-full cqa-flex-shrink-0\" [ngClass]=\"getStatusDotClass(item)\"></span>\n              <a\n                *ngIf=\"item.link\"\n                href=\"javascript:void(0)\"\n                class=\"cqa-text-[#2563EB] cqa-text-xs cqa-leading-[12px] cqa-font-normal hover:cqa-underline cqa-cursor-pointer cqa-block cqa-truncate cqa-min-w-0\"\n                (click)=\"onMetadataLinkClick(item); $event.preventDefault()\">\n                {{ item.value }}\n              </a>\n              <span *ngIf=\"!item.link\" class=\"cqa-text-xs cqa-leading-[12px] cqa-font-normal cqa-align-middle\" [ngClass]=\"getValueTextClass(item)\">\n                {{ item.value }}\n              </span>\n            </div>\n          </div>\n        </ng-container>\n      </div>\n    </div>\n\n    <!-- Labels (Figma: Labels title, cqa-badge chips with tag icon) -->\n    <div *ngIf=\"labels.length\" class=\"cqa-self-stretch cqa-flex cqa-flex-col cqa-justify-start cqa-items-start cqa-gap-2 cqa-text-sm cqa-leading-[19.6px]\">\n      <span class=\"cqa-text-[#111827] cqa-text-sm cqa-font-medium cqa-leading-5\">Labels</span>\n      <div class=\"cqa-flex cqa-flex-wrap cqa-gap-2\">\n        <cqa-badge\n          *ngFor=\"let label of labels\"\n          [label]=\"label\"\n          icon=\"label\"\n          variant=\"outline\"\n          size=\"small\"\n          backgroundColor=\"#ffffff\"\n          textColor=\"#475569\"\n          borderColor=\"#E2E8F0\"\n          iconColor=\"#94A3B8\">\n        </cqa-badge>\n      </div>\n    </div>\n\n    <!-- Configuration Section -->\n    <div *ngIf=\"configSections.length || configSectionsRow2.length\" class=\"cqa-self-stretch cqa-flex cqa-flex-col cqa-justify-start cqa-items-start cqa-gap-2.5\">\n      <div class=\"cqa-self-stretch cqa-inline-flex cqa-justify-start cqa-items-center\">\n        <div class=\"cqa-flex cqa-items-center cqa-gap-2\">\n          <div class=\"cqa-w-5 cqa-h-5 cqa-p-1 cqa-flex-shrink-0 cqa-bg-[#3F43EE1A] cqa-rounded-md cqa-inline-flex cqa-justify-center cqa-items-center\">\n            <mat-icon class=\"cqa-text-[#1B1FEB] cqa-text-[12px] cqa-w-3 cqa-h-3 cqa-leading-none cqa-block\">settings</mat-icon>\n          </div>\n          <span class=\"cqa-text-[#374151] cqa-text-sm cqa-font-semibold cqa-leading-[19.6px]\">{{ configTitle }}</span>\n        </div>\n      </div>\n      <div class=\"cqa-self-stretch cqa-flex cqa-flex-col cqa-justify-start cqa-items-start cqa-gap-2.5\">\n        <div class=\"cqa-self-stretch cqa-grid cqa-grid-cols-1 cqa-gap-2.5\">\n          <ng-container *ngFor=\"let section of configSections; trackBy: trackByConfigTitle\">\n            <cqa-configuration-card\n              [icon]=\"section.icon || 'tune'\"\n              [title]=\"section.title\"\n              [data]=\"section.items\">\n            </cqa-configuration-card>\n          </ng-container>\n        </div>\n        <div *ngIf=\"configSectionsRow2.length\" class=\"cqa-self-stretch cqa-flex cqa-flex-col cqa-gap-4 cqa-text-sm cqa-leading-[19.6px]\">\n          <cqa-configuration-card\n            *ngFor=\"let section of configSectionsRow2; trackBy: trackByConfigTitle\"\n            [icon]=\"section.icon || 'tune'\"\n            [title]=\"section.title\"\n            [data]=\"section.items\">\n          </cqa-configuration-card>\n        </div>\n      </div>\n    </div>\n  </div>\n</div>\n"]}
|
|
174
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"test-case-details.component.js","sourceRoot":"","sources":["../../../../../src/lib/test-case-details/test-case-details.component.ts","../../../../../src/lib/test-case-details/test-case-details.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  Input,\n  Output,\n  EventEmitter,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  OnInit,\n} from '@angular/core';\nimport {\n  TestCaseDetailsConfigSection,\n  TestCaseDetailsMetadataItem,\n} from './test-case-details.models';\nimport {\n  TestCaseDetailsEditFormData,\n  SelectConfigOverrides,\n} from './test-case-details-edit/test-case-details-edit.component';\n\n@Component({\n  selector: 'cqa-test-case-details',\n  templateUrl: './test-case-details.component.html',\n  styleUrls: [],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class TestCaseDetailsComponent implements OnInit {\n  /** Internal editing state when not controlled by parent */\n  private _editing = false;\n\n  /** When provided by parent, use this instead of internal state (fixes Storybook event flow). */\n  @Input() editing?: boolean;\n\n  /** When true, start in edit mode (useful for Storybook). */\n  @Input() startInEditMode = false;\n\n  /** Resolved editing state: parent-controlled or internal */\n  get isEditing(): boolean {\n    return this.editing !== undefined ? this.editing : this._editing;\n  }\n\n  constructor(private cdr: ChangeDetectorRef) {}\n\n  ngOnInit(): void {\n    if (this.startInEditMode) {\n      this._editing = true;\n    }\n  }\n  /** Description section title */\n  @Input() descriptionTitle = 'Description';\n\n  /** Description text content */\n  @Input() descriptionContent = '';\n\n  /** When true, description supports rich text (HTML). Renders as HTML in view mode. */\n  @Input() enableMarkdown = false;\n\n  /** Whether to show the Edit button in the Description header */\n  @Input() showEditButton = false;\n\n  /** Metadata items (createdOn, status, priority, environment, version, testPlanName, etc.) */\n  @Input() metadataItems: TestCaseDetailsMetadataItem[] = [];\n\n  /** Labels/tags (e.g. Automation, API, SDK, UI/UX) */\n  @Input() labels: string[] = [];\n\n  /** Configuration section title */\n  @Input() configTitle = 'Configuration';\n\n  /** Configuration sections (e.g. Execution, AI Configuration) */\n  @Input() configSections: TestCaseDetailsConfigSection[] = [];\n\n  /** Optional config sections displayed in a 2-column row (e.g. Waits & Retries, Device) */\n  @Input() configSectionsRow2: TestCaseDetailsConfigSection[] = [];\n  /** Platform: 'web' or 'mobile'. Defaults to 'web'. Used for Device Settings fields. */\n  @Input() platform: 'web' | 'mobile' = 'web';\n\n  /** When true, filters out Priority and Type from metadata (step groups don't have these). Defaults to false. */\n  @Input() isStepGroup = false;\n\n  /** Override config per select for API-driven options, server search, load more. */\n  @Input() selectConfigOverrides: SelectConfigOverrides = {};\n\n  /** Labels to filter out from metadata for step groups */\n  private readonly stepGroupExcludedMetadataLabels = ['priority', 'type'];\n\n  /** Filtered metadata items - excludes Priority and Type for step groups */\n  get filteredMetadataItems(): TestCaseDetailsMetadataItem[] {\n    if (!this.isStepGroup) {\n      return this.metadataItems;\n    }\n    return this.metadataItems.filter(\n      (item) => !this.stepGroupExcludedMetadataLabels.includes(item.label?.toLowerCase() ?? '')\n    );\n  }\n\n  @Output() editDescription = new EventEmitter<void>();\n  @Output() cancel = new EventEmitter<void>();\n  @Output() saveChanges = new EventEmitter<TestCaseDetailsEditFormData>();\n  @Output() metadataLinkClick = new EventEmitter<TestCaseDetailsMetadataItem>();\n  @Output() selectSearch = new EventEmitter<{ key: string; query: string }>();\n  @Output() selectLoadMore = new EventEmitter<{ key: string; query: string }>();\n  @Output() selectOpened = new EventEmitter<{ key: string }>();\n  @Output() selectionChange = new EventEmitter<{ key: string; value: unknown }>();\n  @Output() labelAdded = new EventEmitter<string>();\n\n  onEditClick(): void {\n    if (this.editing === undefined) {\n      this._editing = true;\n      this.cdr.detectChanges();\n    }\n    this.editDescription.emit();\n  }\n\n  onSaveChanges(data: TestCaseDetailsEditFormData): void {\n    if (this.editing === undefined) {\n      this._editing = false;\n    }\n    this.cdr.detectChanges();\n    this.saveChanges.emit(data);\n  }\n\n  onCancelEdit(): void {\n    this.cancel.emit();\n    if (this.editing === undefined) {\n      this._editing = false;\n    }\n    this.cdr.detectChanges();\n  }\n\n  trackByConfigTitle(_i: number, section: TestCaseDetailsConfigSection): string {\n    return section.title;\n  }\n\n  trackByMetadataLabel(_i: number, item: TestCaseDetailsMetadataItem): string {\n    return item.label;\n  }\n\n\n  onMetadataLinkClick(item: TestCaseDetailsMetadataItem): void {\n    if (item.link) {\n      this.metadataLinkClick.emit(item);\n    }\n  }\n\n  getStatusDotClass(item: TestCaseDetailsMetadataItem): string {\n    if (!item.statusColor) return '';\n    switch (item.statusColor) {\n      case 'yellow':\n        return 'cqa-bg-[#EAB308]';\n      case 'red':\n        return 'cqa-bg-[#DC2626]';\n      case 'green':\n        return 'cqa-bg-[#16A34A]';\n      case 'gray':\n      default:\n        return 'cqa-bg-[#94A3B8]';\n    }\n  }\n\n  /** Text color for metadata value (e.g. red for critical priority) */\n  getValueTextClass(item: TestCaseDetailsMetadataItem): string {\n    if (item.statusColor === 'red') {\n      return 'cqa-text-[#DC2626]';\n    }\n    return 'cqa-text-[#111827]';\n  }\n}\n","<!-- Edit mode: show edit form (Figma design) -->\n<cqa-test-case-details-edit\n  *ngIf=\"isEditing\"\n  [descriptionTitle]=\"descriptionTitle\"\n  [descriptionContent]=\"descriptionContent\"\n  [enableMarkdown]=\"enableMarkdown\"\n  [metadataItems]=\"metadataItems\"\n  [labels]=\"labels\"\n  [configTitle]=\"configTitle\"\n  [configSections]=\"configSections\"\n  [configSectionsRow2]=\"configSectionsRow2\"\n  [platform]=\"platform\"\n  [isStepGroup]=\"isStepGroup\"\n  [selectConfigOverrides]=\"selectConfigOverrides\"\n  (save)=\"onSaveChanges($event)\"\n  (cancel)=\"onCancelEdit()\"\n  (selectSearch)=\"selectSearch.emit($event)\"\n  (selectLoadMore)=\"selectLoadMore.emit($event)\"\n  (selectOpened)=\"selectOpened.emit($event)\"\n  (selectionChange)=\"selectionChange.emit($event)\"\n  (labelAdded)=\"labelAdded.emit($event)\">\n</cqa-test-case-details-edit>\n\n<!-- View mode: read-only details -->\n<div *ngIf=\"!isEditing\" class=\"cqa-self-stretch cqa-py-4 cqa-px-0 cqa-flex cqa-flex-col cqa-justify-start cqa-items-start cqa-gap-4 cqa-text-sm cqa-leading-[19.6px]\">\n  <div class=\"cqa-self-stretch cqa-flex cqa-flex-col cqa-justify-start cqa-items-start cqa-gap-4 cqa-text-sm cqa-leading-[19.6px]\">\n    <!-- Description Section -->\n    <div class=\"cqa-self-stretch cqa-flex cqa-flex-col cqa-justify-start cqa-items-start cqa-gap-2.5\">\n      <div class=\"cqa-self-stretch cqa-inline-flex cqa-justify-between cqa-items-center\">\n        <div class=\"cqa-flex cqa-items-center cqa-gap-2\">\n          <div class=\"cqa-w-5 cqa-h-5 cqa-p-1 cqa-flex-shrink-0 cqa-bg-[#3F43EE1A] cqa-rounded-md cqa-inline-flex cqa-justify-center cqa-items-center\">\n            <mat-icon class=\"cqa-text-[#1B1FEB] cqa-text-[12px] cqa-w-3 cqa-h-3 cqa-leading-none cqa-block\">description</mat-icon>\n          </div>\n          <span class=\"cqa-text-[#374151] cqa-text-sm cqa-font-semibold cqa-leading-[19.6px]\">{{ descriptionTitle }}</span>\n        </div>\n        <button\n          *ngIf=\"showEditButton\"\n          type=\"button\"\n          class=\"cqa-flex cqa-justify-end cqa-items-center cqa-gap-2 cqa-text-[#A3A3A3] cqa-text-xs cqa-font-semibold hover:cqa-text-[#737373] cqa-transition-colors focus:cqa-outline-none focus-visible:cqa-ring-2 focus-visible:cqa-ring-[#3F43EE] focus-visible:cqa-ring-offset-2\"\n          (click)=\"onEditClick()\">\n          <mat-icon class=\"cqa-text-[14px] cqa-w-4 cqa-h-4\">edit</mat-icon>\n          Edit\n        </button>\n      </div>\n      <div *ngIf=\"descriptionContent\" class=\"cqa-self-stretch cqa-flex cqa-flex-col cqa-justify-start cqa-items-start\">\n        <div *ngIf=\"enableMarkdown\" class=\"cqa-self-stretch cqa-text-[#111827] cqa-text-sm cqa-leading-[19.6px] cqa-font-normal cqa-prose cqa-prose-sm cqa-max-w-none\" [innerHTML]=\"descriptionContent\"></div>\n        <div *ngIf=\"!enableMarkdown\" class=\"cqa-self-stretch cqa-text-[#111827] cqa-text-sm cqa-leading-[19.6px] cqa-font-normal\">{{ descriptionContent }}</div>\n      </div>\n    </div>\n\n    <!-- Metadata Section -->\n    <div *ngIf=\"filteredMetadataItems.length\" class=\"cqa-self-stretch cqa-flex cqa-flex-col cqa-justify-start cqa-items-start cqa-gap-2.5\">\n      <div class=\"cqa-self-stretch cqa-grid cqa-grid-cols-2 cqa-gap-x-0 cqa-gap-y-4\">\n        <ng-container *ngFor=\"let item of filteredMetadataItems; trackBy: trackByMetadataLabel\">\n          <div class=\"cqa-flex cqa-flex-col cqa-justify-start cqa-items-start cqa-gap-0.5\">\n            <div class=\"cqa-text-[#6B7280] cqa-text-xs cqa-leading-[15px] cqa-font-medium\">{{ item.label }}</div>\n            <div\n              class=\"cqa-flex cqa-justify-start cqa-items-center cqa-gap-[5px] cqa-min-w-0 cqa-w-full cqa-text-left cqa-text-[#0A0A0A] cqa-border cqa-border-[#F5F5F5]\">\n              <mat-icon *ngIf=\"item.icon && (!item.iconLibrary || item.iconLibrary === 'mat')\" class=\"cqa-text-[#6B7280] cqa-text-sm cqa-w-4 cqa-h-4\">\n                {{ item.icon }}\n              </mat-icon>\n              <span *ngIf=\"item.statusColor\" class=\"cqa-w-[10px] cqa-h-[10px] cqa-rounded-full cqa-flex-shrink-0\" [ngClass]=\"getStatusDotClass(item)\"></span>\n              <a\n                *ngIf=\"item.link\"\n                href=\"javascript:void(0)\"\n                class=\"cqa-text-[#2563EB] cqa-text-xs cqa-leading-[12px] cqa-font-normal hover:cqa-underline cqa-cursor-pointer cqa-block cqa-truncate cqa-min-w-0\"\n                (click)=\"onMetadataLinkClick(item); $event.preventDefault()\">\n                {{ item.value }}\n              </a>\n              <span *ngIf=\"!item.link\" class=\"cqa-text-xs cqa-leading-[12px] cqa-font-normal cqa-align-middle\" [ngClass]=\"getValueTextClass(item)\">\n                {{ item.value }}\n              </span>\n            </div>\n          </div>\n        </ng-container>\n      </div>\n    </div>\n\n    <!-- Labels (Figma: Labels title, cqa-badge chips with tag icon) -->\n    <div *ngIf=\"labels.length\" class=\"cqa-self-stretch cqa-flex cqa-flex-col cqa-justify-start cqa-items-start cqa-gap-2 cqa-text-sm cqa-leading-[19.6px]\">\n      <span class=\"cqa-text-[#111827] cqa-text-sm cqa-font-medium cqa-leading-5\">Labels</span>\n      <div class=\"cqa-flex cqa-flex-wrap cqa-gap-2\">\n        <cqa-badge\n          *ngFor=\"let label of labels\"\n          [label]=\"label\"\n          icon=\"label\"\n          variant=\"outline\"\n          size=\"small\"\n          backgroundColor=\"#ffffff\"\n          textColor=\"#475569\"\n          borderColor=\"#E2E8F0\"\n          iconColor=\"#94A3B8\">\n        </cqa-badge>\n      </div>\n    </div>\n\n    <!-- Configuration Section -->\n    <div *ngIf=\"configSections.length || configSectionsRow2.length\" class=\"cqa-self-stretch cqa-flex cqa-flex-col cqa-justify-start cqa-items-start cqa-gap-2.5\">\n      <div class=\"cqa-self-stretch cqa-inline-flex cqa-justify-start cqa-items-center\">\n        <div class=\"cqa-flex cqa-items-center cqa-gap-2\">\n          <div class=\"cqa-w-5 cqa-h-5 cqa-p-1 cqa-flex-shrink-0 cqa-bg-[#3F43EE1A] cqa-rounded-md cqa-inline-flex cqa-justify-center cqa-items-center\">\n            <mat-icon class=\"cqa-text-[#1B1FEB] cqa-text-[12px] cqa-w-3 cqa-h-3 cqa-leading-none cqa-block\">settings</mat-icon>\n          </div>\n          <span class=\"cqa-text-[#374151] cqa-text-sm cqa-font-semibold cqa-leading-[19.6px]\">{{ configTitle }}</span>\n        </div>\n      </div>\n      <div class=\"cqa-self-stretch cqa-flex cqa-flex-col cqa-justify-start cqa-items-start cqa-gap-2.5\">\n        <div class=\"cqa-self-stretch cqa-grid cqa-grid-cols-1 cqa-gap-2.5\">\n          <ng-container *ngFor=\"let section of configSections; trackBy: trackByConfigTitle\">\n            <cqa-configuration-card\n              [icon]=\"section.icon || 'tune'\"\n              [title]=\"section.title\"\n              [data]=\"section.items\">\n            </cqa-configuration-card>\n          </ng-container>\n        </div>\n        <div *ngIf=\"configSectionsRow2.length\" class=\"cqa-self-stretch cqa-flex cqa-flex-col cqa-gap-4 cqa-text-sm cqa-leading-[19.6px]\">\n          <cqa-configuration-card\n            *ngFor=\"let section of configSectionsRow2; trackBy: trackByConfigTitle\"\n            [icon]=\"section.icon || 'tune'\"\n            [title]=\"section.title\"\n            [data]=\"section.items\">\n          </cqa-configuration-card>\n        </div>\n      </div>\n    </div>\n  </div>\n</div>\n"]}
|