@cqa-lib/cqa-ui 1.1.503 → 1.1.504

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.
@@ -5,15 +5,14 @@ import * as i2 from "@angular/common";
5
5
  /**
6
6
  * Dual-mode card summarising the API mocking configuration of a test case.
7
7
  *
8
- * The card surfaces **one boolean choice** — `restoreMock` as two mutually-exclusive rows
9
- * labelled "Capture API responses" and "Renew API responses":
8
+ * The card surfaces TWO independent flags — `restoreMock` (the "Use mock API responses" row)
9
+ * and `storeMock` (the "Renew and store API responses" row). Both can be off simultaneously
10
+ * (no mocking on the next run); turning either one on forces the other off (they're mutually
11
+ * exclusive in the on-state). Both can never be on at the same time.
10
12
  *
11
- * restoreMock === true → Renew = ON, Capture = OFF
12
- * restoreMock === false → Renew = OFF, Capture = ON
13
- *
14
- * In read-only mode both rows show a value text ("On"/"Off") derived from `restoreMock`.
15
- * In edit mode both rows render a toggle; interacting with either one flips `restoreMock`
16
- * and the card emits `restoreMockChange` so the parent can persist the new value.
13
+ * In read-only mode each row shows On/Off derived from its own flag. In edit mode each row
14
+ * renders a toggle; the card emits `restoreMockChange` and `storeMockChange` whenever a value
15
+ * actually changes so the parent can persist them.
17
16
  */
18
17
  export class ApiMockingCardComponent {
19
18
  constructor() {
@@ -23,11 +22,10 @@ export class ApiMockingCardComponent {
23
22
  this.captureHint = 'Uses stored responses on next run. Turn on after capture completes.';
24
23
  this.renewLabel = 'Renew and store API responses';
25
24
  this.renewHint = 'Re-captures fresh responses on next run. Turns off Use mock.';
26
- /**
27
- * Single source of truth for the card's dual-toggle state.
28
- * Defaults to `false` → Capture is ON, Renew is OFF.
29
- */
25
+ /** "Use mock API responses" row state. Mutually exclusive with `storeMock` when true. */
30
26
  this.restoreMock = false;
27
+ /** "Renew and store API responses" row state. Mutually exclusive with `restoreMock` when true. */
28
+ this.storeMock = false;
31
29
  this.mockedApisCount = 0;
32
30
  this.totalApisCount = 0;
33
31
  this.progressPercent = 0;
@@ -42,18 +40,16 @@ export class ApiMockingCardComponent {
42
40
  /** Hint shown in read-only mode when no mock data exists yet (`showProgress` is false). */
43
41
  this.noDataHint = 'Run this test once to capture API responses first.';
44
42
  this.configure = new EventEmitter();
45
- /**
46
- * Emitted whenever the effective `restoreMock` value changes (either row's toggle was
47
- * interacted with in edit mode). Parent components should persist this value — e.g. under
48
- * `testCase.mockApiSettings.restoreMock`.
49
- */
43
+ /** Emitted whenever `restoreMock` changes (Use-mock row toggled). */
50
44
  this.restoreMockChange = new EventEmitter();
45
+ /** Emitted whenever `storeMock` changes (Renew-and-store row toggled). */
46
+ this.storeMockChange = new EventEmitter();
51
47
  }
52
- // Derived per-row state (template binds these directly so the two rows stay in lock-step).
53
- get renewEnabled() { return this.restoreMock; }
54
- get captureEnabled() { return !this.restoreMock; }
55
- get renewValueText() { return this.restoreMock ? 'On' : 'Off'; }
56
- get captureValueText() { return this.restoreMock ? 'Off' : 'On'; }
48
+ // Per-row derived display state each row reflects its own flag now.
49
+ get captureEnabled() { return this.restoreMock; }
50
+ get renewEnabled() { return this.storeMock; }
51
+ get captureValueText() { return this.restoreMock ? 'On' : 'Off'; }
52
+ get renewValueText() { return this.storeMock ? 'On' : 'Off'; }
57
53
  get computedSummaryText() {
58
54
  if (this.summaryText)
59
55
  return this.summaryText;
@@ -72,20 +68,22 @@ export class ApiMockingCardComponent {
72
68
  this.configure.emit();
73
69
  }
74
70
  /**
75
- * User interacted with the "Renew API responses" toggle in edit mode.
76
- * Renew ON → restoreMock = true (Capture OFF).
77
- * Renew OFF → restoreMock = false (Capture ON — mutual exclusivity).
71
+ * "Use mock API responses" toggle. Turning it on forces `storeMock` off (mutual exclusivity);
72
+ * turning it off leaves the other row alone.
78
73
  */
79
- onRenewToggle(value) {
74
+ onCaptureToggle(value) {
75
+ if (value && this.storeMock)
76
+ this.setStoreMock(false);
80
77
  this.setRestoreMock(value);
81
78
  }
82
79
  /**
83
- * User interacted with the "Capture API responses" toggle in edit mode.
84
- * Capture ON → restoreMock = false (Renew OFF).
85
- * Capture OFF → restoreMock = true (Renew ON — mutual exclusivity).
80
+ * "Renew and store API responses" toggle. Turning it on forces `restoreMock` off; turning
81
+ * it off leaves the other row alone.
86
82
  */
87
- onCaptureToggle(value) {
88
- this.setRestoreMock(!value);
83
+ onRenewToggle(value) {
84
+ if (value && this.restoreMock)
85
+ this.setRestoreMock(false);
86
+ this.setStoreMock(value);
89
87
  }
90
88
  setRestoreMock(next) {
91
89
  if (this.restoreMock === next)
@@ -93,9 +91,15 @@ export class ApiMockingCardComponent {
93
91
  this.restoreMock = next;
94
92
  this.restoreMockChange.emit(next);
95
93
  }
94
+ setStoreMock(next) {
95
+ if (this.storeMock === next)
96
+ return;
97
+ this.storeMock = next;
98
+ this.storeMockChange.emit(next);
99
+ }
96
100
  }
97
101
  ApiMockingCardComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: ApiMockingCardComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
98
- ApiMockingCardComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.4.0", type: ApiMockingCardComponent, selector: "cqa-api-mocking-card", inputs: { title: "title", statusLabel: "statusLabel", captureLabel: "captureLabel", captureHint: "captureHint", renewLabel: "renewLabel", renewHint: "renewHint", restoreMock: "restoreMock", mockedApisCount: "mockedApisCount", totalApisCount: "totalApisCount", progressPercent: "progressPercent", summaryText: "summaryText", percentText: "percentText", configureButtonLabel: "configureButtonLabel", editing: "editing", showProgress: "showProgress", noDataHint: "noDataHint" }, outputs: { configure: "configure", restoreMockChange: "restoreMockChange" }, host: { classAttribute: "cqa-ui-root" }, ngImport: i0, template: "<div class=\"cqa-amc-card\">\n <div class=\"cqa-amc-header\">\n <span class=\"cqa-amc-title\">{{ title }}</span>\n <span class=\"cqa-amc-status\" *ngIf=\"!showProgress &&statusLabel\">{{ statusLabel }}</span>\n </div>\n\n <!-- Read-only rows -->\n <ng-container *ngIf=\"!editing\">\n <div class=\"cqa-amc-row\">\n <span class=\"cqa-amc-label\">{{ captureLabel }}</span>\n <span class=\"cqa-amc-value\">{{ captureValueText }}</span>\n </div>\n <div class=\"cqa-amc-row\">\n <span class=\"cqa-amc-label\">{{ renewLabel }}</span>\n <span class=\"cqa-amc-value\">{{ renewValueText }}</span>\n </div>\n </ng-container>\n\n <!-- Edit rows: toggles with hint text -->\n <ng-container *ngIf=\"editing\">\n <div class=\"cqa-amc-edit-block\">\n <div class=\"cqa-amc-row cqa-amc-row--edit\">\n <cqa-custom-toggle\n [checked]=\"captureEnabled\"\n [ariaLabel]=\"captureLabel\"\n (checkedChange)=\"onCaptureToggle($event)\">\n </cqa-custom-toggle>\n <span class=\"cqa-amc-label\">{{ captureLabel }}</span>\n </div>\n <p *ngIf=\"captureHint\" class=\"cqa-amc-edit-hint\">{{ captureHint }}</p>\n </div>\n <div class=\"cqa-amc-edit-block\">\n <div class=\"cqa-amc-row cqa-amc-row--edit\">\n <cqa-custom-toggle\n [checked]=\"renewEnabled\"\n [ariaLabel]=\"renewLabel\"\n (checkedChange)=\"onRenewToggle($event)\">\n </cqa-custom-toggle>\n <span class=\"cqa-amc-label\">{{ renewLabel }}</span>\n </div>\n <p *ngIf=\"renewHint\" class=\"cqa-amc-edit-hint\">{{ renewHint }}</p>\n </div>\n </ng-container>\n\n <ng-container *ngIf=\"showProgress && !editing\">\n <p class=\"cqa-amc-summary\">{{ computedSummaryText }}</p>\n <div class=\"cqa-amc-progress-track\">\n <div class=\"cqa-amc-progress-fill\" [style.width]=\"progressWidth\"></div>\n </div>\n <p class=\"cqa-amc-percent\">{{ computedPercentText }}</p>\n </ng-container>\n\n <!-- Hint: no mock data yet \u2014 nudge the user to run the test first -->\n <p *ngIf=\"!showProgress && !editing\" class=\"cqa-amc-no-data-hint\">{{ noDataHint }}</p>\n\n <button\n *ngIf=\"!editing\"\n [disabled]=\"!showProgress\"\n type=\"button\"\n class=\"cqa-amc-configure-btn\"\n (click)=\"onConfigureClick()\">\n {{ configureButtonLabel }}\n </button>\n</div>\n", components: [{ type: i1.CustomToggleComponent, selector: "cqa-custom-toggle", inputs: ["checked", "disabled", "ariaLabel"], outputs: ["checkedChange", "change"] }], directives: [{ type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
102
+ ApiMockingCardComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.4.0", type: ApiMockingCardComponent, selector: "cqa-api-mocking-card", inputs: { title: "title", statusLabel: "statusLabel", captureLabel: "captureLabel", captureHint: "captureHint", renewLabel: "renewLabel", renewHint: "renewHint", restoreMock: "restoreMock", storeMock: "storeMock", mockedApisCount: "mockedApisCount", totalApisCount: "totalApisCount", progressPercent: "progressPercent", summaryText: "summaryText", percentText: "percentText", configureButtonLabel: "configureButtonLabel", editing: "editing", showProgress: "showProgress", noDataHint: "noDataHint" }, outputs: { configure: "configure", restoreMockChange: "restoreMockChange", storeMockChange: "storeMockChange" }, host: { classAttribute: "cqa-ui-root" }, ngImport: i0, template: "<div class=\"cqa-amc-card\">\n <div class=\"cqa-amc-header\">\n <span class=\"cqa-amc-title\">{{ title }}</span>\n <span class=\"cqa-amc-status\" *ngIf=\"!showProgress &&statusLabel\">{{ statusLabel }}</span>\n </div>\n\n <!-- Read-only rows -->\n <ng-container *ngIf=\"!editing\">\n <div class=\"cqa-amc-row\">\n <span class=\"cqa-amc-label\">{{ captureLabel }}</span>\n <span class=\"cqa-amc-value\">{{ captureValueText }}</span>\n </div>\n <div class=\"cqa-amc-row\">\n <span class=\"cqa-amc-label\">{{ renewLabel }}</span>\n <span class=\"cqa-amc-value\">{{ renewValueText }}</span>\n </div>\n </ng-container>\n\n <!-- Edit rows: toggles with hint text -->\n <ng-container *ngIf=\"editing\">\n <div class=\"cqa-amc-edit-block\">\n <div class=\"cqa-amc-row cqa-amc-row--edit\">\n <cqa-custom-toggle\n [checked]=\"captureEnabled\"\n [ariaLabel]=\"captureLabel\"\n (checkedChange)=\"onCaptureToggle($event)\">\n </cqa-custom-toggle>\n <span class=\"cqa-amc-label\">{{ captureLabel }}</span>\n </div>\n <p *ngIf=\"captureHint\" class=\"cqa-amc-edit-hint\">{{ captureHint }}</p>\n </div>\n <div class=\"cqa-amc-edit-block\">\n <div class=\"cqa-amc-row cqa-amc-row--edit\">\n <cqa-custom-toggle\n [checked]=\"renewEnabled\"\n [ariaLabel]=\"renewLabel\"\n (checkedChange)=\"onRenewToggle($event)\">\n </cqa-custom-toggle>\n <span class=\"cqa-amc-label\">{{ renewLabel }}</span>\n </div>\n <p *ngIf=\"renewHint\" class=\"cqa-amc-edit-hint\">{{ renewHint }}</p>\n </div>\n </ng-container>\n\n <ng-container *ngIf=\"showProgress && !editing\">\n <p class=\"cqa-amc-summary\">{{ computedSummaryText }}</p>\n <div class=\"cqa-amc-progress-track\">\n <div class=\"cqa-amc-progress-fill\" [style.width]=\"progressWidth\"></div>\n </div>\n <p class=\"cqa-amc-percent\">{{ computedPercentText }}</p>\n </ng-container>\n\n <!-- Hint: no mock data yet \u2014 nudge the user to run the test first -->\n <p *ngIf=\"!showProgress && !editing\" class=\"cqa-amc-no-data-hint\">{{ noDataHint }}</p>\n\n <button\n *ngIf=\"!editing\"\n [disabled]=\"!showProgress\"\n type=\"button\"\n class=\"cqa-amc-configure-btn\"\n (click)=\"onConfigureClick()\">\n {{ configureButtonLabel }}\n </button>\n</div>\n", components: [{ type: i1.CustomToggleComponent, selector: "cqa-custom-toggle", inputs: ["checked", "disabled", "ariaLabel"], outputs: ["checkedChange", "change"] }], directives: [{ type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
99
103
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: ApiMockingCardComponent, decorators: [{
100
104
  type: Component,
101
105
  args: [{ selector: 'cqa-api-mocking-card', host: { class: 'cqa-ui-root' }, changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"cqa-amc-card\">\n <div class=\"cqa-amc-header\">\n <span class=\"cqa-amc-title\">{{ title }}</span>\n <span class=\"cqa-amc-status\" *ngIf=\"!showProgress &&statusLabel\">{{ statusLabel }}</span>\n </div>\n\n <!-- Read-only rows -->\n <ng-container *ngIf=\"!editing\">\n <div class=\"cqa-amc-row\">\n <span class=\"cqa-amc-label\">{{ captureLabel }}</span>\n <span class=\"cqa-amc-value\">{{ captureValueText }}</span>\n </div>\n <div class=\"cqa-amc-row\">\n <span class=\"cqa-amc-label\">{{ renewLabel }}</span>\n <span class=\"cqa-amc-value\">{{ renewValueText }}</span>\n </div>\n </ng-container>\n\n <!-- Edit rows: toggles with hint text -->\n <ng-container *ngIf=\"editing\">\n <div class=\"cqa-amc-edit-block\">\n <div class=\"cqa-amc-row cqa-amc-row--edit\">\n <cqa-custom-toggle\n [checked]=\"captureEnabled\"\n [ariaLabel]=\"captureLabel\"\n (checkedChange)=\"onCaptureToggle($event)\">\n </cqa-custom-toggle>\n <span class=\"cqa-amc-label\">{{ captureLabel }}</span>\n </div>\n <p *ngIf=\"captureHint\" class=\"cqa-amc-edit-hint\">{{ captureHint }}</p>\n </div>\n <div class=\"cqa-amc-edit-block\">\n <div class=\"cqa-amc-row cqa-amc-row--edit\">\n <cqa-custom-toggle\n [checked]=\"renewEnabled\"\n [ariaLabel]=\"renewLabel\"\n (checkedChange)=\"onRenewToggle($event)\">\n </cqa-custom-toggle>\n <span class=\"cqa-amc-label\">{{ renewLabel }}</span>\n </div>\n <p *ngIf=\"renewHint\" class=\"cqa-amc-edit-hint\">{{ renewHint }}</p>\n </div>\n </ng-container>\n\n <ng-container *ngIf=\"showProgress && !editing\">\n <p class=\"cqa-amc-summary\">{{ computedSummaryText }}</p>\n <div class=\"cqa-amc-progress-track\">\n <div class=\"cqa-amc-progress-fill\" [style.width]=\"progressWidth\"></div>\n </div>\n <p class=\"cqa-amc-percent\">{{ computedPercentText }}</p>\n </ng-container>\n\n <!-- Hint: no mock data yet \u2014 nudge the user to run the test first -->\n <p *ngIf=\"!showProgress && !editing\" class=\"cqa-amc-no-data-hint\">{{ noDataHint }}</p>\n\n <button\n *ngIf=\"!editing\"\n [disabled]=\"!showProgress\"\n type=\"button\"\n class=\"cqa-amc-configure-btn\"\n (click)=\"onConfigureClick()\">\n {{ configureButtonLabel }}\n </button>\n</div>\n", styles: [] }]
@@ -113,6 +117,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImpor
113
117
  type: Input
114
118
  }], restoreMock: [{
115
119
  type: Input
120
+ }], storeMock: [{
121
+ type: Input
116
122
  }], mockedApisCount: [{
117
123
  type: Input
118
124
  }], totalApisCount: [{
@@ -135,5 +141,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImpor
135
141
  type: Output
136
142
  }], restoreMockChange: [{
137
143
  type: Output
144
+ }], storeMockChange: [{
145
+ type: Output
138
146
  }] } });
139
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"api-mocking-card.component.js","sourceRoot":"","sources":["../../../../../../src/lib/test-case-details/api-mocking-card/api-mocking-card.component.ts","../../../../../../src/lib/test-case-details/api-mocking-card/api-mocking-card.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output } from '@angular/core';\n\n/**\n * Legacy toggle-change payload kept for back-compat with consumers that haven't migrated\n * to `restoreMockChange` yet. `key` identifies which row was toggled; `value` is the new\n * checked state of that row. New code should listen to `restoreMockChange` instead.\n */\nexport interface ApiMockingCardToggleChange {\n  key: 'captureApiResponses' | 'renewApiResponses';\n  value: boolean;\n}\n\n/**\n * Dual-mode card summarising the API mocking configuration of a test case.\n *\n * The card surfaces **one boolean choice** — `restoreMock` — as two mutually-exclusive rows\n * labelled \"Capture API responses\" and \"Renew API responses\":\n *\n *   restoreMock === true   →   Renew = ON,  Capture = OFF\n *   restoreMock === false  →   Renew = OFF, Capture = ON\n *\n * In read-only mode both rows show a value text (\"On\"/\"Off\") derived from `restoreMock`.\n * In edit mode both rows render a toggle; interacting with either one flips `restoreMock`\n * and the card emits `restoreMockChange` so the parent can persist the new value.\n */\n@Component({\n  selector: 'cqa-api-mocking-card',\n  templateUrl: './api-mocking-card.component.html',\n  // Styles live in src/lib/styles/tailwind.css (the lib ships a single compiled stylesheet);\n  // per-component .scss files are not supported in the ng-packagr build for this lib.\n  styleUrls: [],\n  host: { class: 'cqa-ui-root' },\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class ApiMockingCardComponent {\n  @Input() title: string = 'API Mocking';\n  @Input() statusLabel: string = 'Not configured';\n\n  @Input() captureLabel: string = 'Use mock API responses';\n  @Input() captureHint: string = 'Uses stored responses on next run. Turn on after capture completes.';\n  @Input() renewLabel: string = 'Renew and store API responses';\n  @Input() renewHint: string = 'Re-captures fresh responses on next run. Turns off Use mock.';\n\n  /**\n   * Single source of truth for the card's dual-toggle state.\n   * Defaults to `false` → Capture is ON, Renew is OFF.\n   */\n  @Input() restoreMock: boolean = false;\n\n  @Input() mockedApisCount: number = 0;\n  @Input() totalApisCount: number = 0;\n  @Input() progressPercent: number = 0;\n\n  @Input() summaryText?: string;\n  @Input() percentText?: string;\n\n  @Input() configureButtonLabel: string = 'Configure Mock APIs';\n  @Input() editing: boolean = false;\n\n  /**\n   * Controls whether the \"Mocked X of Y / progress bar / percent\" block is shown.\n   * Hidden when the test case has no captured mock summary yet (and always hidden in\n   * edit mode regardless of this flag).\n   */\n  @Input() showProgress: boolean = false;\n\n  /** Hint shown in read-only mode when no mock data exists yet (`showProgress` is false). */\n  @Input() noDataHint: string = 'Run this test once to capture API responses first.';\n\n  @Output() configure = new EventEmitter<void>();\n  /**\n   * Emitted whenever the effective `restoreMock` value changes (either row's toggle was\n   * interacted with in edit mode). Parent components should persist this value — e.g. under\n   * `testCase.mockApiSettings.restoreMock`.\n   */\n  @Output() restoreMockChange = new EventEmitter<boolean>();\n\n  // Derived per-row state (template binds these directly so the two rows stay in lock-step).\n  get renewEnabled(): boolean { return this.restoreMock; }\n  get captureEnabled(): boolean { return !this.restoreMock; }\n  get renewValueText(): string { return this.restoreMock ? 'On' : 'Off'; }\n  get captureValueText(): string { return this.restoreMock ? 'Off' : 'On'; }\n\n  get computedSummaryText(): string {\n    if (this.summaryText) return this.summaryText;\n    return `${this.mockedApisCount} of ${this.totalApisCount} APIs set to mock`;\n  }\n\n  get computedPercentText(): string {\n    if (this.percentText) return this.percentText;\n    return `${this.progressPercent}% of calls will use mock responses`;\n  }\n\n  get progressWidth(): string {\n    const clamped = Math.max(0, Math.min(100, Number(this.progressPercent) || 0));\n    return `${clamped}%`;\n  }\n\n  onConfigureClick(): void {\n    this.configure.emit();\n  }\n\n  /**\n   * User interacted with the \"Renew API responses\" toggle in edit mode.\n   * Renew ON  → restoreMock = true  (Capture OFF).\n   * Renew OFF → restoreMock = false (Capture ON — mutual exclusivity).\n   */\n  onRenewToggle(value: boolean): void {\n    this.setRestoreMock(value);\n  }\n\n  /**\n   * User interacted with the \"Capture API responses\" toggle in edit mode.\n   * Capture ON  → restoreMock = false (Renew OFF).\n   * Capture OFF → restoreMock = true  (Renew ON — mutual exclusivity).\n   */\n  onCaptureToggle(value: boolean): void {\n    this.setRestoreMock(!value);\n  }\n\n  private setRestoreMock(next: boolean): void {\n    if (this.restoreMock === next) return;\n    this.restoreMock = next;\n    this.restoreMockChange.emit(next);\n  }\n}\n","<div class=\"cqa-amc-card\">\n  <div class=\"cqa-amc-header\">\n    <span class=\"cqa-amc-title\">{{ title }}</span>\n    <span class=\"cqa-amc-status\" *ngIf=\"!showProgress &&statusLabel\">{{ statusLabel }}</span>\n  </div>\n\n  <!-- Read-only rows -->\n  <ng-container *ngIf=\"!editing\">\n    <div class=\"cqa-amc-row\">\n      <span class=\"cqa-amc-label\">{{ captureLabel }}</span>\n      <span class=\"cqa-amc-value\">{{ captureValueText }}</span>\n    </div>\n    <div class=\"cqa-amc-row\">\n      <span class=\"cqa-amc-label\">{{ renewLabel }}</span>\n      <span class=\"cqa-amc-value\">{{ renewValueText }}</span>\n    </div>\n  </ng-container>\n\n  <!-- Edit rows: toggles with hint text -->\n  <ng-container *ngIf=\"editing\">\n    <div class=\"cqa-amc-edit-block\">\n      <div class=\"cqa-amc-row cqa-amc-row--edit\">\n        <cqa-custom-toggle\n          [checked]=\"captureEnabled\"\n          [ariaLabel]=\"captureLabel\"\n          (checkedChange)=\"onCaptureToggle($event)\">\n        </cqa-custom-toggle>\n        <span class=\"cqa-amc-label\">{{ captureLabel }}</span>\n      </div>\n      <p *ngIf=\"captureHint\" class=\"cqa-amc-edit-hint\">{{ captureHint }}</p>\n    </div>\n    <div class=\"cqa-amc-edit-block\">\n      <div class=\"cqa-amc-row cqa-amc-row--edit\">\n        <cqa-custom-toggle\n          [checked]=\"renewEnabled\"\n          [ariaLabel]=\"renewLabel\"\n          (checkedChange)=\"onRenewToggle($event)\">\n        </cqa-custom-toggle>\n        <span class=\"cqa-amc-label\">{{ renewLabel }}</span>\n      </div>\n      <p *ngIf=\"renewHint\" class=\"cqa-amc-edit-hint\">{{ renewHint }}</p>\n    </div>\n  </ng-container>\n\n  <ng-container *ngIf=\"showProgress && !editing\">\n    <p class=\"cqa-amc-summary\">{{ computedSummaryText }}</p>\n    <div class=\"cqa-amc-progress-track\">\n      <div class=\"cqa-amc-progress-fill\" [style.width]=\"progressWidth\"></div>\n    </div>\n    <p class=\"cqa-amc-percent\">{{ computedPercentText }}</p>\n  </ng-container>\n\n  <!-- Hint: no mock data yet — nudge the user to run the test first -->\n  <p *ngIf=\"!showProgress && !editing\" class=\"cqa-amc-no-data-hint\">{{ noDataHint }}</p>\n\n  <button\n    *ngIf=\"!editing\"\n    [disabled]=\"!showProgress\"\n    type=\"button\"\n    class=\"cqa-amc-configure-btn\"\n    (click)=\"onConfigureClick()\">\n    {{ configureButtonLabel }}\n  </button>\n</div>\n"]}
147
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"api-mocking-card.component.js","sourceRoot":"","sources":["../../../../../../src/lib/test-case-details/api-mocking-card/api-mocking-card.component.ts","../../../../../../src/lib/test-case-details/api-mocking-card/api-mocking-card.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output } from '@angular/core';\n\n/**\n * Legacy toggle-change payload kept for back-compat with consumers that haven't migrated\n * to `restoreMockChange` yet. `key` identifies which row was toggled; `value` is the new\n * checked state of that row. New code should listen to `restoreMockChange` instead.\n */\nexport interface ApiMockingCardToggleChange {\n  key: 'captureApiResponses' | 'renewApiResponses';\n  value: boolean;\n}\n\n/**\n * Dual-mode card summarising the API mocking configuration of a test case.\n *\n * The card surfaces TWO independent flags — `restoreMock` (the \"Use mock API responses\" row)\n * and `storeMock` (the \"Renew and store API responses\" row). Both can be off simultaneously\n * (no mocking on the next run); turning either one on forces the other off (they're mutually\n * exclusive in the on-state). Both can never be on at the same time.\n *\n * In read-only mode each row shows On/Off derived from its own flag. In edit mode each row\n * renders a toggle; the card emits `restoreMockChange` and `storeMockChange` whenever a value\n * actually changes so the parent can persist them.\n */\n@Component({\n  selector: 'cqa-api-mocking-card',\n  templateUrl: './api-mocking-card.component.html',\n  // Styles live in src/lib/styles/tailwind.css (the lib ships a single compiled stylesheet);\n  // per-component .scss files are not supported in the ng-packagr build for this lib.\n  styleUrls: [],\n  host: { class: 'cqa-ui-root' },\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class ApiMockingCardComponent {\n  @Input() title: string = 'API Mocking';\n  @Input() statusLabel: string = 'Not configured';\n\n  @Input() captureLabel: string = 'Use mock API responses';\n  @Input() captureHint: string = 'Uses stored responses on next run. Turn on after capture completes.';\n  @Input() renewLabel: string = 'Renew and store API responses';\n  @Input() renewHint: string = 'Re-captures fresh responses on next run. Turns off Use mock.';\n\n  /** \"Use mock API responses\" row state. Mutually exclusive with `storeMock` when true. */\n  @Input() restoreMock: boolean = false;\n  /** \"Renew and store API responses\" row state. Mutually exclusive with `restoreMock` when true. */\n  @Input() storeMock: boolean = false;\n\n  @Input() mockedApisCount: number = 0;\n  @Input() totalApisCount: number = 0;\n  @Input() progressPercent: number = 0;\n\n  @Input() summaryText?: string;\n  @Input() percentText?: string;\n\n  @Input() configureButtonLabel: string = 'Configure Mock APIs';\n  @Input() editing: boolean = false;\n\n  /**\n   * Controls whether the \"Mocked X of Y / progress bar / percent\" block is shown.\n   * Hidden when the test case has no captured mock summary yet (and always hidden in\n   * edit mode regardless of this flag).\n   */\n  @Input() showProgress: boolean = false;\n\n  /** Hint shown in read-only mode when no mock data exists yet (`showProgress` is false). */\n  @Input() noDataHint: string = 'Run this test once to capture API responses first.';\n\n  @Output() configure = new EventEmitter<void>();\n  /** Emitted whenever `restoreMock` changes (Use-mock row toggled). */\n  @Output() restoreMockChange = new EventEmitter<boolean>();\n  /** Emitted whenever `storeMock` changes (Renew-and-store row toggled). */\n  @Output() storeMockChange = new EventEmitter<boolean>();\n\n  // Per-row derived display state — each row reflects its own flag now.\n  get captureEnabled(): boolean { return this.restoreMock; }\n  get renewEnabled(): boolean { return this.storeMock; }\n  get captureValueText(): string { return this.restoreMock ? 'On' : 'Off'; }\n  get renewValueText(): string { return this.storeMock ? 'On' : 'Off'; }\n\n  get computedSummaryText(): string {\n    if (this.summaryText) return this.summaryText;\n    return `${this.mockedApisCount} of ${this.totalApisCount} APIs set to mock`;\n  }\n\n  get computedPercentText(): string {\n    if (this.percentText) return this.percentText;\n    return `${this.progressPercent}% of calls will use mock responses`;\n  }\n\n  get progressWidth(): string {\n    const clamped = Math.max(0, Math.min(100, Number(this.progressPercent) || 0));\n    return `${clamped}%`;\n  }\n\n  onConfigureClick(): void {\n    this.configure.emit();\n  }\n\n  /**\n   * \"Use mock API responses\" toggle. Turning it on forces `storeMock` off (mutual exclusivity);\n   * turning it off leaves the other row alone.\n   */\n  onCaptureToggle(value: boolean): void {\n    if (value && this.storeMock) this.setStoreMock(false);\n    this.setRestoreMock(value);\n  }\n\n  /**\n   * \"Renew and store API responses\" toggle. Turning it on forces `restoreMock` off; turning\n   * it off leaves the other row alone.\n   */\n  onRenewToggle(value: boolean): void {\n    if (value && this.restoreMock) this.setRestoreMock(false);\n    this.setStoreMock(value);\n  }\n\n  private setRestoreMock(next: boolean): void {\n    if (this.restoreMock === next) return;\n    this.restoreMock = next;\n    this.restoreMockChange.emit(next);\n  }\n\n  private setStoreMock(next: boolean): void {\n    if (this.storeMock === next) return;\n    this.storeMock = next;\n    this.storeMockChange.emit(next);\n  }\n}\n","<div class=\"cqa-amc-card\">\n  <div class=\"cqa-amc-header\">\n    <span class=\"cqa-amc-title\">{{ title }}</span>\n    <span class=\"cqa-amc-status\" *ngIf=\"!showProgress &&statusLabel\">{{ statusLabel }}</span>\n  </div>\n\n  <!-- Read-only rows -->\n  <ng-container *ngIf=\"!editing\">\n    <div class=\"cqa-amc-row\">\n      <span class=\"cqa-amc-label\">{{ captureLabel }}</span>\n      <span class=\"cqa-amc-value\">{{ captureValueText }}</span>\n    </div>\n    <div class=\"cqa-amc-row\">\n      <span class=\"cqa-amc-label\">{{ renewLabel }}</span>\n      <span class=\"cqa-amc-value\">{{ renewValueText }}</span>\n    </div>\n  </ng-container>\n\n  <!-- Edit rows: toggles with hint text -->\n  <ng-container *ngIf=\"editing\">\n    <div class=\"cqa-amc-edit-block\">\n      <div class=\"cqa-amc-row cqa-amc-row--edit\">\n        <cqa-custom-toggle\n          [checked]=\"captureEnabled\"\n          [ariaLabel]=\"captureLabel\"\n          (checkedChange)=\"onCaptureToggle($event)\">\n        </cqa-custom-toggle>\n        <span class=\"cqa-amc-label\">{{ captureLabel }}</span>\n      </div>\n      <p *ngIf=\"captureHint\" class=\"cqa-amc-edit-hint\">{{ captureHint }}</p>\n    </div>\n    <div class=\"cqa-amc-edit-block\">\n      <div class=\"cqa-amc-row cqa-amc-row--edit\">\n        <cqa-custom-toggle\n          [checked]=\"renewEnabled\"\n          [ariaLabel]=\"renewLabel\"\n          (checkedChange)=\"onRenewToggle($event)\">\n        </cqa-custom-toggle>\n        <span class=\"cqa-amc-label\">{{ renewLabel }}</span>\n      </div>\n      <p *ngIf=\"renewHint\" class=\"cqa-amc-edit-hint\">{{ renewHint }}</p>\n    </div>\n  </ng-container>\n\n  <ng-container *ngIf=\"showProgress && !editing\">\n    <p class=\"cqa-amc-summary\">{{ computedSummaryText }}</p>\n    <div class=\"cqa-amc-progress-track\">\n      <div class=\"cqa-amc-progress-fill\" [style.width]=\"progressWidth\"></div>\n    </div>\n    <p class=\"cqa-amc-percent\">{{ computedPercentText }}</p>\n  </ng-container>\n\n  <!-- Hint: no mock data yet — nudge the user to run the test first -->\n  <p *ngIf=\"!showProgress && !editing\" class=\"cqa-amc-no-data-hint\">{{ noDataHint }}</p>\n\n  <button\n    *ngIf=\"!editing\"\n    [disabled]=\"!showProgress\"\n    type=\"button\"\n    class=\"cqa-amc-configure-btn\"\n    (click)=\"onConfigureClick()\">\n    {{ configureButtonLabel }}\n  </button>\n</div>\n"]}