@cqa-lib/cqa-ui 1.1.268 → 1.1.269
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/autocomplete/autocomplete.component.mjs +3 -3
- package/esm2020/lib/test-case-details/ai-agent-step/ai-agent-step.component.mjs +3 -3
- package/esm2020/lib/test-case-details/ai-verify-step/ai-verify-step.component.mjs +3 -3
- package/esm2020/lib/test-case-details/api-step/api-step.component.mjs +3 -3
- package/esm2020/lib/test-case-details/condition-step/condition-step.component.mjs +29 -3
- package/esm2020/lib/test-case-details/custom-code-step/custom-code-step.component.mjs +3 -3
- package/esm2020/lib/test-case-details/database-step/database-step.component.mjs +3 -3
- package/esm2020/lib/test-case-details/delete-steps/delete-steps.component.mjs +8 -3
- package/esm2020/lib/test-case-details/loop-step/loop-step.component.mjs +34 -3
- package/esm2020/lib/test-case-details/normal-step/normal-step.component.mjs +3 -3
- package/esm2020/lib/test-case-details/restore-session-step/restore-session-step.component.mjs +3 -3
- package/esm2020/lib/test-case-details/screenshot-step/screenshot-step.component.mjs +3 -3
- package/esm2020/lib/test-case-details/scroll-step/scroll-step.component.mjs +3 -3
- package/esm2020/lib/test-case-details/step-group/step-group.component.mjs +61 -15
- package/esm2020/lib/test-case-details/upload-step/upload-step.component.mjs +3 -3
- package/esm2020/lib/test-case-details/verify-url-step/verify-url-step.component.mjs +3 -3
- package/fesm2015/cqa-lib-cqa-ui.mjs +158 -44
- package/fesm2015/cqa-lib-cqa-ui.mjs.map +1 -1
- package/fesm2020/cqa-lib-cqa-ui.mjs +152 -44
- package/fesm2020/cqa-lib-cqa-ui.mjs.map +1 -1
- package/lib/test-case-details/condition-step/condition-step.component.d.ts +4 -0
- package/lib/test-case-details/delete-steps/delete-steps.component.d.ts +5 -1
- package/lib/test-case-details/loop-step/loop-step.component.d.ts +6 -0
- package/lib/test-case-details/step-group/step-group.component.d.ts +15 -1
- package/package.json +1 -1
- package/styles.css +1 -1
|
@@ -18,13 +18,15 @@ export class DeleteStepsComponent {
|
|
|
18
18
|
this.contextLabel = '';
|
|
19
19
|
/** Optional step images/screenshots map: stepId -> imageUrl */
|
|
20
20
|
this.stepImages = new Map();
|
|
21
|
+
/** Pre-computed display labels from host (e.g. ts-portal-ui), same order as stepsToDelete. */
|
|
22
|
+
this.stepLabels = [];
|
|
21
23
|
this.confirmDelete = new EventEmitter();
|
|
22
24
|
this.cancelled = new EventEmitter();
|
|
23
|
-
// Initialize from dialog data if provided
|
|
24
25
|
if (data) {
|
|
25
26
|
this.stepsToDelete = data.stepsToDelete || [];
|
|
26
27
|
this.contextLabel = data.contextLabel || '';
|
|
27
28
|
this.stepImages = data.stepImages || new Map();
|
|
29
|
+
this.stepLabels = data.stepLabels || [];
|
|
28
30
|
}
|
|
29
31
|
}
|
|
30
32
|
get stepsCount() {
|
|
@@ -37,8 +39,11 @@ export class DeleteStepsComponent {
|
|
|
37
39
|
get selectedStepsSubtitle() {
|
|
38
40
|
return `Selected (${this.stepsCount}) steps for deletion, are you sure you want to delete these steps?`;
|
|
39
41
|
}
|
|
40
|
-
/** Display label
|
|
42
|
+
/** Display label: use stepLabels from host when provided, else compute from step. */
|
|
41
43
|
getStepDisplayLabel(step, index) {
|
|
44
|
+
if (this.stepLabels?.length > index && this.stepLabels[index] != null && this.stepLabels[index] !== '') {
|
|
45
|
+
return this.stepLabels[index];
|
|
46
|
+
}
|
|
42
47
|
if (isNormalStepConfig(step)) {
|
|
43
48
|
return this.getNormalStepLabel(step);
|
|
44
49
|
}
|
|
@@ -129,4 +134,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImpor
|
|
|
129
134
|
}], cancelled: [{
|
|
130
135
|
type: Output
|
|
131
136
|
}] } });
|
|
132
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"delete-steps.component.js","sourceRoot":"","sources":["../../../../../../src/lib/test-case-details/delete-steps/delete-steps.component.ts","../../../../../../src/lib/test-case-details/delete-steps/delete-steps.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,YAAY,EAAS,MAAM,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,eAAe,CAAC;AACzF,OAAO,EAAE,eAAe,EAAE,MAAM,0BAA0B,CAAC;AAC3D,OAAO,EAIL,kBAAkB,GACnB,MAAM,0BAA0B,CAAC;;;;AAElC;;;;GAIG;AAMH,MAAM,OAAO,oBAAoB;IAU/B,YAAwD,IAIvD;QAJuD,SAAI,GAAJ,IAAI,CAI3D;QAbD,sDAAsD;QACtD,kBAAa,GAAyB,EAAE,CAAC;QAEzC,6EAA6E;QAC7E,iBAAY,GAAG,EAAE,CAAC;QAElB,+DAA+D;QAC/D,eAAU,GAAiC,IAAI,GAAG,EAAE,CAAC;QAe3C,kBAAa,GAAG,IAAI,YAAY,EAAQ,CAAC;QACzC,cAAS,GAAG,IAAI,YAAY,EAAQ,CAAC;QAT7C,0CAA0C;QAC1C,IAAI,IAAI,EAAE;YACR,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,aAAa,IAAI,EAAE,CAAC;YAC9C,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,YAAY,IAAI,EAAE,CAAC;YAC5C,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,UAAU,IAAI,IAAI,GAAG,EAAE,CAAC;SAChD;IACH,CAAC;IAKD,IAAI,UAAU;QACZ,OAAO,IAAI,CAAC,aAAa,EAAE,MAAM,IAAI,CAAC,CAAC;IACzC,CAAC;IAED,IAAI,SAAS;QACX,MAAM,CAAC,GAAG,IAAI,CAAC,UAAU,CAAC;QAC1B,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,gBAAgB,CAAC,CAAC,CAAC,UAAU,CAAC,SAAS,CAAC;IAC3D,CAAC;IAED,IAAI,qBAAqB;QACvB,OAAO,aAAa,IAAI,CAAC,UAAU,oEAAoE,CAAC;IAC1G,CAAC;IAED,gFAAgF;IAChF,mBAAmB,CAAC,IAAwB,EAAE,KAAa;QACzD,IAAI,kBAAkB,CAAC,IAAI,CAAC,EAAE;YAC5B,OAAO,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,CAAC;SACtC;QACD,IAAI,WAAW,IAAI,IAAI,IAAI,IAAI,CAAC,SAAS,EAAE;YACzC,OAAO,IAAI,CAAC,SAAS,CAAC;SACvB;QACD,IAAI,WAAW,IAAI,IAAI,IAAI,IAAI,CAAC,SAAS,EAAE;YACzC,OAAO,IAAI,CAAC,SAAS,CAAC;SACvB;QACD,IAAI,UAAU,IAAI,IAAI,EAAE;YACtB,MAAM,IAAI,GAAG,IAA0E,CAAC;YACxF,IAAI,IAAI,CAAC,QAAQ,KAAK,KAAK,IAAI,IAAI,CAAC,eAAe,EAAE;gBACnD,OAAO,aAAa,IAAI,CAAC,eAAe,EAAE,CAAC;aAC5C;YACD,IAAI,IAAI,CAAC,QAAQ,KAAK,OAAO,IAAI,IAAI,CAAC,SAAS,EAAE;gBAC/C,OAAO,UAAU,IAAI,CAAC,SAAS,EAAE,CAAC;aACnC;SACF;QACD,IAAI,IAAI,CAAC,WAAW,EAAE;YACpB,OAAO,IAAI,CAAC,WAAW,CAAC;SACzB;QACD,OAAO,QAAQ,KAAK,GAAG,CAAC,EAAE,CAAC;IAC7B,CAAC;IAEO,kBAAkB,CAAC,IAAsB;QAC/C,MAAM,MAAM,GAAG,IAAI,CAAC,UAAU,IAAI,EAAE,CAAC;QACrC,MAAM,QAAQ,GAAG,CAAC,IAAY,EAAE,EAAE,CAChC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,EAAE,WAAW,EAAE,KAAK,IAAI,CAAC,WAAW,EAAE,CAAC,CAAC;QACnE,MAAM,GAAG,GAAG,CAAC,CAAwD,EAAE,EAAE,CACvE,CAAC,EAAE,YAAY,IAAI,CAAC,EAAE,KAAK,IAAI,EAAE,CAAC;QAEpC,QAAQ,IAAI,CAAC,SAA8B,EAAE;YAC3C,KAAK,UAAU,CAAC,CAAC;gBACf,MAAM,GAAG,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAC;gBAC5B,OAAO,GAAG,CAAC,CAAC,CAAC,eAAe,GAAG,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,aAAa,CAAC;aACxD;YACD,KAAK,UAAU,CAAC,CAAC;gBACf,MAAM,YAAY,GAAG,QAAQ,CAAC,cAAc,CAAC,IAAI,QAAQ,CAAC,aAAa,CAAC,CAAC;gBACzE,OAAO,GAAG,CAAC,YAAY,CAAC,IAAI,eAAe,CAAC;aAC7C;YACD,KAAK,MAAM;gBACT,OAAO,GAAG,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC,IAAI,MAAM,CAAC;YACzC,KAAK,OAAO;gBACV,OAAO,GAAG,CAAC,QAAQ,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS,GAAG,CAAC,QAAQ,CAAC,UAAU,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC;YACpF,KAAK,QAAQ;gBACX,OAAO,GAAG,CAAC,QAAQ,CAAC,aAAa,CAAC,CAAC,IAAI,QAAQ,CAAC;YAClD,KAAK,QAAQ,CAAC,CAAC;gBACb,MAAM,IAAI,GAAG,QAAQ,CAAC,aAAa,CAAC,IAAI,QAAQ,CAAC,QAAQ,CAAC,CAAC;gBAC3D,OAAO,GAAG,CAAC,IAAI,CAAC,IAAI,aAAa,CAAC;aACnC;YACD;gBACE,OAAO,GAAG,CAAC,QAAQ,CAAC,aAAa,CAAC,CAAC,IAAI,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,IAAI,MAAM,CAAC;SACnE;IACH,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,CAAC;IACxB,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,aAAa,CAAC,IAAI,EAAE,CAAC;IAC5B,CAAC;IAED,sCAAsC;IACtC,YAAY,CAAC,IAAwB;QACnC,IAAI,CAAC,IAAI,EAAE,EAAE;YAAE,OAAO,IAAI,CAAC;QAC3B,OAAO,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,IAAI,CAAC;IAC9C,CAAC;IAED,iCAAiC;IACjC,YAAY,CAAC,IAAwB;QACnC,OAAO,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,KAAK,IAAI,CAAC;IAC1C,CAAC;IAED,gEAAgE;IAChE,aAAa,CAAC,IAAwB,EAAE,KAAa;QACnD,MAAM,OAAO,GAAI,IAAY,EAAE,UAAU,CAAC;QAC1C,IAAI,OAAO,IAAI,IAAI,IAAI,OAAO,KAAK,EAAE,EAAE;YACrC,OAAO,OAAO,CAAC;SAChB;QACD,OAAO,KAAK,GAAG,CAAC,CAAC;IACnB,CAAC;;iHA1HU,oBAAoB,kBAUC,eAAe;qGAVpC,oBAAoB,sKCnBjC,s7HAwEA;2FDrDa,oBAAoB;kBALhC,SAAS;+BACE,kBAAkB,QAEtB,EAAE,KAAK,EAAE,aAAa,EAAE;;0BAYjB,QAAQ;;0BAAI,MAAM;2BAAC,eAAe;4CAarC,aAAa;sBAAtB,MAAM;gBACG,SAAS;sBAAlB,MAAM","sourcesContent":["import { Component, EventEmitter, Input, Output, Inject, Optional } from '@angular/core';\nimport { MAT_DIALOG_DATA } from '@angular/material/dialog';\nimport {\n  TestCaseStepConfig,\n  NormalStepConfig,\n  TestCaseEventType,\n  isNormalStepConfig,\n} from '../test-case-step.models';\n\n/**\n * Delete Steps confirmation modal for Test Case Details.\n * Matches the design of Create Step Group: shows selected steps with context (e.g. \"IF lane\"),\n * warning text, and Cancel / Delete actions. Steps are shown with red/danger styling.\n */\n@Component({\n  selector: 'cqa-delete-steps',\n  templateUrl: './delete-steps.component.html',\n  host: { class: 'cqa-ui-root' },\n})\nexport class DeleteStepsComponent {\n  /** Steps that will be deleted (shown in the list). */\n  stepsToDelete: TestCaseStepConfig[] = [];\n\n  /** Context label for the sub-heading, e.g. \"IF lane\", \"ELSE\", \"For loop\". */\n  contextLabel = '';\n\n  /** Optional step images/screenshots map: stepId -> imageUrl */\n  stepImages: Map<string | number, string> = new Map();\n\n  constructor(@Optional() @Inject(MAT_DIALOG_DATA) public data?: {\n    stepsToDelete?: TestCaseStepConfig[];\n    contextLabel?: string;\n    stepImages?: Map<string | number, string>;\n  }) {\n    // Initialize from dialog data if provided\n    if (data) {\n      this.stepsToDelete = data.stepsToDelete || [];\n      this.contextLabel = data.contextLabel || '';\n      this.stepImages = data.stepImages || new Map();\n    }\n  }\n\n  @Output() confirmDelete = new EventEmitter<void>();\n  @Output() cancelled = new EventEmitter<void>();\n\n  get stepsCount(): number {\n    return this.stepsToDelete?.length ?? 0;\n  }\n\n  get titleText(): string {\n    const n = this.stepsCount;\n    return n === 1 ? 'Delete 1 step?' : `Delete ${n} steps?`;\n  }\n\n  get selectedStepsSubtitle(): string {\n    return `Selected (${this.stepsCount}) steps for deletion, are you sure you want to delete these steps?`;\n  }\n\n  /** Display label for a step in the list (same pattern as create-step-group). */\n  getStepDisplayLabel(step: TestCaseStepConfig, index: number): string {\n    if (isNormalStepConfig(step)) {\n      return this.getNormalStepLabel(step);\n    }\n    if ('groupName' in step && step.groupName) {\n      return step.groupName;\n    }\n    if ('condition' in step && step.condition) {\n      return step.condition;\n    }\n    if ('loopType' in step) {\n      const loop = step as { loopType: string; testDataProfile?: string; condition?: string };\n      if (loop.loopType === 'for' && loop.testDataProfile) {\n        return `For loop: ${loop.testDataProfile}`;\n      }\n      if (loop.loopType === 'while' && loop.condition) {\n        return `While: ${loop.condition}`;\n      }\n    }\n    if (step.description) {\n      return step.description;\n    }\n    return `Step ${index + 1}`;\n  }\n\n  private getNormalStepLabel(step: NormalStepConfig): string {\n    const params = step.parameters ?? [];\n    const getParam = (name: string) =>\n      params.find((p) => p.name?.toLowerCase() === name.toLowerCase());\n    const val = (p: { value?: string; displayValue?: string } | undefined) =>\n      p?.displayValue ?? p?.value ?? '';\n\n    switch (step.eventType as TestCaseEventType) {\n      case 'navigate': {\n        const url = getParam('url');\n        return url ? `Navigate to ${val(url)}` : 'Navigate to';\n      }\n      case 'ai-agent': {\n        const instructions = getParam('instructions') ?? getParam('description');\n        return val(instructions) || 'AI Agent step';\n      }\n      case 'type':\n        return val(getParam('text')) || 'Type';\n      case 'click':\n        return val(getParam('selector')) ? `Click ${val(getParam('selector'))}` : 'Click';\n      case 'verify':\n        return val(getParam('description')) || 'Verify';\n      case 'custom': {\n        const desc = getParam('description') ?? getParam('action');\n        return val(desc) || 'Custom step';\n      }\n      default:\n        return val(getParam('description')) || val(params[0]) || 'Step';\n    }\n  }\n\n  onCancel(): void {\n    this.cancelled.emit();\n  }\n\n  onDelete(): void {\n    this.confirmDelete.emit();\n  }\n\n  /** Get step image URL if available */\n  getStepImage(step: TestCaseStepConfig): string | null {\n    if (!step?.id) return null;\n    return this.stepImages.get(step.id) || null;\n  }\n\n  /** Check if step has an image */\n  hasStepImage(step: TestCaseStepConfig): boolean {\n    return this.getStepImage(step) !== null;\n  }\n\n  /** Get step number from step data, falling back to index + 1 */\n  getStepNumber(step: TestCaseStepConfig, index: number): number | string {\n    const stepNum = (step as any)?.stepNumber;\n    if (stepNum != null && stepNum !== '') {\n      return stepNum;\n    }\n    return index + 1;\n  }\n}\n","<div\n  class=\"cqa-bg-white cqa-rounded-[12px] cqa-shadow-lg cqa-border cqa-border-solid cqa-border-[#E5E7EB] cqa-w-full cqa-max-w-[500px] cqa-flex cqa-flex-col cqa-gap-4 cqa-p-6 cqa-box-border cqa-min-h-0\">\n  <!-- Header: title + close (X) -->\n  <div class=\"cqa-flex cqa-items-start cqa-justify-between cqa-gap-2\">\n    <div class=\"cqa-flex cqa-flex-col cqa-gap-1 cqa-min-w-0\">\n      <h2 class=\"cqa-font-medium cqa-text-[22px] cqa-leading-[28px] cqa-tracking-normal cqa-text-[#101828] cqa-m-0\">\n        {{ titleText }}\n      </h2>\n      <p class=\"cqa-font-normal cqa-text-[14px] cqa-leading-[21px] cqa-tracking-[-0.15px] cqa-text-[#4A5565] cqa-m-0\">\n        This action cannot be undone, but you can use the undo function in the toolbar.\n      </p>\n    </div>\n    <button\n      type=\"button\"\n      (click)=\"onCancel()\"\n      class=\"cqa-flex cqa-items-center cqa-justify-center cqa-min-h-7 cqa-min-w-7 cqa-rounded cqa-text-[#6B7280] hover:cqa-bg-[#F3F4F6] cqa-p-0 cqa-flex-shrink-0\"\n      title=\"Close\"\n      aria-label=\"Close\">\n      <svg width=\"20\" height=\"20\" viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" aria-hidden=\"true\">\n        <path d=\"M18 6L6 18M6 6l12 12\" />\n      </svg>\n    </button>\n  </div>\n\n  <!-- Selected steps for [context] (N) – scroll when many steps, scrollbar hidden (same as create-step-group) -->\n  <div class=\"cqa-flex cqa-flex-col cqa-gap-2 cqa-min-h-0\">\n    <label class=\"cqa-font-semibold cqa-text-[12px] cqa-leading-[100%] cqa-tracking-normal cqa-text-[#0A0A0A] cqa-align-middle\">\n      {{ selectedStepsSubtitle }}\n    </label>\n    <div *ngIf=\"stepsCount === 0\" class=\"cqa-text-[14px] cqa-text-[#6B7280] cqa-p-4 cqa-text-center\">\n      No steps selected. Please select at least one step to delete.\n    </div>\n    <div *ngIf=\"stepsCount > 0\" class=\"cqa-scrollbar-hide cqa-flex cqa-flex-col cqa-gap-2 cqa-max-h-[200px] cqa-min-h-0 cqa-overflow-y-auto cqa-overflow-x-hidden cqa-rounded-[8px] cqa-p-[6px] cqa-border cqa-border-solid cqa-border-[rgba(0,0,0,0.1)]\">\n      <div\n        *ngFor=\"let step of stepsToDelete; let i = index\"\n        class=\"cqa-flex cqa-items-center cqa-gap-[8px] cqa-rounded-[4px] cqa-pt-[4px] cqa-pb-[4px] cqa-pl-[8px] cqa-pr-[8px] cqa-bg-[rgba(238,63,63,0.1)]\">\n        <!-- Numbered badge (red) -->\n        <span\n          class=\"cqa-flex cqa-items-center cqa-justify-center cqa-w-7 cqa-h-7 cqa-rounded-full cqa-bg-[#C63535] cqa-text-white cqa-text-[10px] cqa-leading-[15px] cqa-font-medium cqa-flex-shrink-0\">\n          {{ getStepNumber(step, i) }}\n        </span>\n        <!-- Step image if available -->\n        <img\n          *ngIf=\"hasStepImage(step)\"\n          [src]=\"getStepImage(step)\"\n          [alt]=\"'Step ' + getStepNumber(step, i)\"\n          class=\"cqa-w-8 cqa-h-8 cqa-rounded-[4px] cqa-object-cover cqa-flex-shrink-0 cqa-border cqa-border-solid cqa-border-[rgba(220,38,38,0.2)]\">\n        <span [innerHTML]=\"getStepDisplayLabel(step, i)\" class=\"cqa-font-medium cqa-text-[10px] cqa-leading-[15px] cqa-tracking-[0px] cqa-text-[#DC2626] cqa-flex-1 cqa-min-w-0 cqa-truncate\">\n        </span>\n      </div>\n    </div>\n  </div>  \n\n  <!-- Actions: Cancel | Delete (right-aligned) -->\n  <div class=\"cqa-flex cqa-items-center cqa-justify-end cqa-w-full cqa-gap-3\">\n    <cqa-button\n      variant=\"outlined\"\n      btnSize=\"lg\"\n      text=\"Cancel\"\n      [customClass]=\"'cqa-text-[14px] cqa-py-[9px] cqa-bg-white cqa-border cqa-border-solid cqa-border-[#414146] cqa-text-[#414146]'\"\n      (clicked)=\"onCancel()\">\n    </cqa-button>\n    <cqa-button\n      variant=\"filled\"\n      btnSize=\"lg\"\n      text=\"Delete\"\n      [customClass]=\"'cqa-text-[14px] cqa-py-[9px] cqa-rounded-[8px] cqa-border-0 cqa-bg-[#EE3F3F] cqa-text-white'\"\n      [disabled]=\"stepsCount === 0\"\n      (clicked)=\"onDelete()\">\n    </cqa-button>\n  </div>\n</div>\n"]}
|
|
137
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"delete-steps.component.js","sourceRoot":"","sources":["../../../../../../src/lib/test-case-details/delete-steps/delete-steps.component.ts","../../../../../../src/lib/test-case-details/delete-steps/delete-steps.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, Output, Inject, Optional } from '@angular/core';\nimport { MAT_DIALOG_DATA } from '@angular/material/dialog';\nimport {\n  TestCaseStepConfig,\n  NormalStepConfig,\n  TestCaseEventType,\n  isNormalStepConfig,\n} from '../test-case-step.models';\n\n/**\n * Delete Steps confirmation modal for Test Case Details.\n * Matches the design of Create Step Group: shows selected steps with context (e.g. \"IF lane\"),\n * warning text, and Cancel / Delete actions. Steps are shown with red/danger styling.\n */\n@Component({\n  selector: 'cqa-delete-steps',\n  templateUrl: './delete-steps.component.html',\n  host: { class: 'cqa-ui-root' },\n})\nexport class DeleteStepsComponent {\n  /** Steps that will be deleted (shown in the list). */\n  stepsToDelete: TestCaseStepConfig[] = [];\n\n  /** Context label for the sub-heading, e.g. \"IF lane\", \"ELSE\", \"For loop\". */\n  contextLabel = '';\n\n  /** Optional step images/screenshots map: stepId -> imageUrl */\n  stepImages: Map<string | number, string> = new Map();\n\n  /** Pre-computed display labels from host (e.g. ts-portal-ui), same order as stepsToDelete. */\n  stepLabels: string[] = [];\n\n  constructor(@Optional() @Inject(MAT_DIALOG_DATA) public data?: {\n    stepsToDelete?: TestCaseStepConfig[];\n    contextLabel?: string;\n    stepImages?: Map<string | number, string>;\n    stepLabels?: string[];\n  }) {\n    if (data) {\n      this.stepsToDelete = data.stepsToDelete || [];\n      this.contextLabel = data.contextLabel || '';\n      this.stepImages = data.stepImages || new Map();\n      this.stepLabels = data.stepLabels || [];\n    }\n  }\n\n  @Output() confirmDelete = new EventEmitter<void>();\n  @Output() cancelled = new EventEmitter<void>();\n\n  get stepsCount(): number {\n    return this.stepsToDelete?.length ?? 0;\n  }\n\n  get titleText(): string {\n    const n = this.stepsCount;\n    return n === 1 ? 'Delete 1 step?' : `Delete ${n} steps?`;\n  }\n\n  get selectedStepsSubtitle(): string {\n    return `Selected (${this.stepsCount}) steps for deletion, are you sure you want to delete these steps?`;\n  }\n\n  /** Display label: use stepLabels from host when provided, else compute from step. */\n  getStepDisplayLabel(step: TestCaseStepConfig, index: number): string {\n    if (this.stepLabels?.length > index && this.stepLabels[index] != null && this.stepLabels[index] !== '') {\n      return this.stepLabels[index];\n    }\n    if (isNormalStepConfig(step)) {\n      return this.getNormalStepLabel(step);\n    }\n    if ('groupName' in step && step.groupName) {\n      return step.groupName;\n    }\n    if ('condition' in step && step.condition) {\n      return step.condition;\n    }\n    if ('loopType' in step) {\n      const loop = step as { loopType: string; testDataProfile?: string; condition?: string };\n      if (loop.loopType === 'for' && loop.testDataProfile) {\n        return `For loop: ${loop.testDataProfile}`;\n      }\n      if (loop.loopType === 'while' && loop.condition) {\n        return `While: ${loop.condition}`;\n      }\n    }\n    if (step.description) {\n      return step.description;\n    }\n    return `Step ${index + 1}`;\n  }\n\n  private getNormalStepLabel(step: NormalStepConfig): string {\n    const params = step.parameters ?? [];\n    const getParam = (name: string) =>\n      params.find((p) => p.name?.toLowerCase() === name.toLowerCase());\n    const val = (p: { value?: string; displayValue?: string } | undefined) =>\n      p?.displayValue ?? p?.value ?? '';\n\n    switch (step.eventType as TestCaseEventType) {\n      case 'navigate': {\n        const url = getParam('url');\n        return url ? `Navigate to ${val(url)}` : 'Navigate to';\n      }\n      case 'ai-agent': {\n        const instructions = getParam('instructions') ?? getParam('description');\n        return val(instructions) || 'AI Agent step';\n      }\n      case 'type':\n        return val(getParam('text')) || 'Type';\n      case 'click':\n        return val(getParam('selector')) ? `Click ${val(getParam('selector'))}` : 'Click';\n      case 'verify':\n        return val(getParam('description')) || 'Verify';\n      case 'custom': {\n        const desc = getParam('description') ?? getParam('action');\n        return val(desc) || 'Custom step';\n      }\n      default:\n        return val(getParam('description')) || val(params[0]) || 'Step';\n    }\n  }\n\n  onCancel(): void {\n    this.cancelled.emit();\n  }\n\n  onDelete(): void {\n    this.confirmDelete.emit();\n  }\n\n  /** Get step image URL if available */\n  getStepImage(step: TestCaseStepConfig): string | null {\n    if (!step?.id) return null;\n    return this.stepImages.get(step.id) || null;\n  }\n\n  /** Check if step has an image */\n  hasStepImage(step: TestCaseStepConfig): boolean {\n    return this.getStepImage(step) !== null;\n  }\n\n  /** Get step number from step data, falling back to index + 1 */\n  getStepNumber(step: TestCaseStepConfig, index: number): number | string {\n    const stepNum = (step as any)?.stepNumber;\n    if (stepNum != null && stepNum !== '') {\n      return stepNum;\n    }\n    return index + 1;\n  }\n}\n","<div\n  class=\"cqa-bg-white cqa-rounded-[12px] cqa-shadow-lg cqa-border cqa-border-solid cqa-border-[#E5E7EB] cqa-w-full cqa-max-w-[500px] cqa-flex cqa-flex-col cqa-gap-4 cqa-p-6 cqa-box-border cqa-min-h-0\">\n  <!-- Header: title + close (X) -->\n  <div class=\"cqa-flex cqa-items-start cqa-justify-between cqa-gap-2\">\n    <div class=\"cqa-flex cqa-flex-col cqa-gap-1 cqa-min-w-0\">\n      <h2 class=\"cqa-font-medium cqa-text-[22px] cqa-leading-[28px] cqa-tracking-normal cqa-text-[#101828] cqa-m-0\">\n        {{ titleText }}\n      </h2>\n      <p class=\"cqa-font-normal cqa-text-[14px] cqa-leading-[21px] cqa-tracking-[-0.15px] cqa-text-[#4A5565] cqa-m-0\">\n        This action cannot be undone, but you can use the undo function in the toolbar.\n      </p>\n    </div>\n    <button\n      type=\"button\"\n      (click)=\"onCancel()\"\n      class=\"cqa-flex cqa-items-center cqa-justify-center cqa-min-h-7 cqa-min-w-7 cqa-rounded cqa-text-[#6B7280] hover:cqa-bg-[#F3F4F6] cqa-p-0 cqa-flex-shrink-0\"\n      title=\"Close\"\n      aria-label=\"Close\">\n      <svg width=\"20\" height=\"20\" viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" aria-hidden=\"true\">\n        <path d=\"M18 6L6 18M6 6l12 12\" />\n      </svg>\n    </button>\n  </div>\n\n  <!-- Selected steps for [context] (N) – scroll when many steps, scrollbar hidden (same as create-step-group) -->\n  <div class=\"cqa-flex cqa-flex-col cqa-gap-2 cqa-min-h-0\">\n    <label class=\"cqa-font-semibold cqa-text-[12px] cqa-leading-[100%] cqa-tracking-normal cqa-text-[#0A0A0A] cqa-align-middle\">\n      {{ selectedStepsSubtitle }}\n    </label>\n    <div *ngIf=\"stepsCount === 0\" class=\"cqa-text-[14px] cqa-text-[#6B7280] cqa-p-4 cqa-text-center\">\n      No steps selected. Please select at least one step to delete.\n    </div>\n    <div *ngIf=\"stepsCount > 0\" class=\"cqa-scrollbar-hide cqa-flex cqa-flex-col cqa-gap-2 cqa-max-h-[200px] cqa-min-h-0 cqa-overflow-y-auto cqa-overflow-x-hidden cqa-rounded-[8px] cqa-p-[6px] cqa-border cqa-border-solid cqa-border-[rgba(0,0,0,0.1)]\">\n      <div\n        *ngFor=\"let step of stepsToDelete; let i = index\"\n        class=\"cqa-flex cqa-items-center cqa-gap-[8px] cqa-rounded-[4px] cqa-pt-[4px] cqa-pb-[4px] cqa-pl-[8px] cqa-pr-[8px] cqa-bg-[rgba(238,63,63,0.1)]\">\n        <!-- Numbered badge (red) -->\n        <span\n          class=\"cqa-flex cqa-items-center cqa-justify-center cqa-w-7 cqa-h-7 cqa-rounded-full cqa-bg-[#C63535] cqa-text-white cqa-text-[10px] cqa-leading-[15px] cqa-font-medium cqa-flex-shrink-0\">\n          {{ getStepNumber(step, i) }}\n        </span>\n        <!-- Step image if available -->\n        <img\n          *ngIf=\"hasStepImage(step)\"\n          [src]=\"getStepImage(step)\"\n          [alt]=\"'Step ' + getStepNumber(step, i)\"\n          class=\"cqa-w-8 cqa-h-8 cqa-rounded-[4px] cqa-object-cover cqa-flex-shrink-0 cqa-border cqa-border-solid cqa-border-[rgba(220,38,38,0.2)]\">\n        <span [innerHTML]=\"getStepDisplayLabel(step, i)\" class=\"cqa-font-medium cqa-text-[10px] cqa-leading-[15px] cqa-tracking-[0px] cqa-text-[#DC2626] cqa-flex-1 cqa-min-w-0 cqa-truncate\">\n        </span>\n      </div>\n    </div>\n  </div>  \n\n  <!-- Actions: Cancel | Delete (right-aligned) -->\n  <div class=\"cqa-flex cqa-items-center cqa-justify-end cqa-w-full cqa-gap-3\">\n    <cqa-button\n      variant=\"outlined\"\n      btnSize=\"lg\"\n      text=\"Cancel\"\n      [customClass]=\"'cqa-text-[14px] cqa-py-[9px] cqa-bg-white cqa-border cqa-border-solid cqa-border-[#414146] cqa-text-[#414146]'\"\n      (clicked)=\"onCancel()\">\n    </cqa-button>\n    <cqa-button\n      variant=\"filled\"\n      btnSize=\"lg\"\n      text=\"Delete\"\n      [customClass]=\"'cqa-text-[14px] cqa-py-[9px] cqa-rounded-[8px] cqa-border-0 cqa-bg-[#EE3F3F] cqa-text-white'\"\n      [disabled]=\"stepsCount === 0\"\n      (clicked)=\"onDelete()\">\n    </cqa-button>\n  </div>\n</div>\n"]}
|