@cqa-lib/cqa-ui 1.1.190 → 1.1.192

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.
@@ -16,6 +16,152 @@ export const API_EDIT_STEP_LABELS = {
16
16
  const METHODS_WITHOUT_BODY = ['GET', 'HEAD', 'DELETE'];
17
17
  /** Auto-close pairs for payload JSON editor: opening char -> closing char. */
18
18
  const PAYLOAD_AUTO_CLOSE_PAIRS = { '{': '}', '[': ']', '"': '"', "'": "'" };
19
+ function isSingleQuote(ch) {
20
+ return ch === "'" || ch === '\u2018' || ch === '\u2019';
21
+ }
22
+ function isDoubleQuote(ch) {
23
+ return ch === '"' || ch === '\u201C' || ch === '\u201D';
24
+ }
25
+ function isClosingQuote(ch, openQuote) {
26
+ if (isSingleQuote(openQuote))
27
+ return isSingleQuote(ch);
28
+ if (isDoubleQuote(openQuote))
29
+ return isDoubleQuote(ch);
30
+ return ch === openQuote;
31
+ }
32
+ /**
33
+ * Tokenize a string respecting single- and double-quoted segments (for cURL args).
34
+ * Handles straight and smart/curly quotes so pasted cURLs from browsers/docs work.
35
+ */
36
+ function tokenizeCurlLine(line) {
37
+ const tokens = [];
38
+ let i = 0;
39
+ const n = line.length;
40
+ while (i < n) {
41
+ while (i < n && /\s/.test(line[i]))
42
+ i++;
43
+ if (i >= n)
44
+ break;
45
+ const ch = line[i];
46
+ if (isSingleQuote(ch) || isDoubleQuote(ch)) {
47
+ const quote = ch;
48
+ i++;
49
+ let value = '';
50
+ while (i < n && !isClosingQuote(line[i], quote)) {
51
+ if (line[i] === '\\') {
52
+ i++;
53
+ if (i < n)
54
+ value += line[i++];
55
+ }
56
+ else {
57
+ value += line[i++];
58
+ }
59
+ }
60
+ if (i < n)
61
+ i++;
62
+ tokens.push(value);
63
+ continue;
64
+ }
65
+ let word = '';
66
+ while (i < n && !/\s/.test(line[i]) && !isSingleQuote(line[i]) && !isDoubleQuote(line[i])) {
67
+ word += line[i++];
68
+ }
69
+ if (word)
70
+ tokens.push(word);
71
+ }
72
+ return tokens;
73
+ }
74
+ /** Strip one layer of surrounding single or double quotes from a string (e.g. '{"x":1}' -> {"x":1}). */
75
+ function stripSurroundingQuotes(s) {
76
+ if (s.length >= 2 && (s.startsWith("'") && s.endsWith("'")) || (s.startsWith('"') && s.endsWith('"'))) {
77
+ return s.slice(1, -1);
78
+ }
79
+ return s;
80
+ }
81
+ /**
82
+ * Parse a cURL command string and return method, url, headers, and body.
83
+ * Supports -X/--request, -H/--header, -d/--data/--data-raw/--data-binary, and URL.
84
+ * Handles line continuations (backslash-newline) and quoted body payloads.
85
+ */
86
+ function parseCurl(curlString) {
87
+ const raw = (curlString ?? '').trim();
88
+ if (!raw)
89
+ return null;
90
+ // Remove line continuations (backslash followed by newline) so they don't break tokenization
91
+ const noContinuations = raw.replace(/\\\s*\r?\n\s*/g, ' ');
92
+ const normalized = noContinuations.replace(/\r?\n/g, ' ').replace(/\s+/g, ' ');
93
+ const tokens = tokenizeCurlLine(normalized);
94
+ let method = 'GET';
95
+ let url = '';
96
+ const headers = [];
97
+ let body = '';
98
+ const urlPattern = /^https?:\/\//i;
99
+ for (let i = 0; i < tokens.length; i++) {
100
+ const t = tokens[i];
101
+ const consumeNext = () => {
102
+ i++;
103
+ return tokens[i];
104
+ };
105
+ if (t === '-X' || t === '--request') {
106
+ const value = consumeNext();
107
+ if (value)
108
+ method = value.toUpperCase();
109
+ continue;
110
+ }
111
+ if (t === '-H' || t === '--header') {
112
+ const value = consumeNext();
113
+ if (value) {
114
+ const colon = value.indexOf(':');
115
+ if (colon !== -1) {
116
+ const name = value.slice(0, colon).trim();
117
+ const headerValue = value.slice(colon + 1).trim();
118
+ if (name)
119
+ headers.push({ name, type: 'string', value: headerValue });
120
+ }
121
+ }
122
+ continue;
123
+ }
124
+ if (t === '-d' || t === '--data' || t === '--data-raw' || t === '--data-binary' || t === '--data-ascii') {
125
+ const value = consumeNext();
126
+ if (value != null && !String(value).startsWith('@'))
127
+ body = stripSurroundingQuotes(value);
128
+ continue;
129
+ }
130
+ if (t.startsWith('--data=')) {
131
+ const value = t.slice(7);
132
+ if (!value.startsWith('@'))
133
+ body = stripSurroundingQuotes(value.replace(/^["']|["']$/g, ''));
134
+ continue;
135
+ }
136
+ if (t.startsWith('--data-raw=')) {
137
+ const value = t.slice(11);
138
+ if (!value.startsWith('@'))
139
+ body = stripSurroundingQuotes(value.replace(/^["']|["']$/g, ''));
140
+ continue;
141
+ }
142
+ if (t.startsWith('-d')) {
143
+ const value = t.length > 2 ? t.slice(2) : consumeNext();
144
+ if (value != null && !value.startsWith('@'))
145
+ body = stripSurroundingQuotes(value);
146
+ continue;
147
+ }
148
+ if (urlPattern.test(t)) {
149
+ if (!url)
150
+ url = t;
151
+ }
152
+ }
153
+ if (!url) {
154
+ const firstUrl = tokens.find((tok) => urlPattern.test(tok));
155
+ if (firstUrl)
156
+ url = firstUrl;
157
+ }
158
+ // Many cURLs (e.g. from browser devtools) omit -X POST when sending a body; infer POST
159
+ const finalMethod = (method || 'GET').toUpperCase();
160
+ if (body && (finalMethod === 'GET' || finalMethod === 'HEAD')) {
161
+ return { method: 'POST', url, headers, body };
162
+ }
163
+ return { method: finalMethod, url, headers, body };
164
+ }
19
165
  export class ApiEditStepComponent {
20
166
  constructor(fb, cdr) {
21
167
  this.fb = fb;
@@ -27,6 +173,8 @@ export class ApiEditStepComponent {
27
173
  /** Emits when user clicks Send Request, with environment, method, url, and headers. */
28
174
  this.sendRequest = new EventEmitter();
29
175
  this.back = new EventEmitter();
176
+ /** Emits when user clicks the Cancel button (step 1). */
177
+ this.cancel = new EventEmitter();
30
178
  this.next = new EventEmitter();
31
179
  /** Emits when user clicks Create with all entered details: step1 (environment, HTTP method, URL, headers, body), step2 (variable name), step3 (verifications). */
32
180
  this.create = new EventEmitter();
@@ -64,16 +212,41 @@ export class ApiEditStepComponent {
64
212
  searchable: false,
65
213
  options: [],
66
214
  };
215
+ /** Auth type options: array of strings or objects with id, name, value, label (passed from parent). Falls back to built-in list when empty. */
216
+ this.authTypeOptions = [];
217
+ /** Config for Auth Type dropdown (updated when authTypeOptions changes, like environment) */
218
+ this.authTypeSelectConfig = {
219
+ key: 'authType',
220
+ placeholder: 'No Auth',
221
+ searchable: false,
222
+ options: [],
223
+ };
224
+ /** Bearer token value (Authorization tab, when auth type is Bearer Token). */
225
+ this.bearerToken = '';
226
+ this.oauth2GrantTypeSelectConfig = {
227
+ key: 'grantType',
228
+ placeholder: 'Select grant type',
229
+ searchable: false,
230
+ options: [...ApiEditStepComponent.OAUTH_GRANT_TYPE_OPTIONS],
231
+ };
232
+ this.oauth2ClientAuthSelectConfig = {
233
+ key: 'clientAuthentication',
234
+ placeholder: 'Select method',
235
+ searchable: false,
236
+ options: [...ApiEditStepComponent.OAUTH_CLIENT_AUTH_OPTIONS],
237
+ };
67
238
  /** Cached environment value from last selection (so Create payload has the selected value). */
68
239
  this.currentEnvironmentValue = '';
69
240
  /** Cached HTTP method from last selection (so Create payload has the selected value). */
70
241
  this.currentMethodValue = '';
71
- this.url = '';
242
+ this._url = '';
243
+ /** When true, params form changes should not update the URL (we're syncing from URL). */
244
+ this.paramsSyncingFromUrl = false;
72
245
  this.payloadTabs = [
246
+ { value: 'authorization', label: 'Authorization' },
73
247
  { value: 'headers', label: 'Headers' },
74
248
  { value: 'body', label: 'Body' },
75
249
  { value: 'params', label: 'Params' },
76
- { value: 'scripts', label: 'Scripts' },
77
250
  ];
78
251
  this.activePayloadTab = 'headers';
79
252
  /** Step 3: Response verification tabs */
@@ -82,7 +255,7 @@ export class ApiEditStepComponent {
82
255
  { value: 'status', label: 'Status' },
83
256
  ];
84
257
  this.activeResponseVerificationTab = 'response-body';
85
- /** Payload type for Body/Params/Scripts: raw, x-www-form-urlencoded, form-data */
258
+ /** Payload type for Body/Params/Authorization: raw, x-www-form-urlencoded, form-data */
86
259
  this.payloadType = 'raw';
87
260
  /** Segment options for payload type (used by cqa-segment-control) */
88
261
  this.payloadTypeSegments = [
@@ -99,7 +272,7 @@ export class ApiEditStepComponent {
99
272
  searchable: false,
100
273
  options: [...ApiEditStepComponent.DEFAULT_FORMAT_OPTIONS],
101
274
  };
102
- /** Payload text area value for Body/Params/Scripts */
275
+ /** Payload text area value for Body/Params/Authorization */
103
276
  this.payloadText = '';
104
277
  /** JSON parse error when format is JSON and payload is invalid; null when valid or not JSON. */
105
278
  this.payloadJsonError = null;
@@ -228,6 +401,30 @@ export class ApiEditStepComponent {
228
401
  .map((e) => ApiEditStepComponent.getOptionValue(e))
229
402
  .filter((v) => v != null);
230
403
  }
404
+ updateAuthTypeSelectConfig() {
405
+ const options = this.authTypeOptions?.length > 0
406
+ ? this.authTypeOptions.map((a) => ApiEditStepComponent.toSelectOption(a))
407
+ : [...ApiEditStepComponent.DEFAULT_AUTH_TYPE_OPTIONS];
408
+ this.authTypeSelectConfig = {
409
+ ...this.authTypeSelectConfig,
410
+ options,
411
+ };
412
+ }
413
+ getAuthTypeValues() {
414
+ const source = this.authTypeOptions?.length > 0
415
+ ? this.authTypeOptions
416
+ : ApiEditStepComponent.DEFAULT_AUTH_TYPE_OPTIONS;
417
+ return source
418
+ .map((a) => ApiEditStepComponent.getOptionValue(a))
419
+ .filter((v) => v != null);
420
+ }
421
+ /** Current auth type value (e.g. 'no-auth') for template */
422
+ get selectedAuthType() {
423
+ const v = this.authTypeForm?.get('authType')?.value;
424
+ if (v == null || v === '')
425
+ return 'no-auth';
426
+ return typeof v === 'object' ? (v?.value ?? v?.id ?? 'no-auth') : String(v);
427
+ }
231
428
  /** Current HTTP method (from form or default: first of httpMethodOptions). Treats empty string as unset. */
232
429
  get selectedMethod() {
233
430
  const value = this.methodForm?.get('method')?.value;
@@ -277,6 +474,21 @@ export class ApiEditStepComponent {
277
474
  : String(v)
278
475
  : '';
279
476
  }
477
+ /** URL for the request. Getter/setter syncs query params with the Params tab (Postman-style). */
478
+ get url() {
479
+ return this._url;
480
+ }
481
+ set url(value) {
482
+ const next = value ?? '';
483
+ if (this._url === next)
484
+ return;
485
+ this._url = next;
486
+ if (this.paramsFormArray) {
487
+ this.paramsSyncingFromUrl = true;
488
+ this.syncParamsFromUrl();
489
+ this.paramsSyncingFromUrl = false;
490
+ }
491
+ }
280
492
  onPayloadTypeChange(val) {
281
493
  this.payloadType = val;
282
494
  }
@@ -450,6 +662,9 @@ export class ApiEditStepComponent {
450
662
  get keyTypeValueRows() {
451
663
  return (this.keyTypeValueFormArray?.controls ?? []);
452
664
  }
665
+ get paramsRows() {
666
+ return (this.paramsFormArray?.controls ?? []);
667
+ }
453
668
  get verificationRows() {
454
669
  return (this.verificationFormArray?.controls ?? []);
455
670
  }
@@ -539,6 +754,20 @@ export class ApiEditStepComponent {
539
754
  this.environmentForm = this.fb.group({
540
755
  environment: [defaultEnv],
541
756
  });
757
+ this.updateAuthTypeSelectConfig();
758
+ const firstAuthValue = this.getAuthTypeValues()[0];
759
+ const defaultAuthType = this.initialAuthType ?? firstAuthValue ?? 'no-auth';
760
+ this.authTypeForm = this.fb.group({
761
+ authType: [defaultAuthType],
762
+ });
763
+ this.oauth2Form = this.fb.group({
764
+ grantType: ['client_credentials'],
765
+ accessTokenUrl: [''],
766
+ clientId: [''],
767
+ clientSecret: [''],
768
+ scope: [''],
769
+ clientAuthentication: ['basic'],
770
+ });
542
771
  this.environmentFormChangesSub = this.environmentForm.get('environment')?.valueChanges?.subscribe((v) => {
543
772
  const s = v != null && v !== '' ? (typeof v === 'object' ? ApiEditStepComponent.getOptionValue(v) : String(v)) : '';
544
773
  this.currentEnvironmentValue = s ?? '';
@@ -561,6 +790,16 @@ export class ApiEditStepComponent {
561
790
  this.payloadFormatForm = this.fb.group({ format: [defaultFormat] });
562
791
  this.buildKeyValueFormArray();
563
792
  this.buildKeyTypeValueFormArray();
793
+ this.buildParamsFormArray();
794
+ this.paramsFormArrayChangesSub = this.paramsFormArray.valueChanges?.subscribe(() => this.syncUrlFromParams());
795
+ if (this.initialUrl != null && this.initialUrl !== '') {
796
+ this._url = this.initialUrl;
797
+ this.syncParamsFromUrl();
798
+ }
799
+ // Initialize variableName from initialVariableName
800
+ if (this.initialVariableName != null && this.initialVariableName !== '') {
801
+ this.variableName = this.initialVariableName;
802
+ }
564
803
  this.updateVerificationSelectConfig();
565
804
  this.updateVerificationDataTypeSelectConfig();
566
805
  this.buildVerificationFormArray();
@@ -587,6 +826,7 @@ export class ApiEditStepComponent {
587
826
  this.headerNameOptionsChangesSub?.unsubscribe();
588
827
  this.environmentFormChangesSub?.unsubscribe();
589
828
  this.methodFormChangesSub?.unsubscribe();
829
+ this.paramsFormArrayChangesSub?.unsubscribe();
590
830
  }
591
831
  /** Sync line numbers column scroll with payload textarea scroll (Postman-style). */
592
832
  setupPayloadTextareaScrollSync() {
@@ -601,6 +841,9 @@ export class ApiEditStepComponent {
601
841
  textarea.addEventListener('scroll', () => {
602
842
  lineNumbersEl.scrollTop = textarea.scrollTop;
603
843
  });
844
+ lineNumbersEl.addEventListener('scroll', () => {
845
+ textarea.scrollTop = lineNumbersEl.scrollTop;
846
+ });
604
847
  }, 0);
605
848
  }
606
849
  buildKeyValueFormArray(rows) {
@@ -613,6 +856,109 @@ export class ApiEditStepComponent {
613
856
  const groups = initial.map((r) => this.fb.group({ key: [r.key], type: [r.type], value: [r.value] }));
614
857
  this.keyTypeValueFormArray = this.fb.array(groups);
615
858
  }
859
+ buildParamsFormArray(rows) {
860
+ const initial = rows ?? [{ key: '', value: '' }];
861
+ const groups = initial.map((r) => this.fb.group({ key: [r.key], value: [r.value] }));
862
+ if (this.paramsFormArray) {
863
+ this.paramsFormArray.clear();
864
+ groups.forEach((g) => this.paramsFormArray.push(g));
865
+ }
866
+ else {
867
+ this.paramsFormArray = this.fb.array(groups);
868
+ }
869
+ }
870
+ /** Parse URL into base (without query/fragment) and query key-value pairs. Preserves relative URLs. */
871
+ parseQueryParamsFromUrl(urlStr) {
872
+ const empty = { baseUrl: urlStr, rows: [{ key: '', value: '' }] };
873
+ if (!urlStr || !urlStr.trim())
874
+ return empty;
875
+ try {
876
+ const isAbsolute = /^https?:\/\//i.test(urlStr.trim());
877
+ const url = new URL(urlStr, 'http://localhost');
878
+ const baseUrl = isAbsolute ? url.origin + url.pathname : url.pathname;
879
+ const rows = [];
880
+ url.searchParams.forEach((value, key) => {
881
+ rows.push({ key, value });
882
+ });
883
+ if (rows.length === 0)
884
+ rows.push({ key: '', value: '' });
885
+ return { baseUrl, rows };
886
+ }
887
+ catch {
888
+ return empty;
889
+ }
890
+ }
891
+ /** Get base URL (without query/fragment) for building URL from params. Preserves relative URLs. */
892
+ getBaseUrl(urlStr) {
893
+ if (!urlStr || !urlStr.trim())
894
+ return urlStr;
895
+ try {
896
+ const isAbsolute = /^https?:\/\//i.test(urlStr.trim());
897
+ const url = new URL(urlStr, 'http://localhost');
898
+ return isAbsolute ? url.origin + url.pathname : url.pathname;
899
+ }
900
+ catch {
901
+ return urlStr;
902
+ }
903
+ }
904
+ /** Parse application/x-www-form-urlencoded body (key=value&...) into key-value rows. */
905
+ parseFormUrlEncodedBody(body) {
906
+ const trimmed = (body ?? '').trim();
907
+ if (!trimmed)
908
+ return [];
909
+ try {
910
+ const params = new URLSearchParams(trimmed);
911
+ const rows = [];
912
+ params.forEach((value, key) => rows.push({ key, value }));
913
+ return rows;
914
+ }
915
+ catch {
916
+ return [];
917
+ }
918
+ }
919
+ /**
920
+ * If form body has a single key whose value is URL-decoded JSON, return it pretty-printed for Raw body.
921
+ * Otherwise return null (caller keeps x-www-form-urlencoded view).
922
+ */
923
+ tryFormBodyValueAsRawJson(rows) {
924
+ if (rows.length !== 1 || !rows[0].value?.trim())
925
+ return null;
926
+ const value = rows[0].value.trim();
927
+ if (!(value.startsWith('{') || value.startsWith('[')))
928
+ return null;
929
+ try {
930
+ const parsed = JSON.parse(value);
931
+ return JSON.stringify(parsed, null, 2);
932
+ }
933
+ catch {
934
+ return null;
935
+ }
936
+ }
937
+ /** Update Params table from current URL query string (Postman-style). */
938
+ syncParamsFromUrl() {
939
+ const { baseUrl: _b, rows } = this.parseQueryParamsFromUrl(this._url);
940
+ this.buildParamsFormArray(rows);
941
+ this.cdr.markForCheck();
942
+ }
943
+ /** Update URL query string from Params table (Postman-style). */
944
+ syncUrlFromParams() {
945
+ if (this.paramsSyncingFromUrl || !this.paramsFormArray)
946
+ return;
947
+ const baseUrl = this.getBaseUrl(this._url);
948
+ const params = new URLSearchParams();
949
+ for (const c of this.paramsFormArray.controls) {
950
+ const key = (c.get('key')?.value ?? '').trim();
951
+ const value = c.get('value')?.value ?? '';
952
+ if (key !== '')
953
+ params.set(key, value);
954
+ }
955
+ const queryString = params.toString();
956
+ const newUrl = queryString ? `${baseUrl}?${queryString}` : baseUrl;
957
+ if (this._url !== newUrl) {
958
+ this._url = newUrl;
959
+ this.cdr.markForCheck();
960
+ }
961
+ }
616
962
  buildVerificationFormArray(rows) {
617
963
  const defaultVerification = this.getDefaultVerification();
618
964
  const defaultDataType = this.getDefaultDataType();
@@ -647,15 +993,152 @@ export class ApiEditStepComponent {
647
993
  this.headersFormArray = this.fb.array(groups);
648
994
  }
649
995
  }
650
- /** Handler: show import cURL panel (called when user clicks "Import API cURL"). */
996
+ /** Reset all three steps and all entered data to initial/default state. Used when user cancels on step 1. */
997
+ resetAllStepsAndData() {
998
+ this.currentStep = 1;
999
+ const firstMethodValue = this.httpMethodOptions?.length
1000
+ ? ApiEditStepComponent.getOptionValue(this.httpMethodOptions[0])
1001
+ : undefined;
1002
+ const defaultMethod = this.initialMethod ?? firstMethodValue ?? 'GET';
1003
+ const methodVal = typeof defaultMethod === 'string' ? defaultMethod : (ApiEditStepComponent.getOptionValue(defaultMethod) ?? '');
1004
+ this.currentMethodValue = methodVal ?? '';
1005
+ if (this.methodForm)
1006
+ this.methodForm.patchValue({ method: defaultMethod });
1007
+ const firstEnvValue = this.environmentOptions?.length
1008
+ ? ApiEditStepComponent.getOptionValue(this.environmentOptions[0])
1009
+ : undefined;
1010
+ const defaultEnv = this.initialEnvironment ?? firstEnvValue ?? 'Development';
1011
+ const envVal = typeof defaultEnv === 'string' ? defaultEnv : (ApiEditStepComponent.getOptionValue(defaultEnv) ?? '');
1012
+ this.currentEnvironmentValue = envVal ?? '';
1013
+ if (this.environmentForm)
1014
+ this.environmentForm.patchValue({ environment: defaultEnv });
1015
+ this.url = this.initialUrl ?? '';
1016
+ this.buildHeadersFormArray(this.initialHeaders ?? [{ name: '', type: 'string', value: '' }]);
1017
+ this.updateHeaderNameSelectConfig();
1018
+ this.headersChange.emit(this.headers);
1019
+ this.bodyView = 'headers';
1020
+ this.activePayloadTab = 'headers';
1021
+ this.payloadType = 'raw';
1022
+ this.payloadText = '';
1023
+ this.payloadJsonError = null;
1024
+ const defaultFormat = this.initialFormat ?? this.getFormatValues()[0] ?? 'json';
1025
+ if (this.payloadFormatForm)
1026
+ this.payloadFormatForm.patchValue({ format: defaultFormat });
1027
+ this.buildKeyValueFormArray();
1028
+ this.buildKeyTypeValueFormArray();
1029
+ this.buildParamsFormArray();
1030
+ this.importCurlControl.setValue('');
1031
+ this.variableName = '';
1032
+ this.variableNameError = '';
1033
+ this.buildVerificationFormArray();
1034
+ this.buildStatusVerificationFormArray();
1035
+ this.activeResponseVerificationTab = 'response-body';
1036
+ this.validatePayloadJson();
1037
+ this.cdr.detectChanges();
1038
+ }
1039
+ /** Handler: show import cURL panel (called when user clicks "Import API cURL"). Resets textarea so it is cleared each time. */
651
1040
  openImportCurlPanel() {
1041
+ this.importCurlControl.setValue('');
652
1042
  this.bodyView = 'import-curl';
653
1043
  this.cdr.detectChanges();
654
1044
  }
655
- /** Handler: emit cURL value from control and close panel. Called when user clicks Import button. */
1045
+ /** Reset URL, method, headers, body, and params to empty/default before applying imported cURL. */
1046
+ resetRequestFieldsBeforeCurlImport() {
1047
+ const firstMethodValue = this.httpMethodOptions?.length
1048
+ ? ApiEditStepComponent.getOptionValue(this.httpMethodOptions[0])
1049
+ : undefined;
1050
+ const defaultMethod = this.initialMethod ?? firstMethodValue ?? 'GET';
1051
+ this.selectedMethod = typeof defaultMethod === 'string' ? defaultMethod : (ApiEditStepComponent.getOptionValue(defaultMethod) ?? '') ?? 'GET';
1052
+ this.currentMethodValue = this.selectedMethod;
1053
+ if (this.methodForm)
1054
+ this.methodForm.patchValue({ method: defaultMethod });
1055
+ this.url = '';
1056
+ this.buildHeadersFormArray([{ name: '', type: 'string', value: '' }]);
1057
+ this.updateHeaderNameSelectConfig();
1058
+ this.headersChange.emit(this.headers);
1059
+ this.payloadType = 'raw';
1060
+ this.payloadText = '';
1061
+ this.payloadJsonError = null;
1062
+ const defaultFormat = this.initialFormat ?? this.getFormatValues()[0] ?? 'json';
1063
+ if (this.payloadFormatForm)
1064
+ this.payloadFormatForm.patchValue({ format: defaultFormat });
1065
+ this.buildKeyValueFormArray([{ key: '', value: '' }]);
1066
+ this.buildKeyTypeValueFormArray([{ key: '', type: 'text', value: '' }]);
1067
+ this.buildParamsFormArray([{ key: '', value: '' }]);
1068
+ this.validatePayloadJson();
1069
+ this.cdr.detectChanges();
1070
+ }
1071
+ /** Handler: parse cURL from control, bind to form fields, emit and close panel. Called when user clicks Import button. */
656
1072
  onImportCurlConfirm() {
657
1073
  const value = this.importCurlControl.value ?? '';
658
- this.importCurl.emit(typeof value === 'string' ? value : '');
1074
+ const curlStr = typeof value === 'string' ? value : '';
1075
+ this.importCurl.emit(curlStr);
1076
+ this.resetRequestFieldsBeforeCurlImport();
1077
+ const parsed = parseCurl(curlStr);
1078
+ if (parsed) {
1079
+ const methodValue = parsed.method && this.getMethodValues().includes(parsed.method)
1080
+ ? parsed.method
1081
+ : parsed.method || 'GET';
1082
+ this.selectedMethod = methodValue;
1083
+ this.currentMethodValue = methodValue;
1084
+ if (parsed.url)
1085
+ this.url = parsed.url;
1086
+ // Bind Authorization header to Authorization section when present (Bearer or other scheme)
1087
+ let headerRows = parsed.headers;
1088
+ const authHeader = headerRows.find((h) => h.name.toLowerCase() === 'authorization');
1089
+ if (authHeader?.value?.trim()) {
1090
+ const authValue = authHeader.value.trim();
1091
+ const bearerMatch = /^Bearer\s+(.+)$/i.exec(authValue);
1092
+ if (bearerMatch) {
1093
+ const token = bearerMatch[1].trim();
1094
+ if (this.getAuthTypeValues().includes('bearer') && this.authTypeForm) {
1095
+ this.authTypeForm.patchValue({ authType: 'bearer' });
1096
+ this.bearerToken = token;
1097
+ }
1098
+ headerRows = headerRows.filter((h) => h.name.toLowerCase() !== 'authorization');
1099
+ }
1100
+ }
1101
+ headerRows = headerRows.length > 0 ? headerRows : [{ name: '', type: 'string', value: '' }];
1102
+ this.buildHeadersFormArray(headerRows);
1103
+ this.updateHeaderNameSelectConfig();
1104
+ this.headersChange.emit(this.headers);
1105
+ if (parsed.body) {
1106
+ const contentType = parsed.headers
1107
+ .find((h) => h.name.toLowerCase() === 'content-type')
1108
+ ?.value?.toLowerCase() ?? '';
1109
+ const isFormUrlEncoded = contentType.includes('application/x-www-form-urlencoded');
1110
+ if (isFormUrlEncoded) {
1111
+ const rows = this.parseFormUrlEncodedBody(parsed.body);
1112
+ this.buildKeyValueFormArray(rows.length > 0 ? rows : [{ key: '', value: '' }]);
1113
+ const decodedAsJson = this.tryFormBodyValueAsRawJson(rows);
1114
+ if (decodedAsJson != null) {
1115
+ this.payloadType = 'raw';
1116
+ this.payloadText = decodedAsJson;
1117
+ if (this.payloadFormatForm)
1118
+ this.payloadFormatForm.patchValue({ format: 'json' });
1119
+ this.validatePayloadJson();
1120
+ this.payloadJsonError = null;
1121
+ }
1122
+ else {
1123
+ this.payloadType = 'x-www-form-urlencoded';
1124
+ this.payloadText = '';
1125
+ this.payloadJsonError = null;
1126
+ }
1127
+ }
1128
+ else {
1129
+ this.payloadText = parsed.body;
1130
+ this.validatePayloadJson();
1131
+ const trimmed = parsed.body.trim();
1132
+ if ((trimmed.startsWith('{') && trimmed.endsWith('}')) || (trimmed.startsWith('[') && trimmed.endsWith(']'))) {
1133
+ const formatValues = this.getFormatValues();
1134
+ if (formatValues.includes('json') && this.payloadFormatForm) {
1135
+ this.payloadFormatForm.patchValue({ format: 'json' });
1136
+ }
1137
+ }
1138
+ }
1139
+ }
1140
+ this.cdr.detectChanges();
1141
+ }
659
1142
  this.closeImportCurlPanel();
660
1143
  }
661
1144
  /** Handler: emit cancel and close panel. Called when user clicks Cancel in import cURL panel. */
@@ -686,9 +1169,15 @@ export class ApiEditStepComponent {
686
1169
  this.setStep(this.currentStep - 1);
687
1170
  }
688
1171
  else {
1172
+ this.resetAllStepsAndData();
689
1173
  this.back.emit();
690
1174
  }
691
1175
  }
1176
+ /** Called when user clicks the Cancel button (step 1). Emits cancel then runs normal back flow. */
1177
+ onCancel() {
1178
+ this.cancel.emit();
1179
+ this.onBack();
1180
+ }
692
1181
  onNext() {
693
1182
  if (this.currentStep === 2 && !this.variableName?.trim()) {
694
1183
  this.variableNameError = 'Variable Name is required.';
@@ -742,6 +1231,15 @@ export class ApiEditStepComponent {
742
1231
  trackByKeyTypeValue(index) {
743
1232
  return index;
744
1233
  }
1234
+ addParamsRow() {
1235
+ this.paramsFormArray.push(this.fb.group({ key: [''], value: [''] }));
1236
+ }
1237
+ removeParamsRow(index) {
1238
+ this.paramsFormArray.removeAt(index);
1239
+ }
1240
+ trackByParams(index) {
1241
+ return index;
1242
+ }
745
1243
  addVerificationRow() {
746
1244
  this.verificationFormArray.push(this.fb.group({
747
1245
  jsonPath: [''],
@@ -786,18 +1284,37 @@ export class ApiEditStepComponent {
786
1284
  }
787
1285
  /** Minimal payload when getCreatePayload throws (so create always emits). */
788
1286
  getCreatePayloadFallback() {
1287
+ const authType = this.selectedAuthType;
1288
+ const bearerToken = authType === 'bearer' ? (this.bearerToken ?? '') : undefined;
1289
+ let oauth2;
1290
+ if (authType === 'oauth2' && this.oauth2Form) {
1291
+ const grantType = ApiEditStepComponent.getControlValue(this.oauth2Form.get('grantType'));
1292
+ const clientAuth = ApiEditStepComponent.getControlValue(this.oauth2Form.get('clientAuthentication'));
1293
+ oauth2 = {
1294
+ grantType: grantType !== '' ? grantType : 'client_credentials',
1295
+ accessTokenUrl: (this.oauth2Form.get('accessTokenUrl')?.value ?? ''),
1296
+ clientId: (this.oauth2Form.get('clientId')?.value ?? ''),
1297
+ clientSecret: (this.oauth2Form.get('clientSecret')?.value ?? ''),
1298
+ scope: (this.oauth2Form.get('scope')?.value ?? ''),
1299
+ clientAuthentication: clientAuth !== '' ? clientAuth : 'basic',
1300
+ };
1301
+ }
789
1302
  return {
790
1303
  step1: {
791
1304
  environment: '',
792
1305
  method: '',
793
1306
  url: this.url ?? '',
794
1307
  headers: [],
1308
+ authType,
1309
+ ...(bearerToken !== undefined && { bearerToken }),
1310
+ ...(oauth2 !== undefined && { oauth2 }),
795
1311
  activePayloadTab: this.activePayloadTab,
796
1312
  payloadType: this.payloadType,
797
1313
  payloadFormat: '',
798
1314
  payloadText: this.payloadText ?? '',
799
1315
  keyValueRows: [],
800
1316
  keyTypeValueRows: [],
1317
+ paramsRows: [],
801
1318
  },
802
1319
  step2: { variableName: this.variableName ?? '' },
803
1320
  step3: {
@@ -832,6 +1349,11 @@ export class ApiEditStepComponent {
832
1349
  type: c.get('type')?.value ?? 'text',
833
1350
  value: c.get('value')?.value ?? '',
834
1351
  }));
1352
+ const paramsFormArray = this.paramsFormArray;
1353
+ const paramsRows = (paramsFormArray?.controls ?? []).map((c) => ({
1354
+ key: c.get('key')?.value ?? '',
1355
+ value: c.get('value')?.value ?? '',
1356
+ }));
835
1357
  const verificationFormArray = this.verificationFormArray;
836
1358
  const responseBodyVerifications = (verificationFormArray?.controls ?? []).map((c) => ({
837
1359
  jsonPath: c.get('jsonPath')?.value ?? '',
@@ -844,18 +1366,37 @@ export class ApiEditStepComponent {
844
1366
  verification: c.get('verification')?.value ?? '',
845
1367
  expectedValue: c.get('expectedValue')?.value ?? '',
846
1368
  }));
1369
+ const authType = this.selectedAuthType;
1370
+ const bearerToken = authType === 'bearer' ? (this.bearerToken ?? '') : undefined;
1371
+ let oauth2;
1372
+ if (authType === 'oauth2' && this.oauth2Form) {
1373
+ const grantType = ApiEditStepComponent.getControlValue(this.oauth2Form.get('grantType'));
1374
+ const clientAuth = ApiEditStepComponent.getControlValue(this.oauth2Form.get('clientAuthentication'));
1375
+ oauth2 = {
1376
+ grantType: grantType !== '' ? grantType : 'client_credentials',
1377
+ accessTokenUrl: (this.oauth2Form.get('accessTokenUrl')?.value ?? ''),
1378
+ clientId: (this.oauth2Form.get('clientId')?.value ?? ''),
1379
+ clientSecret: (this.oauth2Form.get('clientSecret')?.value ?? ''),
1380
+ scope: (this.oauth2Form.get('scope')?.value ?? ''),
1381
+ clientAuthentication: clientAuth !== '' ? clientAuth : 'basic',
1382
+ };
1383
+ }
847
1384
  return {
848
1385
  step1: {
849
1386
  environment,
850
1387
  method,
851
1388
  url: this.url ?? '',
852
1389
  headers: this.headers,
1390
+ authType,
1391
+ ...(bearerToken !== undefined && { bearerToken }),
1392
+ ...(oauth2 !== undefined && { oauth2 }),
853
1393
  activePayloadTab: this.activePayloadTab,
854
1394
  payloadType: this.payloadType,
855
1395
  payloadFormat: format,
856
1396
  payloadText: this.payloadText ?? '',
857
1397
  keyValueRows,
858
1398
  keyTypeValueRows,
1399
+ paramsRows,
859
1400
  },
860
1401
  step2: {
861
1402
  variableName: this.variableName ?? '',
@@ -918,6 +1459,33 @@ export class ApiEditStepComponent {
918
1459
  }
919
1460
  }
920
1461
  }
1462
+ if (changes['initialAuthType']?.currentValue != null && this.authTypeForm) {
1463
+ const v = changes['initialAuthType'].currentValue;
1464
+ const resolved = typeof v === 'string' ? v : ApiEditStepComponent.getOptionValue(v);
1465
+ if (resolved != null)
1466
+ this.authTypeForm.patchValue({ authType: v });
1467
+ }
1468
+ if (changes['authTypeOptions']) {
1469
+ this.updateAuthTypeSelectConfig();
1470
+ if (this.authTypeForm) {
1471
+ const values = this.getAuthTypeValues();
1472
+ if (values.length > 0) {
1473
+ const current = this.authTypeForm.get('authType')?.value;
1474
+ const currentVal = current != null && current !== ''
1475
+ ? typeof current === 'object'
1476
+ ? ApiEditStepComponent.getOptionValue(current)
1477
+ : String(current)
1478
+ : null;
1479
+ const valid = currentVal != null && values.includes(currentVal);
1480
+ if (!valid) {
1481
+ const firstValue = values[0];
1482
+ if (firstValue != null) {
1483
+ this.authTypeForm.patchValue({ authType: firstValue });
1484
+ }
1485
+ }
1486
+ }
1487
+ }
1488
+ }
921
1489
  if (changes['initialStep']) {
922
1490
  this.applyInitialStep(changes['initialStep'].currentValue);
923
1491
  }
@@ -940,6 +1508,9 @@ export class ApiEditStepComponent {
940
1508
  if (changes['initialFormat']?.currentValue != null && this.payloadFormatForm) {
941
1509
  this.payloadFormatForm.patchValue({ format: changes['initialFormat'].currentValue });
942
1510
  }
1511
+ if (changes['initialVariableName']?.currentValue != null) {
1512
+ this.variableName = changes['initialVariableName'].currentValue;
1513
+ }
943
1514
  if (changes['formatOptions']) {
944
1515
  this.updatePayloadFormatSelectConfig();
945
1516
  if (this.payloadFormatForm) {
@@ -993,6 +1564,24 @@ export class ApiEditStepComponent {
993
1564
  }
994
1565
  }
995
1566
  }
1567
+ /** Default options when authTypeOptions is empty (same shape as environment) */
1568
+ ApiEditStepComponent.DEFAULT_AUTH_TYPE_OPTIONS = [
1569
+ { id: 'no-auth', value: 'no-auth', name: 'No Auth', label: 'No Auth' },
1570
+ { id: 'bearer', value: 'bearer', name: 'Bearer Token', label: 'Bearer Token' },
1571
+ { id: 'oauth2', value: 'oauth2', name: 'OAuth 2.0', label: 'OAuth 2.0' },
1572
+ ];
1573
+ /** Grant type options for OAuth 2.0 */
1574
+ ApiEditStepComponent.OAUTH_GRANT_TYPE_OPTIONS = [
1575
+ { id: 'client_credentials', value: 'client_credentials', name: 'Client Credentials', label: 'Client Credentials' },
1576
+ { id: 'authorization_code', value: 'authorization_code', name: 'Authorization Code', label: 'Authorization Code' },
1577
+ { id: 'password', value: 'password', name: 'Password', label: 'Password' },
1578
+ { id: 'implicit', value: 'implicit', name: 'Implicit', label: 'Implicit' },
1579
+ ];
1580
+ /** Client authentication method options for OAuth 2.0 */
1581
+ ApiEditStepComponent.OAUTH_CLIENT_AUTH_OPTIONS = [
1582
+ { id: 'basic', value: 'basic', name: 'Send as Basic Auth header', label: 'Send as Basic Auth header' },
1583
+ { id: 'body', value: 'body', name: 'Send in body', label: 'Send in body' },
1584
+ ];
996
1585
  ApiEditStepComponent.DEFAULT_FORMAT_OPTIONS = [
997
1586
  { id: 'json', value: 'json', name: 'JSON', label: 'JSON' },
998
1587
  { id: 'xml', value: 'xml', name: 'XML', label: 'XML' },
@@ -1006,7 +1595,7 @@ ApiEditStepComponent.DEFAULT_HEADER_NAME_OPTIONS = [
1006
1595
  'Accept-Language',
1007
1596
  'Access-Control-Request-Headers',
1008
1597
  'Access-Control-Request-Method',
1009
- 'Authorization',
1598
+ 'Scripts',
1010
1599
  'Cache-Control',
1011
1600
  'Content-MD5',
1012
1601
  'Content-Length',
@@ -1064,10 +1653,10 @@ ApiEditStepComponent.DEFAULT_STATUS_VERIFICATION_OPTIONS = [
1064
1653
  { id: 'greater-than', value: 'greater-than', name: 'Greater than', label: 'Greater than' },
1065
1654
  ];
1066
1655
  ApiEditStepComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: ApiEditStepComponent, deps: [{ token: i1.FormBuilder }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
1067
- ApiEditStepComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.4.0", type: ApiEditStepComponent, selector: "cqa-api-edit-step", inputs: { initialMethod: "initialMethod", initialEnvironment: "initialEnvironment", initialStep: "initialStep", initialUrl: "initialUrl", initialPayloadTab: "initialPayloadTab", initialHeaders: "initialHeaders", initialResponsePreview: "initialResponsePreview", httpMethodOptions: "httpMethodOptions", environmentOptions: "environmentOptions", formatOptions: "formatOptions", initialFormat: "initialFormat", headerNameOptions: "headerNameOptions", verificationOptions: "verificationOptions", verificationDataTypeOptions: "verificationDataTypeOptions", statusVerificationOptions: "statusVerificationOptions" }, outputs: { importCurl: "importCurl", importCurlCancel: "importCurlCancel", sendRequest: "sendRequest", back: "back", next: "next", create: "create", headersChange: "headersChange" }, host: { classAttribute: "cqa-ui-root" }, viewQueries: [{ propertyName: "payloadEditorWithLinesRef", first: true, predicate: ["payloadEditorWithLinesRef"], descendants: true }, { propertyName: "payloadTextareaRef", first: true, predicate: ["payloadTextareaRef"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<div class=\"cqa-api-edit-step-container\">\n <!-- Title -->\n <h2\n class=\"cqa-api-edit-step-title cqa-font-inter cqa-text-[12px] cqa-font-semibold cqa-leading-[100%] cqa-tracking-normal cqa-text-[#000000]\">\n Create API Test Step</h2>\n\n <!-- Step indicator: all three steps visible, active step highlighted (Postman-style) -->\n <div class=\"cqa-api-edit-step-indicator\">\n <ng-container *ngFor=\"let step of stepLabels; let i = index\">\n <cqa-button type=\"button\" variant=\"text\"\n customClass=\"cqa-api-edit-step-indicator-item cqa-api-edit-step-indicator-item--clickable\"\n [attr.aria-label]=\"'Step ' + step.index + ': ' + step.label\" [attr.aria-pressed]=\"step.index === currentStep\"\n (clicked)=\"setStep(step.index)\">\n <span class=\"cqa-api-edit-step-indicator-circle\"\n [class.cqa-api-edit-step-indicator-circle--active]=\"step.index === currentStep\">\n {{ step.index }}\n </span>\n <span class=\"cqa-api-edit-step-indicator-label\"\n [class.cqa-api-edit-step-indicator-label--active]=\"step.index === currentStep\">\n {{ step.label }}\n </span>\n <div *ngIf=\"i < stepLabels.length - 1\" class=\"cqa-api-edit-step-indicator-line\" aria-hidden=\"true\"></div>\n </cqa-button>\n </ng-container>\n </div>\n\n <!-- Step content viewport: smooth slide between steps -->\n <div class=\"cqa-api-edit-step-viewport\">\n <div class=\"cqa-api-edit-step-strip\" [style.transform]=\"'translateX(' + stripTranslatePercent + '%)'\">\n <!-- Step 1: Environment, request, body, response -->\n <div class=\"cqa-api-edit-step-panel\">\n <!-- Environment row: new line, select aligned right -->\n <div class=\"cqa-api-edit-step-environment-row\">\n <cqa-dynamic-select *ngIf=\"environmentForm\" [form]=\"environmentForm\" [config]=\"environmentSelectConfig\"\n class=\"cqa-api-edit-step-environment-select\" aria-label=\"Environment\"\n (selectionChange)=\"onEnvironmentSelectionChange($event)\">\n </cqa-dynamic-select>\n </div>\n\n <!-- Request row: method, URL, buttons -->\n <div class=\"cqa-api-edit-step-request-row\">\n <cqa-dynamic-select *ngIf=\"methodForm\" [form]=\"methodForm\" [config]=\"methodSelectConfig\"\n class=\"cqa-api-edit-step-method-select\" aria-label=\"HTTP method\"\n (selectionChange)=\"onMethodSelectionChange($event)\">\n </cqa-dynamic-select>\n <div class=\"cqa-api-edit-step-url-wrap\">\n <cqa-custom-input [(value)]=\"url\" [label]=\"''\" placeholder=\"\" [fullWidth]=\"true\" size=\"md\">\n </cqa-custom-input>\n </div>\n <div class=\"cqa-api-edit-step-import-curl-trigger\" style=\"display: contents\" (click)=\"openImportCurlPanel()\">\n <cqa-button type=\"button\" variant=\"outlined\" btnSize=\"lg\" text=\"Import API cURL\"\n customClass=\"cqa-api-edit-step-btn-outline cqa-font-inter cqa-text-[14px] cqa-font-semibold cqa-leading-[100%] cqa-tracking-normal cqa-text-[#414146]\">\n </cqa-button>\n </div>\n <cqa-button variant=\"filled\" btnSize=\"lg\" text=\"Send Request\" (clicked)=\"onSendRequest()\"\n customClass=\"cqa-api-edit-step-btn-primary cqa-font-inter cqa-text-[14px] cqa-font-semibold cqa-leading-[100%] cqa-tracking-normal cqa-text-[#FBFCFF]\">\n </cqa-button>\n </div>\n\n\n\n <!-- Body content: header section (default) OR import cURL section -->\n <ng-container *ngIf=\"bodyView === 'import-curl'\">\n <div class=\"cqa-api-edit-step-import-curl-panel\">\n <div class=\"cqa-api-edit-step-import-curl-header\">\n <h3 class=\"cqa-api-edit-step-import-curl-title\">Import API cURL</h3>\n </div>\n <div class=\"cqa-api-edit-step-import-curl-separator\"></div>\n <div class=\"cqa-api-edit-step-import-curl-body\">\n <cqa-custom-textarea [value]=\"importCurlControl.value\"\n (valueChange)=\"importCurlControl.setValue($event)\"\n placeholder=\"Paste your cURL command here (e.g., curl -X POST https://api.example.com/users)\"\n [fullWidth]=\"true\" [rows]=\"8\" resize=\"vertical\" size=\"md\"\n class=\"cqa-api-edit-step-import-curl-textarea\">\n </cqa-custom-textarea>\n </div>\n <div class=\"cqa-api-edit-step-import-curl-footer\">\n <cqa-button type=\"button\" variant=\"outlined\" btnSize=\"lg\" text=\"Cancel\"\n customClass=\"cqa-api-edit-step-import-curl-btn-cancel\" (clicked)=\"onCancelImportCurl()\"></cqa-button>\n <cqa-button type=\"button\" variant=\"filled\" btnSize=\"lg\" text=\"Import\"\n customClass=\"cqa-api-edit-step-import-curl-btn-import\" (clicked)=\"onImportCurlConfirm()\"></cqa-button>\n </div>\n </div>\n </ng-container>\n\n <ng-container *ngIf=\"bodyView === 'headers'\">\n <div class=\"cqa-api-edit-step-tabs-wrapper\">\n <div class=\"cqa-api-edit-step-tabs\">\n <cqa-button *ngFor=\"let tab of payloadTabs\" type=\"button\" variant=\"text\" [text]=\"tab.label\"\n [customClass]=\"'cqa-api-edit-step-tab' + (activePayloadTab === tab.value ? ' cqa-api-edit-step-tab--active' : '') + (isMethodWithoutBody && tab.value !== 'headers' ? ' cqa-api-edit-step-tab--disabled' : '')\"\n [disabled]=\"isMethodWithoutBody && tab.value !== 'headers'\"\n (clicked)=\"setPayloadTab(tab.value)\">\n </cqa-button>\n </div>\n\n <!-- Payload content (Headers) -->\n <div *ngIf=\"activePayloadTab === 'headers'\" class=\"cqa-api-edit-step-payload\">\n <div class=\"cqa-api-edit-step-headers-grid\">\n <span class=\"cqa-api-edit-step-headers-label\">Header Name</span>\n <span class=\"cqa-api-edit-step-headers-label\">Header Value</span>\n <span class=\"cqa-api-edit-step-headers-label cqa-api-edit-step-headers-label--empty\"\n aria-hidden=\"true\"></span>\n </div>\n <div *ngFor=\"let row of headerRows; let i = index; trackBy: trackByHeader\" [formGroup]=\"row\"\n class=\"cqa-api-edit-step-header-row\">\n <cqa-dynamic-select [form]=\"row\" [config]=\"headerNameSelectConfig\"\n (addCustomValue)=\"onHeaderNameAddCustomValue($event, row)\"\n class=\"cqa-api-edit-step-header-type-select cqa-w-full\">\n </cqa-dynamic-select>\n <cqa-custom-input [value]=\"row.get('value')?.value ?? ''\"\n (valueChange)=\"row.get('value')?.setValue($event)\" placeholder=\"Value\" [fullWidth]=\"true\" size=\"sm\"\n class=\"cqa-api-edit-step-header-value-input\" ariaLabel=\"Header value\">\n </cqa-custom-input>\n <cqa-button type=\"button\" variant=\"text\" [customClass]=\"'cqa-api-edit-step-header-delete'\"\n [tooltip]=\"'Remove header'\" (clicked)=\"removeHeader(i)\">\n <svg class=\"cqa-api-edit-step-header-delete-icon\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\"\n fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\" aria-hidden=\"true\">\n <path\n d=\"M10.6663 6V12.6667H5.33301V6H10.6663ZM9.66634 2H6.33301L5.66634 2.66667H3.33301V4H12.6663V2.66667H10.333L9.66634 2ZM11.9997 4.66667H3.99967V12.6667C3.99967 13.4 4.59967 14 5.33301 14H10.6663C11.3997 14 11.9997 13.4 11.9997 12.6667V4.66667Z\"\n fill=\"#F9BFBF\" />\n </svg>\n </cqa-button>\n </div>\n <div class=\"cqa-api-edit-step-add-header-wrap\">\n <cqa-button type=\"button\" variant=\"text\" text=\"+ Add Header\"\n [customClass]=\"'cqa-api-edit-step-add-header-link'\" (clicked)=\"addHeader()\">\n </cqa-button>\n </div>\n </div>\n\n <!-- Payload content (Body only): type, format, text area, Back/Next -->\n <div *ngIf=\"activePayloadTab === 'body'\"\n class=\"cqa-api-edit-step-payload cqa-api-edit-step-payload-editor\">\n <div class=\"cqa-api-edit-step-payload-type-row\">\n <span class=\"cqa-api-edit-step-payload-type-label\">Type</span>\n <div class=\"cqa-api-edit-step-payload-type-radios\">\n <cqa-segment-control [value]=\"payloadType\" [segments]=\"payloadTypeSegments\"\n (valueChange)=\"onPayloadTypeChange($event)\"\n class=\"cqa-api-edit-step-payload-type-segment\">\n </cqa-segment-control>\n </div>\n <div *ngIf=\"payloadType === 'raw'\" class=\"cqa-api-edit-step-payload-format-wrap\">\n <span class=\"cqa-api-edit-step-payload-format-label\">Format:</span>\n <cqa-dynamic-select *ngIf=\"payloadFormatForm\" [form]=\"payloadFormatForm\"\n [config]=\"payloadFormatSelectConfig\" class=\"cqa-api-edit-step-payload-format-select\"\n aria-label=\"Format\">\n </cqa-dynamic-select>\n </div>\n </div>\n <!-- Raw: text area with line numbers (Postman-style payload body) -->\n <div *ngIf=\"payloadType === 'raw'\" class=\"cqa-api-edit-step-payload-body\" #payloadEditorWithLinesRef>\n <div class=\"cqa-api-edit-step-payload-editor-with-lines\">\n <div class=\"cqa-api-edit-step-payload-line-numbers\" aria-hidden=\"true\">\n <span *ngFor=\"let n of payloadLineNumbers\" class=\"cqa-api-edit-step-payload-line-num\">\n <span *ngIf=\"payloadJsonError && payloadJsonError.line === n\"\n class=\"cqa-api-edit-step-payload-line-error-icon\" [title]=\"payloadJsonErrorTooltip\"\n aria-label=\"Parse error on this line\">\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"14\" height=\"14\" viewBox=\"0 0 14 14\" fill=\"none\" aria-hidden=\"true\">\n <circle cx=\"7\" cy=\"7\" r=\"6\" fill=\"#EF4444\"/>\n <path d=\"M4 4l6 6M10 4l-6 6\" stroke=\"white\" stroke-width=\"1.5\" stroke-linecap=\"round\"/>\n </svg>\n </span>\n <span class=\"cqa-api-edit-step-payload-line-num-text\">{{ n }}</span>\n </span>\n </div>\n <div class=\"cqa-api-edit-step-payload-textarea-cell\">\n <div class=\"cqa-api-edit-step-payload-textarea cqa-w-full cqa-flex cqa-flex-col cqa-min-h-0\"\n [ngClass]=\"{'cqa-api-edit-step-payload-textarea--error': payloadJsonError}\">\n <textarea #payloadTextareaRef\n class=\"cqa-api-edit-step-payload-textarea-input cqa-w-full cqa-resize-y cqa-outline-none cqa-box-border\"\n [ngClass]=\"{'cqa-api-edit-step-payload-textarea-input--error': payloadJsonError}\"\n [value]=\"payloadText\"\n [attr.rows]=\"10\"\n placeholder=\"\"\n [attr.aria-label]=\"'Payload'\"\n [attr.aria-invalid]=\"!!payloadJsonError\"\n (input)=\"onPayloadInput($event)\"\n (keydown)=\"onPayloadKeydown($event)\">\n </textarea>\n </div>\n </div>\n </div>\n <p *ngIf=\"payloadJsonError\" class=\"cqa-api-edit-step-payload-json-error-msg\">\n Invalid JSON format. Please check your syntax.\n </p>\n </div>\n\n <!-- x-www-form-urlencoded: Key\u2013Value rows, add/remove dynamically -->\n <div *ngIf=\"payloadType === 'x-www-form-urlencoded'\" class=\"cqa-api-edit-step-key-value\">\n <div class=\"cqa-api-edit-step-key-value-grid cqa-api-edit-step-key-value-header\">\n <span class=\"cqa-api-edit-step-key-value-label\">Key</span>\n <span class=\"cqa-api-edit-step-key-value-label\">Value</span>\n <span class=\"cqa-api-edit-step-key-value-label cqa-api-edit-step-key-value-label--empty\"\n aria-hidden=\"true\"></span>\n </div>\n <div *ngFor=\"let row of keyValueRows; let i = index; trackBy: trackByKeyValue\" [formGroup]=\"row\"\n class=\"cqa-api-edit-step-key-value-row\">\n <cqa-custom-input [value]=\"row.get('key')?.value ?? ''\"\n (valueChange)=\"row.get('key')?.setValue($event)\" placeholder=\"Key\" [fullWidth]=\"true\" size=\"sm\"\n class=\"cqa-api-edit-step-key-value-input\" ariaLabel=\"Key\">\n </cqa-custom-input>\n <cqa-custom-input [value]=\"row.get('value')?.value ?? ''\"\n (valueChange)=\"row.get('value')?.setValue($event)\" placeholder=\"Value\" [fullWidth]=\"true\" size=\"sm\"\n class=\"cqa-api-edit-step-key-value-input\" ariaLabel=\"Value\">\n </cqa-custom-input>\n <cqa-button type=\"button\" variant=\"text\" [customClass]=\"'cqa-api-edit-step-key-value-delete'\"\n [tooltip]=\"'Remove row'\" (clicked)=\"removeKeyValueRow(i)\">\n <svg class=\"cqa-api-edit-step-key-value-delete-icon\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\"\n fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\" aria-hidden=\"true\">\n <path\n d=\"M10.6663 6V12.6667H5.33301V6H10.6663ZM9.66634 2H6.33301L5.66634 2.66667H3.33301V4H12.6663V2.66667H10.333L9.66634 2ZM11.9997 4.66667H3.99967V12.6667C3.99967 13.4 4.59967 14 5.33301 14H10.6663C11.3997 14 11.9997 13.4 11.9997 12.6667V4.66667Z\"\n fill=\"#F9BFBF\" />\n </svg>\n </cqa-button>\n </div>\n <div class=\"cqa-api-edit-step-key-value-add-wrap\">\n <cqa-button type=\"button\" variant=\"filled\" btnSize=\"lg\" text=\"+ Add Row\"\n customClass=\"cqa-api-edit-step-key-value-add-btn\" (clicked)=\"addKeyValueRow()\">\n </cqa-button>\n </div>\n </div>\n\n <!-- Form Data: Key\u2013Type\u2013Value rows; Type is a dropdown (Text/File), add/remove dynamically -->\n <div *ngIf=\"payloadType === 'form-data'\" class=\"cqa-api-edit-step-key-type-value\">\n <div class=\"cqa-api-edit-step-key-type-value-header\">\n <span class=\"cqa-api-edit-step-key-type-value-label\">Key</span>\n <span class=\"cqa-api-edit-step-key-type-value-label\">Type</span>\n <span class=\"cqa-api-edit-step-key-type-value-label\">Value</span>\n <span class=\"cqa-api-edit-step-key-type-value-label cqa-api-edit-step-key-type-value-label--empty\"\n aria-hidden=\"true\"></span>\n </div>\n <div *ngFor=\"let row of keyTypeValueRows; let i = index; trackBy: trackByKeyTypeValue\" [formGroup]=\"row\"\n class=\"cqa-api-edit-step-key-type-value-row\">\n <cqa-custom-input [value]=\"row.get('key')?.value ?? ''\"\n (valueChange)=\"row.get('key')?.setValue($event)\" placeholder=\"Key\" [fullWidth]=\"true\" size=\"sm\"\n class=\"cqa-api-edit-step-key-type-value-input\" ariaLabel=\"Key\">\n </cqa-custom-input>\n <cqa-dynamic-select [form]=\"row\" [config]=\"keyTypeValueTypeSelectConfig\"\n class=\"cqa-api-edit-step-key-type-value-type-select cqa-w-full\">\n </cqa-dynamic-select>\n <cqa-custom-input [value]=\"row.get('value')?.value ?? ''\"\n (valueChange)=\"row.get('value')?.setValue($event)\" placeholder=\"Value\" [fullWidth]=\"true\" size=\"sm\"\n class=\"cqa-api-edit-step-key-type-value-input\" ariaLabel=\"Value\">\n </cqa-custom-input>\n <cqa-button type=\"button\" variant=\"text\" [customClass]=\"'cqa-api-edit-step-key-type-value-delete'\"\n [tooltip]=\"'Remove row'\" (clicked)=\"removeKeyTypeValueRow(i)\">\n <svg class=\"cqa-api-edit-step-key-type-value-delete-icon\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\"\n fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\" aria-hidden=\"true\">\n <path\n d=\"M10.6663 6V12.6667H5.33301V6H10.6663ZM9.66634 2H6.33301L5.66634 2.66667H3.33301V4H12.6663V2.66667H10.333L9.66634 2ZM11.9997 4.66667H3.99967V12.6667C3.99967 13.4 4.59967 14 5.33301 14H10.6663C11.3997 14 11.9997 13.4 11.9997 12.6667V4.66667Z\"\n fill=\"#F9BFBF\" />\n </svg>\n </cqa-button>\n </div>\n <div class=\"cqa-api-edit-step-key-type-value-add-wrap\">\n <cqa-button type=\"button\" variant=\"filled\" btnSize=\"lg\" text=\"+ Add Row\"\n customClass=\"cqa-api-edit-step-key-type-value-add-btn\" (clicked)=\"addKeyTypeValueRow()\">\n </cqa-button>\n </div>\n </div>\n </div>\n </div>\n </ng-container>\n\n </div>\n <!-- Step 2: Variable Name: input, validation, Back / Next -->\n <div class=\"cqa-api-edit-step-panel\">\n <div class=\"cqa-api-edit-step-variable-section\">\n <div class=\"cqa-api-edit-step-variable-input-wrap\">\n <cqa-custom-input [(value)]=\"variableName\" [label]=\"''\" placeholder=\"Variable Name\" [fullWidth]=\"true\"\n size=\"md\" (valueChange)=\"onVariableNameChange()\" aria-label=\"Variable Name\">\n </cqa-custom-input>\n </div>\n <p *ngIf=\"variableNameError\" class=\"cqa-api-edit-step-variable-error\" role=\"alert\">{{ variableNameError }}</p>\n </div>\n </div>\n <!-- Step 3: Response Body / Status tabs -->\n <div class=\"cqa-api-edit-step-panel\">\n <div class=\"cqa-api-edit-step-tabs-wrapper\">\n <div class=\"cqa-api-edit-step-tabs\">\n <cqa-button *ngFor=\"let tab of responseVerificationTabs\" type=\"button\" variant=\"text\" [text]=\"tab.label\"\n [customClass]=\"'cqa-api-edit-step-tab' + (activeResponseVerificationTab === tab.value ? ' cqa-api-edit-step-tab--active' : '')\"\n (clicked)=\"setResponseVerificationTab(tab.value)\">\n </cqa-button>\n </div>\n\n <!-- Response Body tab content: verification grid -->\n <div *ngIf=\"activeResponseVerificationTab === 'response-body'\" class=\"cqa-api-edit-step-step3-content\">\n <div class=\"cqa-api-edit-step-verification-header-row\">\n <span></span>\n <cqa-button type=\"button\" variant=\"text\" text=\"Add Verification\"\n customClass=\"cqa-api-edit-step-verification-add-link\" (clicked)=\"addVerificationRow()\">\n </cqa-button>\n </div>\n <div class=\"cqa-api-edit-step-verification\">\n <div class=\"cqa-api-edit-step-verification-grid cqa-api-edit-step-verification-grid-header\">\n <span class=\"cqa-api-edit-step-verification-label\">S.no</span>\n <span class=\"cqa-api-edit-step-verification-label\">JSON Path</span>\n <span class=\"cqa-api-edit-step-verification-label\">Verification</span>\n <span class=\"cqa-api-edit-step-verification-label\">Data Type</span>\n <span class=\"cqa-api-edit-step-verification-label\">Expected Value</span>\n <span class=\"cqa-api-edit-step-verification-label cqa-api-edit-step-verification-label--empty\"\n aria-hidden=\"true\"></span>\n </div>\n <div *ngFor=\"let row of verificationRows; let i = index; trackBy: trackByVerification\" [formGroup]=\"row\"\n class=\"cqa-api-edit-step-verification-row\">\n <span class=\"cqa-api-edit-step-verification-sno\">{{ i + 1 }}</span>\n <cqa-custom-input [value]=\"row.get('jsonPath')?.value ?? ''\"\n (valueChange)=\"row.get('jsonPath')?.setValue($event)\" placeholder=\"Json Path\" [fullWidth]=\"true\"\n size=\"sm\" class=\"cqa-api-edit-step-verification-input\" ariaLabel=\"JSON Path\">\n </cqa-custom-input>\n <cqa-dynamic-select [form]=\"row\" [config]=\"verificationSelectConfig\"\n class=\"cqa-api-edit-step-verification-select cqa-w-full\">\n </cqa-dynamic-select>\n <cqa-dynamic-select [form]=\"row\" [config]=\"verificationDataTypeSelectConfig\"\n class=\"cqa-api-edit-step-verification-select cqa-w-full\"\n (selectionChange)=\"onVerificationDataTypeChange(row, $event)\">\n </cqa-dynamic-select>\n <!-- Expected Value: text for String/Array/Object, number for Number, dropdown for Boolean -->\n <ng-container [ngSwitch]=\"row.get('dataType')?.value\">\n <cqa-dynamic-select *ngSwitchCase=\"'boolean'\" [form]=\"row\"\n [config]=\"verificationExpectedValueBooleanSelectConfig\"\n class=\"cqa-api-edit-step-verification-select cqa-api-edit-step-verification-expected-select cqa-w-full\">\n </cqa-dynamic-select>\n <cqa-custom-input *ngSwitchCase=\"'number'\" [value]=\"row.get('expectedValue')?.value ?? ''\"\n (valueChange)=\"row.get('expectedValue')?.setValue($event)\" placeholder=\"Expected Value (number)\"\n type=\"number\" [fullWidth]=\"true\" size=\"sm\"\n class=\"cqa-api-edit-step-verification-input cqa-api-edit-step-verification-expected-number\"\n ariaLabel=\"Expected Value\">\n </cqa-custom-input>\n <cqa-custom-input *ngSwitchDefault [value]=\"row.get('expectedValue')?.value ?? ''\"\n (valueChange)=\"row.get('expectedValue')?.setValue($event)\"\n placeholder=\"Expected Value in String\" [fullWidth]=\"true\" size=\"sm\"\n class=\"cqa-api-edit-step-verification-input\" ariaLabel=\"Expected Value\">\n </cqa-custom-input>\n </ng-container>\n <cqa-button type=\"button\" variant=\"text\" [customClass]=\"'cqa-api-edit-step-verification-delete'\"\n [tooltip]=\"'Remove row'\" (clicked)=\"removeVerificationRow(i)\">\n <svg class=\"cqa-api-edit-step-verification-delete-icon\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\"\n fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\" aria-hidden=\"true\">\n <path\n d=\"M10.6663 6V12.6667H5.33301V6H10.6663ZM9.66634 2H6.33301L5.66634 2.66667H3.33301V4H12.6663V2.66667H10.333L9.66634 2ZM11.9997 4.66667H3.99967V12.6667C3.99967 13.4 4.59967 14 5.33301 14H10.6663C11.3997 14 11.9997 13.4 11.9997 12.6667V4.66667Z\"\n fill=\"#F9BFBF\" />\n </svg>\n </cqa-button>\n </div>\n </div>\n </div>\n\n <!-- Status tab content: S.no, Verification dropdown, Expected Value, add/remove rows -->\n <div *ngIf=\"activeResponseVerificationTab === 'status'\" class=\"cqa-api-edit-step-step3-content\">\n <div class=\"cqa-api-edit-step-verification-header-row\">\n <span></span>\n <cqa-button type=\"button\" variant=\"text\" text=\"Add Verification\"\n customClass=\"cqa-api-edit-step-verification-add-link\" (clicked)=\"addStatusVerificationRow()\">\n </cqa-button>\n </div>\n <div class=\"cqa-api-edit-step-status-verification\">\n <div class=\"cqa-api-edit-step-status-verification-header\">\n <span class=\"cqa-api-edit-step-verification-label\">S.no</span>\n <span class=\"cqa-api-edit-step-verification-label\">Verification</span>\n <span class=\"cqa-api-edit-step-verification-label\">Expected Value</span>\n <span class=\"cqa-api-edit-step-verification-label cqa-api-edit-step-verification-label--empty\"\n aria-hidden=\"true\"></span>\n </div>\n <div *ngFor=\"let row of statusVerificationRows; let i = index; trackBy: trackByStatusVerification\"\n [formGroup]=\"row\" class=\"cqa-api-edit-step-status-verification-row\">\n <span class=\"cqa-api-edit-step-verification-sno\">{{ i + 1 }}</span>\n <cqa-dynamic-select [form]=\"row\" [config]=\"statusVerificationSelectConfig\"\n class=\"cqa-api-edit-step-status-verification-select cqa-w-full\">\n </cqa-dynamic-select>\n <cqa-custom-input [value]=\"row.get('expectedValue')?.value ?? ''\"\n (valueChange)=\"row.get('expectedValue')?.setValue($event)\" placeholder=\"Expected Value\"\n type=\"number\" [fullWidth]=\"true\" size=\"sm\" class=\"cqa-api-edit-step-verification-input\"\n ariaLabel=\"Expected Value\">\n </cqa-custom-input>\n <cqa-button type=\"button\" variant=\"text\" [customClass]=\"'cqa-api-edit-step-verification-delete'\"\n [tooltip]=\"'Remove row'\" (clicked)=\"removeStatusVerificationRow(i)\">\n <svg class=\"cqa-api-edit-step-verification-delete-icon\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\"\n fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\" aria-hidden=\"true\">\n <path\n d=\"M10.6663 6V12.6667H5.33301V6H10.6663ZM9.66634 2H6.33301L5.66634 2.66667H3.33301V4H12.6663V2.66667H10.333L9.66634 2ZM11.9997 4.66667H3.99967V12.6667C3.99967 13.4 4.59967 14 5.33301 14H10.6663C11.3997 14 11.9997 13.4 11.9997 12.6667V4.66667Z\"\n fill=\"#F9BFBF\" />\n </svg>\n </cqa-button>\n </div>\n </div>\n </div>\n </div>\n </div>\n </div>\n </div>\n\n <!-- Response Preview -->\n <div class=\"cqa-api-edit-step-response\">\n <h3 class=\"cqa-api-edit-step-response-title\">Response Preview</h3>\n <pre class=\"cqa-api-edit-step-response-content\">{{ responsePreview }}</pre>\n </div>\n\n <!-- Step actions: one row, full width. Step 1: Cancel + Next; Step 2: Back + Next; Step 3: Back + Create -->\n <div class=\"cqa-api-edit-step-actions\">\n <ng-container [ngSwitch]=\"currentStep\">\n <ng-container *ngSwitchCase=\"1\">\n <cqa-button type=\"button\" variant=\"outlined\" btnSize=\"lg\" text=\"Cancel\"\n customClass=\"cqa-api-edit-step-actions-btn-cancel\" (clicked)=\"onBack()\">\n </cqa-button>\n <cqa-button type=\"button\" variant=\"filled\" btnSize=\"lg\" text=\"Next\"\n customClass=\"cqa-api-edit-step-actions-btn-next\" (clicked)=\"onNext()\">\n </cqa-button>\n </ng-container>\n <ng-container *ngSwitchCase=\"2\">\n <cqa-button type=\"button\" variant=\"outlined\" btnSize=\"lg\" text=\"Back\"\n customClass=\"cqa-api-edit-step-actions-btn-back\" (clicked)=\"onBack()\">\n </cqa-button>\n <cqa-button type=\"button\" variant=\"filled\" btnSize=\"lg\" text=\"Next\"\n customClass=\"cqa-api-edit-step-actions-btn-next\" (clicked)=\"onNext()\">\n </cqa-button>\n </ng-container>\n <ng-container *ngSwitchCase=\"3\">\n <cqa-button type=\"button\" variant=\"outlined\" btnSize=\"lg\" text=\"Back\"\n customClass=\"cqa-api-edit-step-actions-btn-back\" (clicked)=\"onBack()\">\n </cqa-button>\n <cqa-button type=\"button\" variant=\"filled\" btnSize=\"lg\" text=\"Create\"\n customClass=\"cqa-api-edit-step-actions-btn-create\" (clicked)=\"onCreate()\">\n </cqa-button>\n </ng-container>\n </ng-container>\n </div>\n</div>", components: [{ type: i2.ButtonComponent, selector: "cqa-button", inputs: ["variant", "btnSize", "disabled", "icon", "iconPosition", "fullWidth", "iconColor", "type", "text", "customClass", "inlineStyles", "tooltip", "tooltipPosition"], outputs: ["clicked"] }, { type: i3.DynamicSelectFieldComponent, selector: "cqa-dynamic-select", inputs: ["form", "config"], outputs: ["selectionChange", "selectClick", "searchChange", "loadMore", "addCustomValue"] }, { type: i4.CustomInputComponent, selector: "cqa-custom-input", inputs: ["label", "type", "placeholder", "value", "disabled", "errors", "required", "ariaLabel", "size", "fullWidth", "maxLength", "showCharCount", "inputInlineStyle", "labelInlineStyle"], outputs: ["valueChange", "blurred", "focused", "enterPressed"] }, { type: i5.CustomTextareaComponent, selector: "cqa-custom-textarea", inputs: ["label", "placeholder", "value", "disabled", "errors", "required", "ariaLabel", "size", "fullWidth", "maxLength", "showCharCount", "rows", "cols", "resize", "textareaInlineStyle", "labelInlineStyle"], outputs: ["valueChange", "blurred", "focused"] }, { type: i6.SegmentControlComponent, selector: "cqa-segment-control", inputs: ["segments", "value", "disabled", "containerBgColor"], outputs: ["valueChange"] }], directives: [{ type: i7.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i7.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { type: i1.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { type: i7.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i7.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { type: i7.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { type: i7.NgSwitchDefault, selector: "[ngSwitchDefault]" }], changeDetection: i0.ChangeDetectionStrategy.Default });
1656
+ ApiEditStepComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.4.0", type: ApiEditStepComponent, selector: "cqa-api-edit-step", inputs: { initialMethod: "initialMethod", initialEnvironment: "initialEnvironment", initialStep: "initialStep", initialUrl: "initialUrl", initialPayloadTab: "initialPayloadTab", initialHeaders: "initialHeaders", initialResponsePreview: "initialResponsePreview", initialVariableName: "initialVariableName", editMode: "editMode", httpMethodOptions: "httpMethodOptions", environmentOptions: "environmentOptions", authTypeOptions: "authTypeOptions", initialAuthType: "initialAuthType", formatOptions: "formatOptions", initialFormat: "initialFormat", headerNameOptions: "headerNameOptions", verificationOptions: "verificationOptions", verificationDataTypeOptions: "verificationDataTypeOptions", statusVerificationOptions: "statusVerificationOptions" }, outputs: { importCurl: "importCurl", importCurlCancel: "importCurlCancel", sendRequest: "sendRequest", back: "back", cancel: "cancel", next: "next", create: "create", headersChange: "headersChange" }, host: { classAttribute: "cqa-ui-root" }, viewQueries: [{ propertyName: "payloadEditorWithLinesRef", first: true, predicate: ["payloadEditorWithLinesRef"], descendants: true }, { propertyName: "payloadTextareaRef", first: true, predicate: ["payloadTextareaRef"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<div class=\"cqa-api-edit-step-container cqa-bg-[#ffffff] cqa-flex cqa-flex-col cqa-w-full cqa-h-full cqa-p-[16px] cqa-gap-[12px] cqa-overflow-y-auto cqa-overflow-x-hidden cqa-box-border\">\n\n <h2 class=\"cqa-api-edit-step-title cqa-font-inter cqa-text-[12px] cqa-font-semibold cqa-leading-[100%] cqa-tracking-normal cqa-text-[#000000] cqa-m-0\">\n {{ editMode ? 'Update API Test Step' : 'Create API Test Step' }}\n </h2>\n\n <div class=\"cqa-api-edit-step-indicator cqa-flex cqa-items-center cqa-gap-0 cqa-max-[767px]:cqa-flex-wrap cqa-max-[767px]:cqa-gap-2 cqa-max-[767px]:cqa-justify-start\"\n [class.cqa-justify-start]=\"stepLabels.length === 1\"\n [class.cqa-justify-between]=\"stepLabels.length !== 1\">\n <ng-container *ngFor=\"let step of stepLabels; let i = index\">\n <cqa-button type=\"button\" variant=\"text\"\n customClass=\"cqa-api-edit-step-indicator-item cqa-api-edit-step-indicator-item--clickable cqa-flex cqa-items-center cqa-gap-[10px] cqa-cursor-pointer cqa-border-none cqa-p-0 cqa-font-inherit cqa-text-inherit cqa-text-left !cqa-bg-transparent\"\n [attr.aria-label]=\"'Step ' + step.index + ': ' + step.label\" [attr.aria-pressed]=\"step.index === currentStep\"\n (clicked)=\"setStep(step.index)\">\n <span class=\"cqa-api-edit-step-indicator-circle cqa-w-8 cqa-h-8 cqa-rounded-full cqa-inline-flex cqa-items-center cqa-justify-center cqa-text-sm cqa-font-medium cqa-leading-none cqa-border-none cqa-shrink-0\"\n [ngClass]=\"step.index === currentStep ? 'cqa-bg-[#4F46E5] cqa-text-white' : 'cqa-bg-[#E0E0E0] cqa-text-[#666666]'\">\n {{ step.index }}\n </span>\n <span class=\"cqa-api-edit-step-indicator-label cqa-text-sm cqa-leading-[18px] cqa-font-normal cqa-max-[767px]:cqa-text-xs\"\n [ngClass]=\"step.index === currentStep ? 'cqa-text-[#4F46E5]' : 'cqa-text-[#666666]'\">\n {{ step.label }}\n </span>\n <div *ngIf=\"i < stepLabels.length - 1\" class=\"cqa-api-edit-step-indicator-line cqa-w-[96px] cqa-h-[2px] cqa-bg-[#E0E0E0] cqa-my-0 cqa-mx-[6px] cqa-shrink-0 cqa-self-center cqa-max-[767px]:cqa-w-[24px] cqa-max-[767px]:cqa-mx-1\" aria-hidden=\"true\"></div>\n </cqa-button>\n </ng-container>\n </div>\n\n <!-- Step content viewport: only the active step body is shown (*ngIf) -->\n <div class=\"cqa-api-edit-step-viewport cqa-w-full\">\n <!-- Step 1: Environment, request, body, response -->\n <div *ngIf=\"currentStep === 1\" class=\"cqa-api-edit-step-panel cqa-flex cqa-flex-col cqa-gap-6 cqa-box-border cqa-w-full\">\n <!-- Environment row: new line, select aligned right -->\n <div class=\"cqa-api-edit-step-environment-row cqa-flex cqa-justify-end cqa-items-center\">\n <cqa-dynamic-select *ngIf=\"environmentForm\" [form]=\"environmentForm\" [config]=\"environmentSelectConfig\"\n class=\"cqa-api-edit-step-environment-select cqa-shrink-0 cqa-w-auto cqa-min-w-[315px] cqa-max-w-[315px] cqa-max-[767px]:cqa-min-w-0 cqa-max-[767px]:cqa-max-w-full cqa-max-[767px]:cqa-w-full [&_.mat-form-field-wrapper]:cqa-pb-0\" aria-label=\"Environment\"\n (selectionChange)=\"onEnvironmentSelectionChange($event)\">\n </cqa-dynamic-select>\n </div>\n\n <!-- Request row: method, URL, buttons -->\n <div class=\"cqa-api-edit-step-request-row cqa-flex cqa-items-center cqa-gap-3 cqa-flex-wrap cqa-max-[767px]:cqa-flex-col cqa-max-[767px]:cqa-items-stretch cqa-max-[767px]:cqa-gap-2.5\">\n <cqa-dynamic-select *ngIf=\"methodForm\" [form]=\"methodForm\" [config]=\"methodSelectConfig\"\n class=\"cqa-api-edit-step-method-select cqa-shrink-0 cqa-w-auto cqa-min-w-[152px] cqa-max-w-[152px] cqa-max-[767px]:cqa-min-w-0 cqa-max-[767px]:cqa-max-w-full cqa-max-[767px]:cqa-w-full\" aria-label=\"HTTP method\"\n (selectionChange)=\"onMethodSelectionChange($event)\">\n </cqa-dynamic-select>\n <div class=\"cqa-api-edit-step-url-wrap cqa-flex-1 cqa-min-w-[200px] cqa-max-[767px]:cqa-min-w-0 cqa-max-[767px]:cqa-w-full [&_cqa-custom-input_.cqa-relative_input]:cqa-h-[40px] [&_cqa-custom-input_.cqa-relative_input]:cqa-bg-white [&_cqa-custom-input_.cqa-relative_input]:cqa-border [&_cqa-custom-input_.cqa-relative_input]:cqa-border-solid [&_cqa-custom-input_.cqa-relative_input]:cqa-border-[#D1D5DB] [&_cqa-custom-input_.cqa-relative_input]:cqa-rounded-md [&_cqa-custom-input_.cqa-relative_input]:cqa-text-sm [&_cqa-custom-input_.cqa-relative_input]:cqa-text-[#374151]\">\n <cqa-custom-input [(value)]=\"url\" [label]=\"''\" placeholder=\"\" [fullWidth]=\"true\" size=\"md\">\n </cqa-custom-input>\n </div>\n <div class=\"cqa-api-edit-step-import-curl-trigger cqa-contents cqa-max-[767px]:cqa-w-full cqa-max-[767px]:!cqa-flex\" (click)=\"openImportCurlPanel()\">\n <cqa-button type=\"button\" variant=\"outlined\" btnSize=\"lg\" text=\"Import API cURL\"\n customClass=\"cqa-api-edit-step-btn-outline !cqa-bg-white !cqa-border !cqa-border-solid !cqa-border-[#6B7280] cqa-text-[#414146] cqa-font-inter cqa-text-[14px] cqa-font-semibold cqa-leading-[100%] cqa-tracking-normal hover:!cqa-bg-[#F9FAFB] hover:!cqa-text-[#414146] cqa-max-[767px]:cqa-w-full\">\n </cqa-button>\n </div>\n <cqa-button variant=\"filled\" btnSize=\"lg\" text=\"Send Request\" (clicked)=\"onSendRequest()\"\n customClass=\"cqa-api-edit-step-btn-primary cqa-font-inter cqa-text-[14px] cqa-font-semibold cqa-leading-[100%] cqa-tracking-normal !cqa-bg-[#3F43EE] cqa-text-[#FBFCFF] !cqa-border-none cqa-py-2.5 cqa-px-6 cqa-gap-2 cqa-rounded-lg cqa-min-h-[37px] cqa-box-border hover:!cqa-bg-[#1B1FEB] cqa-max-[767px]:cqa-w-full\">\n </cqa-button>\n </div>\n\n\n\n <!-- Body content: header section (default) OR import cURL section -->\n <ng-container *ngIf=\"bodyView === 'import-curl'\">\n <div class=\"cqa-api-edit-step-import-curl-panel cqa-flex cqa-flex-col cqa-bg-white cqa-rounded-lg cqa-border cqa-border-solid cqa-border-[#E5E7EB] cqa-shadow-[0_1px_3px_rgba(0,0,0,0.08)] cqa-overflow-hidden\">\n <div class=\"cqa-api-edit-step-import-curl-header cqa-flex cqa-items-center cqa-justify-between cqa-py-3 cqa-px-5 cqa-border-b cqa-border-solid cqa-border-[#E2E8F0] cqa-bg-[#F9FAFB] cqa-rounded-t-lg cqa-max-[767px]:cqa-px-4\">\n <h3 class=\"cqa-api-edit-step-import-curl-title cqa-m-0 cqa-text-xs cqa-font-bold cqa-leading-[18px] cqa-text-[#374151]\">Import API cURL</h3>\n </div>\n <div class=\"cqa-api-edit-step-import-curl-separator cqa-h-px cqa-bg-[#E2E8F0] cqa-my-0 cqa-mx-5\"></div>\n <div class=\"cqa-api-edit-step-import-curl-body\">\n <cqa-custom-textarea [value]=\"importCurlControl.value\"\n (valueChange)=\"importCurlControl.setValue($event)\"\n placeholder=\"Paste your cURL command here (e.g., curl -X POST https://api.example.com/users)\"\n [fullWidth]=\"true\" [rows]=\"8\" resize=\"vertical\" size=\"md\"\n class=\"cqa-api-edit-step-import-curl-textarea\">\n </cqa-custom-textarea>\n </div>\n <div class=\"cqa-api-edit-step-import-curl-footer\">\n <cqa-button type=\"button\" variant=\"outlined\" btnSize=\"lg\" text=\"Cancel\"\n customClass=\"cqa-api-edit-step-import-curl-btn-cancel\" (clicked)=\"onCancelImportCurl()\"></cqa-button>\n <cqa-button type=\"button\" variant=\"filled\" btnSize=\"lg\" text=\"Import\"\n customClass=\"cqa-api-edit-step-import-curl-btn-import\" (clicked)=\"onImportCurlConfirm()\"></cqa-button>\n </div>\n </div>\n </ng-container>\n\n <ng-container *ngIf=\"bodyView === 'headers'\">\n <div class=\"cqa-api-edit-step-tabs-wrapper\">\n <div class=\"cqa-api-edit-step-tabs\">\n <cqa-button *ngFor=\"let tab of payloadTabs\" type=\"button\" variant=\"text\" [text]=\"tab.label\"\n [customClass]=\"'cqa-api-edit-step-tab' + (activePayloadTab === tab.value ? ' cqa-api-edit-step-tab--active' : '') + (isMethodWithoutBody && (tab.value === 'body' || tab.value === 'params') ? ' cqa-api-edit-step-tab--disabled' : '')\"\n [disabled]=\"isMethodWithoutBody && (tab.value === 'body' || tab.value === 'params')\"\n (clicked)=\"setPayloadTab(tab.value)\">\n </cqa-button>\n </div>\n\n <!-- Payload content (Authorization) -->\n <div *ngIf=\"activePayloadTab === 'authorization'\" class=\"cqa-api-edit-step-payload\"\n [attr.style]=\"'padding: 20px; min-height: 200px;'\">\n <div [attr.style]=\"'display: flex; flex-direction: column; gap: 20px;'\">\n <div [attr.style]=\"'display: flex; flex-direction: column; gap: 8px; width: fit-content;'\">\n <span [attr.style]=\"'font-size: 11px; font-weight: 600; letter-spacing: 0.02em; color: #6B7280; text-transform: uppercase; line-height: 1.25;'\">AUTH TYPE</span>\n <cqa-dynamic-select *ngIf=\"authTypeForm\" [form]=\"authTypeForm\" [config]=\"authTypeSelectConfig\"\n class=\"cqa-api-edit-step-auth-type-select\" aria-label=\"Auth type\"\n [attr.style]=\"'min-width: 160px;'\">\n </cqa-dynamic-select>\n </div>\n <!-- No Auth: centered message -->\n <div *ngIf=\"selectedAuthType === 'no-auth'\"\n [attr.style]=\"'flex: 1; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 12px; min-width: 0; text-align: center;'\">\n <div aria-hidden=\"true\"\n [attr.style]=\"'width: 48px; height: 48px; border-radius: 10px; background: #F3F4F6; display: flex; align-items: center; justify-content: center; flex-shrink: 0;'\">\n <svg width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\" style=\"display: block;\">\n <rect x=\"5\" y=\"11\" width=\"14\" height=\"2\" rx=\"1\" fill=\"#9CA3AF\"/>\n </svg>\n </div>\n <span [attr.style]=\"'font-size: 16px; font-weight: 600; color: #374151; line-height: 1.25;'\">No Auth</span>\n <div [attr.style]=\"'display: flex; align-items: center; justify-content: center; gap: 6px; flex-wrap: wrap;'\">\n <span [attr.style]=\"'font-size: 14px; font-weight: 400; color: #9CA3AF; line-height: 1.4;'\">This request does not use any authorization.</span>\n <span role=\"img\" aria-label=\"More information\" title=\"This request does not use any authorization.\"\n [attr.style]=\"'display: inline-flex; align-items: center; justify-content: center; width: 18px; height: 18px; color: #9CA3AF; flex-shrink: 0;'\">\n <svg width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\" style=\"display: block;\">\n <circle cx=\"8\" cy=\"8\" r=\"7\" stroke=\"#9CA3AF\" stroke-width=\"1.5\" fill=\"none\"/>\n <path d=\"M8 7v4M8 5v.5\" stroke=\"#9CA3AF\" stroke-width=\"1.5\" stroke-linecap=\"round\"/>\n </svg>\n </span>\n </div>\n </div>\n <!-- Bearer Token: Token label + textarea -->\n <div *ngIf=\"selectedAuthType === 'bearer'\"\n [attr.style]=\"'flex: 1; display: flex; flex-direction: column; gap: 10px; min-width: 0;'\">\n <span [attr.style]=\"'font-size: 12px; font-weight: 600; color: #374151; line-height: 1.25;'\">Token</span>\n <cqa-custom-textarea [(value)]=\"bearerToken\"\n placeholder=\"Enter bearer token\"\n [fullWidth]=\"true\" [rows]=\"6\" resize=\"vertical\" size=\"md\"\n class=\"cqa-api-edit-step-auth-token-textarea\" ariaLabel=\"Bearer token\">\n </cqa-custom-textarea>\n </div>\n <!-- OAuth 2.0: Grant Type, Access Token URL, Client ID, Client Secret, Scope, Client Authentication -->\n <div *ngIf=\"selectedAuthType === 'oauth2' && oauth2Form\"\n class=\"cqa-api-edit-step-oauth2-grid\"\n [attr.style]=\"'display: grid; grid-template-columns: 1fr 1fr; gap: 16px 24px; width: 100%;'\">\n <div [attr.style]=\"'display: flex; flex-direction: column; gap: 6px; min-width: 0;'\">\n <span [attr.style]=\"'font-size: 12px; font-weight: 600; color: #374151; line-height: 1.25;'\">Grant Type</span>\n <cqa-dynamic-select *ngIf=\"oauth2Form\" [form]=\"oauth2Form\" [config]=\"oauth2GrantTypeSelectConfig\"\n class=\"cqa-api-edit-step-auth-oauth-select\" aria-label=\"OAuth grant type\"\n [attr.style]=\"'min-width: 0; width: 100%;'\">\n </cqa-dynamic-select>\n <span [attr.style]=\"'font-size: 11px; font-style: italic; color: #6B7280; line-height: 1.3;'\">OAuth grant type</span>\n </div>\n <div [attr.style]=\"'display: flex; flex-direction: column; gap: 6px; min-width: 0;'\">\n <span [attr.style]=\"'font-size: 12px; font-weight: 600; color: #374151; line-height: 1.25;'\">Access Token URL</span>\n <cqa-custom-input [value]=\"oauth2Form.get('accessTokenUrl')?.value\"\n (valueChange)=\"oauth2Form.get('accessTokenUrl')?.setValue($event)\"\n [label]=\"''\" placeholder=\"Enter OAuth token endpoint\" [fullWidth]=\"true\" size=\"md\"\n ariaLabel=\"Access Token URL\">\n </cqa-custom-input>\n <span [attr.style]=\"'font-size: 11px; font-style: italic; color: #6B7280; line-height: 1.3;'\">OAuth token endpoint</span>\n </div>\n <div [attr.style]=\"'display: flex; flex-direction: column; gap: 6px; min-width: 0;'\">\n <span [attr.style]=\"'font-size: 12px; font-weight: 600; color: #374151; line-height: 1.25;'\">Client ID</span>\n <cqa-custom-input [value]=\"oauth2Form.get('clientId')?.value\"\n (valueChange)=\"oauth2Form.get('clientId')?.setValue($event)\"\n [label]=\"''\" placeholder=\"Enter OAuth client identifier\" [fullWidth]=\"true\" size=\"md\"\n ariaLabel=\"Client ID\">\n </cqa-custom-input>\n <span [attr.style]=\"'font-size: 11px; font-style: italic; color: #6B7280; line-height: 1.3;'\">OAuth client identifier</span>\n </div>\n <div [attr.style]=\"'display: flex; flex-direction: column; gap: 6px; min-width: 0;'\">\n <span [attr.style]=\"'font-size: 12px; font-weight: 600; color: #374151; line-height: 1.25;'\">Client Secret</span>\n <cqa-custom-input [value]=\"oauth2Form.get('clientSecret')?.value\"\n (valueChange)=\"oauth2Form.get('clientSecret')?.setValue($event)\"\n type=\"password\" [label]=\"''\" placeholder=\"Enter OAuth client secret\" [fullWidth]=\"true\" size=\"md\"\n ariaLabel=\"Client Secret\">\n </cqa-custom-input>\n <span [attr.style]=\"'font-size: 11px; font-style: italic; color: #6B7280; line-height: 1.3;'\">OAuth client secret</span>\n </div>\n <div [attr.style]=\"'display: flex; flex-direction: column; gap: 6px; min-width: 0;'\">\n <span [attr.style]=\"'font-size: 12px; font-weight: 600; color: #374151; line-height: 1.25;'\">Scope</span>\n <cqa-custom-input [value]=\"oauth2Form.get('scope')?.value\"\n (valueChange)=\"oauth2Form.get('scope')?.setValue($event)\"\n [label]=\"''\" placeholder=\"Enter space-separated scopes\" [fullWidth]=\"true\" size=\"md\"\n ariaLabel=\"Scope\">\n </cqa-custom-input>\n <span [attr.style]=\"'font-size: 11px; font-style: italic; color: #6B7280; line-height: 1.3;'\">Space-separated scopes</span>\n </div>\n <div [attr.style]=\"'display: flex; flex-direction: column; gap: 6px; min-width: 0;'\">\n <span [attr.style]=\"'font-size: 12px; font-weight: 600; color: #374151; line-height: 1.25;'\">Client Authentication</span>\n <cqa-dynamic-select *ngIf=\"oauth2Form\" [form]=\"oauth2Form\" [config]=\"oauth2ClientAuthSelectConfig\"\n class=\"cqa-api-edit-step-auth-oauth-select\" aria-label=\"Client authentication method\"\n [attr.style]=\"'min-width: 0; width: 100%;'\">\n </cqa-dynamic-select>\n <span [attr.style]=\"'font-size: 11px; font-style: italic; color: #6B7280; line-height: 1.3;'\">Client authentication method</span>\n </div>\n </div>\n </div>\n </div>\n\n <!-- Payload content (Headers) -->\n <div *ngIf=\"activePayloadTab === 'headers'\" class=\"cqa-api-edit-step-payload\">\n <div class=\"cqa-api-edit-step-headers-grid\">\n <span class=\"cqa-api-edit-step-headers-label\">Header Name</span>\n <span class=\"cqa-api-edit-step-headers-label\">Header Value</span>\n <span class=\"cqa-api-edit-step-headers-label cqa-api-edit-step-headers-label--empty\"\n aria-hidden=\"true\"></span>\n </div>\n <div *ngFor=\"let row of headerRows; let i = index; trackBy: trackByHeader\" [formGroup]=\"row\"\n class=\"cqa-api-edit-step-header-row\">\n <cqa-dynamic-select [form]=\"row\" [config]=\"headerNameSelectConfig\"\n (addCustomValue)=\"onHeaderNameAddCustomValue($event, row)\"\n class=\"cqa-api-edit-step-header-type-select cqa-w-full\">\n </cqa-dynamic-select>\n <cqa-custom-input [value]=\"row.get('value')?.value ?? ''\"\n (valueChange)=\"row.get('value')?.setValue($event)\" placeholder=\"Value\" [fullWidth]=\"true\" size=\"sm\"\n class=\"cqa-api-edit-step-header-value-input\" ariaLabel=\"Header value\">\n </cqa-custom-input>\n <cqa-button type=\"button\" variant=\"text\" [customClass]=\"'cqa-api-edit-step-header-delete'\"\n [tooltip]=\"'Remove header'\" (clicked)=\"removeHeader(i)\">\n <svg class=\"cqa-api-edit-step-header-delete-icon\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\"\n fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\" aria-hidden=\"true\">\n <path\n d=\"M10.6663 6V12.6667H5.33301V6H10.6663ZM9.66634 2H6.33301L5.66634 2.66667H3.33301V4H12.6663V2.66667H10.333L9.66634 2ZM11.9997 4.66667H3.99967V12.6667C3.99967 13.4 4.59967 14 5.33301 14H10.6663C11.3997 14 11.9997 13.4 11.9997 12.6667V4.66667Z\"\n fill=\"#F9BFBF\" />\n </svg>\n </cqa-button>\n </div>\n <div class=\"cqa-api-edit-step-add-header-wrap\">\n <cqa-button type=\"button\" variant=\"text\" text=\"+ Add Header\"\n [customClass]=\"'cqa-api-edit-step-add-header-link'\" (clicked)=\"addHeader()\">\n </cqa-button>\n </div>\n </div>\n\n <!-- Payload content (Params): Key\u2013Value table with add/delete rows -->\n <div *ngIf=\"activePayloadTab === 'params'\" class=\"cqa-api-edit-step-payload\">\n <div class=\"cqa-api-edit-step-key-value-grid cqa-api-edit-step-key-value-header\">\n <span class=\"cqa-api-edit-step-key-value-label\">Key</span>\n <span class=\"cqa-api-edit-step-key-value-label\">Value</span>\n <span class=\"cqa-api-edit-step-key-value-label cqa-api-edit-step-key-value-label--empty\"\n aria-hidden=\"true\"></span>\n </div>\n <div *ngFor=\"let row of paramsRows; let i = index; trackBy: trackByParams\" [formGroup]=\"row\"\n class=\"cqa-api-edit-step-key-value-row\">\n <cqa-custom-input [value]=\"row.get('key')?.value ?? ''\"\n (valueChange)=\"row.get('key')?.setValue($event)\" placeholder=\"Key\" [fullWidth]=\"true\" size=\"sm\"\n class=\"cqa-api-edit-step-key-value-input\" ariaLabel=\"Key\">\n </cqa-custom-input>\n <cqa-custom-input [value]=\"row.get('value')?.value ?? ''\"\n (valueChange)=\"row.get('value')?.setValue($event)\" placeholder=\"Value\" [fullWidth]=\"true\" size=\"sm\"\n class=\"cqa-api-edit-step-key-value-input\" ariaLabel=\"Value\">\n </cqa-custom-input>\n <cqa-button type=\"button\" variant=\"text\" [customClass]=\"'cqa-api-edit-step-key-value-delete'\"\n [tooltip]=\"'Remove row'\" (clicked)=\"removeParamsRow(i)\">\n <svg class=\"cqa-api-edit-step-key-value-delete-icon\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\"\n fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\" aria-hidden=\"true\">\n <path\n d=\"M10.6663 6V12.6667H5.33301V6H10.6663ZM9.66634 2H6.33301L5.66634 2.66667H3.33301V4H12.6663V2.66667H10.333L9.66634 2ZM11.9997 4.66667H3.99967V12.6667C3.99967 13.4 4.59967 14 5.33301 14H10.6663C11.3997 14 11.9997 13.4 11.9997 12.6667V4.66667Z\"\n fill=\"#F9BFBF\" />\n </svg>\n </cqa-button>\n </div>\n <div class=\"cqa-api-edit-step-key-value-add-wrap\">\n <cqa-button type=\"button\" variant=\"filled\" btnSize=\"lg\" text=\"+ Add Row\"\n customClass=\"cqa-api-edit-step-key-value-add-btn\" (clicked)=\"addParamsRow()\">\n </cqa-button>\n </div>\n </div>\n\n <!-- Payload content (Body only): type, format, text area, Back/Next -->\n <div *ngIf=\"activePayloadTab === 'body'\"\n class=\"cqa-api-edit-step-payload cqa-api-edit-step-payload-editor\">\n <div class=\"cqa-api-edit-step-payload-type-row\">\n <span class=\"cqa-api-edit-step-payload-type-label\">Type</span>\n <div class=\"cqa-api-edit-step-payload-type-radios\">\n <cqa-segment-control [value]=\"payloadType\" [segments]=\"payloadTypeSegments\"\n (valueChange)=\"onPayloadTypeChange($event)\"\n class=\"cqa-api-edit-step-payload-type-segment\">\n </cqa-segment-control>\n </div>\n <div *ngIf=\"payloadType === 'raw'\" class=\"cqa-api-edit-step-payload-format-wrap\">\n <span class=\"cqa-api-edit-step-payload-format-label\">Format:</span>\n <cqa-dynamic-select *ngIf=\"payloadFormatForm\" [form]=\"payloadFormatForm\"\n [config]=\"payloadFormatSelectConfig\" class=\"cqa-api-edit-step-payload-format-select\"\n aria-label=\"Format\">\n </cqa-dynamic-select>\n </div>\n </div>\n <!-- Raw: text area with line numbers (Postman-style payload body) -->\n <div *ngIf=\"payloadType === 'raw'\" class=\"cqa-api-edit-step-payload-body\" #payloadEditorWithLinesRef>\n <div class=\"cqa-api-edit-step-payload-editor-with-lines\">\n <div class=\"cqa-api-edit-step-payload-line-numbers\" aria-hidden=\"true\">\n <span *ngFor=\"let n of payloadLineNumbers\" class=\"cqa-api-edit-step-payload-line-num\">\n <span *ngIf=\"payloadJsonError && payloadJsonError.line === n\"\n class=\"cqa-api-edit-step-payload-line-error-icon\" [title]=\"payloadJsonErrorTooltip\"\n aria-label=\"Parse error on this line\">\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"14\" height=\"14\" viewBox=\"0 0 14 14\" fill=\"none\" aria-hidden=\"true\">\n <circle cx=\"7\" cy=\"7\" r=\"6\" fill=\"#EF4444\"/>\n <path d=\"M4 4l6 6M10 4l-6 6\" stroke=\"white\" stroke-width=\"1.5\" stroke-linecap=\"round\"/>\n </svg>\n </span>\n <span class=\"cqa-api-edit-step-payload-line-num-text\">{{ n }}</span>\n </span>\n </div>\n <div class=\"cqa-api-edit-step-payload-textarea-cell\">\n <div class=\"cqa-api-edit-step-payload-textarea cqa-w-full cqa-flex cqa-flex-col cqa-min-h-0\"\n [ngClass]=\"{'cqa-api-edit-step-payload-textarea--error': payloadJsonError}\">\n <textarea #payloadTextareaRef\n class=\"cqa-api-edit-step-payload-textarea-input cqa-w-full cqa-outline-none cqa-box-border\"\n [ngClass]=\"{'cqa-api-edit-step-payload-textarea-input--error': payloadJsonError}\"\n [value]=\"payloadText\"\n placeholder=\"\"\n [attr.aria-label]=\"'Payload'\"\n [attr.aria-invalid]=\"!!payloadJsonError\"\n (input)=\"onPayloadInput($event)\"\n (keydown)=\"onPayloadKeydown($event)\">\n </textarea>\n </div>\n </div>\n </div>\n <p *ngIf=\"payloadJsonError\" class=\"cqa-api-edit-step-payload-json-error-msg\">\n Invalid JSON format. Please check your syntax.\n </p>\n </div>\n\n <!-- x-www-form-urlencoded: Key\u2013Value rows, add/remove dynamically -->\n <div *ngIf=\"payloadType === 'x-www-form-urlencoded'\" class=\"cqa-api-edit-step-key-value\">\n <div class=\"cqa-api-edit-step-key-value-grid cqa-api-edit-step-key-value-header\">\n <span class=\"cqa-api-edit-step-key-value-label\">Key</span>\n <span class=\"cqa-api-edit-step-key-value-label\">Value</span>\n <span class=\"cqa-api-edit-step-key-value-label cqa-api-edit-step-key-value-label--empty\"\n aria-hidden=\"true\"></span>\n </div>\n <div *ngFor=\"let row of keyValueRows; let i = index; trackBy: trackByKeyValue\" [formGroup]=\"row\"\n class=\"cqa-api-edit-step-key-value-row\">\n <cqa-custom-input [value]=\"row.get('key')?.value ?? ''\"\n (valueChange)=\"row.get('key')?.setValue($event)\" placeholder=\"Key\" [fullWidth]=\"true\" size=\"sm\"\n class=\"cqa-api-edit-step-key-value-input\" ariaLabel=\"Key\">\n </cqa-custom-input>\n <cqa-custom-input [value]=\"row.get('value')?.value ?? ''\"\n (valueChange)=\"row.get('value')?.setValue($event)\" placeholder=\"Value\" [fullWidth]=\"true\" size=\"sm\"\n class=\"cqa-api-edit-step-key-value-input\" ariaLabel=\"Value\">\n </cqa-custom-input>\n <cqa-button type=\"button\" variant=\"text\" [customClass]=\"'cqa-api-edit-step-key-value-delete'\"\n [tooltip]=\"'Remove row'\" (clicked)=\"removeKeyValueRow(i)\">\n <svg class=\"cqa-api-edit-step-key-value-delete-icon\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\"\n fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\" aria-hidden=\"true\">\n <path\n d=\"M10.6663 6V12.6667H5.33301V6H10.6663ZM9.66634 2H6.33301L5.66634 2.66667H3.33301V4H12.6663V2.66667H10.333L9.66634 2ZM11.9997 4.66667H3.99967V12.6667C3.99967 13.4 4.59967 14 5.33301 14H10.6663C11.3997 14 11.9997 13.4 11.9997 12.6667V4.66667Z\"\n fill=\"#F9BFBF\" />\n </svg>\n </cqa-button>\n </div>\n <div class=\"cqa-api-edit-step-key-value-add-wrap\">\n <cqa-button type=\"button\" variant=\"filled\" btnSize=\"lg\" text=\"+ Add Row\"\n customClass=\"cqa-api-edit-step-key-value-add-btn\" (clicked)=\"addKeyValueRow()\">\n </cqa-button>\n </div>\n </div>\n\n <!-- Form Data: Key\u2013Type\u2013Value rows; Type is a dropdown (Text/File), add/remove dynamically -->\n <div *ngIf=\"payloadType === 'form-data'\" class=\"cqa-api-edit-step-key-type-value\">\n <div class=\"cqa-api-edit-step-key-type-value-header\">\n <span class=\"cqa-api-edit-step-key-type-value-label\">Key</span>\n <span class=\"cqa-api-edit-step-key-type-value-label\">Type</span>\n <span class=\"cqa-api-edit-step-key-type-value-label\">Value</span>\n <span class=\"cqa-api-edit-step-key-type-value-label cqa-api-edit-step-key-type-value-label--empty\"\n aria-hidden=\"true\"></span>\n </div>\n <div *ngFor=\"let row of keyTypeValueRows; let i = index; trackBy: trackByKeyTypeValue\" [formGroup]=\"row\"\n class=\"cqa-api-edit-step-key-type-value-row\">\n <cqa-custom-input [value]=\"row.get('key')?.value ?? ''\"\n (valueChange)=\"row.get('key')?.setValue($event)\" placeholder=\"Key\" [fullWidth]=\"true\" size=\"sm\"\n class=\"cqa-api-edit-step-key-type-value-input\" ariaLabel=\"Key\">\n </cqa-custom-input>\n <cqa-dynamic-select [form]=\"row\" [config]=\"keyTypeValueTypeSelectConfig\"\n class=\"cqa-api-edit-step-key-type-value-type-select cqa-w-full\">\n </cqa-dynamic-select>\n <cqa-custom-input [value]=\"row.get('value')?.value ?? ''\"\n (valueChange)=\"row.get('value')?.setValue($event)\" placeholder=\"Value\" [fullWidth]=\"true\" size=\"sm\"\n class=\"cqa-api-edit-step-key-type-value-input\" ariaLabel=\"Value\">\n </cqa-custom-input>\n <cqa-button type=\"button\" variant=\"text\" [customClass]=\"'cqa-api-edit-step-key-type-value-delete'\"\n [tooltip]=\"'Remove row'\" (clicked)=\"removeKeyTypeValueRow(i)\">\n <svg class=\"cqa-api-edit-step-key-type-value-delete-icon\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\"\n fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\" aria-hidden=\"true\">\n <path\n d=\"M10.6663 6V12.6667H5.33301V6H10.6663ZM9.66634 2H6.33301L5.66634 2.66667H3.33301V4H12.6663V2.66667H10.333L9.66634 2ZM11.9997 4.66667H3.99967V12.6667C3.99967 13.4 4.59967 14 5.33301 14H10.6663C11.3997 14 11.9997 13.4 11.9997 12.6667V4.66667Z\"\n fill=\"#F9BFBF\" />\n </svg>\n </cqa-button>\n </div>\n <div class=\"cqa-api-edit-step-key-type-value-add-wrap\">\n <cqa-button type=\"button\" variant=\"filled\" btnSize=\"lg\" text=\"+ Add Row\"\n customClass=\"cqa-api-edit-step-key-type-value-add-btn\" (clicked)=\"addKeyTypeValueRow()\">\n </cqa-button>\n </div>\n </div>\n </div>\n </div>\n </ng-container>\n\n </div>\n <!-- Step 2: Variable Name: input, validation, Back / Next -->\n <div *ngIf=\"currentStep === 2\" class=\"cqa-api-edit-step-panel cqa-flex cqa-flex-col cqa-gap-6 cqa-box-border cqa-w-full\">\n <div class=\"cqa-api-edit-step-variable-section\">\n <div class=\"cqa-api-edit-step-variable-input-wrap\">\n <cqa-custom-input [(value)]=\"variableName\" [label]=\"''\" placeholder=\"Variable Name\" [fullWidth]=\"true\"\n size=\"md\" (valueChange)=\"onVariableNameChange()\" aria-label=\"Variable Name\">\n </cqa-custom-input>\n </div>\n <p *ngIf=\"variableNameError\" class=\"cqa-api-edit-step-variable-error\" role=\"alert\">{{ variableNameError }}</p>\n </div>\n </div>\n <!-- Step 3: Response Body / Status tabs -->\n <div *ngIf=\"currentStep === 3\" class=\"cqa-api-edit-step-panel cqa-flex cqa-flex-col cqa-gap-6 cqa-box-border cqa-w-full\">\n <div class=\"cqa-api-edit-step-tabs-wrapper\">\n <div class=\"cqa-api-edit-step-tabs\">\n <cqa-button *ngFor=\"let tab of responseVerificationTabs\" type=\"button\" variant=\"text\" [text]=\"tab.label\"\n [customClass]=\"'cqa-api-edit-step-tab' + (activeResponseVerificationTab === tab.value ? ' cqa-api-edit-step-tab--active' : '')\"\n (clicked)=\"setResponseVerificationTab(tab.value)\">\n </cqa-button>\n </div>\n\n <!-- Response Body tab content: verification grid -->\n <div *ngIf=\"activeResponseVerificationTab === 'response-body'\" class=\"cqa-api-edit-step-step3-content\">\n <div class=\"cqa-api-edit-step-verification-header-row\">\n <span></span>\n <cqa-button type=\"button\" variant=\"text\" text=\"Add Verification\"\n customClass=\"cqa-api-edit-step-verification-add-link\" (clicked)=\"addVerificationRow()\">\n </cqa-button>\n </div>\n <div class=\"cqa-api-edit-step-verification\">\n <div class=\"cqa-api-edit-step-verification-grid cqa-api-edit-step-verification-grid-header\">\n <span class=\"cqa-api-edit-step-verification-label\">S.no</span>\n <span class=\"cqa-api-edit-step-verification-label\">JSON Path</span>\n <span class=\"cqa-api-edit-step-verification-label\">Verification</span>\n <span class=\"cqa-api-edit-step-verification-label\">Data Type</span>\n <span class=\"cqa-api-edit-step-verification-label\">Expected Value</span>\n <span class=\"cqa-api-edit-step-verification-label cqa-api-edit-step-verification-label--empty\"\n aria-hidden=\"true\"></span>\n </div>\n <div *ngFor=\"let row of verificationRows; let i = index; trackBy: trackByVerification\" [formGroup]=\"row\"\n class=\"cqa-api-edit-step-verification-row\">\n <span class=\"cqa-api-edit-step-verification-sno\">{{ i + 1 }}</span>\n <cqa-custom-input [value]=\"row.get('jsonPath')?.value ?? ''\"\n (valueChange)=\"row.get('jsonPath')?.setValue($event)\" placeholder=\"Json Path\" [fullWidth]=\"true\"\n size=\"sm\" class=\"cqa-api-edit-step-verification-input\" ariaLabel=\"JSON Path\">\n </cqa-custom-input>\n <cqa-dynamic-select [form]=\"row\" [config]=\"verificationSelectConfig\"\n class=\"cqa-api-edit-step-verification-select cqa-w-full\">\n </cqa-dynamic-select>\n <cqa-dynamic-select [form]=\"row\" [config]=\"verificationDataTypeSelectConfig\"\n class=\"cqa-api-edit-step-verification-select cqa-w-full\"\n (selectionChange)=\"onVerificationDataTypeChange(row, $event)\">\n </cqa-dynamic-select>\n <!-- Expected Value: text for String/Array/Object, number for Number, dropdown for Boolean -->\n <ng-container [ngSwitch]=\"row.get('dataType')?.value\">\n <cqa-dynamic-select *ngSwitchCase=\"'boolean'\" [form]=\"row\"\n [config]=\"verificationExpectedValueBooleanSelectConfig\"\n class=\"cqa-api-edit-step-verification-select cqa-api-edit-step-verification-expected-select cqa-w-full\">\n </cqa-dynamic-select>\n <cqa-custom-input *ngSwitchCase=\"'number'\" [value]=\"row.get('expectedValue')?.value ?? ''\"\n (valueChange)=\"row.get('expectedValue')?.setValue($event)\" placeholder=\"Expected Value (number)\"\n type=\"number\" [fullWidth]=\"true\" size=\"sm\"\n class=\"cqa-api-edit-step-verification-input cqa-api-edit-step-verification-expected-number\"\n ariaLabel=\"Expected Value\">\n </cqa-custom-input>\n <cqa-custom-input *ngSwitchDefault [value]=\"row.get('expectedValue')?.value ?? ''\"\n (valueChange)=\"row.get('expectedValue')?.setValue($event)\"\n placeholder=\"Expected Value in String\" [fullWidth]=\"true\" size=\"sm\"\n class=\"cqa-api-edit-step-verification-input\" ariaLabel=\"Expected Value\">\n </cqa-custom-input>\n </ng-container>\n <cqa-button type=\"button\" variant=\"text\" [customClass]=\"'cqa-api-edit-step-verification-delete'\"\n [tooltip]=\"'Remove row'\" (clicked)=\"removeVerificationRow(i)\">\n <svg class=\"cqa-api-edit-step-verification-delete-icon\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\"\n fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\" aria-hidden=\"true\">\n <path\n d=\"M10.6663 6V12.6667H5.33301V6H10.6663ZM9.66634 2H6.33301L5.66634 2.66667H3.33301V4H12.6663V2.66667H10.333L9.66634 2ZM11.9997 4.66667H3.99967V12.6667C3.99967 13.4 4.59967 14 5.33301 14H10.6663C11.3997 14 11.9997 13.4 11.9997 12.6667V4.66667Z\"\n fill=\"#F9BFBF\" />\n </svg>\n </cqa-button>\n </div>\n </div>\n </div>\n\n <!-- Status tab content: S.no, Verification dropdown, Expected Value, add/remove rows -->\n <div *ngIf=\"activeResponseVerificationTab === 'status'\" class=\"cqa-api-edit-step-step3-content\">\n <div class=\"cqa-api-edit-step-verification-header-row\">\n <span></span>\n <cqa-button type=\"button\" variant=\"text\" text=\"Add Verification\"\n customClass=\"cqa-api-edit-step-verification-add-link\" (clicked)=\"addStatusVerificationRow()\">\n </cqa-button>\n </div>\n <div class=\"cqa-api-edit-step-status-verification\">\n <div class=\"cqa-api-edit-step-status-verification-header\">\n <span class=\"cqa-api-edit-step-verification-label\">S.no</span>\n <span class=\"cqa-api-edit-step-verification-label\">Verification</span>\n <span class=\"cqa-api-edit-step-verification-label\">Expected Value</span>\n <span class=\"cqa-api-edit-step-verification-label cqa-api-edit-step-verification-label--empty\"\n aria-hidden=\"true\"></span>\n </div>\n <div *ngFor=\"let row of statusVerificationRows; let i = index; trackBy: trackByStatusVerification\"\n [formGroup]=\"row\" class=\"cqa-api-edit-step-status-verification-row\">\n <span class=\"cqa-api-edit-step-verification-sno\">{{ i + 1 }}</span>\n <cqa-dynamic-select [form]=\"row\" [config]=\"statusVerificationSelectConfig\"\n class=\"cqa-api-edit-step-status-verification-select cqa-w-full\">\n </cqa-dynamic-select>\n <cqa-custom-input [value]=\"row.get('expectedValue')?.value ?? ''\"\n (valueChange)=\"row.get('expectedValue')?.setValue($event)\" placeholder=\"Expected Value\"\n type=\"number\" [fullWidth]=\"true\" size=\"sm\" class=\"cqa-api-edit-step-verification-input\"\n ariaLabel=\"Expected Value\">\n </cqa-custom-input>\n <cqa-button type=\"button\" variant=\"text\" [customClass]=\"'cqa-api-edit-step-verification-delete'\"\n [tooltip]=\"'Remove row'\" (clicked)=\"removeStatusVerificationRow(i)\">\n <svg class=\"cqa-api-edit-step-verification-delete-icon\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\"\n fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\" aria-hidden=\"true\">\n <path\n d=\"M10.6663 6V12.6667H5.33301V6H10.6663ZM9.66634 2H6.33301L5.66634 2.66667H3.33301V4H12.6663V2.66667H10.333L9.66634 2ZM11.9997 4.66667H3.99967V12.6667C3.99967 13.4 4.59967 14 5.33301 14H10.6663C11.3997 14 11.9997 13.4 11.9997 12.6667V4.66667Z\"\n fill=\"#F9BFBF\" />\n </svg>\n </cqa-button>\n </div>\n </div>\n </div>\n </div>\n </div>\n </div>\n\n <!-- Response Preview -->\n <div class=\"cqa-api-edit-step-response\">\n <h3 class=\"cqa-api-edit-step-response-title cqa-text-[14px] cqa-font-bold cqa-leading-[20px] cqa-text-[#111827] cqa-m-0 cqa-mb-[12px] cqa-shrink-0\">Response Preview</h3>\n <pre class=\"cqa-api-edit-step-response-content\">{{ responsePreview }}</pre>\n </div>\n\n <!-- Step actions: one row, full width. Step 1: Cancel + Next; Step 2: Back + Next; Step 3: Back + Create -->\n <div class=\"cqa-api-edit-step-actions\">\n <ng-container [ngSwitch]=\"currentStep\">\n <ng-container *ngSwitchCase=\"1\">\n <cqa-button type=\"button\" variant=\"outlined\" btnSize=\"lg\" text=\"Cancel\"\n customClass=\"cqa-api-edit-step-actions-btn-cancel\" (clicked)=\"onCancel()\">\n </cqa-button>\n <cqa-button type=\"button\" variant=\"filled\" btnSize=\"lg\" text=\"Next\"\n customClass=\"cqa-api-edit-step-actions-btn-next\" (clicked)=\"onNext()\">\n </cqa-button>\n </ng-container>\n <ng-container *ngSwitchCase=\"2\">\n <cqa-button type=\"button\" variant=\"outlined\" btnSize=\"lg\" text=\"Back\"\n customClass=\"cqa-api-edit-step-actions-btn-back\" (clicked)=\"onBack()\">\n </cqa-button>\n <cqa-button type=\"button\" variant=\"filled\" btnSize=\"lg\" text=\"Next\"\n customClass=\"cqa-api-edit-step-actions-btn-next\" (clicked)=\"onNext()\">\n </cqa-button>\n </ng-container>\n <ng-container *ngSwitchCase=\"3\">\n <cqa-button type=\"button\" variant=\"outlined\" btnSize=\"lg\" text=\"Back\"\n customClass=\"cqa-api-edit-step-actions-btn-back\" (clicked)=\"onBack()\">\n </cqa-button>\n <cqa-button type=\"button\" variant=\"filled\" btnSize=\"lg\" [text]=\"editMode ? 'Update' : 'Create'\"\n customClass=\"cqa-api-edit-step-actions-btn-create\" (clicked)=\"onCreate()\">\n </cqa-button>\n </ng-container>\n </ng-container>\n </div>\n</div>", components: [{ type: i2.ButtonComponent, selector: "cqa-button", inputs: ["variant", "btnSize", "disabled", "icon", "iconPosition", "fullWidth", "iconColor", "type", "text", "customClass", "inlineStyles", "tooltip", "tooltipPosition"], outputs: ["clicked"] }, { type: i3.DynamicSelectFieldComponent, selector: "cqa-dynamic-select", inputs: ["form", "config"], outputs: ["selectionChange", "selectClick", "searchChange", "loadMore", "addCustomValue"] }, { type: i4.CustomInputComponent, selector: "cqa-custom-input", inputs: ["label", "type", "placeholder", "value", "disabled", "errors", "required", "ariaLabel", "size", "fullWidth", "maxLength", "showCharCount", "inputInlineStyle", "labelInlineStyle"], outputs: ["valueChange", "blurred", "focused", "enterPressed"] }, { type: i5.CustomTextareaComponent, selector: "cqa-custom-textarea", inputs: ["label", "placeholder", "value", "disabled", "errors", "required", "ariaLabel", "size", "fullWidth", "maxLength", "showCharCount", "rows", "cols", "resize", "textareaInlineStyle", "labelInlineStyle"], outputs: ["valueChange", "blurred", "focused"] }, { type: i6.SegmentControlComponent, selector: "cqa-segment-control", inputs: ["segments", "value", "disabled", "containerBgColor"], outputs: ["valueChange"] }], directives: [{ type: i7.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i7.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i7.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { type: i1.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { type: i7.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { type: i7.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { type: i7.NgSwitchDefault, selector: "[ngSwitchDefault]" }], changeDetection: i0.ChangeDetectionStrategy.Default });
1068
1657
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: ApiEditStepComponent, decorators: [{
1069
1658
  type: Component,
1070
- args: [{ selector: 'cqa-api-edit-step', host: { class: 'cqa-ui-root' }, changeDetection: ChangeDetectionStrategy.Default, template: "<div class=\"cqa-api-edit-step-container\">\n <!-- Title -->\n <h2\n class=\"cqa-api-edit-step-title cqa-font-inter cqa-text-[12px] cqa-font-semibold cqa-leading-[100%] cqa-tracking-normal cqa-text-[#000000]\">\n Create API Test Step</h2>\n\n <!-- Step indicator: all three steps visible, active step highlighted (Postman-style) -->\n <div class=\"cqa-api-edit-step-indicator\">\n <ng-container *ngFor=\"let step of stepLabels; let i = index\">\n <cqa-button type=\"button\" variant=\"text\"\n customClass=\"cqa-api-edit-step-indicator-item cqa-api-edit-step-indicator-item--clickable\"\n [attr.aria-label]=\"'Step ' + step.index + ': ' + step.label\" [attr.aria-pressed]=\"step.index === currentStep\"\n (clicked)=\"setStep(step.index)\">\n <span class=\"cqa-api-edit-step-indicator-circle\"\n [class.cqa-api-edit-step-indicator-circle--active]=\"step.index === currentStep\">\n {{ step.index }}\n </span>\n <span class=\"cqa-api-edit-step-indicator-label\"\n [class.cqa-api-edit-step-indicator-label--active]=\"step.index === currentStep\">\n {{ step.label }}\n </span>\n <div *ngIf=\"i < stepLabels.length - 1\" class=\"cqa-api-edit-step-indicator-line\" aria-hidden=\"true\"></div>\n </cqa-button>\n </ng-container>\n </div>\n\n <!-- Step content viewport: smooth slide between steps -->\n <div class=\"cqa-api-edit-step-viewport\">\n <div class=\"cqa-api-edit-step-strip\" [style.transform]=\"'translateX(' + stripTranslatePercent + '%)'\">\n <!-- Step 1: Environment, request, body, response -->\n <div class=\"cqa-api-edit-step-panel\">\n <!-- Environment row: new line, select aligned right -->\n <div class=\"cqa-api-edit-step-environment-row\">\n <cqa-dynamic-select *ngIf=\"environmentForm\" [form]=\"environmentForm\" [config]=\"environmentSelectConfig\"\n class=\"cqa-api-edit-step-environment-select\" aria-label=\"Environment\"\n (selectionChange)=\"onEnvironmentSelectionChange($event)\">\n </cqa-dynamic-select>\n </div>\n\n <!-- Request row: method, URL, buttons -->\n <div class=\"cqa-api-edit-step-request-row\">\n <cqa-dynamic-select *ngIf=\"methodForm\" [form]=\"methodForm\" [config]=\"methodSelectConfig\"\n class=\"cqa-api-edit-step-method-select\" aria-label=\"HTTP method\"\n (selectionChange)=\"onMethodSelectionChange($event)\">\n </cqa-dynamic-select>\n <div class=\"cqa-api-edit-step-url-wrap\">\n <cqa-custom-input [(value)]=\"url\" [label]=\"''\" placeholder=\"\" [fullWidth]=\"true\" size=\"md\">\n </cqa-custom-input>\n </div>\n <div class=\"cqa-api-edit-step-import-curl-trigger\" style=\"display: contents\" (click)=\"openImportCurlPanel()\">\n <cqa-button type=\"button\" variant=\"outlined\" btnSize=\"lg\" text=\"Import API cURL\"\n customClass=\"cqa-api-edit-step-btn-outline cqa-font-inter cqa-text-[14px] cqa-font-semibold cqa-leading-[100%] cqa-tracking-normal cqa-text-[#414146]\">\n </cqa-button>\n </div>\n <cqa-button variant=\"filled\" btnSize=\"lg\" text=\"Send Request\" (clicked)=\"onSendRequest()\"\n customClass=\"cqa-api-edit-step-btn-primary cqa-font-inter cqa-text-[14px] cqa-font-semibold cqa-leading-[100%] cqa-tracking-normal cqa-text-[#FBFCFF]\">\n </cqa-button>\n </div>\n\n\n\n <!-- Body content: header section (default) OR import cURL section -->\n <ng-container *ngIf=\"bodyView === 'import-curl'\">\n <div class=\"cqa-api-edit-step-import-curl-panel\">\n <div class=\"cqa-api-edit-step-import-curl-header\">\n <h3 class=\"cqa-api-edit-step-import-curl-title\">Import API cURL</h3>\n </div>\n <div class=\"cqa-api-edit-step-import-curl-separator\"></div>\n <div class=\"cqa-api-edit-step-import-curl-body\">\n <cqa-custom-textarea [value]=\"importCurlControl.value\"\n (valueChange)=\"importCurlControl.setValue($event)\"\n placeholder=\"Paste your cURL command here (e.g., curl -X POST https://api.example.com/users)\"\n [fullWidth]=\"true\" [rows]=\"8\" resize=\"vertical\" size=\"md\"\n class=\"cqa-api-edit-step-import-curl-textarea\">\n </cqa-custom-textarea>\n </div>\n <div class=\"cqa-api-edit-step-import-curl-footer\">\n <cqa-button type=\"button\" variant=\"outlined\" btnSize=\"lg\" text=\"Cancel\"\n customClass=\"cqa-api-edit-step-import-curl-btn-cancel\" (clicked)=\"onCancelImportCurl()\"></cqa-button>\n <cqa-button type=\"button\" variant=\"filled\" btnSize=\"lg\" text=\"Import\"\n customClass=\"cqa-api-edit-step-import-curl-btn-import\" (clicked)=\"onImportCurlConfirm()\"></cqa-button>\n </div>\n </div>\n </ng-container>\n\n <ng-container *ngIf=\"bodyView === 'headers'\">\n <div class=\"cqa-api-edit-step-tabs-wrapper\">\n <div class=\"cqa-api-edit-step-tabs\">\n <cqa-button *ngFor=\"let tab of payloadTabs\" type=\"button\" variant=\"text\" [text]=\"tab.label\"\n [customClass]=\"'cqa-api-edit-step-tab' + (activePayloadTab === tab.value ? ' cqa-api-edit-step-tab--active' : '') + (isMethodWithoutBody && tab.value !== 'headers' ? ' cqa-api-edit-step-tab--disabled' : '')\"\n [disabled]=\"isMethodWithoutBody && tab.value !== 'headers'\"\n (clicked)=\"setPayloadTab(tab.value)\">\n </cqa-button>\n </div>\n\n <!-- Payload content (Headers) -->\n <div *ngIf=\"activePayloadTab === 'headers'\" class=\"cqa-api-edit-step-payload\">\n <div class=\"cqa-api-edit-step-headers-grid\">\n <span class=\"cqa-api-edit-step-headers-label\">Header Name</span>\n <span class=\"cqa-api-edit-step-headers-label\">Header Value</span>\n <span class=\"cqa-api-edit-step-headers-label cqa-api-edit-step-headers-label--empty\"\n aria-hidden=\"true\"></span>\n </div>\n <div *ngFor=\"let row of headerRows; let i = index; trackBy: trackByHeader\" [formGroup]=\"row\"\n class=\"cqa-api-edit-step-header-row\">\n <cqa-dynamic-select [form]=\"row\" [config]=\"headerNameSelectConfig\"\n (addCustomValue)=\"onHeaderNameAddCustomValue($event, row)\"\n class=\"cqa-api-edit-step-header-type-select cqa-w-full\">\n </cqa-dynamic-select>\n <cqa-custom-input [value]=\"row.get('value')?.value ?? ''\"\n (valueChange)=\"row.get('value')?.setValue($event)\" placeholder=\"Value\" [fullWidth]=\"true\" size=\"sm\"\n class=\"cqa-api-edit-step-header-value-input\" ariaLabel=\"Header value\">\n </cqa-custom-input>\n <cqa-button type=\"button\" variant=\"text\" [customClass]=\"'cqa-api-edit-step-header-delete'\"\n [tooltip]=\"'Remove header'\" (clicked)=\"removeHeader(i)\">\n <svg class=\"cqa-api-edit-step-header-delete-icon\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\"\n fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\" aria-hidden=\"true\">\n <path\n d=\"M10.6663 6V12.6667H5.33301V6H10.6663ZM9.66634 2H6.33301L5.66634 2.66667H3.33301V4H12.6663V2.66667H10.333L9.66634 2ZM11.9997 4.66667H3.99967V12.6667C3.99967 13.4 4.59967 14 5.33301 14H10.6663C11.3997 14 11.9997 13.4 11.9997 12.6667V4.66667Z\"\n fill=\"#F9BFBF\" />\n </svg>\n </cqa-button>\n </div>\n <div class=\"cqa-api-edit-step-add-header-wrap\">\n <cqa-button type=\"button\" variant=\"text\" text=\"+ Add Header\"\n [customClass]=\"'cqa-api-edit-step-add-header-link'\" (clicked)=\"addHeader()\">\n </cqa-button>\n </div>\n </div>\n\n <!-- Payload content (Body only): type, format, text area, Back/Next -->\n <div *ngIf=\"activePayloadTab === 'body'\"\n class=\"cqa-api-edit-step-payload cqa-api-edit-step-payload-editor\">\n <div class=\"cqa-api-edit-step-payload-type-row\">\n <span class=\"cqa-api-edit-step-payload-type-label\">Type</span>\n <div class=\"cqa-api-edit-step-payload-type-radios\">\n <cqa-segment-control [value]=\"payloadType\" [segments]=\"payloadTypeSegments\"\n (valueChange)=\"onPayloadTypeChange($event)\"\n class=\"cqa-api-edit-step-payload-type-segment\">\n </cqa-segment-control>\n </div>\n <div *ngIf=\"payloadType === 'raw'\" class=\"cqa-api-edit-step-payload-format-wrap\">\n <span class=\"cqa-api-edit-step-payload-format-label\">Format:</span>\n <cqa-dynamic-select *ngIf=\"payloadFormatForm\" [form]=\"payloadFormatForm\"\n [config]=\"payloadFormatSelectConfig\" class=\"cqa-api-edit-step-payload-format-select\"\n aria-label=\"Format\">\n </cqa-dynamic-select>\n </div>\n </div>\n <!-- Raw: text area with line numbers (Postman-style payload body) -->\n <div *ngIf=\"payloadType === 'raw'\" class=\"cqa-api-edit-step-payload-body\" #payloadEditorWithLinesRef>\n <div class=\"cqa-api-edit-step-payload-editor-with-lines\">\n <div class=\"cqa-api-edit-step-payload-line-numbers\" aria-hidden=\"true\">\n <span *ngFor=\"let n of payloadLineNumbers\" class=\"cqa-api-edit-step-payload-line-num\">\n <span *ngIf=\"payloadJsonError && payloadJsonError.line === n\"\n class=\"cqa-api-edit-step-payload-line-error-icon\" [title]=\"payloadJsonErrorTooltip\"\n aria-label=\"Parse error on this line\">\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"14\" height=\"14\" viewBox=\"0 0 14 14\" fill=\"none\" aria-hidden=\"true\">\n <circle cx=\"7\" cy=\"7\" r=\"6\" fill=\"#EF4444\"/>\n <path d=\"M4 4l6 6M10 4l-6 6\" stroke=\"white\" stroke-width=\"1.5\" stroke-linecap=\"round\"/>\n </svg>\n </span>\n <span class=\"cqa-api-edit-step-payload-line-num-text\">{{ n }}</span>\n </span>\n </div>\n <div class=\"cqa-api-edit-step-payload-textarea-cell\">\n <div class=\"cqa-api-edit-step-payload-textarea cqa-w-full cqa-flex cqa-flex-col cqa-min-h-0\"\n [ngClass]=\"{'cqa-api-edit-step-payload-textarea--error': payloadJsonError}\">\n <textarea #payloadTextareaRef\n class=\"cqa-api-edit-step-payload-textarea-input cqa-w-full cqa-resize-y cqa-outline-none cqa-box-border\"\n [ngClass]=\"{'cqa-api-edit-step-payload-textarea-input--error': payloadJsonError}\"\n [value]=\"payloadText\"\n [attr.rows]=\"10\"\n placeholder=\"\"\n [attr.aria-label]=\"'Payload'\"\n [attr.aria-invalid]=\"!!payloadJsonError\"\n (input)=\"onPayloadInput($event)\"\n (keydown)=\"onPayloadKeydown($event)\">\n </textarea>\n </div>\n </div>\n </div>\n <p *ngIf=\"payloadJsonError\" class=\"cqa-api-edit-step-payload-json-error-msg\">\n Invalid JSON format. Please check your syntax.\n </p>\n </div>\n\n <!-- x-www-form-urlencoded: Key\u2013Value rows, add/remove dynamically -->\n <div *ngIf=\"payloadType === 'x-www-form-urlencoded'\" class=\"cqa-api-edit-step-key-value\">\n <div class=\"cqa-api-edit-step-key-value-grid cqa-api-edit-step-key-value-header\">\n <span class=\"cqa-api-edit-step-key-value-label\">Key</span>\n <span class=\"cqa-api-edit-step-key-value-label\">Value</span>\n <span class=\"cqa-api-edit-step-key-value-label cqa-api-edit-step-key-value-label--empty\"\n aria-hidden=\"true\"></span>\n </div>\n <div *ngFor=\"let row of keyValueRows; let i = index; trackBy: trackByKeyValue\" [formGroup]=\"row\"\n class=\"cqa-api-edit-step-key-value-row\">\n <cqa-custom-input [value]=\"row.get('key')?.value ?? ''\"\n (valueChange)=\"row.get('key')?.setValue($event)\" placeholder=\"Key\" [fullWidth]=\"true\" size=\"sm\"\n class=\"cqa-api-edit-step-key-value-input\" ariaLabel=\"Key\">\n </cqa-custom-input>\n <cqa-custom-input [value]=\"row.get('value')?.value ?? ''\"\n (valueChange)=\"row.get('value')?.setValue($event)\" placeholder=\"Value\" [fullWidth]=\"true\" size=\"sm\"\n class=\"cqa-api-edit-step-key-value-input\" ariaLabel=\"Value\">\n </cqa-custom-input>\n <cqa-button type=\"button\" variant=\"text\" [customClass]=\"'cqa-api-edit-step-key-value-delete'\"\n [tooltip]=\"'Remove row'\" (clicked)=\"removeKeyValueRow(i)\">\n <svg class=\"cqa-api-edit-step-key-value-delete-icon\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\"\n fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\" aria-hidden=\"true\">\n <path\n d=\"M10.6663 6V12.6667H5.33301V6H10.6663ZM9.66634 2H6.33301L5.66634 2.66667H3.33301V4H12.6663V2.66667H10.333L9.66634 2ZM11.9997 4.66667H3.99967V12.6667C3.99967 13.4 4.59967 14 5.33301 14H10.6663C11.3997 14 11.9997 13.4 11.9997 12.6667V4.66667Z\"\n fill=\"#F9BFBF\" />\n </svg>\n </cqa-button>\n </div>\n <div class=\"cqa-api-edit-step-key-value-add-wrap\">\n <cqa-button type=\"button\" variant=\"filled\" btnSize=\"lg\" text=\"+ Add Row\"\n customClass=\"cqa-api-edit-step-key-value-add-btn\" (clicked)=\"addKeyValueRow()\">\n </cqa-button>\n </div>\n </div>\n\n <!-- Form Data: Key\u2013Type\u2013Value rows; Type is a dropdown (Text/File), add/remove dynamically -->\n <div *ngIf=\"payloadType === 'form-data'\" class=\"cqa-api-edit-step-key-type-value\">\n <div class=\"cqa-api-edit-step-key-type-value-header\">\n <span class=\"cqa-api-edit-step-key-type-value-label\">Key</span>\n <span class=\"cqa-api-edit-step-key-type-value-label\">Type</span>\n <span class=\"cqa-api-edit-step-key-type-value-label\">Value</span>\n <span class=\"cqa-api-edit-step-key-type-value-label cqa-api-edit-step-key-type-value-label--empty\"\n aria-hidden=\"true\"></span>\n </div>\n <div *ngFor=\"let row of keyTypeValueRows; let i = index; trackBy: trackByKeyTypeValue\" [formGroup]=\"row\"\n class=\"cqa-api-edit-step-key-type-value-row\">\n <cqa-custom-input [value]=\"row.get('key')?.value ?? ''\"\n (valueChange)=\"row.get('key')?.setValue($event)\" placeholder=\"Key\" [fullWidth]=\"true\" size=\"sm\"\n class=\"cqa-api-edit-step-key-type-value-input\" ariaLabel=\"Key\">\n </cqa-custom-input>\n <cqa-dynamic-select [form]=\"row\" [config]=\"keyTypeValueTypeSelectConfig\"\n class=\"cqa-api-edit-step-key-type-value-type-select cqa-w-full\">\n </cqa-dynamic-select>\n <cqa-custom-input [value]=\"row.get('value')?.value ?? ''\"\n (valueChange)=\"row.get('value')?.setValue($event)\" placeholder=\"Value\" [fullWidth]=\"true\" size=\"sm\"\n class=\"cqa-api-edit-step-key-type-value-input\" ariaLabel=\"Value\">\n </cqa-custom-input>\n <cqa-button type=\"button\" variant=\"text\" [customClass]=\"'cqa-api-edit-step-key-type-value-delete'\"\n [tooltip]=\"'Remove row'\" (clicked)=\"removeKeyTypeValueRow(i)\">\n <svg class=\"cqa-api-edit-step-key-type-value-delete-icon\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\"\n fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\" aria-hidden=\"true\">\n <path\n d=\"M10.6663 6V12.6667H5.33301V6H10.6663ZM9.66634 2H6.33301L5.66634 2.66667H3.33301V4H12.6663V2.66667H10.333L9.66634 2ZM11.9997 4.66667H3.99967V12.6667C3.99967 13.4 4.59967 14 5.33301 14H10.6663C11.3997 14 11.9997 13.4 11.9997 12.6667V4.66667Z\"\n fill=\"#F9BFBF\" />\n </svg>\n </cqa-button>\n </div>\n <div class=\"cqa-api-edit-step-key-type-value-add-wrap\">\n <cqa-button type=\"button\" variant=\"filled\" btnSize=\"lg\" text=\"+ Add Row\"\n customClass=\"cqa-api-edit-step-key-type-value-add-btn\" (clicked)=\"addKeyTypeValueRow()\">\n </cqa-button>\n </div>\n </div>\n </div>\n </div>\n </ng-container>\n\n </div>\n <!-- Step 2: Variable Name: input, validation, Back / Next -->\n <div class=\"cqa-api-edit-step-panel\">\n <div class=\"cqa-api-edit-step-variable-section\">\n <div class=\"cqa-api-edit-step-variable-input-wrap\">\n <cqa-custom-input [(value)]=\"variableName\" [label]=\"''\" placeholder=\"Variable Name\" [fullWidth]=\"true\"\n size=\"md\" (valueChange)=\"onVariableNameChange()\" aria-label=\"Variable Name\">\n </cqa-custom-input>\n </div>\n <p *ngIf=\"variableNameError\" class=\"cqa-api-edit-step-variable-error\" role=\"alert\">{{ variableNameError }}</p>\n </div>\n </div>\n <!-- Step 3: Response Body / Status tabs -->\n <div class=\"cqa-api-edit-step-panel\">\n <div class=\"cqa-api-edit-step-tabs-wrapper\">\n <div class=\"cqa-api-edit-step-tabs\">\n <cqa-button *ngFor=\"let tab of responseVerificationTabs\" type=\"button\" variant=\"text\" [text]=\"tab.label\"\n [customClass]=\"'cqa-api-edit-step-tab' + (activeResponseVerificationTab === tab.value ? ' cqa-api-edit-step-tab--active' : '')\"\n (clicked)=\"setResponseVerificationTab(tab.value)\">\n </cqa-button>\n </div>\n\n <!-- Response Body tab content: verification grid -->\n <div *ngIf=\"activeResponseVerificationTab === 'response-body'\" class=\"cqa-api-edit-step-step3-content\">\n <div class=\"cqa-api-edit-step-verification-header-row\">\n <span></span>\n <cqa-button type=\"button\" variant=\"text\" text=\"Add Verification\"\n customClass=\"cqa-api-edit-step-verification-add-link\" (clicked)=\"addVerificationRow()\">\n </cqa-button>\n </div>\n <div class=\"cqa-api-edit-step-verification\">\n <div class=\"cqa-api-edit-step-verification-grid cqa-api-edit-step-verification-grid-header\">\n <span class=\"cqa-api-edit-step-verification-label\">S.no</span>\n <span class=\"cqa-api-edit-step-verification-label\">JSON Path</span>\n <span class=\"cqa-api-edit-step-verification-label\">Verification</span>\n <span class=\"cqa-api-edit-step-verification-label\">Data Type</span>\n <span class=\"cqa-api-edit-step-verification-label\">Expected Value</span>\n <span class=\"cqa-api-edit-step-verification-label cqa-api-edit-step-verification-label--empty\"\n aria-hidden=\"true\"></span>\n </div>\n <div *ngFor=\"let row of verificationRows; let i = index; trackBy: trackByVerification\" [formGroup]=\"row\"\n class=\"cqa-api-edit-step-verification-row\">\n <span class=\"cqa-api-edit-step-verification-sno\">{{ i + 1 }}</span>\n <cqa-custom-input [value]=\"row.get('jsonPath')?.value ?? ''\"\n (valueChange)=\"row.get('jsonPath')?.setValue($event)\" placeholder=\"Json Path\" [fullWidth]=\"true\"\n size=\"sm\" class=\"cqa-api-edit-step-verification-input\" ariaLabel=\"JSON Path\">\n </cqa-custom-input>\n <cqa-dynamic-select [form]=\"row\" [config]=\"verificationSelectConfig\"\n class=\"cqa-api-edit-step-verification-select cqa-w-full\">\n </cqa-dynamic-select>\n <cqa-dynamic-select [form]=\"row\" [config]=\"verificationDataTypeSelectConfig\"\n class=\"cqa-api-edit-step-verification-select cqa-w-full\"\n (selectionChange)=\"onVerificationDataTypeChange(row, $event)\">\n </cqa-dynamic-select>\n <!-- Expected Value: text for String/Array/Object, number for Number, dropdown for Boolean -->\n <ng-container [ngSwitch]=\"row.get('dataType')?.value\">\n <cqa-dynamic-select *ngSwitchCase=\"'boolean'\" [form]=\"row\"\n [config]=\"verificationExpectedValueBooleanSelectConfig\"\n class=\"cqa-api-edit-step-verification-select cqa-api-edit-step-verification-expected-select cqa-w-full\">\n </cqa-dynamic-select>\n <cqa-custom-input *ngSwitchCase=\"'number'\" [value]=\"row.get('expectedValue')?.value ?? ''\"\n (valueChange)=\"row.get('expectedValue')?.setValue($event)\" placeholder=\"Expected Value (number)\"\n type=\"number\" [fullWidth]=\"true\" size=\"sm\"\n class=\"cqa-api-edit-step-verification-input cqa-api-edit-step-verification-expected-number\"\n ariaLabel=\"Expected Value\">\n </cqa-custom-input>\n <cqa-custom-input *ngSwitchDefault [value]=\"row.get('expectedValue')?.value ?? ''\"\n (valueChange)=\"row.get('expectedValue')?.setValue($event)\"\n placeholder=\"Expected Value in String\" [fullWidth]=\"true\" size=\"sm\"\n class=\"cqa-api-edit-step-verification-input\" ariaLabel=\"Expected Value\">\n </cqa-custom-input>\n </ng-container>\n <cqa-button type=\"button\" variant=\"text\" [customClass]=\"'cqa-api-edit-step-verification-delete'\"\n [tooltip]=\"'Remove row'\" (clicked)=\"removeVerificationRow(i)\">\n <svg class=\"cqa-api-edit-step-verification-delete-icon\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\"\n fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\" aria-hidden=\"true\">\n <path\n d=\"M10.6663 6V12.6667H5.33301V6H10.6663ZM9.66634 2H6.33301L5.66634 2.66667H3.33301V4H12.6663V2.66667H10.333L9.66634 2ZM11.9997 4.66667H3.99967V12.6667C3.99967 13.4 4.59967 14 5.33301 14H10.6663C11.3997 14 11.9997 13.4 11.9997 12.6667V4.66667Z\"\n fill=\"#F9BFBF\" />\n </svg>\n </cqa-button>\n </div>\n </div>\n </div>\n\n <!-- Status tab content: S.no, Verification dropdown, Expected Value, add/remove rows -->\n <div *ngIf=\"activeResponseVerificationTab === 'status'\" class=\"cqa-api-edit-step-step3-content\">\n <div class=\"cqa-api-edit-step-verification-header-row\">\n <span></span>\n <cqa-button type=\"button\" variant=\"text\" text=\"Add Verification\"\n customClass=\"cqa-api-edit-step-verification-add-link\" (clicked)=\"addStatusVerificationRow()\">\n </cqa-button>\n </div>\n <div class=\"cqa-api-edit-step-status-verification\">\n <div class=\"cqa-api-edit-step-status-verification-header\">\n <span class=\"cqa-api-edit-step-verification-label\">S.no</span>\n <span class=\"cqa-api-edit-step-verification-label\">Verification</span>\n <span class=\"cqa-api-edit-step-verification-label\">Expected Value</span>\n <span class=\"cqa-api-edit-step-verification-label cqa-api-edit-step-verification-label--empty\"\n aria-hidden=\"true\"></span>\n </div>\n <div *ngFor=\"let row of statusVerificationRows; let i = index; trackBy: trackByStatusVerification\"\n [formGroup]=\"row\" class=\"cqa-api-edit-step-status-verification-row\">\n <span class=\"cqa-api-edit-step-verification-sno\">{{ i + 1 }}</span>\n <cqa-dynamic-select [form]=\"row\" [config]=\"statusVerificationSelectConfig\"\n class=\"cqa-api-edit-step-status-verification-select cqa-w-full\">\n </cqa-dynamic-select>\n <cqa-custom-input [value]=\"row.get('expectedValue')?.value ?? ''\"\n (valueChange)=\"row.get('expectedValue')?.setValue($event)\" placeholder=\"Expected Value\"\n type=\"number\" [fullWidth]=\"true\" size=\"sm\" class=\"cqa-api-edit-step-verification-input\"\n ariaLabel=\"Expected Value\">\n </cqa-custom-input>\n <cqa-button type=\"button\" variant=\"text\" [customClass]=\"'cqa-api-edit-step-verification-delete'\"\n [tooltip]=\"'Remove row'\" (clicked)=\"removeStatusVerificationRow(i)\">\n <svg class=\"cqa-api-edit-step-verification-delete-icon\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\"\n fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\" aria-hidden=\"true\">\n <path\n d=\"M10.6663 6V12.6667H5.33301V6H10.6663ZM9.66634 2H6.33301L5.66634 2.66667H3.33301V4H12.6663V2.66667H10.333L9.66634 2ZM11.9997 4.66667H3.99967V12.6667C3.99967 13.4 4.59967 14 5.33301 14H10.6663C11.3997 14 11.9997 13.4 11.9997 12.6667V4.66667Z\"\n fill=\"#F9BFBF\" />\n </svg>\n </cqa-button>\n </div>\n </div>\n </div>\n </div>\n </div>\n </div>\n </div>\n\n <!-- Response Preview -->\n <div class=\"cqa-api-edit-step-response\">\n <h3 class=\"cqa-api-edit-step-response-title\">Response Preview</h3>\n <pre class=\"cqa-api-edit-step-response-content\">{{ responsePreview }}</pre>\n </div>\n\n <!-- Step actions: one row, full width. Step 1: Cancel + Next; Step 2: Back + Next; Step 3: Back + Create -->\n <div class=\"cqa-api-edit-step-actions\">\n <ng-container [ngSwitch]=\"currentStep\">\n <ng-container *ngSwitchCase=\"1\">\n <cqa-button type=\"button\" variant=\"outlined\" btnSize=\"lg\" text=\"Cancel\"\n customClass=\"cqa-api-edit-step-actions-btn-cancel\" (clicked)=\"onBack()\">\n </cqa-button>\n <cqa-button type=\"button\" variant=\"filled\" btnSize=\"lg\" text=\"Next\"\n customClass=\"cqa-api-edit-step-actions-btn-next\" (clicked)=\"onNext()\">\n </cqa-button>\n </ng-container>\n <ng-container *ngSwitchCase=\"2\">\n <cqa-button type=\"button\" variant=\"outlined\" btnSize=\"lg\" text=\"Back\"\n customClass=\"cqa-api-edit-step-actions-btn-back\" (clicked)=\"onBack()\">\n </cqa-button>\n <cqa-button type=\"button\" variant=\"filled\" btnSize=\"lg\" text=\"Next\"\n customClass=\"cqa-api-edit-step-actions-btn-next\" (clicked)=\"onNext()\">\n </cqa-button>\n </ng-container>\n <ng-container *ngSwitchCase=\"3\">\n <cqa-button type=\"button\" variant=\"outlined\" btnSize=\"lg\" text=\"Back\"\n customClass=\"cqa-api-edit-step-actions-btn-back\" (clicked)=\"onBack()\">\n </cqa-button>\n <cqa-button type=\"button\" variant=\"filled\" btnSize=\"lg\" text=\"Create\"\n customClass=\"cqa-api-edit-step-actions-btn-create\" (clicked)=\"onCreate()\">\n </cqa-button>\n </ng-container>\n </ng-container>\n </div>\n</div>" }]
1659
+ args: [{ selector: 'cqa-api-edit-step', host: { class: 'cqa-ui-root' }, changeDetection: ChangeDetectionStrategy.Default, template: "<div class=\"cqa-api-edit-step-container cqa-bg-[#ffffff] cqa-flex cqa-flex-col cqa-w-full cqa-h-full cqa-p-[16px] cqa-gap-[12px] cqa-overflow-y-auto cqa-overflow-x-hidden cqa-box-border\">\n\n <h2 class=\"cqa-api-edit-step-title cqa-font-inter cqa-text-[12px] cqa-font-semibold cqa-leading-[100%] cqa-tracking-normal cqa-text-[#000000] cqa-m-0\">\n {{ editMode ? 'Update API Test Step' : 'Create API Test Step' }}\n </h2>\n\n <div class=\"cqa-api-edit-step-indicator cqa-flex cqa-items-center cqa-gap-0 cqa-max-[767px]:cqa-flex-wrap cqa-max-[767px]:cqa-gap-2 cqa-max-[767px]:cqa-justify-start\"\n [class.cqa-justify-start]=\"stepLabels.length === 1\"\n [class.cqa-justify-between]=\"stepLabels.length !== 1\">\n <ng-container *ngFor=\"let step of stepLabels; let i = index\">\n <cqa-button type=\"button\" variant=\"text\"\n customClass=\"cqa-api-edit-step-indicator-item cqa-api-edit-step-indicator-item--clickable cqa-flex cqa-items-center cqa-gap-[10px] cqa-cursor-pointer cqa-border-none cqa-p-0 cqa-font-inherit cqa-text-inherit cqa-text-left !cqa-bg-transparent\"\n [attr.aria-label]=\"'Step ' + step.index + ': ' + step.label\" [attr.aria-pressed]=\"step.index === currentStep\"\n (clicked)=\"setStep(step.index)\">\n <span class=\"cqa-api-edit-step-indicator-circle cqa-w-8 cqa-h-8 cqa-rounded-full cqa-inline-flex cqa-items-center cqa-justify-center cqa-text-sm cqa-font-medium cqa-leading-none cqa-border-none cqa-shrink-0\"\n [ngClass]=\"step.index === currentStep ? 'cqa-bg-[#4F46E5] cqa-text-white' : 'cqa-bg-[#E0E0E0] cqa-text-[#666666]'\">\n {{ step.index }}\n </span>\n <span class=\"cqa-api-edit-step-indicator-label cqa-text-sm cqa-leading-[18px] cqa-font-normal cqa-max-[767px]:cqa-text-xs\"\n [ngClass]=\"step.index === currentStep ? 'cqa-text-[#4F46E5]' : 'cqa-text-[#666666]'\">\n {{ step.label }}\n </span>\n <div *ngIf=\"i < stepLabels.length - 1\" class=\"cqa-api-edit-step-indicator-line cqa-w-[96px] cqa-h-[2px] cqa-bg-[#E0E0E0] cqa-my-0 cqa-mx-[6px] cqa-shrink-0 cqa-self-center cqa-max-[767px]:cqa-w-[24px] cqa-max-[767px]:cqa-mx-1\" aria-hidden=\"true\"></div>\n </cqa-button>\n </ng-container>\n </div>\n\n <!-- Step content viewport: only the active step body is shown (*ngIf) -->\n <div class=\"cqa-api-edit-step-viewport cqa-w-full\">\n <!-- Step 1: Environment, request, body, response -->\n <div *ngIf=\"currentStep === 1\" class=\"cqa-api-edit-step-panel cqa-flex cqa-flex-col cqa-gap-6 cqa-box-border cqa-w-full\">\n <!-- Environment row: new line, select aligned right -->\n <div class=\"cqa-api-edit-step-environment-row cqa-flex cqa-justify-end cqa-items-center\">\n <cqa-dynamic-select *ngIf=\"environmentForm\" [form]=\"environmentForm\" [config]=\"environmentSelectConfig\"\n class=\"cqa-api-edit-step-environment-select cqa-shrink-0 cqa-w-auto cqa-min-w-[315px] cqa-max-w-[315px] cqa-max-[767px]:cqa-min-w-0 cqa-max-[767px]:cqa-max-w-full cqa-max-[767px]:cqa-w-full [&_.mat-form-field-wrapper]:cqa-pb-0\" aria-label=\"Environment\"\n (selectionChange)=\"onEnvironmentSelectionChange($event)\">\n </cqa-dynamic-select>\n </div>\n\n <!-- Request row: method, URL, buttons -->\n <div class=\"cqa-api-edit-step-request-row cqa-flex cqa-items-center cqa-gap-3 cqa-flex-wrap cqa-max-[767px]:cqa-flex-col cqa-max-[767px]:cqa-items-stretch cqa-max-[767px]:cqa-gap-2.5\">\n <cqa-dynamic-select *ngIf=\"methodForm\" [form]=\"methodForm\" [config]=\"methodSelectConfig\"\n class=\"cqa-api-edit-step-method-select cqa-shrink-0 cqa-w-auto cqa-min-w-[152px] cqa-max-w-[152px] cqa-max-[767px]:cqa-min-w-0 cqa-max-[767px]:cqa-max-w-full cqa-max-[767px]:cqa-w-full\" aria-label=\"HTTP method\"\n (selectionChange)=\"onMethodSelectionChange($event)\">\n </cqa-dynamic-select>\n <div class=\"cqa-api-edit-step-url-wrap cqa-flex-1 cqa-min-w-[200px] cqa-max-[767px]:cqa-min-w-0 cqa-max-[767px]:cqa-w-full [&_cqa-custom-input_.cqa-relative_input]:cqa-h-[40px] [&_cqa-custom-input_.cqa-relative_input]:cqa-bg-white [&_cqa-custom-input_.cqa-relative_input]:cqa-border [&_cqa-custom-input_.cqa-relative_input]:cqa-border-solid [&_cqa-custom-input_.cqa-relative_input]:cqa-border-[#D1D5DB] [&_cqa-custom-input_.cqa-relative_input]:cqa-rounded-md [&_cqa-custom-input_.cqa-relative_input]:cqa-text-sm [&_cqa-custom-input_.cqa-relative_input]:cqa-text-[#374151]\">\n <cqa-custom-input [(value)]=\"url\" [label]=\"''\" placeholder=\"\" [fullWidth]=\"true\" size=\"md\">\n </cqa-custom-input>\n </div>\n <div class=\"cqa-api-edit-step-import-curl-trigger cqa-contents cqa-max-[767px]:cqa-w-full cqa-max-[767px]:!cqa-flex\" (click)=\"openImportCurlPanel()\">\n <cqa-button type=\"button\" variant=\"outlined\" btnSize=\"lg\" text=\"Import API cURL\"\n customClass=\"cqa-api-edit-step-btn-outline !cqa-bg-white !cqa-border !cqa-border-solid !cqa-border-[#6B7280] cqa-text-[#414146] cqa-font-inter cqa-text-[14px] cqa-font-semibold cqa-leading-[100%] cqa-tracking-normal hover:!cqa-bg-[#F9FAFB] hover:!cqa-text-[#414146] cqa-max-[767px]:cqa-w-full\">\n </cqa-button>\n </div>\n <cqa-button variant=\"filled\" btnSize=\"lg\" text=\"Send Request\" (clicked)=\"onSendRequest()\"\n customClass=\"cqa-api-edit-step-btn-primary cqa-font-inter cqa-text-[14px] cqa-font-semibold cqa-leading-[100%] cqa-tracking-normal !cqa-bg-[#3F43EE] cqa-text-[#FBFCFF] !cqa-border-none cqa-py-2.5 cqa-px-6 cqa-gap-2 cqa-rounded-lg cqa-min-h-[37px] cqa-box-border hover:!cqa-bg-[#1B1FEB] cqa-max-[767px]:cqa-w-full\">\n </cqa-button>\n </div>\n\n\n\n <!-- Body content: header section (default) OR import cURL section -->\n <ng-container *ngIf=\"bodyView === 'import-curl'\">\n <div class=\"cqa-api-edit-step-import-curl-panel cqa-flex cqa-flex-col cqa-bg-white cqa-rounded-lg cqa-border cqa-border-solid cqa-border-[#E5E7EB] cqa-shadow-[0_1px_3px_rgba(0,0,0,0.08)] cqa-overflow-hidden\">\n <div class=\"cqa-api-edit-step-import-curl-header cqa-flex cqa-items-center cqa-justify-between cqa-py-3 cqa-px-5 cqa-border-b cqa-border-solid cqa-border-[#E2E8F0] cqa-bg-[#F9FAFB] cqa-rounded-t-lg cqa-max-[767px]:cqa-px-4\">\n <h3 class=\"cqa-api-edit-step-import-curl-title cqa-m-0 cqa-text-xs cqa-font-bold cqa-leading-[18px] cqa-text-[#374151]\">Import API cURL</h3>\n </div>\n <div class=\"cqa-api-edit-step-import-curl-separator cqa-h-px cqa-bg-[#E2E8F0] cqa-my-0 cqa-mx-5\"></div>\n <div class=\"cqa-api-edit-step-import-curl-body\">\n <cqa-custom-textarea [value]=\"importCurlControl.value\"\n (valueChange)=\"importCurlControl.setValue($event)\"\n placeholder=\"Paste your cURL command here (e.g., curl -X POST https://api.example.com/users)\"\n [fullWidth]=\"true\" [rows]=\"8\" resize=\"vertical\" size=\"md\"\n class=\"cqa-api-edit-step-import-curl-textarea\">\n </cqa-custom-textarea>\n </div>\n <div class=\"cqa-api-edit-step-import-curl-footer\">\n <cqa-button type=\"button\" variant=\"outlined\" btnSize=\"lg\" text=\"Cancel\"\n customClass=\"cqa-api-edit-step-import-curl-btn-cancel\" (clicked)=\"onCancelImportCurl()\"></cqa-button>\n <cqa-button type=\"button\" variant=\"filled\" btnSize=\"lg\" text=\"Import\"\n customClass=\"cqa-api-edit-step-import-curl-btn-import\" (clicked)=\"onImportCurlConfirm()\"></cqa-button>\n </div>\n </div>\n </ng-container>\n\n <ng-container *ngIf=\"bodyView === 'headers'\">\n <div class=\"cqa-api-edit-step-tabs-wrapper\">\n <div class=\"cqa-api-edit-step-tabs\">\n <cqa-button *ngFor=\"let tab of payloadTabs\" type=\"button\" variant=\"text\" [text]=\"tab.label\"\n [customClass]=\"'cqa-api-edit-step-tab' + (activePayloadTab === tab.value ? ' cqa-api-edit-step-tab--active' : '') + (isMethodWithoutBody && (tab.value === 'body' || tab.value === 'params') ? ' cqa-api-edit-step-tab--disabled' : '')\"\n [disabled]=\"isMethodWithoutBody && (tab.value === 'body' || tab.value === 'params')\"\n (clicked)=\"setPayloadTab(tab.value)\">\n </cqa-button>\n </div>\n\n <!-- Payload content (Authorization) -->\n <div *ngIf=\"activePayloadTab === 'authorization'\" class=\"cqa-api-edit-step-payload\"\n [attr.style]=\"'padding: 20px; min-height: 200px;'\">\n <div [attr.style]=\"'display: flex; flex-direction: column; gap: 20px;'\">\n <div [attr.style]=\"'display: flex; flex-direction: column; gap: 8px; width: fit-content;'\">\n <span [attr.style]=\"'font-size: 11px; font-weight: 600; letter-spacing: 0.02em; color: #6B7280; text-transform: uppercase; line-height: 1.25;'\">AUTH TYPE</span>\n <cqa-dynamic-select *ngIf=\"authTypeForm\" [form]=\"authTypeForm\" [config]=\"authTypeSelectConfig\"\n class=\"cqa-api-edit-step-auth-type-select\" aria-label=\"Auth type\"\n [attr.style]=\"'min-width: 160px;'\">\n </cqa-dynamic-select>\n </div>\n <!-- No Auth: centered message -->\n <div *ngIf=\"selectedAuthType === 'no-auth'\"\n [attr.style]=\"'flex: 1; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 12px; min-width: 0; text-align: center;'\">\n <div aria-hidden=\"true\"\n [attr.style]=\"'width: 48px; height: 48px; border-radius: 10px; background: #F3F4F6; display: flex; align-items: center; justify-content: center; flex-shrink: 0;'\">\n <svg width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\" style=\"display: block;\">\n <rect x=\"5\" y=\"11\" width=\"14\" height=\"2\" rx=\"1\" fill=\"#9CA3AF\"/>\n </svg>\n </div>\n <span [attr.style]=\"'font-size: 16px; font-weight: 600; color: #374151; line-height: 1.25;'\">No Auth</span>\n <div [attr.style]=\"'display: flex; align-items: center; justify-content: center; gap: 6px; flex-wrap: wrap;'\">\n <span [attr.style]=\"'font-size: 14px; font-weight: 400; color: #9CA3AF; line-height: 1.4;'\">This request does not use any authorization.</span>\n <span role=\"img\" aria-label=\"More information\" title=\"This request does not use any authorization.\"\n [attr.style]=\"'display: inline-flex; align-items: center; justify-content: center; width: 18px; height: 18px; color: #9CA3AF; flex-shrink: 0;'\">\n <svg width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\" style=\"display: block;\">\n <circle cx=\"8\" cy=\"8\" r=\"7\" stroke=\"#9CA3AF\" stroke-width=\"1.5\" fill=\"none\"/>\n <path d=\"M8 7v4M8 5v.5\" stroke=\"#9CA3AF\" stroke-width=\"1.5\" stroke-linecap=\"round\"/>\n </svg>\n </span>\n </div>\n </div>\n <!-- Bearer Token: Token label + textarea -->\n <div *ngIf=\"selectedAuthType === 'bearer'\"\n [attr.style]=\"'flex: 1; display: flex; flex-direction: column; gap: 10px; min-width: 0;'\">\n <span [attr.style]=\"'font-size: 12px; font-weight: 600; color: #374151; line-height: 1.25;'\">Token</span>\n <cqa-custom-textarea [(value)]=\"bearerToken\"\n placeholder=\"Enter bearer token\"\n [fullWidth]=\"true\" [rows]=\"6\" resize=\"vertical\" size=\"md\"\n class=\"cqa-api-edit-step-auth-token-textarea\" ariaLabel=\"Bearer token\">\n </cqa-custom-textarea>\n </div>\n <!-- OAuth 2.0: Grant Type, Access Token URL, Client ID, Client Secret, Scope, Client Authentication -->\n <div *ngIf=\"selectedAuthType === 'oauth2' && oauth2Form\"\n class=\"cqa-api-edit-step-oauth2-grid\"\n [attr.style]=\"'display: grid; grid-template-columns: 1fr 1fr; gap: 16px 24px; width: 100%;'\">\n <div [attr.style]=\"'display: flex; flex-direction: column; gap: 6px; min-width: 0;'\">\n <span [attr.style]=\"'font-size: 12px; font-weight: 600; color: #374151; line-height: 1.25;'\">Grant Type</span>\n <cqa-dynamic-select *ngIf=\"oauth2Form\" [form]=\"oauth2Form\" [config]=\"oauth2GrantTypeSelectConfig\"\n class=\"cqa-api-edit-step-auth-oauth-select\" aria-label=\"OAuth grant type\"\n [attr.style]=\"'min-width: 0; width: 100%;'\">\n </cqa-dynamic-select>\n <span [attr.style]=\"'font-size: 11px; font-style: italic; color: #6B7280; line-height: 1.3;'\">OAuth grant type</span>\n </div>\n <div [attr.style]=\"'display: flex; flex-direction: column; gap: 6px; min-width: 0;'\">\n <span [attr.style]=\"'font-size: 12px; font-weight: 600; color: #374151; line-height: 1.25;'\">Access Token URL</span>\n <cqa-custom-input [value]=\"oauth2Form.get('accessTokenUrl')?.value\"\n (valueChange)=\"oauth2Form.get('accessTokenUrl')?.setValue($event)\"\n [label]=\"''\" placeholder=\"Enter OAuth token endpoint\" [fullWidth]=\"true\" size=\"md\"\n ariaLabel=\"Access Token URL\">\n </cqa-custom-input>\n <span [attr.style]=\"'font-size: 11px; font-style: italic; color: #6B7280; line-height: 1.3;'\">OAuth token endpoint</span>\n </div>\n <div [attr.style]=\"'display: flex; flex-direction: column; gap: 6px; min-width: 0;'\">\n <span [attr.style]=\"'font-size: 12px; font-weight: 600; color: #374151; line-height: 1.25;'\">Client ID</span>\n <cqa-custom-input [value]=\"oauth2Form.get('clientId')?.value\"\n (valueChange)=\"oauth2Form.get('clientId')?.setValue($event)\"\n [label]=\"''\" placeholder=\"Enter OAuth client identifier\" [fullWidth]=\"true\" size=\"md\"\n ariaLabel=\"Client ID\">\n </cqa-custom-input>\n <span [attr.style]=\"'font-size: 11px; font-style: italic; color: #6B7280; line-height: 1.3;'\">OAuth client identifier</span>\n </div>\n <div [attr.style]=\"'display: flex; flex-direction: column; gap: 6px; min-width: 0;'\">\n <span [attr.style]=\"'font-size: 12px; font-weight: 600; color: #374151; line-height: 1.25;'\">Client Secret</span>\n <cqa-custom-input [value]=\"oauth2Form.get('clientSecret')?.value\"\n (valueChange)=\"oauth2Form.get('clientSecret')?.setValue($event)\"\n type=\"password\" [label]=\"''\" placeholder=\"Enter OAuth client secret\" [fullWidth]=\"true\" size=\"md\"\n ariaLabel=\"Client Secret\">\n </cqa-custom-input>\n <span [attr.style]=\"'font-size: 11px; font-style: italic; color: #6B7280; line-height: 1.3;'\">OAuth client secret</span>\n </div>\n <div [attr.style]=\"'display: flex; flex-direction: column; gap: 6px; min-width: 0;'\">\n <span [attr.style]=\"'font-size: 12px; font-weight: 600; color: #374151; line-height: 1.25;'\">Scope</span>\n <cqa-custom-input [value]=\"oauth2Form.get('scope')?.value\"\n (valueChange)=\"oauth2Form.get('scope')?.setValue($event)\"\n [label]=\"''\" placeholder=\"Enter space-separated scopes\" [fullWidth]=\"true\" size=\"md\"\n ariaLabel=\"Scope\">\n </cqa-custom-input>\n <span [attr.style]=\"'font-size: 11px; font-style: italic; color: #6B7280; line-height: 1.3;'\">Space-separated scopes</span>\n </div>\n <div [attr.style]=\"'display: flex; flex-direction: column; gap: 6px; min-width: 0;'\">\n <span [attr.style]=\"'font-size: 12px; font-weight: 600; color: #374151; line-height: 1.25;'\">Client Authentication</span>\n <cqa-dynamic-select *ngIf=\"oauth2Form\" [form]=\"oauth2Form\" [config]=\"oauth2ClientAuthSelectConfig\"\n class=\"cqa-api-edit-step-auth-oauth-select\" aria-label=\"Client authentication method\"\n [attr.style]=\"'min-width: 0; width: 100%;'\">\n </cqa-dynamic-select>\n <span [attr.style]=\"'font-size: 11px; font-style: italic; color: #6B7280; line-height: 1.3;'\">Client authentication method</span>\n </div>\n </div>\n </div>\n </div>\n\n <!-- Payload content (Headers) -->\n <div *ngIf=\"activePayloadTab === 'headers'\" class=\"cqa-api-edit-step-payload\">\n <div class=\"cqa-api-edit-step-headers-grid\">\n <span class=\"cqa-api-edit-step-headers-label\">Header Name</span>\n <span class=\"cqa-api-edit-step-headers-label\">Header Value</span>\n <span class=\"cqa-api-edit-step-headers-label cqa-api-edit-step-headers-label--empty\"\n aria-hidden=\"true\"></span>\n </div>\n <div *ngFor=\"let row of headerRows; let i = index; trackBy: trackByHeader\" [formGroup]=\"row\"\n class=\"cqa-api-edit-step-header-row\">\n <cqa-dynamic-select [form]=\"row\" [config]=\"headerNameSelectConfig\"\n (addCustomValue)=\"onHeaderNameAddCustomValue($event, row)\"\n class=\"cqa-api-edit-step-header-type-select cqa-w-full\">\n </cqa-dynamic-select>\n <cqa-custom-input [value]=\"row.get('value')?.value ?? ''\"\n (valueChange)=\"row.get('value')?.setValue($event)\" placeholder=\"Value\" [fullWidth]=\"true\" size=\"sm\"\n class=\"cqa-api-edit-step-header-value-input\" ariaLabel=\"Header value\">\n </cqa-custom-input>\n <cqa-button type=\"button\" variant=\"text\" [customClass]=\"'cqa-api-edit-step-header-delete'\"\n [tooltip]=\"'Remove header'\" (clicked)=\"removeHeader(i)\">\n <svg class=\"cqa-api-edit-step-header-delete-icon\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\"\n fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\" aria-hidden=\"true\">\n <path\n d=\"M10.6663 6V12.6667H5.33301V6H10.6663ZM9.66634 2H6.33301L5.66634 2.66667H3.33301V4H12.6663V2.66667H10.333L9.66634 2ZM11.9997 4.66667H3.99967V12.6667C3.99967 13.4 4.59967 14 5.33301 14H10.6663C11.3997 14 11.9997 13.4 11.9997 12.6667V4.66667Z\"\n fill=\"#F9BFBF\" />\n </svg>\n </cqa-button>\n </div>\n <div class=\"cqa-api-edit-step-add-header-wrap\">\n <cqa-button type=\"button\" variant=\"text\" text=\"+ Add Header\"\n [customClass]=\"'cqa-api-edit-step-add-header-link'\" (clicked)=\"addHeader()\">\n </cqa-button>\n </div>\n </div>\n\n <!-- Payload content (Params): Key\u2013Value table with add/delete rows -->\n <div *ngIf=\"activePayloadTab === 'params'\" class=\"cqa-api-edit-step-payload\">\n <div class=\"cqa-api-edit-step-key-value-grid cqa-api-edit-step-key-value-header\">\n <span class=\"cqa-api-edit-step-key-value-label\">Key</span>\n <span class=\"cqa-api-edit-step-key-value-label\">Value</span>\n <span class=\"cqa-api-edit-step-key-value-label cqa-api-edit-step-key-value-label--empty\"\n aria-hidden=\"true\"></span>\n </div>\n <div *ngFor=\"let row of paramsRows; let i = index; trackBy: trackByParams\" [formGroup]=\"row\"\n class=\"cqa-api-edit-step-key-value-row\">\n <cqa-custom-input [value]=\"row.get('key')?.value ?? ''\"\n (valueChange)=\"row.get('key')?.setValue($event)\" placeholder=\"Key\" [fullWidth]=\"true\" size=\"sm\"\n class=\"cqa-api-edit-step-key-value-input\" ariaLabel=\"Key\">\n </cqa-custom-input>\n <cqa-custom-input [value]=\"row.get('value')?.value ?? ''\"\n (valueChange)=\"row.get('value')?.setValue($event)\" placeholder=\"Value\" [fullWidth]=\"true\" size=\"sm\"\n class=\"cqa-api-edit-step-key-value-input\" ariaLabel=\"Value\">\n </cqa-custom-input>\n <cqa-button type=\"button\" variant=\"text\" [customClass]=\"'cqa-api-edit-step-key-value-delete'\"\n [tooltip]=\"'Remove row'\" (clicked)=\"removeParamsRow(i)\">\n <svg class=\"cqa-api-edit-step-key-value-delete-icon\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\"\n fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\" aria-hidden=\"true\">\n <path\n d=\"M10.6663 6V12.6667H5.33301V6H10.6663ZM9.66634 2H6.33301L5.66634 2.66667H3.33301V4H12.6663V2.66667H10.333L9.66634 2ZM11.9997 4.66667H3.99967V12.6667C3.99967 13.4 4.59967 14 5.33301 14H10.6663C11.3997 14 11.9997 13.4 11.9997 12.6667V4.66667Z\"\n fill=\"#F9BFBF\" />\n </svg>\n </cqa-button>\n </div>\n <div class=\"cqa-api-edit-step-key-value-add-wrap\">\n <cqa-button type=\"button\" variant=\"filled\" btnSize=\"lg\" text=\"+ Add Row\"\n customClass=\"cqa-api-edit-step-key-value-add-btn\" (clicked)=\"addParamsRow()\">\n </cqa-button>\n </div>\n </div>\n\n <!-- Payload content (Body only): type, format, text area, Back/Next -->\n <div *ngIf=\"activePayloadTab === 'body'\"\n class=\"cqa-api-edit-step-payload cqa-api-edit-step-payload-editor\">\n <div class=\"cqa-api-edit-step-payload-type-row\">\n <span class=\"cqa-api-edit-step-payload-type-label\">Type</span>\n <div class=\"cqa-api-edit-step-payload-type-radios\">\n <cqa-segment-control [value]=\"payloadType\" [segments]=\"payloadTypeSegments\"\n (valueChange)=\"onPayloadTypeChange($event)\"\n class=\"cqa-api-edit-step-payload-type-segment\">\n </cqa-segment-control>\n </div>\n <div *ngIf=\"payloadType === 'raw'\" class=\"cqa-api-edit-step-payload-format-wrap\">\n <span class=\"cqa-api-edit-step-payload-format-label\">Format:</span>\n <cqa-dynamic-select *ngIf=\"payloadFormatForm\" [form]=\"payloadFormatForm\"\n [config]=\"payloadFormatSelectConfig\" class=\"cqa-api-edit-step-payload-format-select\"\n aria-label=\"Format\">\n </cqa-dynamic-select>\n </div>\n </div>\n <!-- Raw: text area with line numbers (Postman-style payload body) -->\n <div *ngIf=\"payloadType === 'raw'\" class=\"cqa-api-edit-step-payload-body\" #payloadEditorWithLinesRef>\n <div class=\"cqa-api-edit-step-payload-editor-with-lines\">\n <div class=\"cqa-api-edit-step-payload-line-numbers\" aria-hidden=\"true\">\n <span *ngFor=\"let n of payloadLineNumbers\" class=\"cqa-api-edit-step-payload-line-num\">\n <span *ngIf=\"payloadJsonError && payloadJsonError.line === n\"\n class=\"cqa-api-edit-step-payload-line-error-icon\" [title]=\"payloadJsonErrorTooltip\"\n aria-label=\"Parse error on this line\">\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"14\" height=\"14\" viewBox=\"0 0 14 14\" fill=\"none\" aria-hidden=\"true\">\n <circle cx=\"7\" cy=\"7\" r=\"6\" fill=\"#EF4444\"/>\n <path d=\"M4 4l6 6M10 4l-6 6\" stroke=\"white\" stroke-width=\"1.5\" stroke-linecap=\"round\"/>\n </svg>\n </span>\n <span class=\"cqa-api-edit-step-payload-line-num-text\">{{ n }}</span>\n </span>\n </div>\n <div class=\"cqa-api-edit-step-payload-textarea-cell\">\n <div class=\"cqa-api-edit-step-payload-textarea cqa-w-full cqa-flex cqa-flex-col cqa-min-h-0\"\n [ngClass]=\"{'cqa-api-edit-step-payload-textarea--error': payloadJsonError}\">\n <textarea #payloadTextareaRef\n class=\"cqa-api-edit-step-payload-textarea-input cqa-w-full cqa-outline-none cqa-box-border\"\n [ngClass]=\"{'cqa-api-edit-step-payload-textarea-input--error': payloadJsonError}\"\n [value]=\"payloadText\"\n placeholder=\"\"\n [attr.aria-label]=\"'Payload'\"\n [attr.aria-invalid]=\"!!payloadJsonError\"\n (input)=\"onPayloadInput($event)\"\n (keydown)=\"onPayloadKeydown($event)\">\n </textarea>\n </div>\n </div>\n </div>\n <p *ngIf=\"payloadJsonError\" class=\"cqa-api-edit-step-payload-json-error-msg\">\n Invalid JSON format. Please check your syntax.\n </p>\n </div>\n\n <!-- x-www-form-urlencoded: Key\u2013Value rows, add/remove dynamically -->\n <div *ngIf=\"payloadType === 'x-www-form-urlencoded'\" class=\"cqa-api-edit-step-key-value\">\n <div class=\"cqa-api-edit-step-key-value-grid cqa-api-edit-step-key-value-header\">\n <span class=\"cqa-api-edit-step-key-value-label\">Key</span>\n <span class=\"cqa-api-edit-step-key-value-label\">Value</span>\n <span class=\"cqa-api-edit-step-key-value-label cqa-api-edit-step-key-value-label--empty\"\n aria-hidden=\"true\"></span>\n </div>\n <div *ngFor=\"let row of keyValueRows; let i = index; trackBy: trackByKeyValue\" [formGroup]=\"row\"\n class=\"cqa-api-edit-step-key-value-row\">\n <cqa-custom-input [value]=\"row.get('key')?.value ?? ''\"\n (valueChange)=\"row.get('key')?.setValue($event)\" placeholder=\"Key\" [fullWidth]=\"true\" size=\"sm\"\n class=\"cqa-api-edit-step-key-value-input\" ariaLabel=\"Key\">\n </cqa-custom-input>\n <cqa-custom-input [value]=\"row.get('value')?.value ?? ''\"\n (valueChange)=\"row.get('value')?.setValue($event)\" placeholder=\"Value\" [fullWidth]=\"true\" size=\"sm\"\n class=\"cqa-api-edit-step-key-value-input\" ariaLabel=\"Value\">\n </cqa-custom-input>\n <cqa-button type=\"button\" variant=\"text\" [customClass]=\"'cqa-api-edit-step-key-value-delete'\"\n [tooltip]=\"'Remove row'\" (clicked)=\"removeKeyValueRow(i)\">\n <svg class=\"cqa-api-edit-step-key-value-delete-icon\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\"\n fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\" aria-hidden=\"true\">\n <path\n d=\"M10.6663 6V12.6667H5.33301V6H10.6663ZM9.66634 2H6.33301L5.66634 2.66667H3.33301V4H12.6663V2.66667H10.333L9.66634 2ZM11.9997 4.66667H3.99967V12.6667C3.99967 13.4 4.59967 14 5.33301 14H10.6663C11.3997 14 11.9997 13.4 11.9997 12.6667V4.66667Z\"\n fill=\"#F9BFBF\" />\n </svg>\n </cqa-button>\n </div>\n <div class=\"cqa-api-edit-step-key-value-add-wrap\">\n <cqa-button type=\"button\" variant=\"filled\" btnSize=\"lg\" text=\"+ Add Row\"\n customClass=\"cqa-api-edit-step-key-value-add-btn\" (clicked)=\"addKeyValueRow()\">\n </cqa-button>\n </div>\n </div>\n\n <!-- Form Data: Key\u2013Type\u2013Value rows; Type is a dropdown (Text/File), add/remove dynamically -->\n <div *ngIf=\"payloadType === 'form-data'\" class=\"cqa-api-edit-step-key-type-value\">\n <div class=\"cqa-api-edit-step-key-type-value-header\">\n <span class=\"cqa-api-edit-step-key-type-value-label\">Key</span>\n <span class=\"cqa-api-edit-step-key-type-value-label\">Type</span>\n <span class=\"cqa-api-edit-step-key-type-value-label\">Value</span>\n <span class=\"cqa-api-edit-step-key-type-value-label cqa-api-edit-step-key-type-value-label--empty\"\n aria-hidden=\"true\"></span>\n </div>\n <div *ngFor=\"let row of keyTypeValueRows; let i = index; trackBy: trackByKeyTypeValue\" [formGroup]=\"row\"\n class=\"cqa-api-edit-step-key-type-value-row\">\n <cqa-custom-input [value]=\"row.get('key')?.value ?? ''\"\n (valueChange)=\"row.get('key')?.setValue($event)\" placeholder=\"Key\" [fullWidth]=\"true\" size=\"sm\"\n class=\"cqa-api-edit-step-key-type-value-input\" ariaLabel=\"Key\">\n </cqa-custom-input>\n <cqa-dynamic-select [form]=\"row\" [config]=\"keyTypeValueTypeSelectConfig\"\n class=\"cqa-api-edit-step-key-type-value-type-select cqa-w-full\">\n </cqa-dynamic-select>\n <cqa-custom-input [value]=\"row.get('value')?.value ?? ''\"\n (valueChange)=\"row.get('value')?.setValue($event)\" placeholder=\"Value\" [fullWidth]=\"true\" size=\"sm\"\n class=\"cqa-api-edit-step-key-type-value-input\" ariaLabel=\"Value\">\n </cqa-custom-input>\n <cqa-button type=\"button\" variant=\"text\" [customClass]=\"'cqa-api-edit-step-key-type-value-delete'\"\n [tooltip]=\"'Remove row'\" (clicked)=\"removeKeyTypeValueRow(i)\">\n <svg class=\"cqa-api-edit-step-key-type-value-delete-icon\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\"\n fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\" aria-hidden=\"true\">\n <path\n d=\"M10.6663 6V12.6667H5.33301V6H10.6663ZM9.66634 2H6.33301L5.66634 2.66667H3.33301V4H12.6663V2.66667H10.333L9.66634 2ZM11.9997 4.66667H3.99967V12.6667C3.99967 13.4 4.59967 14 5.33301 14H10.6663C11.3997 14 11.9997 13.4 11.9997 12.6667V4.66667Z\"\n fill=\"#F9BFBF\" />\n </svg>\n </cqa-button>\n </div>\n <div class=\"cqa-api-edit-step-key-type-value-add-wrap\">\n <cqa-button type=\"button\" variant=\"filled\" btnSize=\"lg\" text=\"+ Add Row\"\n customClass=\"cqa-api-edit-step-key-type-value-add-btn\" (clicked)=\"addKeyTypeValueRow()\">\n </cqa-button>\n </div>\n </div>\n </div>\n </div>\n </ng-container>\n\n </div>\n <!-- Step 2: Variable Name: input, validation, Back / Next -->\n <div *ngIf=\"currentStep === 2\" class=\"cqa-api-edit-step-panel cqa-flex cqa-flex-col cqa-gap-6 cqa-box-border cqa-w-full\">\n <div class=\"cqa-api-edit-step-variable-section\">\n <div class=\"cqa-api-edit-step-variable-input-wrap\">\n <cqa-custom-input [(value)]=\"variableName\" [label]=\"''\" placeholder=\"Variable Name\" [fullWidth]=\"true\"\n size=\"md\" (valueChange)=\"onVariableNameChange()\" aria-label=\"Variable Name\">\n </cqa-custom-input>\n </div>\n <p *ngIf=\"variableNameError\" class=\"cqa-api-edit-step-variable-error\" role=\"alert\">{{ variableNameError }}</p>\n </div>\n </div>\n <!-- Step 3: Response Body / Status tabs -->\n <div *ngIf=\"currentStep === 3\" class=\"cqa-api-edit-step-panel cqa-flex cqa-flex-col cqa-gap-6 cqa-box-border cqa-w-full\">\n <div class=\"cqa-api-edit-step-tabs-wrapper\">\n <div class=\"cqa-api-edit-step-tabs\">\n <cqa-button *ngFor=\"let tab of responseVerificationTabs\" type=\"button\" variant=\"text\" [text]=\"tab.label\"\n [customClass]=\"'cqa-api-edit-step-tab' + (activeResponseVerificationTab === tab.value ? ' cqa-api-edit-step-tab--active' : '')\"\n (clicked)=\"setResponseVerificationTab(tab.value)\">\n </cqa-button>\n </div>\n\n <!-- Response Body tab content: verification grid -->\n <div *ngIf=\"activeResponseVerificationTab === 'response-body'\" class=\"cqa-api-edit-step-step3-content\">\n <div class=\"cqa-api-edit-step-verification-header-row\">\n <span></span>\n <cqa-button type=\"button\" variant=\"text\" text=\"Add Verification\"\n customClass=\"cqa-api-edit-step-verification-add-link\" (clicked)=\"addVerificationRow()\">\n </cqa-button>\n </div>\n <div class=\"cqa-api-edit-step-verification\">\n <div class=\"cqa-api-edit-step-verification-grid cqa-api-edit-step-verification-grid-header\">\n <span class=\"cqa-api-edit-step-verification-label\">S.no</span>\n <span class=\"cqa-api-edit-step-verification-label\">JSON Path</span>\n <span class=\"cqa-api-edit-step-verification-label\">Verification</span>\n <span class=\"cqa-api-edit-step-verification-label\">Data Type</span>\n <span class=\"cqa-api-edit-step-verification-label\">Expected Value</span>\n <span class=\"cqa-api-edit-step-verification-label cqa-api-edit-step-verification-label--empty\"\n aria-hidden=\"true\"></span>\n </div>\n <div *ngFor=\"let row of verificationRows; let i = index; trackBy: trackByVerification\" [formGroup]=\"row\"\n class=\"cqa-api-edit-step-verification-row\">\n <span class=\"cqa-api-edit-step-verification-sno\">{{ i + 1 }}</span>\n <cqa-custom-input [value]=\"row.get('jsonPath')?.value ?? ''\"\n (valueChange)=\"row.get('jsonPath')?.setValue($event)\" placeholder=\"Json Path\" [fullWidth]=\"true\"\n size=\"sm\" class=\"cqa-api-edit-step-verification-input\" ariaLabel=\"JSON Path\">\n </cqa-custom-input>\n <cqa-dynamic-select [form]=\"row\" [config]=\"verificationSelectConfig\"\n class=\"cqa-api-edit-step-verification-select cqa-w-full\">\n </cqa-dynamic-select>\n <cqa-dynamic-select [form]=\"row\" [config]=\"verificationDataTypeSelectConfig\"\n class=\"cqa-api-edit-step-verification-select cqa-w-full\"\n (selectionChange)=\"onVerificationDataTypeChange(row, $event)\">\n </cqa-dynamic-select>\n <!-- Expected Value: text for String/Array/Object, number for Number, dropdown for Boolean -->\n <ng-container [ngSwitch]=\"row.get('dataType')?.value\">\n <cqa-dynamic-select *ngSwitchCase=\"'boolean'\" [form]=\"row\"\n [config]=\"verificationExpectedValueBooleanSelectConfig\"\n class=\"cqa-api-edit-step-verification-select cqa-api-edit-step-verification-expected-select cqa-w-full\">\n </cqa-dynamic-select>\n <cqa-custom-input *ngSwitchCase=\"'number'\" [value]=\"row.get('expectedValue')?.value ?? ''\"\n (valueChange)=\"row.get('expectedValue')?.setValue($event)\" placeholder=\"Expected Value (number)\"\n type=\"number\" [fullWidth]=\"true\" size=\"sm\"\n class=\"cqa-api-edit-step-verification-input cqa-api-edit-step-verification-expected-number\"\n ariaLabel=\"Expected Value\">\n </cqa-custom-input>\n <cqa-custom-input *ngSwitchDefault [value]=\"row.get('expectedValue')?.value ?? ''\"\n (valueChange)=\"row.get('expectedValue')?.setValue($event)\"\n placeholder=\"Expected Value in String\" [fullWidth]=\"true\" size=\"sm\"\n class=\"cqa-api-edit-step-verification-input\" ariaLabel=\"Expected Value\">\n </cqa-custom-input>\n </ng-container>\n <cqa-button type=\"button\" variant=\"text\" [customClass]=\"'cqa-api-edit-step-verification-delete'\"\n [tooltip]=\"'Remove row'\" (clicked)=\"removeVerificationRow(i)\">\n <svg class=\"cqa-api-edit-step-verification-delete-icon\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\"\n fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\" aria-hidden=\"true\">\n <path\n d=\"M10.6663 6V12.6667H5.33301V6H10.6663ZM9.66634 2H6.33301L5.66634 2.66667H3.33301V4H12.6663V2.66667H10.333L9.66634 2ZM11.9997 4.66667H3.99967V12.6667C3.99967 13.4 4.59967 14 5.33301 14H10.6663C11.3997 14 11.9997 13.4 11.9997 12.6667V4.66667Z\"\n fill=\"#F9BFBF\" />\n </svg>\n </cqa-button>\n </div>\n </div>\n </div>\n\n <!-- Status tab content: S.no, Verification dropdown, Expected Value, add/remove rows -->\n <div *ngIf=\"activeResponseVerificationTab === 'status'\" class=\"cqa-api-edit-step-step3-content\">\n <div class=\"cqa-api-edit-step-verification-header-row\">\n <span></span>\n <cqa-button type=\"button\" variant=\"text\" text=\"Add Verification\"\n customClass=\"cqa-api-edit-step-verification-add-link\" (clicked)=\"addStatusVerificationRow()\">\n </cqa-button>\n </div>\n <div class=\"cqa-api-edit-step-status-verification\">\n <div class=\"cqa-api-edit-step-status-verification-header\">\n <span class=\"cqa-api-edit-step-verification-label\">S.no</span>\n <span class=\"cqa-api-edit-step-verification-label\">Verification</span>\n <span class=\"cqa-api-edit-step-verification-label\">Expected Value</span>\n <span class=\"cqa-api-edit-step-verification-label cqa-api-edit-step-verification-label--empty\"\n aria-hidden=\"true\"></span>\n </div>\n <div *ngFor=\"let row of statusVerificationRows; let i = index; trackBy: trackByStatusVerification\"\n [formGroup]=\"row\" class=\"cqa-api-edit-step-status-verification-row\">\n <span class=\"cqa-api-edit-step-verification-sno\">{{ i + 1 }}</span>\n <cqa-dynamic-select [form]=\"row\" [config]=\"statusVerificationSelectConfig\"\n class=\"cqa-api-edit-step-status-verification-select cqa-w-full\">\n </cqa-dynamic-select>\n <cqa-custom-input [value]=\"row.get('expectedValue')?.value ?? ''\"\n (valueChange)=\"row.get('expectedValue')?.setValue($event)\" placeholder=\"Expected Value\"\n type=\"number\" [fullWidth]=\"true\" size=\"sm\" class=\"cqa-api-edit-step-verification-input\"\n ariaLabel=\"Expected Value\">\n </cqa-custom-input>\n <cqa-button type=\"button\" variant=\"text\" [customClass]=\"'cqa-api-edit-step-verification-delete'\"\n [tooltip]=\"'Remove row'\" (clicked)=\"removeStatusVerificationRow(i)\">\n <svg class=\"cqa-api-edit-step-verification-delete-icon\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\"\n fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\" aria-hidden=\"true\">\n <path\n d=\"M10.6663 6V12.6667H5.33301V6H10.6663ZM9.66634 2H6.33301L5.66634 2.66667H3.33301V4H12.6663V2.66667H10.333L9.66634 2ZM11.9997 4.66667H3.99967V12.6667C3.99967 13.4 4.59967 14 5.33301 14H10.6663C11.3997 14 11.9997 13.4 11.9997 12.6667V4.66667Z\"\n fill=\"#F9BFBF\" />\n </svg>\n </cqa-button>\n </div>\n </div>\n </div>\n </div>\n </div>\n </div>\n\n <!-- Response Preview -->\n <div class=\"cqa-api-edit-step-response\">\n <h3 class=\"cqa-api-edit-step-response-title cqa-text-[14px] cqa-font-bold cqa-leading-[20px] cqa-text-[#111827] cqa-m-0 cqa-mb-[12px] cqa-shrink-0\">Response Preview</h3>\n <pre class=\"cqa-api-edit-step-response-content\">{{ responsePreview }}</pre>\n </div>\n\n <!-- Step actions: one row, full width. Step 1: Cancel + Next; Step 2: Back + Next; Step 3: Back + Create -->\n <div class=\"cqa-api-edit-step-actions\">\n <ng-container [ngSwitch]=\"currentStep\">\n <ng-container *ngSwitchCase=\"1\">\n <cqa-button type=\"button\" variant=\"outlined\" btnSize=\"lg\" text=\"Cancel\"\n customClass=\"cqa-api-edit-step-actions-btn-cancel\" (clicked)=\"onCancel()\">\n </cqa-button>\n <cqa-button type=\"button\" variant=\"filled\" btnSize=\"lg\" text=\"Next\"\n customClass=\"cqa-api-edit-step-actions-btn-next\" (clicked)=\"onNext()\">\n </cqa-button>\n </ng-container>\n <ng-container *ngSwitchCase=\"2\">\n <cqa-button type=\"button\" variant=\"outlined\" btnSize=\"lg\" text=\"Back\"\n customClass=\"cqa-api-edit-step-actions-btn-back\" (clicked)=\"onBack()\">\n </cqa-button>\n <cqa-button type=\"button\" variant=\"filled\" btnSize=\"lg\" text=\"Next\"\n customClass=\"cqa-api-edit-step-actions-btn-next\" (clicked)=\"onNext()\">\n </cqa-button>\n </ng-container>\n <ng-container *ngSwitchCase=\"3\">\n <cqa-button type=\"button\" variant=\"outlined\" btnSize=\"lg\" text=\"Back\"\n customClass=\"cqa-api-edit-step-actions-btn-back\" (clicked)=\"onBack()\">\n </cqa-button>\n <cqa-button type=\"button\" variant=\"filled\" btnSize=\"lg\" [text]=\"editMode ? 'Update' : 'Create'\"\n customClass=\"cqa-api-edit-step-actions-btn-create\" (clicked)=\"onCreate()\">\n </cqa-button>\n </ng-container>\n </ng-container>\n </div>\n</div>" }]
1071
1660
  }], ctorParameters: function () { return [{ type: i1.FormBuilder }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { initialMethod: [{
1072
1661
  type: Input
1073
1662
  }], initialEnvironment: [{
@@ -1082,6 +1671,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImpor
1082
1671
  type: Input
1083
1672
  }], initialResponsePreview: [{
1084
1673
  type: Input
1674
+ }], initialVariableName: [{
1675
+ type: Input
1676
+ }], editMode: [{
1677
+ type: Input
1085
1678
  }], importCurl: [{
1086
1679
  type: Output
1087
1680
  }], importCurlCancel: [{
@@ -1090,6 +1683,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImpor
1090
1683
  type: Output
1091
1684
  }], back: [{
1092
1685
  type: Output
1686
+ }], cancel: [{
1687
+ type: Output
1093
1688
  }], next: [{
1094
1689
  type: Output
1095
1690
  }], create: [{
@@ -1100,6 +1695,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImpor
1100
1695
  type: Input
1101
1696
  }], environmentOptions: [{
1102
1697
  type: Input
1698
+ }], authTypeOptions: [{
1699
+ type: Input
1700
+ }], initialAuthType: [{
1701
+ type: Input
1103
1702
  }], formatOptions: [{
1104
1703
  type: Input
1105
1704
  }], initialFormat: [{
@@ -1119,4 +1718,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImpor
1119
1718
  }], statusVerificationOptions: [{
1120
1719
  type: Input
1121
1720
  }] } });
1122
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"api-edit-step.component.js","sourceRoot":"","sources":["../../../../../../src/lib/test-case-details/api-edit-step/api-edit-step.component.ts","../../../../../../src/lib/test-case-details/api-edit-step/api-edit-step.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Output,\n  SimpleChanges,\n  ViewChild,\n} from '@angular/core';\nimport { FormArray, FormBuilder, FormControl, FormGroup } from '@angular/forms';\nimport { Subscription } from 'rxjs';\nimport { DynamicSelectFieldConfig, SelectOption } from '../../dynamic-select/dynamic-select-field.component';\n\nexport const API_EDIT_STEP_LABELS = {\n  REQUEST_DETAILS: 'Request Details',\n  STORE_RESPONSE: 'Store Response',\n  VALIDATION: 'Validation',\n} as const;\n\nexport type ApiEditPayloadTab = 'headers' | 'body' | 'params' | 'scripts';\n\n/** Which body content block is visible: headers (tabs) or import cURL textarea. */\nexport type ApiEditBodyView = 'headers' | 'import-curl';\n\nexport interface ApiEditHeaderRow {\n  name: string;\n  type: string;\n  value: string;\n}\n\n/** Payload emitted when user clicks Send Request (environment, method, url, headers). */\nexport interface ApiEditSendRequestPayload {\n  environment: string;\n  method: string;\n  url: string;\n  headers: ApiEditHeaderRow[];\n}\n\n/** Step 1 request + body payload. */\nexport interface ApiEditStep1Payload {\n  environment: string;\n  method: string;\n  url: string;\n  headers: ApiEditHeaderRow[];\n  activePayloadTab: ApiEditPayloadTab;\n  payloadType: 'raw' | 'x-www-form-urlencoded' | 'form-data';\n  payloadFormat: string;\n  payloadText: string;\n  keyValueRows: { key: string; value: string }[];\n  keyTypeValueRows: { key: string; type: string; value: string }[];\n}\n\n/** Step 2 store-response payload. */\nexport interface ApiEditStep2Payload {\n  variableName: string;\n}\n\n/** Response body verification row. */\nexport interface ApiEditResponseBodyVerificationRow {\n  jsonPath: string;\n  verification: string;\n  dataType: string;\n  expectedValue: string;\n}\n\n/** Status verification row. */\nexport interface ApiEditStatusVerificationRow {\n  verification: string;\n  expectedValue: string;\n}\n\n/** Step 3 validation payload. */\nexport interface ApiEditStep3Payload {\n  activeResponseVerificationTab: 'response-body' | 'status';\n  responseBodyVerifications: ApiEditResponseBodyVerificationRow[];\n  statusVerifications: ApiEditStatusVerificationRow[];\n}\n\n/** Full payload emitted when user clicks Create (all steps’ data). */\nexport interface ApiEditCreatePayload {\n  step1: ApiEditStep1Payload;\n  step2: ApiEditStep2Payload;\n  step3: ApiEditStep3Payload;\n}\n\n/** Environment option: either a string (display = value) or an object with id, name, value, label. */\nexport type EnvironmentOptionInput = string | SelectOption;\n\nconst METHODS_WITHOUT_BODY = ['GET', 'HEAD', 'DELETE'];\n\n/** Auto-close pairs for payload JSON editor: opening char -> closing char. */\nconst PAYLOAD_AUTO_CLOSE_PAIRS: Record<string, string> = { '{': '}', '[': ']', '\"': '\"', \"'\": \"'\" };\n\n@Component({\n  selector: 'cqa-api-edit-step',\n  templateUrl: './api-edit-step.component.html',\n  host: { class: 'cqa-ui-root' },\n  changeDetection: ChangeDetectionStrategy.Default,\n})\nexport class ApiEditStepComponent implements OnChanges, OnInit, AfterViewInit, OnDestroy {\n  @Input() initialMethod?: string;\n  @Input() initialEnvironment?: string;\n  @Input() initialStep?: number;\n  @Input() initialUrl?: string;\n  @Input() initialPayloadTab?: ApiEditPayloadTab;\n  @Input() initialHeaders?: ApiEditHeaderRow[];\n  @Input() initialResponsePreview?: string;\n\n  /** Emits the cURL string when user clicks Import (value from the textarea control). */\n  @Output() importCurl = new EventEmitter<string>();\n  /** Emits when user cancels the Import cURL panel (clicks Cancel). */\n  @Output() importCurlCancel = new EventEmitter<void>();\n  /** Emits when user clicks Send Request, with environment, method, url, and headers. */\n  @Output() sendRequest = new EventEmitter<ApiEditSendRequestPayload>();\n  @Output() back = new EventEmitter<void>();\n  @Output() next = new EventEmitter<void>();\n  /** Emits when user clicks Create with all entered details: step1 (environment, HTTP method, URL, headers, body), step2 (variable name), step3 (verifications). */\n  @Output() create = new EventEmitter<ApiEditCreatePayload>();\n  /** Emits whenever headers change (add, remove, or edit) so the parent can reflect them in the canvas/controls. */\n  @Output() headersChange = new EventEmitter<ApiEditHeaderRow[]>();\n\n  /** Form control for Import cURL textarea; value is emitted when user clicks Import. */\n  readonly importCurlControl = new FormControl('');\n\n  variableName = '';\n  variableNameError = '';\n\n  /** Controls which body content is visible: headers (default) or import-curl. */\n  bodyView: ApiEditBodyView = 'headers';\n\n  readonly stepLabels = [\n    { index: 1, label: API_EDIT_STEP_LABELS.REQUEST_DETAILS },\n    { index: 2, label: API_EDIT_STEP_LABELS.STORE_RESPONSE },\n    { index: 3, label: API_EDIT_STEP_LABELS.VALIDATION },\n  ];\n  currentStep = 1;\n\n  /** The label for the current step only (used when showing a single step in the indicator). */\n  get activeStepLabel(): { index: number; label: string } | undefined {\n    return this.stepLabels[this.currentStep - 1];\n  }\n\n  private readonly minStep = 1;\n  private readonly maxStep = 3;\n\n  /** Percentage to translate the step strip (0, -33.333, -66.666) for CSS transition. */\n  get stripTranslatePercent(): number {\n    return (this.currentStep - 1) * -33.333;\n  }\n\n  setStep(step: number): void {\n    if (step >= this.minStep && step <= this.maxStep) {\n      this.currentStep = step;\n    }\n  }\n\n  private applyInitialStep(value: number | undefined): void {\n    if (value == null) return;\n    const clamped = Math.max(this.minStep, Math.min(this.maxStep, Math.floor(value)));\n    this.currentStep = clamped;\n  }\n\n  /** HTTP method options: array of strings or objects with id, name, value, label (passed from parent). */\n  @Input() httpMethodOptions: EnvironmentOptionInput[] = [];\n\n  /** Form for HTTP method select (cqa-dynamic-select) */\n  methodForm!: FormGroup;\n\n  /** Config for method dropdown (updated when httpMethodOptions changes to avoid new reference every CD) */\n  methodSelectConfig: DynamicSelectFieldConfig = {\n    key: 'method',\n    placeholder: 'Method',\n    searchable: false,\n    options: [],\n  };\n\n  private updateMethodSelectConfig(): void {\n    const options = (this.httpMethodOptions ?? []).map((m) => ApiEditStepComponent.toSelectOption(m));\n    this.methodSelectConfig = {\n      ...this.methodSelectConfig,\n      options,\n    };\n  }\n\n  private getMethodValues(): string[] {\n    return (this.httpMethodOptions ?? [])\n      .map((m) => ApiEditStepComponent.getOptionValue(m))\n      .filter((v): v is string => v != null);\n  }\n\n  /** Form for environment select (cqa-dynamic-select) */\n  environmentForm!: FormGroup;\n\n  /** Environment options: array of strings or objects with id, name, value, label (passed from parent). */\n  @Input() environmentOptions: EnvironmentOptionInput[] = [];\n\n  /** Config for environment dropdown (updated when environmentOptions changes to avoid new reference every CD) */\n  environmentSelectConfig: DynamicSelectFieldConfig = {\n    key: 'environment',\n    placeholder: 'Environment',\n    searchable: false,\n    options: [],\n  };\n\n  private static toSelectOption(item: EnvironmentOptionInput): SelectOption {\n    if (typeof item === 'string') {\n      return { id: item, value: item, name: item, label: item };\n    }\n    const o = item as SelectOption;\n    return {\n      id: o.id ?? o.value,\n      value: o.value ?? o.id,\n      name: o.name ?? o.label ?? String(o.value ?? o.id),\n      label: o.label ?? o.name ?? String(o.value ?? o.id),\n    };\n  }\n\n  private static getOptionValue(item: EnvironmentOptionInput): string | undefined {\n    if (typeof item === 'string') return item;\n    const o = item as SelectOption;\n    const v = o.value ?? o.id;\n    return v != null ? String(v) : undefined;\n  }\n\n  private updateEnvironmentSelectConfig(): void {\n    const options = (this.environmentOptions ?? []).map((e) => ApiEditStepComponent.toSelectOption(e));\n    this.environmentSelectConfig = {\n      ...this.environmentSelectConfig,\n      options,\n    };\n  }\n\n  private getEnvironmentValues(): string[] {\n    return (this.environmentOptions ?? [])\n      .map((e) => ApiEditStepComponent.getOptionValue(e))\n      .filter((v): v is string => v != null);\n  }\n\n  /** Current HTTP method (from form or default: first of httpMethodOptions). Treats empty string as unset. */\n  get selectedMethod(): string {\n    const value = this.methodForm?.get('method')?.value;\n    const firstValue = this.httpMethodOptions?.length\n      ? ApiEditStepComponent.getOptionValue(this.httpMethodOptions[0])\n      : undefined;\n    const resolved = value != null && value !== '' ? (typeof value === 'object' ? ApiEditStepComponent.getOptionValue(value as EnvironmentOptionInput) : String(value)) : undefined;\n    return resolved ?? firstValue ?? 'GET';\n  }\n  set selectedMethod(v: string) {\n    this.methodForm?.patchValue({ method: v });\n  }\n\n  /** True when the selected HTTP method is GET, HEAD, or DELETE (no request body). */\n  get isMethodWithoutBody(): boolean {\n    const method = this.selectedMethod != null ? String(this.selectedMethod).toUpperCase() : '';\n    return METHODS_WITHOUT_BODY.includes(method);\n  }\n\n  /** Cached environment value from last selection (so Create payload has the selected value). */\n  private currentEnvironmentValue = '';\n\n  /** Cached HTTP method from last selection (so Create payload has the selected value). */\n  private currentMethodValue = '';\n\n  /** Current environment (from form or default: first of environmentOptions). Treats empty string as unset. */\n  get selectedEnvironment(): string {\n    const value = this.environmentForm?.get('environment')?.value;\n    const firstValue = this.environmentOptions?.length\n      ? ApiEditStepComponent.getOptionValue(this.environmentOptions[0])\n      : undefined;\n    const resolved = value != null && value !== '' ? (typeof value === 'object' ? ApiEditStepComponent.getOptionValue(value as EnvironmentOptionInput) : String(value)) : undefined;\n    return resolved ?? firstValue ?? 'Development';\n  }\n  set selectedEnvironment(v: string) {\n    this.environmentForm?.patchValue({ environment: v });\n  }\n\n  /** Called when user selects an environment; keeps currentEnvironmentValue in sync for create payload. */\n  onEnvironmentSelectionChange(event: { key: string; value: unknown }): void {\n    const v = event.value;\n    this.currentEnvironmentValue =\n      v != null\n        ? typeof v === 'object'\n          ? (ApiEditStepComponent.getOptionValue(v as EnvironmentOptionInput) ?? '')\n          : String(v)\n        : '';\n  }\n\n  /** Called when user selects an HTTP method; keeps currentMethodValue in sync for create payload. */\n  onMethodSelectionChange(event: { key: string; value: unknown }): void {\n    const v = event.value;\n    this.currentMethodValue =\n      v != null\n        ? typeof v === 'object'\n          ? (ApiEditStepComponent.getOptionValue(v as EnvironmentOptionInput) ?? '')\n          : String(v)\n        : '';\n  }\n\n  url = '';\n\n  readonly payloadTabs: { value: ApiEditPayloadTab; label: string }[] = [\n    { value: 'headers', label: 'Headers' },\n    { value: 'body', label: 'Body' },\n    { value: 'params', label: 'Params' },\n    { value: 'scripts', label: 'Scripts' },\n  ];\n  activePayloadTab: ApiEditPayloadTab = 'headers';\n\n  /** Step 3: Response verification tabs */\n  readonly responseVerificationTabs: { value: 'response-body' | 'status'; label: string }[] = [\n    { value: 'response-body', label: 'Response Body' },\n    { value: 'status', label: 'Status' },\n  ];\n  activeResponseVerificationTab: 'response-body' | 'status' = 'response-body';\n\n  /** Payload type for Body/Params/Scripts: raw, x-www-form-urlencoded, form-data */\n  payloadType: 'raw' | 'x-www-form-urlencoded' | 'form-data' = 'raw';\n\n  /** Segment options for payload type (used by cqa-segment-control) */\n  readonly payloadTypeSegments = [\n    { label: 'Raw', value: 'raw' },\n    { label: 'x-www-form-urlencoded', value: 'x-www-form-urlencoded' },\n    { label: 'Form Data', value: 'form-data' },\n  ];\n\n  onPayloadTypeChange(val: string): void {\n    this.payloadType = val as 'raw' | 'x-www-form-urlencoded' | 'form-data';\n  }\n\n  /** Form for Format select (Body/Params/Scripts) */\n  payloadFormatForm!: FormGroup;\n\n  /** Format options: array of strings or objects (passed from parent). Falls back to JSON, XML, HTML, Text when empty. */\n  @Input() formatOptions: EnvironmentOptionInput[] = [];\n\n  @Input() initialFormat?: string;\n\n  private static readonly DEFAULT_FORMAT_OPTIONS: SelectOption[] = [\n    { id: 'json', value: 'json', name: 'JSON', label: 'JSON' },\n    { id: 'xml', value: 'xml', name: 'XML', label: 'XML' },\n    { id: 'html', value: 'html', name: 'HTML', label: 'HTML' },\n    { id: 'text', value: 'text', name: 'Text', label: 'Text' },\n  ];\n\n  /** Config for Format dropdown (updated when formatOptions changes, like Method dropdown) */\n  payloadFormatSelectConfig: DynamicSelectFieldConfig = {\n    key: 'format',\n    placeholder: 'Select',\n    searchable: false,\n    options: [...ApiEditStepComponent.DEFAULT_FORMAT_OPTIONS],\n  };\n\n  private updatePayloadFormatSelectConfig(): void {\n    const options =\n      this.formatOptions?.length > 0\n        ? this.formatOptions.map((f) => ApiEditStepComponent.toSelectOption(f))\n        : ApiEditStepComponent.DEFAULT_FORMAT_OPTIONS;\n    this.payloadFormatSelectConfig = {\n      ...this.payloadFormatSelectConfig,\n      options,\n    };\n  }\n\n  private getFormatValues(): string[] {\n    const source =\n      this.formatOptions?.length > 0\n        ? this.formatOptions\n        : (ApiEditStepComponent.DEFAULT_FORMAT_OPTIONS as EnvironmentOptionInput[]);\n    return source\n      .map((f) => ApiEditStepComponent.getOptionValue(f as EnvironmentOptionInput))\n      .filter((v): v is string => v != null);\n  }\n\n  /** Payload text area value for Body/Params/Scripts */\n  payloadText = '';\n\n  /** JSON parse error when format is JSON and payload is invalid; null when valid or not JSON. */\n  payloadJsonError: {\n    line: number;\n    column: number;\n    message: string;\n    excerpt: string;\n    caretOffset: number;\n  } | null = null;\n\n  /** Line numbers for payload textarea (1, 2, 3, ...) based on current line count. */\n  get payloadLineNumbers(): number[] {\n    const n = Math.max(1, (this.payloadText || '').split(/\\r?\\n/).length);\n    return Array.from({ length: n }, (_, i) => i + 1);\n  }\n\n  /** Whether current payload format is JSON (so we validate and show JSON editor behavior). */\n  get isPayloadFormatJson(): boolean {\n    const format = this.payloadFormatForm?.get('format')?.value;\n    return format === 'json';\n  }\n\n  /** Error messages for the payload textarea (red border + bottom line). */\n  get payloadJsonErrors(): string[] {\n    return this.payloadJsonError ? ['Invalid JSON format. Please check your syntax.'] : [];\n  }\n\n  /** Tooltip content for the line-level error icon (parse error on line X, excerpt, caret, message). */\n  get payloadJsonErrorTooltip(): string {\n    if (!this.payloadJsonError) return '';\n    const e = this.payloadJsonError;\n    const caret = ' '.repeat(e.caretOffset) + '^';\n    return `Parse error on line ${e.line}:\\n\\n${e.excerpt}\\n${caret}\\n\\n${e.message}`;\n  }\n\n  onPayloadTextChange(value: string): void {\n    this.payloadText = value;\n    this.validatePayloadJson();\n  }\n\n  onPayloadInput(event: Event): void {\n    const target = event.target as HTMLTextAreaElement | null;\n    this.onPayloadTextChange(target?.value ?? '');\n  }\n\n  onPayloadKeydown(event: KeyboardEvent): void {\n    if (!this.isPayloadFormatJson) return;\n    const key = event.key;\n    const close = PAYLOAD_AUTO_CLOSE_PAIRS[key];\n    if (!close) return;\n    const target = event.target as HTMLTextAreaElement | null;\n    if (!target) return;\n    event.preventDefault();\n    const start = target.selectionStart ?? 0;\n    const end = target.selectionEnd ?? start;\n    const before = this.payloadText.slice(0, start);\n    const after = this.payloadText.slice(end);\n    const insertPos = start + 1;\n    const newValue = before + key + close + after;\n    this.payloadText = newValue;\n    this.validatePayloadJson();\n    setTimeout(() => {\n      this.payloadTextareaRef?.nativeElement?.setSelectionRange(insertPos, insertPos);\n    }, 0);\n  }\n\n  /** Validate payload when format is JSON; sets payloadJsonError or clears it. */\n  validatePayloadJson(): void {\n    if (!this.isPayloadFormatJson) {\n      this.payloadJsonError = null;\n      return;\n    }\n    const text = this.payloadText ?? '';\n    if (text.trim() === '') {\n      this.payloadJsonError = null;\n      return;\n    }\n    try {\n      JSON.parse(text);\n      this.payloadJsonError = null;\n    } catch (err) {\n      const message = err instanceof Error ? err.message : String(err);\n      const position = this.extractPositionFromJsonError(message);\n      const { line, column } = this.positionToLineColumn(text, position);\n      const lines = text.split(/\\r?\\n/);\n      const lineIndex = Math.max(0, line - 1);\n      const lineContent = lines[lineIndex] ?? '';\n      const excerpt = lineContent || ' ';\n      const caretOffset = lineIndex === line - 1 ? Math.min(column - 1, lineContent.length) : 0;\n      this.payloadJsonError = {\n        line,\n        column,\n        message: this.normalizeJsonErrorMessage(message),\n        excerpt,\n        caretOffset,\n      };\n    }\n    this.cdr.markForCheck();\n  }\n\n  private extractPositionFromJsonError(message: string): number {\n    const match = message.match(/position\\s+(\\d+)/i) || message.match(/at\\s+position\\s+(\\d+)/i);\n    return match ? parseInt(match[1], 10) : 0;\n  }\n\n  private positionToLineColumn(text: string, position: number): { line: number; column: number } {\n    const before = text.slice(0, Math.min(position, text.length));\n    const lines = before.split(/\\r?\\n/);\n    const line = lines.length;\n    const lastLine = lines[lines.length - 1] ?? '';\n    return { line, column: lastLine.length + 1 };\n  }\n\n  private normalizeJsonErrorMessage(message: string): string {\n    if (message.includes('Expecting') || message.includes('expecting')) return message;\n    const tokenMatch = message.match(/Unexpected token\\s+['\"]?([^'\"]+)['\"]?/i)\n      || message.match(/unexpected character.*?([^\\s]+)/i);\n    const token = tokenMatch ? tokenMatch[1].trim() : 'undefined';\n    return `Expecting 'STRING', 'NUMBER', 'NULL', 'TRUE', 'FALSE', '{', '[', got '${token}'`;\n  }\n\n  @ViewChild('payloadEditorWithLinesRef') payloadEditorWithLinesRef?: ElementRef<HTMLElement>;\n  @ViewChild('payloadTextareaRef') payloadTextareaRef?: ElementRef<HTMLTextAreaElement>;\n\n  private static readonly DEFAULT_HEADER_NAME_OPTIONS: string[] = [\n    'Accept',\n    'Accept-Charset',\n    'Accept-Encoding',\n    'Accept-Language',\n    'Access-Control-Request-Headers',\n    'Access-Control-Request-Method',\n    'Authorization',\n    'Cache-Control',\n    'Content-MD5',\n    'Content-Length',\n    'Content-Transfer-Encoding',\n    'Content-Type',\n    'Cookie',\n    'Date',\n    'Expect',\n    'From',\n    'Host',\n    'If-Match',\n    'If-Modified-Since',\n    'If-None-Match',\n    'If-Unmodified-Since',\n    'If-Range',\n    'Keep-Alive',\n    'Max-Forwards',\n    'Origin',\n    'Pragma',\n    'Proxy-Authorization',\n    'Range',\n    'Referer',\n    'TE',\n    'Trailer',\n    'Transfer-Encoding',\n    'Upgrade',\n    'User-Agent',\n    'Via',\n    'Warning',\n    'X-Requested-With',\n    'X-Do-Not-Track',\n    'DNT',\n    'x-api-key',\n    'Connection',\n  ];\n\n  /** Header name options: array of strings or objects with id, name, value, label (passed from parent). Falls back to built-in list when empty. */\n  @Input() headerNameOptions: EnvironmentOptionInput[] = [];\n\n  /** Form array for header rows; each item is FormGroup({ name, value }) for cqa-dynamic-select and value input */\n  headersFormArray!: FormArray;\n\n  /** Typed accessor for template (FormArray.controls is AbstractControl[]) */\n  get headerRows(): FormGroup[] {\n    return (this.headersFormArray?.controls ?? []) as FormGroup[];\n  }\n\n  /** Config for header name dropdown (updated when headerNameOptions changes to avoid new reference every CD) */\n  headerNameSelectConfig: DynamicSelectFieldConfig = {\n    key: 'name',\n    placeholder: 'Select header',\n    searchable: true,\n    allowCustomValue: true,\n    options: [],\n  };\n\n  private updateHeaderNameSelectConfig(): void {\n    const source =\n      this.headerNameOptions?.length > 0\n        ? this.headerNameOptions\n        : (ApiEditStepComponent.DEFAULT_HEADER_NAME_OPTIONS as EnvironmentOptionInput[]);\n    const baseOptions = source.map((h) => ApiEditStepComponent.toSelectOption(h));\n    const baseValues = new Set(baseOptions.map((o) => String(o.value ?? o.id ?? '').trim()).filter(Boolean));\n    const currentNamesFromForm = this.getCurrentHeaderNamesFromForm();\n    const extraOptions: SelectOption[] = [];\n    for (const name of currentNamesFromForm) {\n      const key = name.trim();\n      if (key && !baseValues.has(key)) {\n        baseValues.add(key);\n        extraOptions.push({ id: key, value: key, name: key, label: key });\n      }\n    }\n    const options = [...baseOptions, ...extraOptions];\n    this.headerNameSelectConfig = {\n      ...this.headerNameSelectConfig,\n      options,\n    };\n  }\n\n  /** Collects distinct non-empty header names currently in the headers form (for dynamic options). */\n  private getCurrentHeaderNamesFromForm(): string[] {\n    const names: string[] = [];\n    const seen = new Set<string>();\n    if (!this.headersFormArray?.controls?.length) return names;\n    for (const control of this.headersFormArray.controls) {\n      const name = (control as FormGroup).get('name')?.value;\n      const str = name != null ? String(name).trim() : '';\n      if (str && !seen.has(str)) {\n        seen.add(str);\n        names.push(str);\n      }\n    }\n    return names;\n  }\n\n  private readonly defaultHeaders: ApiEditHeaderRow[] = [\n    { name: 'Content-Type', type: 'string', value: 'application/json' },\n  ];\n\n  /** Form array for key-value rows (Body payload); each item is FormGroup({ key, value }) */\n  keyValueFormArray!: FormArray;\n\n  get keyValueRows(): FormGroup[] {\n    return (this.keyValueFormArray?.controls ?? []) as FormGroup[];\n  }\n\n  /** Form array for key-type-value rows; each item is FormGroup({ key, type, value }) */\n  keyTypeValueFormArray!: FormArray;\n\n  get keyTypeValueRows(): FormGroup[] {\n    return (this.keyTypeValueFormArray?.controls ?? []) as FormGroup[];\n  }\n\n  /** Config for Type dropdown in key-type-value rows (Text, File) */\n  readonly keyTypeValueTypeSelectConfig: DynamicSelectFieldConfig = {\n    key: 'type',\n    placeholder: 'Text',\n    searchable: false,\n    options: [\n      { id: 'text', value: 'text', name: 'Text', label: 'Text' },\n      { id: 'file', value: 'file', name: 'File', label: 'File' },\n    ],\n  };\n\n  /** Form array for response body verification rows; each item is FormGroup({ jsonPath, verification, dataType, expectedValue }) */\n  verificationFormArray!: FormArray;\n\n  get verificationRows(): FormGroup[] {\n    return (this.verificationFormArray?.controls ?? []) as FormGroup[];\n  }\n\n  /** Verification options: array of strings or objects (passed from parent). Falls back to built-in list when empty. */\n  @Input() verificationOptions: EnvironmentOptionInput[] = [];\n\n  private static readonly DEFAULT_VERIFICATION_OPTIONS: SelectOption[] = [\n    { id: 'equals', value: 'equals', name: 'Equals', label: 'Equals' },\n    { id: 'not-equal', value: 'not-equal', name: 'Not equal', label: 'Not equal' },\n    { id: 'less-than', value: 'less-than', name: 'Less than', label: 'Less than' },\n    { id: 'greater-than', value: 'greater-than', name: 'Greater than', label: 'Greater than' },\n    { id: 'is-null', value: 'is-null', name: 'Is null', label: 'Is null' },\n    { id: 'is-not-null', value: 'is-not-null', name: 'Is not null', label: 'Is not null' },\n  ];\n\n  /** Config for Verification dropdown (updated when verificationOptions changes, like Method dropdown) */\n  verificationSelectConfig: DynamicSelectFieldConfig = {\n    key: 'verification',\n    placeholder: 'Equals',\n    searchable: false,\n    options: [...ApiEditStepComponent.DEFAULT_VERIFICATION_OPTIONS],\n  };\n\n  private updateVerificationSelectConfig(): void {\n    const options =\n      this.verificationOptions?.length > 0\n        ? this.verificationOptions.map((v) => ApiEditStepComponent.toSelectOption(v))\n        : ApiEditStepComponent.DEFAULT_VERIFICATION_OPTIONS;\n    this.verificationSelectConfig = {\n      ...this.verificationSelectConfig,\n      options,\n    };\n  }\n\n  private getVerificationValues(): string[] {\n    const source =\n      this.verificationOptions?.length > 0\n        ? this.verificationOptions\n        : (ApiEditStepComponent.DEFAULT_VERIFICATION_OPTIONS as EnvironmentOptionInput[]);\n    return source\n      .map((v) => ApiEditStepComponent.getOptionValue(v as EnvironmentOptionInput))\n      .filter((v): v is string => v != null);\n  }\n\n  private getDefaultVerification(): string {\n    const values = this.getVerificationValues();\n    return values.length > 0 ? values[0] : 'equals';\n  }\n\n  /** Data Type options: array of strings or objects (passed from parent). Falls back to built-in list when empty. */\n  @Input() verificationDataTypeOptions: EnvironmentOptionInput[] = [];\n\n  private static readonly DEFAULT_DATA_TYPE_OPTIONS: SelectOption[] = [\n    { id: 'string', value: 'string', name: 'String', label: 'String' },\n    { id: 'number', value: 'number', name: 'Number', label: 'Number' },\n    { id: 'boolean', value: 'boolean', name: 'Boolean', label: 'Boolean' },\n    { id: 'array', value: 'array', name: 'Array', label: 'Array' },\n    { id: 'object', value: 'object', name: 'Object', label: 'Object' },\n  ];\n\n  /** Config for Data Type dropdown (updated when verificationDataTypeOptions changes, like Method dropdown) */\n  verificationDataTypeSelectConfig: DynamicSelectFieldConfig = {\n    key: 'dataType',\n    placeholder: 'String',\n    searchable: false,\n    options: [...ApiEditStepComponent.DEFAULT_DATA_TYPE_OPTIONS],\n  };\n\n  private updateVerificationDataTypeSelectConfig(): void {\n    const options =\n      this.verificationDataTypeOptions?.length > 0\n        ? this.verificationDataTypeOptions.map((d) => ApiEditStepComponent.toSelectOption(d))\n        : ApiEditStepComponent.DEFAULT_DATA_TYPE_OPTIONS;\n    this.verificationDataTypeSelectConfig = {\n      ...this.verificationDataTypeSelectConfig,\n      options,\n    };\n  }\n\n  private getDataTypeValues(): string[] {\n    const source =\n      this.verificationDataTypeOptions?.length > 0\n        ? this.verificationDataTypeOptions\n        : (ApiEditStepComponent.DEFAULT_DATA_TYPE_OPTIONS as EnvironmentOptionInput[]);\n    return source\n      .map((d) => ApiEditStepComponent.getOptionValue(d as EnvironmentOptionInput))\n      .filter((v): v is string => v != null);\n  }\n\n  private getDefaultDataType(): string {\n    const values = this.getDataTypeValues();\n    return values.length > 0 ? values[0] : 'string';\n  }\n\n  /** Config for Expected Value when Data Type is Boolean (true/false dropdown) */\n  readonly verificationExpectedValueBooleanSelectConfig: DynamicSelectFieldConfig = {\n    key: 'expectedValue',\n    placeholder: 'Select',\n    searchable: false,\n    options: [\n      { id: 'true', value: 'true', name: 'true', label: 'true' },\n      { id: 'false', value: 'false', name: 'false', label: 'false' },\n    ],\n  };\n\n  /** Form array for Status tab verification rows; each item is FormGroup({ verification, expectedValue }) */\n  statusVerificationFormArray!: FormArray;\n\n  get statusVerificationRows(): FormGroup[] {\n    return (this.statusVerificationFormArray?.controls ?? []) as FormGroup[];\n  }\n\n  /** Config for Status tab Verification dropdown (Equals, Not equal, Less than, Greater than) */\n  /** Status tab Verification options (Equals, Not equal, etc.). Falls back to built-in list when empty. */\n  @Input() statusVerificationOptions: EnvironmentOptionInput[] = [];\n\n  private static readonly DEFAULT_STATUS_VERIFICATION_OPTIONS: SelectOption[] = [\n    { id: 'equals', value: 'equals', name: 'Equals', label: 'Equals' },\n    { id: 'not-equal', value: 'not-equal', name: 'Not equal', label: 'Not equal' },\n    { id: 'less-than', value: 'less-than', name: 'Less than', label: 'Less than' },\n    { id: 'greater-than', value: 'greater-than', name: 'Greater than', label: 'Greater than' },\n  ];\n\n  /** Config for Status tab Verification dropdown (updated when statusVerificationOptions changes). */\n  statusVerificationSelectConfig: DynamicSelectFieldConfig = {\n    key: 'verification',\n    placeholder: 'Equals',\n    searchable: false,\n    options: [...ApiEditStepComponent.DEFAULT_STATUS_VERIFICATION_OPTIONS],\n  };\n\n  private updateStatusVerificationSelectConfig(): void {\n    const options =\n      this.statusVerificationOptions?.length > 0\n        ? this.statusVerificationOptions.map((o) => ApiEditStepComponent.toSelectOption(o))\n        : ApiEditStepComponent.DEFAULT_STATUS_VERIFICATION_OPTIONS;\n    this.statusVerificationSelectConfig = {\n      ...this.statusVerificationSelectConfig,\n      options,\n    };\n  }\n\n  private getStatusVerificationValues(): string[] {\n    const source =\n      this.statusVerificationOptions?.length > 0\n        ? this.statusVerificationOptions\n        : (ApiEditStepComponent.DEFAULT_STATUS_VERIFICATION_OPTIONS as EnvironmentOptionInput[]);\n    return source\n      .map((o) => ApiEditStepComponent.getOptionValue(o as EnvironmentOptionInput))\n      .filter((v): v is string => v != null);\n  }\n\n  private getDefaultStatusVerification(): string {\n    const values = this.getStatusVerificationValues();\n    return values.length > 0 ? values[0] : 'equals';\n  }\n\n  responsePreview = ``;\n\n  private methodChangesSub?: Subscription;\n  private formatChangesSub?: Subscription;\n  private headerNameOptionsChangesSub?: Subscription;\n  private environmentFormChangesSub?: Subscription;\n  private methodFormChangesSub?: Subscription;\n\n  constructor(\n    private readonly fb: FormBuilder,\n    private readonly cdr: ChangeDetectorRef,\n  ) {}\n\n  ngOnInit(): void {\n    this.applyInitialStep(this.initialStep);\n    this.updateMethodSelectConfig();\n    this.updateHeaderNameSelectConfig();\n    const firstMethodValue = this.httpMethodOptions?.length\n      ? ApiEditStepComponent.getOptionValue(this.httpMethodOptions[0])\n      : undefined;\n    const defaultMethod = this.initialMethod ?? firstMethodValue ?? 'GET';\n    this.currentMethodValue = typeof defaultMethod === 'string' ? defaultMethod : (ApiEditStepComponent.getOptionValue(defaultMethod as EnvironmentOptionInput) ?? '');\n    this.methodForm = this.fb.group({\n      method: [defaultMethod],\n    });\n    const firstValue = this.environmentOptions?.length\n      ? ApiEditStepComponent.getOptionValue(this.environmentOptions[0])\n      : undefined;\n    const defaultEnv = this.initialEnvironment ?? firstValue ?? 'Development';\n    this.currentEnvironmentValue = typeof defaultEnv === 'string' ? defaultEnv : (ApiEditStepComponent.getOptionValue(defaultEnv as EnvironmentOptionInput) ?? '');\n    this.environmentForm = this.fb.group({\n      environment: [defaultEnv],\n    });\n    this.environmentFormChangesSub = this.environmentForm.get('environment')?.valueChanges?.subscribe((v: unknown) => {\n      const s = v != null && v !== '' ? (typeof v === 'object' ? ApiEditStepComponent.getOptionValue(v as EnvironmentOptionInput) : String(v)) : '';\n      this.currentEnvironmentValue = s ?? '';\n    });\n    this.methodFormChangesSub = this.methodForm.get('method')?.valueChanges?.subscribe((v: unknown) => {\n      const s = v != null && v !== '' ? (typeof v === 'object' ? ApiEditStepComponent.getOptionValue(v as EnvironmentOptionInput) : String(v)) : '';\n      this.currentMethodValue = s ?? '';\n    });\n    this.buildHeadersFormArray(\n      this.initialHeaders ?? [{ name: '', type: 'string', value: '' }]\n    );\n    this.headerNameOptionsChangesSub = this.headersFormArray?.valueChanges?.subscribe(() => {\n      this.updateHeaderNameSelectConfig();\n      this.headersChange.emit(this.headers);\n    });\n    this.updateHeaderNameSelectConfig();\n    this.headersChange.emit(this.headers);\n    this.updateEnvironmentSelectConfig();\n    this.updatePayloadFormatSelectConfig();\n    const firstFormatValue = this.getFormatValues()[0];\n    const defaultFormat = this.initialFormat ?? firstFormatValue ?? 'json';\n    this.payloadFormatForm = this.fb.group({ format: [defaultFormat] });\n    this.buildKeyValueFormArray();\n    this.buildKeyTypeValueFormArray();\n    this.updateVerificationSelectConfig();\n    this.updateVerificationDataTypeSelectConfig();\n    this.buildVerificationFormArray();\n    this.updateStatusVerificationSelectConfig();\n    this.buildStatusVerificationFormArray();\n    this.methodChangesSub = this.methodForm.get('method')?.valueChanges?.subscribe((value: string) => {\n      const method = value != null ? String(value).toUpperCase() : '';\n      if (METHODS_WITHOUT_BODY.includes(method) && this.activePayloadTab !== 'headers') {\n        this.activePayloadTab = 'headers';\n        this.cdr.detectChanges();\n      }\n    });\n    this.formatChangesSub = this.payloadFormatForm.get('format')?.valueChanges?.subscribe(() => {\n      this.validatePayloadJson();\n    });\n    this.validatePayloadJson();\n  }\n\n  ngAfterViewInit(): void {\n    this.setupPayloadTextareaScrollSync();\n  }\n\n  ngOnDestroy(): void {\n    this.methodChangesSub?.unsubscribe();\n    this.formatChangesSub?.unsubscribe();\n    this.headerNameOptionsChangesSub?.unsubscribe();\n    this.environmentFormChangesSub?.unsubscribe();\n    this.methodFormChangesSub?.unsubscribe();\n  }\n\n  /** Sync line numbers column scroll with payload textarea scroll (Postman-style). */\n  private setupPayloadTextareaScrollSync(): void {\n    setTimeout(() => {\n      const host = this.payloadEditorWithLinesRef?.nativeElement;\n      if (!host) return;\n      const lineNumbersEl = host.querySelector('.cqa-api-edit-step-payload-line-numbers') as HTMLElement | null;\n      const textarea = host.querySelector('textarea');\n      if (!lineNumbersEl || !textarea) return;\n      textarea.addEventListener('scroll', () => {\n        lineNumbersEl.scrollTop = textarea.scrollTop;\n      });\n    }, 0);\n  }\n\n  private buildKeyValueFormArray(rows?: { key: string; value: string }[]): void {\n    const initial = rows ?? [{ key: '', value: '' }];\n    const groups = initial.map((r) => this.fb.group({ key: [r.key], value: [r.value] }));\n    this.keyValueFormArray = this.fb.array(groups);\n  }\n\n  private buildKeyTypeValueFormArray(rows?: { key: string; type: string; value: string }[]): void {\n    const initial = rows ?? [{ key: '', type: 'text', value: '' }];\n    const groups = initial.map((r) => this.fb.group({ key: [r.key], type: [r.type], value: [r.value] }));\n    this.keyTypeValueFormArray = this.fb.array(groups);\n  }\n\n  private buildVerificationFormArray(rows?: { jsonPath: string; verification: string; dataType: string; expectedValue: string }[]): void {\n    const defaultVerification = this.getDefaultVerification();\n    const defaultDataType = this.getDefaultDataType();\n    const initial = rows ?? [{ jsonPath: '', verification: defaultVerification, dataType: defaultDataType, expectedValue: '' }];\n    const groups = initial.map((r) =>\n      this.fb.group({\n        jsonPath: [r.jsonPath],\n        verification: [r.verification],\n        dataType: [r.dataType],\n        expectedValue: [r.expectedValue],\n      })\n    );\n    this.verificationFormArray = this.fb.array(groups);\n  }\n\n  private buildStatusVerificationFormArray(rows?: { verification: string; expectedValue: string }[]): void {\n    const defaultVerification = this.getDefaultStatusVerification();\n    const initial = rows ?? [{ verification: defaultVerification, expectedValue: '' }];\n    const groups = initial.map((r) =>\n      this.fb.group({\n        verification: [r.verification],\n        expectedValue: [r.expectedValue],\n      })\n    );\n    this.statusVerificationFormArray = this.fb.array(groups);\n  }\n\n  private buildHeadersFormArray(rows: ApiEditHeaderRow[]): void {\n    const groups = rows.map((h) =>\n      this.fb.group({\n        name: [h.name],\n        value: [h.value],\n      })\n    );\n    if (this.headersFormArray) {\n      this.headersFormArray.clear();\n      groups.forEach((g) => this.headersFormArray.push(g));\n    } else {\n      this.headersFormArray = this.fb.array(groups);\n    }\n  }\n\n  /** Handler: show import cURL panel (called when user clicks \"Import API cURL\"). */\n  openImportCurlPanel(): void {\n    this.bodyView = 'import-curl';\n    this.cdr.detectChanges();\n  }\n\n  /** Handler: emit cURL value from control and close panel. Called when user clicks Import button. */\n  onImportCurlConfirm(): void {\n    const value = this.importCurlControl.value ?? '';\n    this.importCurl.emit(typeof value === 'string' ? value : '');\n    this.closeImportCurlPanel();\n  }\n\n  /** Handler: emit cancel and close panel. Called when user clicks Cancel in import cURL panel. */\n  onCancelImportCurl(): void {\n    this.importCurlCancel.emit();\n    this.closeImportCurlPanel();\n  }\n\n  /** Handler: show headers section (called from Cancel or after Import in import panel). */\n  closeImportCurlPanel(): void {\n    this.bodyView = 'headers';\n    this.cdr.detectChanges();\n  }\n\n  onSendRequest(): void {\n    const environment = this.selectedEnvironment != null ? String(this.selectedEnvironment) : '';\n    const method = this.selectedMethod != null ? String(this.selectedMethod) : '';\n    this.sendRequest.emit({\n      environment,\n      method,\n      url: this.url ?? '',\n      headers: this.headers,\n    });\n  }\n\n  onVariableNameChange(): void {\n    this.variableNameError = '';\n  }\n\n  onBack(): void {\n    if (this.currentStep > 1) {\n      this.setStep(this.currentStep - 1);\n    } else {\n      this.back.emit();\n    }\n  }\n\n  onNext(): void {\n    if (this.currentStep === 2 && !this.variableName?.trim()) {\n      this.variableNameError = 'Variable Name is required.';\n      return;\n    }\n    this.variableNameError = '';\n    if (this.currentStep < this.stepLabels.length) {\n      this.setStep(this.currentStep + 1);\n    } else {\n      this.next.emit();\n    }\n  }\n\n  setPayloadTab(value: ApiEditPayloadTab): void {\n    this.activePayloadTab = value;\n  }\n\n  setResponseVerificationTab(value: 'response-body' | 'status'): void {\n    this.activeResponseVerificationTab = value;\n  }\n\n  addHeader(): void {\n    this.headersFormArray.push(\n      this.fb.group({ name: [''], value: [''] })\n    );\n  }\n\n  removeHeader(index: number): void {\n    this.headersFormArray.removeAt(index);\n  }\n\n  /** When user adds a custom header name via the dropdown \"Add '…'\" option, set the control value. */\n  onHeaderNameAddCustomValue(event: { key: string; value: string }, row: FormGroup): void {\n    const control = row.get(event.key);\n    if (control && event.value != null) {\n      control.setValue(event.value.trim());\n    }\n  }\n\n  trackByHeader(index: number): number {\n    return index;\n  }\n\n  addKeyValueRow(): void {\n    this.keyValueFormArray.push(this.fb.group({ key: [''], value: [''] }));\n  }\n\n  removeKeyValueRow(index: number): void {\n    this.keyValueFormArray.removeAt(index);\n  }\n\n  trackByKeyValue(index: number): number {\n    return index;\n  }\n\n  addKeyTypeValueRow(): void {\n    this.keyTypeValueFormArray.push(this.fb.group({ key: [''], type: ['text'], value: [''] }));\n  }\n\n  removeKeyTypeValueRow(index: number): void {\n    this.keyTypeValueFormArray.removeAt(index);\n  }\n\n  trackByKeyTypeValue(index: number): number {\n    return index;\n  }\n\n  addVerificationRow(): void {\n    this.verificationFormArray.push(\n      this.fb.group({\n        jsonPath: [''],\n        verification: [this.getDefaultVerification()],\n        dataType: [this.getDefaultDataType()],\n        expectedValue: [''],\n      })\n    );\n  }\n\n  removeVerificationRow(index: number): void {\n    this.verificationFormArray.removeAt(index);\n  }\n\n  trackByVerification(index: number): number {\n    return index;\n  }\n\n  /** When Data Type changes in Response Body verification, reset Expected Value for that row. */\n  onVerificationDataTypeChange(row: FormGroup, event: { key: string; value: unknown }): void {\n    if (event.key === 'dataType') {\n      row.get('expectedValue')?.setValue('', { emitEvent: false });\n    }\n  }\n\n  addStatusVerificationRow(): void {\n    this.statusVerificationFormArray.push(\n      this.fb.group({ verification: [this.getDefaultStatusVerification()], expectedValue: [''] })\n    );\n  }\n\n  removeStatusVerificationRow(index: number): void {\n    this.statusVerificationFormArray.removeAt(index);\n  }\n\n  trackByStatusVerification(index: number): number {\n    return index;\n  }\n\n  /** Emit all entered details (environment, HTTP method, URL, headers, body, step2 variable, step3 verifications) when user clicks Create. */\n  onCreate(): void {\n    console.log('9999999');\n    \n    try {\n      const payload = this.getCreatePayload();\n      console.log('9999999 payload', payload);\n      this.create.emit(payload);\n    } catch (err) {\n      console.error('ApiEditStep getCreatePayload error:', err);\n      this.create.emit(this.getCreatePayloadFallback());\n    }\n  }\n\n  /** Minimal payload when getCreatePayload throws (so create always emits). */\n  private getCreatePayloadFallback(): ApiEditCreatePayload {\n    return {\n      step1: {\n        environment: '',\n        method: '',\n        url: this.url ?? '',\n        headers: [],\n        activePayloadTab: this.activePayloadTab,\n        payloadType: this.payloadType,\n        payloadFormat: '',\n        payloadText: this.payloadText ?? '',\n        keyValueRows: [],\n        keyTypeValueRows: [],\n      },\n      step2: { variableName: this.variableName ?? '' },\n      step3: {\n        activeResponseVerificationTab: this.activeResponseVerificationTab,\n        responseBodyVerifications: [],\n        statusVerifications: [],\n      },\n    };\n  }\n\n  /** Normalize form control value to string (handles object or string). */\n  private static getControlValue(control: { value: unknown } | null | undefined): string {\n    const v = control?.value;\n    if (v == null || v === '') return '';\n    return typeof v === 'object' ? (ApiEditStepComponent.getOptionValue(v as EnvironmentOptionInput) ?? '') : String(v);\n  }\n\n  /** Build full create payload: environment, HTTP method, URL, headers, body (step1), variable name (step2), verifications (step3). */\n  private getCreatePayload(): ApiEditCreatePayload {\n    const envFromForm = ApiEditStepComponent.getControlValue(this.environmentForm?.get('environment') as { value: unknown } | null);\n    const environment =\n      envFromForm !== '' ? envFromForm : (this.currentEnvironmentValue !== '' ? this.currentEnvironmentValue : this.selectedEnvironment);\n    const methodFromForm = ApiEditStepComponent.getControlValue(this.methodForm?.get('method') as { value: unknown } | null);\n    const method =\n      methodFromForm !== '' ? methodFromForm : (this.currentMethodValue !== '' ? this.currentMethodValue : this.selectedMethod);\n    const format = this.payloadFormatForm?.get('format')?.value ?? '';\n    const keyValueFormArray = this.keyValueFormArray;\n    const keyValueRows = (keyValueFormArray?.controls ?? []).map((c) => ({\n      key: (c as FormGroup).get('key')?.value ?? '',\n      value: (c as FormGroup).get('value')?.value ?? '',\n    }));\n    const keyTypeValueFormArray = this.keyTypeValueFormArray;\n    const keyTypeValueRows = (keyTypeValueFormArray?.controls ?? []).map((c) => ({\n      key: (c as FormGroup).get('key')?.value ?? '',\n      type: (c as FormGroup).get('type')?.value ?? 'text',\n      value: (c as FormGroup).get('value')?.value ?? '',\n    }));\n    const verificationFormArray = this.verificationFormArray;\n    const responseBodyVerifications = (verificationFormArray?.controls ?? []).map((c) => ({\n      jsonPath: (c as FormGroup).get('jsonPath')?.value ?? '',\n      verification: (c as FormGroup).get('verification')?.value ?? '',\n      dataType: (c as FormGroup).get('dataType')?.value ?? '',\n      expectedValue: (c as FormGroup).get('expectedValue')?.value ?? '',\n    }));\n    const statusVerificationFormArray = this.statusVerificationFormArray;\n    const statusVerifications = (statusVerificationFormArray?.controls ?? []).map((c) => ({\n      verification: (c as FormGroup).get('verification')?.value ?? '',\n      expectedValue: (c as FormGroup).get('expectedValue')?.value ?? '',\n    }));\n    return {\n      step1: {\n        environment,\n        method,\n        url: this.url ?? '',\n        headers: this.headers,\n        activePayloadTab: this.activePayloadTab,\n        payloadType: this.payloadType,\n        payloadFormat: format,\n        payloadText: this.payloadText ?? '',\n        keyValueRows,\n        keyTypeValueRows,\n      },\n      step2: {\n        variableName: this.variableName ?? '',\n      },\n      step3: {\n        activeResponseVerificationTab: this.activeResponseVerificationTab,\n        responseBodyVerifications,\n        statusVerifications,\n      },\n    };\n  }\n\n  /** Current header rows from form (for consumers that read headers) */\n  get headers(): ApiEditHeaderRow[] {\n    if (!this.headersFormArray) return [];\n    return this.headersFormArray.controls.map((c) => ({\n      name: (c as FormGroup).get('name')?.value ?? '',\n      type: 'string',\n      value: (c as FormGroup).get('value')?.value ?? '',\n    }));\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes['initialMethod']?.currentValue != null && this.methodForm) {\n      const v = changes['initialMethod'].currentValue;\n      this.currentMethodValue = typeof v === 'string' ? v : (ApiEditStepComponent.getOptionValue(v as EnvironmentOptionInput) ?? '');\n      this.methodForm.patchValue({ method: v });\n    }\n    if (changes['httpMethodOptions']) {\n      this.updateMethodSelectConfig();\n      if (this.methodForm && this.httpMethodOptions?.length) {\n        const current = this.methodForm.get('method')?.value;\n        const values = this.getMethodValues();\n        const valid = values.includes(current);\n        if (!valid) {\n          const firstValue = ApiEditStepComponent.getOptionValue(this.httpMethodOptions[0]);\n          if (firstValue != null) {\n            this.currentMethodValue = firstValue;\n            this.methodForm.patchValue({ method: firstValue });\n          }\n        }\n      }\n    }\n    if (changes['initialEnvironment']?.currentValue != null && this.environmentForm) {\n      const v = changes['initialEnvironment'].currentValue;\n      this.currentEnvironmentValue = typeof v === 'string' ? v : (ApiEditStepComponent.getOptionValue(v as EnvironmentOptionInput) ?? '');\n      this.environmentForm.patchValue({ environment: v });\n    }\n    if (changes['environmentOptions']) {\n      this.updateEnvironmentSelectConfig();\n      if (this.environmentForm && this.environmentOptions?.length) {\n        const current = this.environmentForm.get('environment')?.value;\n        const values = this.getEnvironmentValues();\n        const valid = values.includes(current);\n        if (!valid) {\n          const firstValue = ApiEditStepComponent.getOptionValue(this.environmentOptions[0]);\n          if (firstValue != null) {\n            this.currentEnvironmentValue = firstValue;\n            this.environmentForm.patchValue({ environment: firstValue });\n          }\n        }\n      }\n    }\n    if (changes['initialStep']) {\n      this.applyInitialStep(changes['initialStep'].currentValue);\n    }\n    if (changes['initialUrl']?.currentValue != null) {\n      this.url = changes['initialUrl'].currentValue;\n    }\n    if (changes['initialPayloadTab']?.currentValue != null) {\n      this.activePayloadTab = changes['initialPayloadTab'].currentValue;\n    }\n    if (changes['headerNameOptions']) {\n      this.updateHeaderNameSelectConfig();\n    }\n    if (changes['initialHeaders']?.currentValue != null) {\n      this.buildHeadersFormArray(changes['initialHeaders'].currentValue as ApiEditHeaderRow[]);\n      this.updateHeaderNameSelectConfig();\n    }\n    if (changes['initialResponsePreview']?.currentValue != null) {\n      this.responsePreview = changes['initialResponsePreview'].currentValue;\n    }\n    if (changes['initialFormat']?.currentValue != null && this.payloadFormatForm) {\n      this.payloadFormatForm.patchValue({ format: changes['initialFormat'].currentValue });\n    }\n    if (changes['formatOptions']) {\n      this.updatePayloadFormatSelectConfig();\n      if (this.payloadFormatForm) {\n        const current = this.payloadFormatForm.get('format')?.value;\n        const values = this.getFormatValues();\n        const valid = values.includes(current);\n        if (!valid && values.length > 0) {\n          const firstValue = values[0];\n          this.payloadFormatForm.patchValue({ format: firstValue });\n        }\n      }\n    }\n    if (changes['verificationOptions']) {\n      this.updateVerificationSelectConfig();\n      const values = this.getVerificationValues();\n      const defaultVerification = this.getDefaultVerification();\n      if (this.verificationFormArray && values.length > 0) {\n        this.verificationFormArray.controls.forEach((control) => {\n          const current = (control as FormGroup).get('verification')?.value;\n          if (current && !values.includes(current)) {\n            (control as FormGroup).patchValue({ verification: defaultVerification });\n          }\n        });\n      }\n    }\n    if (changes['verificationDataTypeOptions']) {\n      this.updateVerificationDataTypeSelectConfig();\n      const values = this.getDataTypeValues();\n      const defaultDataType = this.getDefaultDataType();\n      if (this.verificationFormArray && values.length > 0) {\n        this.verificationFormArray.controls.forEach((control) => {\n          const current = (control as FormGroup).get('dataType')?.value;\n          if (current && !values.includes(current)) {\n            (control as FormGroup).patchValue({ dataType: defaultDataType });\n          }\n        });\n      }\n    }\n    if (changes['statusVerificationOptions']) {\n      this.updateStatusVerificationSelectConfig();\n      const values = this.getStatusVerificationValues();\n      const defaultVerification = this.getDefaultStatusVerification();\n      if (this.statusVerificationFormArray && values.length > 0) {\n        this.statusVerificationFormArray.controls.forEach((control) => {\n          const current = (control as FormGroup).get('verification')?.value;\n          if (current && !values.includes(current)) {\n            (control as FormGroup).patchValue({ verification: defaultVerification });\n          }\n        });\n      }\n    }\n  }\n}\n","<div class=\"cqa-api-edit-step-container\">\n  <!-- Title -->\n  <h2\n    class=\"cqa-api-edit-step-title cqa-font-inter cqa-text-[12px] cqa-font-semibold cqa-leading-[100%] cqa-tracking-normal cqa-text-[#000000]\">\n    Create API Test Step</h2>\n\n  <!-- Step indicator: all three steps visible, active step highlighted (Postman-style) -->\n  <div class=\"cqa-api-edit-step-indicator\">\n    <ng-container *ngFor=\"let step of stepLabels; let i = index\">\n      <cqa-button type=\"button\" variant=\"text\"\n        customClass=\"cqa-api-edit-step-indicator-item cqa-api-edit-step-indicator-item--clickable\"\n        [attr.aria-label]=\"'Step ' + step.index + ': ' + step.label\" [attr.aria-pressed]=\"step.index === currentStep\"\n        (clicked)=\"setStep(step.index)\">\n        <span class=\"cqa-api-edit-step-indicator-circle\"\n          [class.cqa-api-edit-step-indicator-circle--active]=\"step.index === currentStep\">\n          {{ step.index }}\n        </span>\n        <span class=\"cqa-api-edit-step-indicator-label\"\n          [class.cqa-api-edit-step-indicator-label--active]=\"step.index === currentStep\">\n          {{ step.label }}\n        </span>\n        <div *ngIf=\"i < stepLabels.length - 1\" class=\"cqa-api-edit-step-indicator-line\" aria-hidden=\"true\"></div>\n      </cqa-button>\n    </ng-container>\n  </div>\n\n  <!-- Step content viewport: smooth slide between steps -->\n  <div class=\"cqa-api-edit-step-viewport\">\n    <div class=\"cqa-api-edit-step-strip\" [style.transform]=\"'translateX(' + stripTranslatePercent + '%)'\">\n      <!-- Step 1: Environment, request, body, response -->\n      <div class=\"cqa-api-edit-step-panel\">\n        <!-- Environment row: new line, select aligned right -->\n        <div class=\"cqa-api-edit-step-environment-row\">\n          <cqa-dynamic-select *ngIf=\"environmentForm\" [form]=\"environmentForm\" [config]=\"environmentSelectConfig\"\n            class=\"cqa-api-edit-step-environment-select\" aria-label=\"Environment\"\n            (selectionChange)=\"onEnvironmentSelectionChange($event)\">\n          </cqa-dynamic-select>\n        </div>\n\n        <!-- Request row: method, URL, buttons -->\n        <div class=\"cqa-api-edit-step-request-row\">\n          <cqa-dynamic-select *ngIf=\"methodForm\" [form]=\"methodForm\" [config]=\"methodSelectConfig\"\n            class=\"cqa-api-edit-step-method-select\" aria-label=\"HTTP method\"\n            (selectionChange)=\"onMethodSelectionChange($event)\">\n          </cqa-dynamic-select>\n          <div class=\"cqa-api-edit-step-url-wrap\">\n            <cqa-custom-input [(value)]=\"url\" [label]=\"''\" placeholder=\"\" [fullWidth]=\"true\" size=\"md\">\n            </cqa-custom-input>\n          </div>\n          <div class=\"cqa-api-edit-step-import-curl-trigger\" style=\"display: contents\" (click)=\"openImportCurlPanel()\">\n            <cqa-button type=\"button\" variant=\"outlined\" btnSize=\"lg\" text=\"Import API cURL\"\n              customClass=\"cqa-api-edit-step-btn-outline cqa-font-inter cqa-text-[14px] cqa-font-semibold cqa-leading-[100%] cqa-tracking-normal cqa-text-[#414146]\">\n            </cqa-button>\n          </div>\n          <cqa-button variant=\"filled\" btnSize=\"lg\" text=\"Send Request\" (clicked)=\"onSendRequest()\"\n            customClass=\"cqa-api-edit-step-btn-primary cqa-font-inter cqa-text-[14px] cqa-font-semibold cqa-leading-[100%] cqa-tracking-normal cqa-text-[#FBFCFF]\">\n          </cqa-button>\n        </div>\n\n\n\n        <!-- Body content: header section (default) OR import cURL section -->\n        <ng-container *ngIf=\"bodyView === 'import-curl'\">\n          <div class=\"cqa-api-edit-step-import-curl-panel\">\n            <div class=\"cqa-api-edit-step-import-curl-header\">\n              <h3 class=\"cqa-api-edit-step-import-curl-title\">Import API cURL</h3>\n            </div>\n            <div class=\"cqa-api-edit-step-import-curl-separator\"></div>\n            <div class=\"cqa-api-edit-step-import-curl-body\">\n              <cqa-custom-textarea [value]=\"importCurlControl.value\"\n                (valueChange)=\"importCurlControl.setValue($event)\"\n                placeholder=\"Paste your cURL command here (e.g., curl -X POST https://api.example.com/users)\"\n                [fullWidth]=\"true\" [rows]=\"8\" resize=\"vertical\" size=\"md\"\n                class=\"cqa-api-edit-step-import-curl-textarea\">\n              </cqa-custom-textarea>\n            </div>\n            <div class=\"cqa-api-edit-step-import-curl-footer\">\n              <cqa-button type=\"button\" variant=\"outlined\" btnSize=\"lg\" text=\"Cancel\"\n                customClass=\"cqa-api-edit-step-import-curl-btn-cancel\" (clicked)=\"onCancelImportCurl()\"></cqa-button>\n              <cqa-button type=\"button\" variant=\"filled\" btnSize=\"lg\" text=\"Import\"\n                customClass=\"cqa-api-edit-step-import-curl-btn-import\" (clicked)=\"onImportCurlConfirm()\"></cqa-button>\n            </div>\n          </div>\n        </ng-container>\n\n        <ng-container *ngIf=\"bodyView === 'headers'\">\n          <div class=\"cqa-api-edit-step-tabs-wrapper\">\n            <div class=\"cqa-api-edit-step-tabs\">\n              <cqa-button *ngFor=\"let tab of payloadTabs\" type=\"button\" variant=\"text\" [text]=\"tab.label\"\n                [customClass]=\"'cqa-api-edit-step-tab' + (activePayloadTab === tab.value ? ' cqa-api-edit-step-tab--active' : '') + (isMethodWithoutBody && tab.value !== 'headers' ? ' cqa-api-edit-step-tab--disabled' : '')\"\n                [disabled]=\"isMethodWithoutBody && tab.value !== 'headers'\"\n                (clicked)=\"setPayloadTab(tab.value)\">\n              </cqa-button>\n            </div>\n\n            <!-- Payload content (Headers) -->\n            <div *ngIf=\"activePayloadTab === 'headers'\" class=\"cqa-api-edit-step-payload\">\n              <div class=\"cqa-api-edit-step-headers-grid\">\n                <span class=\"cqa-api-edit-step-headers-label\">Header Name</span>\n                <span class=\"cqa-api-edit-step-headers-label\">Header Value</span>\n                <span class=\"cqa-api-edit-step-headers-label cqa-api-edit-step-headers-label--empty\"\n                  aria-hidden=\"true\"></span>\n              </div>\n              <div *ngFor=\"let row of headerRows; let i = index; trackBy: trackByHeader\" [formGroup]=\"row\"\n                class=\"cqa-api-edit-step-header-row\">\n                <cqa-dynamic-select [form]=\"row\" [config]=\"headerNameSelectConfig\"\n                  (addCustomValue)=\"onHeaderNameAddCustomValue($event, row)\"\n                  class=\"cqa-api-edit-step-header-type-select cqa-w-full\">\n                </cqa-dynamic-select>\n                <cqa-custom-input [value]=\"row.get('value')?.value ?? ''\"\n                  (valueChange)=\"row.get('value')?.setValue($event)\" placeholder=\"Value\" [fullWidth]=\"true\" size=\"sm\"\n                  class=\"cqa-api-edit-step-header-value-input\" ariaLabel=\"Header value\">\n                </cqa-custom-input>\n                <cqa-button type=\"button\" variant=\"text\" [customClass]=\"'cqa-api-edit-step-header-delete'\"\n                  [tooltip]=\"'Remove header'\" (clicked)=\"removeHeader(i)\">\n                  <svg class=\"cqa-api-edit-step-header-delete-icon\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\"\n                    fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\" aria-hidden=\"true\">\n                    <path\n                      d=\"M10.6663 6V12.6667H5.33301V6H10.6663ZM9.66634 2H6.33301L5.66634 2.66667H3.33301V4H12.6663V2.66667H10.333L9.66634 2ZM11.9997 4.66667H3.99967V12.6667C3.99967 13.4 4.59967 14 5.33301 14H10.6663C11.3997 14 11.9997 13.4 11.9997 12.6667V4.66667Z\"\n                      fill=\"#F9BFBF\" />\n                  </svg>\n                </cqa-button>\n              </div>\n              <div class=\"cqa-api-edit-step-add-header-wrap\">\n                <cqa-button type=\"button\" variant=\"text\" text=\"+ Add Header\"\n                  [customClass]=\"'cqa-api-edit-step-add-header-link'\" (clicked)=\"addHeader()\">\n                </cqa-button>\n              </div>\n            </div>\n\n            <!-- Payload content (Body only): type, format, text area, Back/Next -->\n            <div *ngIf=\"activePayloadTab === 'body'\"\n              class=\"cqa-api-edit-step-payload cqa-api-edit-step-payload-editor\">\n              <div class=\"cqa-api-edit-step-payload-type-row\">\n                <span class=\"cqa-api-edit-step-payload-type-label\">Type</span>\n                <div class=\"cqa-api-edit-step-payload-type-radios\">\n                  <cqa-segment-control [value]=\"payloadType\" [segments]=\"payloadTypeSegments\"\n                    (valueChange)=\"onPayloadTypeChange($event)\"\n                    class=\"cqa-api-edit-step-payload-type-segment\">\n                  </cqa-segment-control>\n                </div>\n                <div *ngIf=\"payloadType === 'raw'\" class=\"cqa-api-edit-step-payload-format-wrap\">\n                  <span class=\"cqa-api-edit-step-payload-format-label\">Format:</span>\n                  <cqa-dynamic-select *ngIf=\"payloadFormatForm\" [form]=\"payloadFormatForm\"\n                    [config]=\"payloadFormatSelectConfig\" class=\"cqa-api-edit-step-payload-format-select\"\n                    aria-label=\"Format\">\n                  </cqa-dynamic-select>\n                </div>\n              </div>\n              <!-- Raw: text area with line numbers (Postman-style payload body) -->\n              <div *ngIf=\"payloadType === 'raw'\" class=\"cqa-api-edit-step-payload-body\" #payloadEditorWithLinesRef>\n                <div class=\"cqa-api-edit-step-payload-editor-with-lines\">\n                  <div class=\"cqa-api-edit-step-payload-line-numbers\" aria-hidden=\"true\">\n                    <span *ngFor=\"let n of payloadLineNumbers\" class=\"cqa-api-edit-step-payload-line-num\">\n                      <span *ngIf=\"payloadJsonError && payloadJsonError.line === n\"\n                        class=\"cqa-api-edit-step-payload-line-error-icon\" [title]=\"payloadJsonErrorTooltip\"\n                        aria-label=\"Parse error on this line\">\n                        <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"14\" height=\"14\" viewBox=\"0 0 14 14\" fill=\"none\" aria-hidden=\"true\">\n                          <circle cx=\"7\" cy=\"7\" r=\"6\" fill=\"#EF4444\"/>\n                          <path d=\"M4 4l6 6M10 4l-6 6\" stroke=\"white\" stroke-width=\"1.5\" stroke-linecap=\"round\"/>\n                        </svg>\n                      </span>\n                      <span class=\"cqa-api-edit-step-payload-line-num-text\">{{ n }}</span>\n                    </span>\n                  </div>\n                  <div class=\"cqa-api-edit-step-payload-textarea-cell\">\n                    <div class=\"cqa-api-edit-step-payload-textarea cqa-w-full cqa-flex cqa-flex-col cqa-min-h-0\"\n                      [ngClass]=\"{'cqa-api-edit-step-payload-textarea--error': payloadJsonError}\">\n                      <textarea #payloadTextareaRef\n                        class=\"cqa-api-edit-step-payload-textarea-input cqa-w-full cqa-resize-y cqa-outline-none cqa-box-border\"\n                        [ngClass]=\"{'cqa-api-edit-step-payload-textarea-input--error': payloadJsonError}\"\n                        [value]=\"payloadText\"\n                        [attr.rows]=\"10\"\n                        placeholder=\"\"\n                        [attr.aria-label]=\"'Payload'\"\n                        [attr.aria-invalid]=\"!!payloadJsonError\"\n                        (input)=\"onPayloadInput($event)\"\n                        (keydown)=\"onPayloadKeydown($event)\">\n                      </textarea>\n                    </div>\n                  </div>\n                </div>\n                <p *ngIf=\"payloadJsonError\" class=\"cqa-api-edit-step-payload-json-error-msg\">\n                  Invalid JSON format. Please check your syntax.\n                </p>\n              </div>\n\n              <!-- x-www-form-urlencoded: Key–Value rows, add/remove dynamically -->\n              <div *ngIf=\"payloadType === 'x-www-form-urlencoded'\" class=\"cqa-api-edit-step-key-value\">\n                <div class=\"cqa-api-edit-step-key-value-grid cqa-api-edit-step-key-value-header\">\n                  <span class=\"cqa-api-edit-step-key-value-label\">Key</span>\n                  <span class=\"cqa-api-edit-step-key-value-label\">Value</span>\n                  <span class=\"cqa-api-edit-step-key-value-label cqa-api-edit-step-key-value-label--empty\"\n                    aria-hidden=\"true\"></span>\n                </div>\n                <div *ngFor=\"let row of keyValueRows; let i = index; trackBy: trackByKeyValue\" [formGroup]=\"row\"\n                  class=\"cqa-api-edit-step-key-value-row\">\n                  <cqa-custom-input [value]=\"row.get('key')?.value ?? ''\"\n                    (valueChange)=\"row.get('key')?.setValue($event)\" placeholder=\"Key\" [fullWidth]=\"true\" size=\"sm\"\n                    class=\"cqa-api-edit-step-key-value-input\" ariaLabel=\"Key\">\n                  </cqa-custom-input>\n                  <cqa-custom-input [value]=\"row.get('value')?.value ?? ''\"\n                    (valueChange)=\"row.get('value')?.setValue($event)\" placeholder=\"Value\" [fullWidth]=\"true\" size=\"sm\"\n                    class=\"cqa-api-edit-step-key-value-input\" ariaLabel=\"Value\">\n                  </cqa-custom-input>\n                  <cqa-button type=\"button\" variant=\"text\" [customClass]=\"'cqa-api-edit-step-key-value-delete'\"\n                    [tooltip]=\"'Remove row'\" (clicked)=\"removeKeyValueRow(i)\">\n                    <svg class=\"cqa-api-edit-step-key-value-delete-icon\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\"\n                      fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\" aria-hidden=\"true\">\n                      <path\n                        d=\"M10.6663 6V12.6667H5.33301V6H10.6663ZM9.66634 2H6.33301L5.66634 2.66667H3.33301V4H12.6663V2.66667H10.333L9.66634 2ZM11.9997 4.66667H3.99967V12.6667C3.99967 13.4 4.59967 14 5.33301 14H10.6663C11.3997 14 11.9997 13.4 11.9997 12.6667V4.66667Z\"\n                        fill=\"#F9BFBF\" />\n                    </svg>\n                  </cqa-button>\n                </div>\n                <div class=\"cqa-api-edit-step-key-value-add-wrap\">\n                  <cqa-button type=\"button\" variant=\"filled\" btnSize=\"lg\" text=\"+ Add Row\"\n                    customClass=\"cqa-api-edit-step-key-value-add-btn\" (clicked)=\"addKeyValueRow()\">\n                  </cqa-button>\n                </div>\n              </div>\n\n              <!-- Form Data: Key–Type–Value rows; Type is a dropdown (Text/File), add/remove dynamically -->\n              <div *ngIf=\"payloadType === 'form-data'\" class=\"cqa-api-edit-step-key-type-value\">\n                <div class=\"cqa-api-edit-step-key-type-value-header\">\n                  <span class=\"cqa-api-edit-step-key-type-value-label\">Key</span>\n                  <span class=\"cqa-api-edit-step-key-type-value-label\">Type</span>\n                  <span class=\"cqa-api-edit-step-key-type-value-label\">Value</span>\n                  <span class=\"cqa-api-edit-step-key-type-value-label cqa-api-edit-step-key-type-value-label--empty\"\n                    aria-hidden=\"true\"></span>\n                </div>\n                <div *ngFor=\"let row of keyTypeValueRows; let i = index; trackBy: trackByKeyTypeValue\" [formGroup]=\"row\"\n                  class=\"cqa-api-edit-step-key-type-value-row\">\n                  <cqa-custom-input [value]=\"row.get('key')?.value ?? ''\"\n                    (valueChange)=\"row.get('key')?.setValue($event)\" placeholder=\"Key\" [fullWidth]=\"true\" size=\"sm\"\n                    class=\"cqa-api-edit-step-key-type-value-input\" ariaLabel=\"Key\">\n                  </cqa-custom-input>\n                  <cqa-dynamic-select [form]=\"row\" [config]=\"keyTypeValueTypeSelectConfig\"\n                    class=\"cqa-api-edit-step-key-type-value-type-select cqa-w-full\">\n                  </cqa-dynamic-select>\n                  <cqa-custom-input [value]=\"row.get('value')?.value ?? ''\"\n                    (valueChange)=\"row.get('value')?.setValue($event)\" placeholder=\"Value\" [fullWidth]=\"true\" size=\"sm\"\n                    class=\"cqa-api-edit-step-key-type-value-input\" ariaLabel=\"Value\">\n                  </cqa-custom-input>\n                  <cqa-button type=\"button\" variant=\"text\" [customClass]=\"'cqa-api-edit-step-key-type-value-delete'\"\n                    [tooltip]=\"'Remove row'\" (clicked)=\"removeKeyTypeValueRow(i)\">\n                    <svg class=\"cqa-api-edit-step-key-type-value-delete-icon\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\"\n                      fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\" aria-hidden=\"true\">\n                      <path\n                        d=\"M10.6663 6V12.6667H5.33301V6H10.6663ZM9.66634 2H6.33301L5.66634 2.66667H3.33301V4H12.6663V2.66667H10.333L9.66634 2ZM11.9997 4.66667H3.99967V12.6667C3.99967 13.4 4.59967 14 5.33301 14H10.6663C11.3997 14 11.9997 13.4 11.9997 12.6667V4.66667Z\"\n                        fill=\"#F9BFBF\" />\n                    </svg>\n                  </cqa-button>\n                </div>\n                <div class=\"cqa-api-edit-step-key-type-value-add-wrap\">\n                  <cqa-button type=\"button\" variant=\"filled\" btnSize=\"lg\" text=\"+ Add Row\"\n                    customClass=\"cqa-api-edit-step-key-type-value-add-btn\" (clicked)=\"addKeyTypeValueRow()\">\n                  </cqa-button>\n                </div>\n              </div>\n            </div>\n          </div>\n        </ng-container>\n\n      </div>\n      <!-- Step 2: Variable Name: input, validation, Back / Next -->\n      <div class=\"cqa-api-edit-step-panel\">\n        <div class=\"cqa-api-edit-step-variable-section\">\n          <div class=\"cqa-api-edit-step-variable-input-wrap\">\n            <cqa-custom-input [(value)]=\"variableName\" [label]=\"''\" placeholder=\"Variable Name\" [fullWidth]=\"true\"\n              size=\"md\" (valueChange)=\"onVariableNameChange()\" aria-label=\"Variable Name\">\n            </cqa-custom-input>\n          </div>\n          <p *ngIf=\"variableNameError\" class=\"cqa-api-edit-step-variable-error\" role=\"alert\">{{ variableNameError }}</p>\n        </div>\n      </div>\n      <!-- Step 3: Response Body / Status tabs -->\n      <div class=\"cqa-api-edit-step-panel\">\n        <div class=\"cqa-api-edit-step-tabs-wrapper\">\n          <div class=\"cqa-api-edit-step-tabs\">\n            <cqa-button *ngFor=\"let tab of responseVerificationTabs\" type=\"button\" variant=\"text\" [text]=\"tab.label\"\n              [customClass]=\"'cqa-api-edit-step-tab' + (activeResponseVerificationTab === tab.value ? ' cqa-api-edit-step-tab--active' : '')\"\n              (clicked)=\"setResponseVerificationTab(tab.value)\">\n            </cqa-button>\n          </div>\n\n          <!-- Response Body tab content: verification grid -->\n          <div *ngIf=\"activeResponseVerificationTab === 'response-body'\" class=\"cqa-api-edit-step-step3-content\">\n            <div class=\"cqa-api-edit-step-verification-header-row\">\n              <span></span>\n              <cqa-button type=\"button\" variant=\"text\" text=\"Add Verification\"\n                customClass=\"cqa-api-edit-step-verification-add-link\" (clicked)=\"addVerificationRow()\">\n              </cqa-button>\n            </div>\n            <div class=\"cqa-api-edit-step-verification\">\n              <div class=\"cqa-api-edit-step-verification-grid cqa-api-edit-step-verification-grid-header\">\n                <span class=\"cqa-api-edit-step-verification-label\">S.no</span>\n                <span class=\"cqa-api-edit-step-verification-label\">JSON Path</span>\n                <span class=\"cqa-api-edit-step-verification-label\">Verification</span>\n                <span class=\"cqa-api-edit-step-verification-label\">Data Type</span>\n                <span class=\"cqa-api-edit-step-verification-label\">Expected Value</span>\n                <span class=\"cqa-api-edit-step-verification-label cqa-api-edit-step-verification-label--empty\"\n                  aria-hidden=\"true\"></span>\n              </div>\n              <div *ngFor=\"let row of verificationRows; let i = index; trackBy: trackByVerification\" [formGroup]=\"row\"\n                class=\"cqa-api-edit-step-verification-row\">\n                <span class=\"cqa-api-edit-step-verification-sno\">{{ i + 1 }}</span>\n                <cqa-custom-input [value]=\"row.get('jsonPath')?.value ?? ''\"\n                  (valueChange)=\"row.get('jsonPath')?.setValue($event)\" placeholder=\"Json Path\" [fullWidth]=\"true\"\n                  size=\"sm\" class=\"cqa-api-edit-step-verification-input\" ariaLabel=\"JSON Path\">\n                </cqa-custom-input>\n                <cqa-dynamic-select [form]=\"row\" [config]=\"verificationSelectConfig\"\n                  class=\"cqa-api-edit-step-verification-select cqa-w-full\">\n                </cqa-dynamic-select>\n                <cqa-dynamic-select [form]=\"row\" [config]=\"verificationDataTypeSelectConfig\"\n                  class=\"cqa-api-edit-step-verification-select cqa-w-full\"\n                  (selectionChange)=\"onVerificationDataTypeChange(row, $event)\">\n                </cqa-dynamic-select>\n                <!-- Expected Value: text for String/Array/Object, number for Number, dropdown for Boolean -->\n                <ng-container [ngSwitch]=\"row.get('dataType')?.value\">\n                  <cqa-dynamic-select *ngSwitchCase=\"'boolean'\" [form]=\"row\"\n                    [config]=\"verificationExpectedValueBooleanSelectConfig\"\n                    class=\"cqa-api-edit-step-verification-select cqa-api-edit-step-verification-expected-select cqa-w-full\">\n                  </cqa-dynamic-select>\n                  <cqa-custom-input *ngSwitchCase=\"'number'\" [value]=\"row.get('expectedValue')?.value ?? ''\"\n                    (valueChange)=\"row.get('expectedValue')?.setValue($event)\" placeholder=\"Expected Value (number)\"\n                    type=\"number\" [fullWidth]=\"true\" size=\"sm\"\n                    class=\"cqa-api-edit-step-verification-input cqa-api-edit-step-verification-expected-number\"\n                    ariaLabel=\"Expected Value\">\n                  </cqa-custom-input>\n                  <cqa-custom-input *ngSwitchDefault [value]=\"row.get('expectedValue')?.value ?? ''\"\n                    (valueChange)=\"row.get('expectedValue')?.setValue($event)\"\n                    placeholder=\"Expected Value in String\" [fullWidth]=\"true\" size=\"sm\"\n                    class=\"cqa-api-edit-step-verification-input\" ariaLabel=\"Expected Value\">\n                  </cqa-custom-input>\n                </ng-container>\n                <cqa-button type=\"button\" variant=\"text\" [customClass]=\"'cqa-api-edit-step-verification-delete'\"\n                  [tooltip]=\"'Remove row'\" (clicked)=\"removeVerificationRow(i)\">\n                  <svg class=\"cqa-api-edit-step-verification-delete-icon\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\"\n                    fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\" aria-hidden=\"true\">\n                    <path\n                      d=\"M10.6663 6V12.6667H5.33301V6H10.6663ZM9.66634 2H6.33301L5.66634 2.66667H3.33301V4H12.6663V2.66667H10.333L9.66634 2ZM11.9997 4.66667H3.99967V12.6667C3.99967 13.4 4.59967 14 5.33301 14H10.6663C11.3997 14 11.9997 13.4 11.9997 12.6667V4.66667Z\"\n                      fill=\"#F9BFBF\" />\n                  </svg>\n                </cqa-button>\n              </div>\n            </div>\n          </div>\n\n          <!-- Status tab content: S.no, Verification dropdown, Expected Value, add/remove rows -->\n          <div *ngIf=\"activeResponseVerificationTab === 'status'\" class=\"cqa-api-edit-step-step3-content\">\n            <div class=\"cqa-api-edit-step-verification-header-row\">\n              <span></span>\n              <cqa-button type=\"button\" variant=\"text\" text=\"Add Verification\"\n                customClass=\"cqa-api-edit-step-verification-add-link\" (clicked)=\"addStatusVerificationRow()\">\n              </cqa-button>\n            </div>\n            <div class=\"cqa-api-edit-step-status-verification\">\n              <div class=\"cqa-api-edit-step-status-verification-header\">\n                <span class=\"cqa-api-edit-step-verification-label\">S.no</span>\n                <span class=\"cqa-api-edit-step-verification-label\">Verification</span>\n                <span class=\"cqa-api-edit-step-verification-label\">Expected Value</span>\n                <span class=\"cqa-api-edit-step-verification-label cqa-api-edit-step-verification-label--empty\"\n                  aria-hidden=\"true\"></span>\n              </div>\n              <div *ngFor=\"let row of statusVerificationRows; let i = index; trackBy: trackByStatusVerification\"\n                [formGroup]=\"row\" class=\"cqa-api-edit-step-status-verification-row\">\n                <span class=\"cqa-api-edit-step-verification-sno\">{{ i + 1 }}</span>\n                <cqa-dynamic-select [form]=\"row\" [config]=\"statusVerificationSelectConfig\"\n                  class=\"cqa-api-edit-step-status-verification-select cqa-w-full\">\n                </cqa-dynamic-select>\n                <cqa-custom-input [value]=\"row.get('expectedValue')?.value ?? ''\"\n                  (valueChange)=\"row.get('expectedValue')?.setValue($event)\" placeholder=\"Expected Value\"\n                  type=\"number\" [fullWidth]=\"true\" size=\"sm\" class=\"cqa-api-edit-step-verification-input\"\n                  ariaLabel=\"Expected Value\">\n                </cqa-custom-input>\n                <cqa-button type=\"button\" variant=\"text\" [customClass]=\"'cqa-api-edit-step-verification-delete'\"\n                  [tooltip]=\"'Remove row'\" (clicked)=\"removeStatusVerificationRow(i)\">\n                  <svg class=\"cqa-api-edit-step-verification-delete-icon\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\"\n                    fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\" aria-hidden=\"true\">\n                    <path\n                      d=\"M10.6663 6V12.6667H5.33301V6H10.6663ZM9.66634 2H6.33301L5.66634 2.66667H3.33301V4H12.6663V2.66667H10.333L9.66634 2ZM11.9997 4.66667H3.99967V12.6667C3.99967 13.4 4.59967 14 5.33301 14H10.6663C11.3997 14 11.9997 13.4 11.9997 12.6667V4.66667Z\"\n                      fill=\"#F9BFBF\" />\n                  </svg>\n                </cqa-button>\n              </div>\n            </div>\n          </div>\n        </div>\n      </div>\n    </div>\n  </div>\n\n  <!-- Response Preview -->\n  <div class=\"cqa-api-edit-step-response\">\n    <h3 class=\"cqa-api-edit-step-response-title\">Response Preview</h3>\n    <pre class=\"cqa-api-edit-step-response-content\">{{ responsePreview }}</pre>\n  </div>\n\n  <!-- Step actions: one row, full width. Step 1: Cancel + Next; Step 2: Back + Next; Step 3: Back + Create -->\n  <div class=\"cqa-api-edit-step-actions\">\n    <ng-container [ngSwitch]=\"currentStep\">\n      <ng-container *ngSwitchCase=\"1\">\n        <cqa-button type=\"button\" variant=\"outlined\" btnSize=\"lg\" text=\"Cancel\"\n          customClass=\"cqa-api-edit-step-actions-btn-cancel\" (clicked)=\"onBack()\">\n        </cqa-button>\n        <cqa-button type=\"button\" variant=\"filled\" btnSize=\"lg\" text=\"Next\"\n          customClass=\"cqa-api-edit-step-actions-btn-next\" (clicked)=\"onNext()\">\n        </cqa-button>\n      </ng-container>\n      <ng-container *ngSwitchCase=\"2\">\n        <cqa-button type=\"button\" variant=\"outlined\" btnSize=\"lg\" text=\"Back\"\n          customClass=\"cqa-api-edit-step-actions-btn-back\" (clicked)=\"onBack()\">\n        </cqa-button>\n        <cqa-button type=\"button\" variant=\"filled\" btnSize=\"lg\" text=\"Next\"\n          customClass=\"cqa-api-edit-step-actions-btn-next\" (clicked)=\"onNext()\">\n        </cqa-button>\n      </ng-container>\n      <ng-container *ngSwitchCase=\"3\">\n        <cqa-button type=\"button\" variant=\"outlined\" btnSize=\"lg\" text=\"Back\"\n          customClass=\"cqa-api-edit-step-actions-btn-back\" (clicked)=\"onBack()\">\n        </cqa-button>\n        <cqa-button type=\"button\" variant=\"filled\" btnSize=\"lg\" text=\"Create\"\n          customClass=\"cqa-api-edit-step-actions-btn-create\" (clicked)=\"onCreate()\">\n        </cqa-button>\n      </ng-container>\n    </ng-container>\n  </div>\n</div>"]}
1721
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"api-edit-step.component.js","sourceRoot":"","sources":["../../../../../../src/lib/test-case-details/api-edit-step/api-edit-step.component.ts","../../../../../../src/lib/test-case-details/api-edit-step/api-edit-step.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Output,\n  SimpleChanges,\n  ViewChild,\n} from '@angular/core';\nimport { FormArray, FormBuilder, FormControl, FormGroup } from '@angular/forms';\nimport { Subscription } from 'rxjs';\nimport { DynamicSelectFieldConfig, SelectOption } from '../../dynamic-select/dynamic-select-field.component';\n\nexport const API_EDIT_STEP_LABELS = {\n  REQUEST_DETAILS: 'Request Details',\n  STORE_RESPONSE: 'Store Response',\n  VALIDATION: 'Validation',\n} as const;\n\nexport type ApiEditPayloadTab = 'headers' | 'body' | 'params' | 'authorization';\n\n/** Which body content block is visible: headers (tabs) or import cURL textarea. */\nexport type ApiEditBodyView = 'headers' | 'import-curl';\n\nexport interface ApiEditHeaderRow {\n  name: string;\n  type: string;\n  value: string;\n}\n\n/** Payload emitted when user clicks Send Request (environment, method, url, headers). */\nexport interface ApiEditSendRequestPayload {\n  environment: string;\n  method: string;\n  url: string;\n  headers: ApiEditHeaderRow[];\n}\n\n/** OAuth 2.0 auth fields (when auth type is OAuth 2.0). */\nexport interface ApiEditOAuth2Payload {\n  grantType: string;\n  accessTokenUrl: string;\n  clientId: string;\n  clientSecret: string;\n  scope: string;\n  clientAuthentication: string;\n}\n\n/** Step 1 request + body payload. */\nexport interface ApiEditStep1Payload {\n  environment: string;\n  method: string;\n  url: string;\n  headers: ApiEditHeaderRow[];\n  /** Selected auth type: e.g. 'no-auth', 'bearer', 'oauth2'. */\n  authType: string;\n  /** Bearer token value when authType is 'bearer'. */\n  bearerToken?: string;\n  /** OAuth 2.0 fields when authType is 'oauth2'. */\n  oauth2?: ApiEditOAuth2Payload;\n  activePayloadTab: ApiEditPayloadTab;\n  payloadType: 'raw' | 'x-www-form-urlencoded' | 'form-data';\n  payloadFormat: string;\n  payloadText: string;\n  keyValueRows: { key: string; value: string }[];\n  keyTypeValueRows: { key: string; type: string; value: string }[];\n  paramsRows: { key: string; value: string }[];\n}\n\n/** Step 2 store-response payload. */\nexport interface ApiEditStep2Payload {\n  variableName: string;\n}\n\n/** Response body verification row. */\nexport interface ApiEditResponseBodyVerificationRow {\n  jsonPath: string;\n  verification: string;\n  dataType: string;\n  expectedValue: string;\n}\n\n/** Status verification row. */\nexport interface ApiEditStatusVerificationRow {\n  verification: string;\n  expectedValue: string;\n}\n\n/** Step 3 validation payload. */\nexport interface ApiEditStep3Payload {\n  activeResponseVerificationTab: 'response-body' | 'status';\n  responseBodyVerifications: ApiEditResponseBodyVerificationRow[];\n  statusVerifications: ApiEditStatusVerificationRow[];\n}\n\n/** Full payload emitted when user clicks Create (all steps’ data). */\nexport interface ApiEditCreatePayload {\n  step1: ApiEditStep1Payload;\n  step2: ApiEditStep2Payload;\n  step3: ApiEditStep3Payload;\n}\n\n/** Environment option: either a string (display = value) or an object with id, name, value, label. */\nexport type EnvironmentOptionInput = string | SelectOption;\n\nconst METHODS_WITHOUT_BODY = ['GET', 'HEAD', 'DELETE'];\n\n/** Auto-close pairs for payload JSON editor: opening char -> closing char. */\nconst PAYLOAD_AUTO_CLOSE_PAIRS: Record<string, string> = { '{': '}', '[': ']', '\"': '\"', \"'\": \"'\" };\n\n/** Result of parsing a cURL command. */\nexport interface ParsedCurl {\n  method: string;\n  url: string;\n  headers: ApiEditHeaderRow[];\n  body: string;\n}\n\nfunction isSingleQuote(ch: string): boolean {\n  return ch === \"'\" || ch === '\\u2018' || ch === '\\u2019';\n}\nfunction isDoubleQuote(ch: string): boolean {\n  return ch === '\"' || ch === '\\u201C' || ch === '\\u201D';\n}\nfunction isClosingQuote(ch: string, openQuote: string): boolean {\n  if (isSingleQuote(openQuote)) return isSingleQuote(ch);\n  if (isDoubleQuote(openQuote)) return isDoubleQuote(ch);\n  return ch === openQuote;\n}\n\n/**\n * Tokenize a string respecting single- and double-quoted segments (for cURL args).\n * Handles straight and smart/curly quotes so pasted cURLs from browsers/docs work.\n */\nfunction tokenizeCurlLine(line: string): string[] {\n  const tokens: string[] = [];\n  let i = 0;\n  const n = line.length;\n  while (i < n) {\n    while (i < n && /\\s/.test(line[i])) i++;\n    if (i >= n) break;\n    const ch = line[i];\n    if (isSingleQuote(ch) || isDoubleQuote(ch)) {\n      const quote = ch;\n      i++;\n      let value = '';\n      while (i < n && !isClosingQuote(line[i], quote)) {\n        if (line[i] === '\\\\') {\n          i++;\n          if (i < n) value += line[i++];\n        } else {\n          value += line[i++];\n        }\n      }\n      if (i < n) i++;\n      tokens.push(value);\n      continue;\n    }\n    let word = '';\n    while (i < n && !/\\s/.test(line[i]) && !isSingleQuote(line[i]) && !isDoubleQuote(line[i])) {\n      word += line[i++];\n    }\n    if (word) tokens.push(word);\n  }\n  return tokens;\n}\n\n/** Strip one layer of surrounding single or double quotes from a string (e.g. '{\"x\":1}' -> {\"x\":1}). */\nfunction stripSurroundingQuotes(s: string): string {\n  if (s.length >= 2 && (s.startsWith(\"'\") && s.endsWith(\"'\")) || (s.startsWith('\"') && s.endsWith('\"'))) {\n    return s.slice(1, -1);\n  }\n  return s;\n}\n\n/**\n * Parse a cURL command string and return method, url, headers, and body.\n * Supports -X/--request, -H/--header, -d/--data/--data-raw/--data-binary, and URL.\n * Handles line continuations (backslash-newline) and quoted body payloads.\n */\nfunction parseCurl(curlString: string): ParsedCurl | null {\n  const raw = (curlString ?? '').trim();\n  if (!raw) return null;\n  // Remove line continuations (backslash followed by newline) so they don't break tokenization\n  const noContinuations = raw.replace(/\\\\\\s*\\r?\\n\\s*/g, ' ');\n  const normalized = noContinuations.replace(/\\r?\\n/g, ' ').replace(/\\s+/g, ' ');\n  const tokens = tokenizeCurlLine(normalized);\n  let method = 'GET';\n  let url = '';\n  const headers: ApiEditHeaderRow[] = [];\n  let body = '';\n  const urlPattern = /^https?:\\/\\//i;\n  for (let i = 0; i < tokens.length; i++) {\n    const t = tokens[i];\n    const consumeNext = () => {\n      i++;\n      return tokens[i];\n    };\n    if (t === '-X' || t === '--request') {\n      const value = consumeNext();\n      if (value) method = value.toUpperCase();\n      continue;\n    }\n    if (t === '-H' || t === '--header') {\n      const value = consumeNext();\n      if (value) {\n        const colon = value.indexOf(':');\n        if (colon !== -1) {\n          const name = value.slice(0, colon).trim();\n          const headerValue = value.slice(colon + 1).trim();\n          if (name) headers.push({ name, type: 'string', value: headerValue });\n        }\n      }\n      continue;\n    }\n    if (t === '-d' || t === '--data' || t === '--data-raw' || t === '--data-binary' || t === '--data-ascii') {\n      const value = consumeNext();\n      if (value != null && !String(value).startsWith('@')) body = stripSurroundingQuotes(value);\n      continue;\n    }\n    if (t.startsWith('--data=')) {\n      const value = t.slice(7);\n      if (!value.startsWith('@')) body = stripSurroundingQuotes(value.replace(/^[\"']|[\"']$/g, ''));\n      continue;\n    }\n    if (t.startsWith('--data-raw=')) {\n      const value = t.slice(11);\n      if (!value.startsWith('@')) body = stripSurroundingQuotes(value.replace(/^[\"']|[\"']$/g, ''));\n      continue;\n    }\n    if (t.startsWith('-d')) {\n      const value = t.length > 2 ? t.slice(2) : consumeNext();\n      if (value != null && !value.startsWith('@')) body = stripSurroundingQuotes(value);\n      continue;\n    }\n    if (urlPattern.test(t)) {\n      if (!url) url = t;\n    }\n  }\n  if (!url) {\n    const firstUrl = tokens.find((tok) => urlPattern.test(tok));\n    if (firstUrl) url = firstUrl;\n  }\n  // Many cURLs (e.g. from browser devtools) omit -X POST when sending a body; infer POST\n  const finalMethod = (method || 'GET').toUpperCase();\n  if (body && (finalMethod === 'GET' || finalMethod === 'HEAD')) {\n    return { method: 'POST', url, headers, body };\n  }\n  return { method: finalMethod, url, headers, body };\n}\n\n@Component({\n  selector: 'cqa-api-edit-step',\n  templateUrl: './api-edit-step.component.html',\n  host: { class: 'cqa-ui-root' },\n  changeDetection: ChangeDetectionStrategy.Default,\n})\nexport class ApiEditStepComponent implements OnChanges, OnInit, AfterViewInit, OnDestroy {\n  @Input() initialMethod?: string;\n  @Input() initialEnvironment?: string;\n  @Input() initialStep?: number;\n  @Input() initialUrl?: string;\n  @Input() initialPayloadTab?: ApiEditPayloadTab;\n  @Input() initialHeaders?: ApiEditHeaderRow[];\n  @Input() initialResponsePreview?: string;\n  @Input() initialVariableName?: string;\n  @Input() editMode?: boolean;\n\n  /** Emits the cURL string when user clicks Import (value from the textarea control). */\n  @Output() importCurl = new EventEmitter<string>();\n  /** Emits when user cancels the Import cURL panel (clicks Cancel). */\n  @Output() importCurlCancel = new EventEmitter<void>();\n  /** Emits when user clicks Send Request, with environment, method, url, and headers. */\n  @Output() sendRequest = new EventEmitter<ApiEditSendRequestPayload>();\n  @Output() back = new EventEmitter<void>();\n  /** Emits when user clicks the Cancel button (step 1). */\n  @Output() cancel = new EventEmitter<void>();\n  @Output() next = new EventEmitter<void>();\n  /** Emits when user clicks Create with all entered details: step1 (environment, HTTP method, URL, headers, body), step2 (variable name), step3 (verifications). */\n  @Output() create = new EventEmitter<ApiEditCreatePayload>();\n  /** Emits whenever headers change (add, remove, or edit) so the parent can reflect them in the canvas/controls. */\n  @Output() headersChange = new EventEmitter<ApiEditHeaderRow[]>();\n\n  /** Form control for Import cURL textarea; value is emitted when user clicks Import. */\n  readonly importCurlControl = new FormControl('');\n\n  variableName = '';\n  variableNameError = '';\n\n  /** Controls which body content is visible: headers (default) or import-curl. */\n  bodyView: ApiEditBodyView = 'headers';\n\n  readonly stepLabels = [\n    { index: 1, label: API_EDIT_STEP_LABELS.REQUEST_DETAILS },\n    { index: 2, label: API_EDIT_STEP_LABELS.STORE_RESPONSE },\n    { index: 3, label: API_EDIT_STEP_LABELS.VALIDATION },\n  ];\n  currentStep = 1;\n\n  /** The label for the current step only (used when showing a single step in the indicator). */\n  get activeStepLabel(): { index: number; label: string } | undefined {\n    return this.stepLabels[this.currentStep - 1];\n  }\n\n  private readonly minStep = 1;\n  private readonly maxStep = 3;\n\n  /** Percentage to translate the step strip (0, -33.333, -66.666) for CSS transition. */\n  get stripTranslatePercent(): number {\n    return (this.currentStep - 1) * -33.333;\n  }\n\n  setStep(step: number): void {\n    if (step >= this.minStep && step <= this.maxStep) {\n      this.currentStep = step;\n    }\n  }\n\n  private applyInitialStep(value: number | undefined): void {\n    if (value == null) return;\n    const clamped = Math.max(this.minStep, Math.min(this.maxStep, Math.floor(value)));\n    this.currentStep = clamped;\n  }\n\n  /** HTTP method options: array of strings or objects with id, name, value, label (passed from parent). */\n  @Input() httpMethodOptions: EnvironmentOptionInput[] = [];\n\n  /** Form for HTTP method select (cqa-dynamic-select) */\n  methodForm!: FormGroup;\n\n  /** Config for method dropdown (updated when httpMethodOptions changes to avoid new reference every CD) */\n  methodSelectConfig: DynamicSelectFieldConfig = {\n    key: 'method',\n    placeholder: 'Method',\n    searchable: false,\n    options: [],\n  };\n\n  private updateMethodSelectConfig(): void {\n    const options = (this.httpMethodOptions ?? []).map((m) => ApiEditStepComponent.toSelectOption(m));\n    this.methodSelectConfig = {\n      ...this.methodSelectConfig,\n      options,\n    };\n  }\n\n  private getMethodValues(): string[] {\n    return (this.httpMethodOptions ?? [])\n      .map((m) => ApiEditStepComponent.getOptionValue(m))\n      .filter((v): v is string => v != null);\n  }\n\n  /** Form for environment select (cqa-dynamic-select) */\n  environmentForm!: FormGroup;\n\n  /** Environment options: array of strings or objects with id, name, value, label (passed from parent). */\n  @Input() environmentOptions: EnvironmentOptionInput[] = [];\n\n  /** Config for environment dropdown (updated when environmentOptions changes to avoid new reference every CD) */\n  environmentSelectConfig: DynamicSelectFieldConfig = {\n    key: 'environment',\n    placeholder: 'Environment',\n    searchable: false,\n    options: [],\n  };\n\n  private static toSelectOption(item: EnvironmentOptionInput): SelectOption {\n    if (typeof item === 'string') {\n      return { id: item, value: item, name: item, label: item };\n    }\n    const o = item as SelectOption;\n    return {\n      id: o.id ?? o.value,\n      value: o.value ?? o.id,\n      name: o.name ?? o.label ?? String(o.value ?? o.id),\n      label: o.label ?? o.name ?? String(o.value ?? o.id),\n    };\n  }\n\n  private static getOptionValue(item: EnvironmentOptionInput): string | undefined {\n    if (typeof item === 'string') return item;\n    const o = item as SelectOption;\n    const v = o.value ?? o.id;\n    return v != null ? String(v) : undefined;\n  }\n\n  private updateEnvironmentSelectConfig(): void {\n    const options = (this.environmentOptions ?? []).map((e) => ApiEditStepComponent.toSelectOption(e));\n    this.environmentSelectConfig = {\n      ...this.environmentSelectConfig,\n      options,\n    };\n  }\n\n  private getEnvironmentValues(): string[] {\n    return (this.environmentOptions ?? [])\n      .map((e) => ApiEditStepComponent.getOptionValue(e))\n      .filter((v): v is string => v != null);\n  }\n\n  /** Form for Auth Type select (Authorization tab) */\n  authTypeForm!: FormGroup;\n\n  /** Auth type options: array of strings or objects with id, name, value, label (passed from parent). Falls back to built-in list when empty. */\n  @Input() authTypeOptions: EnvironmentOptionInput[] = [];\n\n  /** Initial auth type (string or option object). When not set, first of authTypeOptions or default \"No Auth\" is used. */\n  @Input() initialAuthType?: string | EnvironmentOptionInput;\n\n  /** Default options when authTypeOptions is empty (same shape as environment) */\n  private static readonly DEFAULT_AUTH_TYPE_OPTIONS: SelectOption[] = [\n    { id: 'no-auth', value: 'no-auth', name: 'No Auth', label: 'No Auth' },\n    { id: 'bearer', value: 'bearer', name: 'Bearer Token', label: 'Bearer Token' },\n    { id: 'oauth2', value: 'oauth2', name: 'OAuth 2.0', label: 'OAuth 2.0' },\n  ];\n\n  /** Config for Auth Type dropdown (updated when authTypeOptions changes, like environment) */\n  authTypeSelectConfig: DynamicSelectFieldConfig = {\n    key: 'authType',\n    placeholder: 'No Auth',\n    searchable: false,\n    options: [],\n  };\n\n  private updateAuthTypeSelectConfig(): void {\n    const options =\n      this.authTypeOptions?.length > 0\n        ? this.authTypeOptions.map((a) => ApiEditStepComponent.toSelectOption(a))\n        : [...ApiEditStepComponent.DEFAULT_AUTH_TYPE_OPTIONS];\n    this.authTypeSelectConfig = {\n      ...this.authTypeSelectConfig,\n      options,\n    };\n  }\n\n  private getAuthTypeValues(): string[] {\n    const source =\n      this.authTypeOptions?.length > 0\n        ? this.authTypeOptions\n        : (ApiEditStepComponent.DEFAULT_AUTH_TYPE_OPTIONS as EnvironmentOptionInput[]);\n    return source\n      .map((a) => ApiEditStepComponent.getOptionValue(a as EnvironmentOptionInput))\n      .filter((v): v is string => v != null);\n  }\n\n  /** Current auth type value (e.g. 'no-auth') for template */\n  get selectedAuthType(): string {\n    const v = this.authTypeForm?.get('authType')?.value;\n    if (v == null || v === '') return 'no-auth';\n    return typeof v === 'object' ? (v?.value ?? v?.id ?? 'no-auth') : String(v);\n  }\n\n  /** Bearer token value (Authorization tab, when auth type is Bearer Token). */\n  bearerToken = '';\n\n  /** Form for OAuth 2.0 fields (Authorization tab when auth type is OAuth 2.0). */\n  oauth2Form!: FormGroup;\n\n  /** Grant type options for OAuth 2.0 */\n  private static readonly OAUTH_GRANT_TYPE_OPTIONS: SelectOption[] = [\n    { id: 'client_credentials', value: 'client_credentials', name: 'Client Credentials', label: 'Client Credentials' },\n    { id: 'authorization_code', value: 'authorization_code', name: 'Authorization Code', label: 'Authorization Code' },\n    { id: 'password', value: 'password', name: 'Password', label: 'Password' },\n    { id: 'implicit', value: 'implicit', name: 'Implicit', label: 'Implicit' },\n  ];\n\n  /** Client authentication method options for OAuth 2.0 */\n  private static readonly OAUTH_CLIENT_AUTH_OPTIONS: SelectOption[] = [\n    { id: 'basic', value: 'basic', name: 'Send as Basic Auth header', label: 'Send as Basic Auth header' },\n    { id: 'body', value: 'body', name: 'Send in body', label: 'Send in body' },\n  ];\n\n  readonly oauth2GrantTypeSelectConfig: DynamicSelectFieldConfig = {\n    key: 'grantType',\n    placeholder: 'Select grant type',\n    searchable: false,\n    options: [...ApiEditStepComponent.OAUTH_GRANT_TYPE_OPTIONS],\n  };\n\n  readonly oauth2ClientAuthSelectConfig: DynamicSelectFieldConfig = {\n    key: 'clientAuthentication',\n    placeholder: 'Select method',\n    searchable: false,\n    options: [...ApiEditStepComponent.OAUTH_CLIENT_AUTH_OPTIONS],\n  };\n\n  /** Current HTTP method (from form or default: first of httpMethodOptions). Treats empty string as unset. */\n  get selectedMethod(): string {\n    const value = this.methodForm?.get('method')?.value;\n    const firstValue = this.httpMethodOptions?.length\n      ? ApiEditStepComponent.getOptionValue(this.httpMethodOptions[0])\n      : undefined;\n    const resolved = value != null && value !== '' ? (typeof value === 'object' ? ApiEditStepComponent.getOptionValue(value as EnvironmentOptionInput) : String(value)) : undefined;\n    return resolved ?? firstValue ?? 'GET';\n  }\n  set selectedMethod(v: string) {\n    this.methodForm?.patchValue({ method: v });\n  }\n\n  /** True when the selected HTTP method is GET, HEAD, or DELETE (no request body). */\n  get isMethodWithoutBody(): boolean {\n    const method = this.selectedMethod != null ? String(this.selectedMethod).toUpperCase() : '';\n    return METHODS_WITHOUT_BODY.includes(method);\n  }\n\n  /** Cached environment value from last selection (so Create payload has the selected value). */\n  private currentEnvironmentValue = '';\n\n  /** Cached HTTP method from last selection (so Create payload has the selected value). */\n  private currentMethodValue = '';\n\n  /** Current environment (from form or default: first of environmentOptions). Treats empty string as unset. */\n  get selectedEnvironment(): string {\n    const value = this.environmentForm?.get('environment')?.value;\n    const firstValue = this.environmentOptions?.length\n      ? ApiEditStepComponent.getOptionValue(this.environmentOptions[0])\n      : undefined;\n    const resolved = value != null && value !== '' ? (typeof value === 'object' ? ApiEditStepComponent.getOptionValue(value as EnvironmentOptionInput) : String(value)) : undefined;\n    return resolved ?? firstValue ?? 'Development';\n  }\n  set selectedEnvironment(v: string) {\n    this.environmentForm?.patchValue({ environment: v });\n  }\n\n  /** Called when user selects an environment; keeps currentEnvironmentValue in sync for create payload. */\n  onEnvironmentSelectionChange(event: { key: string; value: unknown }): void {\n    const v = event.value;\n    this.currentEnvironmentValue =\n      v != null\n        ? typeof v === 'object'\n          ? (ApiEditStepComponent.getOptionValue(v as EnvironmentOptionInput) ?? '')\n          : String(v)\n        : '';\n  }\n\n  /** Called when user selects an HTTP method; keeps currentMethodValue in sync for create payload. */\n  onMethodSelectionChange(event: { key: string; value: unknown }): void {\n    const v = event.value;\n    this.currentMethodValue =\n      v != null\n        ? typeof v === 'object'\n          ? (ApiEditStepComponent.getOptionValue(v as EnvironmentOptionInput) ?? '')\n          : String(v)\n        : '';\n  }\n\n  private _url = '';\n\n  /** URL for the request. Getter/setter syncs query params with the Params tab (Postman-style). */\n  get url(): string {\n    return this._url;\n  }\n  set url(value: string) {\n    const next = value ?? '';\n    if (this._url === next) return;\n    this._url = next;\n    if (this.paramsFormArray) {\n      this.paramsSyncingFromUrl = true;\n      this.syncParamsFromUrl();\n      this.paramsSyncingFromUrl = false;\n    }\n  }\n\n  /** When true, params form changes should not update the URL (we're syncing from URL). */\n  private paramsSyncingFromUrl = false;\n\n  readonly payloadTabs: { value: ApiEditPayloadTab; label: string }[] = [\n    { value: 'authorization', label: 'Authorization' },\n    { value: 'headers', label: 'Headers' },\n    { value: 'body', label: 'Body' },\n    { value: 'params', label: 'Params' },\n  ];\n  activePayloadTab: ApiEditPayloadTab = 'headers';\n\n  /** Step 3: Response verification tabs */\n  readonly responseVerificationTabs: { value: 'response-body' | 'status'; label: string }[] = [\n    { value: 'response-body', label: 'Response Body' },\n    { value: 'status', label: 'Status' },\n  ];\n  activeResponseVerificationTab: 'response-body' | 'status' = 'response-body';\n\n  /** Payload type for Body/Params/Authorization: raw, x-www-form-urlencoded, form-data */\n  payloadType: 'raw' | 'x-www-form-urlencoded' | 'form-data' = 'raw';\n\n  /** Segment options for payload type (used by cqa-segment-control) */\n  readonly payloadTypeSegments = [\n    { label: 'Raw', value: 'raw' },\n    { label: 'x-www-form-urlencoded', value: 'x-www-form-urlencoded' },\n    { label: 'Form Data', value: 'form-data' },\n  ];\n\n  onPayloadTypeChange(val: string): void {\n    this.payloadType = val as 'raw' | 'x-www-form-urlencoded' | 'form-data';\n  }\n\n  /** Form for Format select (Body/Params/Authorization) */\n  payloadFormatForm!: FormGroup;\n\n  /** Format options: array of strings or objects (passed from parent). Falls back to JSON, XML, HTML, Text when empty. */\n  @Input() formatOptions: EnvironmentOptionInput[] = [];\n\n  @Input() initialFormat?: string;\n\n  private static readonly DEFAULT_FORMAT_OPTIONS: SelectOption[] = [\n    { id: 'json', value: 'json', name: 'JSON', label: 'JSON' },\n    { id: 'xml', value: 'xml', name: 'XML', label: 'XML' },\n    { id: 'html', value: 'html', name: 'HTML', label: 'HTML' },\n    { id: 'text', value: 'text', name: 'Text', label: 'Text' },\n  ];\n\n  /** Config for Format dropdown (updated when formatOptions changes, like Method dropdown) */\n  payloadFormatSelectConfig: DynamicSelectFieldConfig = {\n    key: 'format',\n    placeholder: 'Select',\n    searchable: false,\n    options: [...ApiEditStepComponent.DEFAULT_FORMAT_OPTIONS],\n  };\n\n  private updatePayloadFormatSelectConfig(): void {\n    const options =\n      this.formatOptions?.length > 0\n        ? this.formatOptions.map((f) => ApiEditStepComponent.toSelectOption(f))\n        : ApiEditStepComponent.DEFAULT_FORMAT_OPTIONS;\n    this.payloadFormatSelectConfig = {\n      ...this.payloadFormatSelectConfig,\n      options,\n    };\n  }\n\n  private getFormatValues(): string[] {\n    const source =\n      this.formatOptions?.length > 0\n        ? this.formatOptions\n        : (ApiEditStepComponent.DEFAULT_FORMAT_OPTIONS as EnvironmentOptionInput[]);\n    return source\n      .map((f) => ApiEditStepComponent.getOptionValue(f as EnvironmentOptionInput))\n      .filter((v): v is string => v != null);\n  }\n\n  /** Payload text area value for Body/Params/Authorization */\n  payloadText = '';\n\n  /** JSON parse error when format is JSON and payload is invalid; null when valid or not JSON. */\n  payloadJsonError: {\n    line: number;\n    column: number;\n    message: string;\n    excerpt: string;\n    caretOffset: number;\n  } | null = null;\n\n  /** Line numbers for payload textarea (1, 2, 3, ...) based on current line count. */\n  get payloadLineNumbers(): number[] {\n    const n = Math.max(1, (this.payloadText || '').split(/\\r?\\n/).length);\n    return Array.from({ length: n }, (_, i) => i + 1);\n  }\n\n  /** Whether current payload format is JSON (so we validate and show JSON editor behavior). */\n  get isPayloadFormatJson(): boolean {\n    const format = this.payloadFormatForm?.get('format')?.value;\n    return format === 'json';\n  }\n\n  /** Error messages for the payload textarea (red border + bottom line). */\n  get payloadJsonErrors(): string[] {\n    return this.payloadJsonError ? ['Invalid JSON format. Please check your syntax.'] : [];\n  }\n\n  /** Tooltip content for the line-level error icon (parse error on line X, excerpt, caret, message). */\n  get payloadJsonErrorTooltip(): string {\n    if (!this.payloadJsonError) return '';\n    const e = this.payloadJsonError;\n    const caret = ' '.repeat(e.caretOffset) + '^';\n    return `Parse error on line ${e.line}:\\n\\n${e.excerpt}\\n${caret}\\n\\n${e.message}`;\n  }\n\n  onPayloadTextChange(value: string): void {\n    this.payloadText = value;\n    this.validatePayloadJson();\n  }\n\n  onPayloadInput(event: Event): void {\n    const target = event.target as HTMLTextAreaElement | null;\n    this.onPayloadTextChange(target?.value ?? '');\n  }\n\n  onPayloadKeydown(event: KeyboardEvent): void {\n    if (!this.isPayloadFormatJson) return;\n    const key = event.key;\n    const close = PAYLOAD_AUTO_CLOSE_PAIRS[key];\n    if (!close) return;\n    const target = event.target as HTMLTextAreaElement | null;\n    if (!target) return;\n    event.preventDefault();\n    const start = target.selectionStart ?? 0;\n    const end = target.selectionEnd ?? start;\n    const before = this.payloadText.slice(0, start);\n    const after = this.payloadText.slice(end);\n    const insertPos = start + 1;\n    const newValue = before + key + close + after;\n    this.payloadText = newValue;\n    this.validatePayloadJson();\n    setTimeout(() => {\n      this.payloadTextareaRef?.nativeElement?.setSelectionRange(insertPos, insertPos);\n    }, 0);\n  }\n\n  /** Validate payload when format is JSON; sets payloadJsonError or clears it. */\n  validatePayloadJson(): void {\n    if (!this.isPayloadFormatJson) {\n      this.payloadJsonError = null;\n      return;\n    }\n    const text = this.payloadText ?? '';\n    if (text.trim() === '') {\n      this.payloadJsonError = null;\n      return;\n    }\n    try {\n      JSON.parse(text);\n      this.payloadJsonError = null;\n    } catch (err) {\n      const message = err instanceof Error ? err.message : String(err);\n      const position = this.extractPositionFromJsonError(message);\n      const { line, column } = this.positionToLineColumn(text, position);\n      const lines = text.split(/\\r?\\n/);\n      const lineIndex = Math.max(0, line - 1);\n      const lineContent = lines[lineIndex] ?? '';\n      const excerpt = lineContent || ' ';\n      const caretOffset = lineIndex === line - 1 ? Math.min(column - 1, lineContent.length) : 0;\n      this.payloadJsonError = {\n        line,\n        column,\n        message: this.normalizeJsonErrorMessage(message),\n        excerpt,\n        caretOffset,\n      };\n    }\n    this.cdr.markForCheck();\n  }\n\n  private extractPositionFromJsonError(message: string): number {\n    const match = message.match(/position\\s+(\\d+)/i) || message.match(/at\\s+position\\s+(\\d+)/i);\n    return match ? parseInt(match[1], 10) : 0;\n  }\n\n  private positionToLineColumn(text: string, position: number): { line: number; column: number } {\n    const before = text.slice(0, Math.min(position, text.length));\n    const lines = before.split(/\\r?\\n/);\n    const line = lines.length;\n    const lastLine = lines[lines.length - 1] ?? '';\n    return { line, column: lastLine.length + 1 };\n  }\n\n  private normalizeJsonErrorMessage(message: string): string {\n    if (message.includes('Expecting') || message.includes('expecting')) return message;\n    const tokenMatch = message.match(/Unexpected token\\s+['\"]?([^'\"]+)['\"]?/i)\n      || message.match(/unexpected character.*?([^\\s]+)/i);\n    const token = tokenMatch ? tokenMatch[1].trim() : 'undefined';\n    return `Expecting 'STRING', 'NUMBER', 'NULL', 'TRUE', 'FALSE', '{', '[', got '${token}'`;\n  }\n\n  @ViewChild('payloadEditorWithLinesRef') payloadEditorWithLinesRef?: ElementRef<HTMLElement>;\n  @ViewChild('payloadTextareaRef') payloadTextareaRef?: ElementRef<HTMLTextAreaElement>;\n\n  private static readonly DEFAULT_HEADER_NAME_OPTIONS: string[] = [\n    'Accept',\n    'Accept-Charset',\n    'Accept-Encoding',\n    'Accept-Language',\n    'Access-Control-Request-Headers',\n    'Access-Control-Request-Method',\n    'Scripts',\n    'Cache-Control',\n    'Content-MD5',\n    'Content-Length',\n    'Content-Transfer-Encoding',\n    'Content-Type',\n    'Cookie',\n    'Date',\n    'Expect',\n    'From',\n    'Host',\n    'If-Match',\n    'If-Modified-Since',\n    'If-None-Match',\n    'If-Unmodified-Since',\n    'If-Range',\n    'Keep-Alive',\n    'Max-Forwards',\n    'Origin',\n    'Pragma',\n    'Proxy-Authorization',\n    'Range',\n    'Referer',\n    'TE',\n    'Trailer',\n    'Transfer-Encoding',\n    'Upgrade',\n    'User-Agent',\n    'Via',\n    'Warning',\n    'X-Requested-With',\n    'X-Do-Not-Track',\n    'DNT',\n    'x-api-key',\n    'Connection',\n  ];\n\n  /** Header name options: array of strings or objects with id, name, value, label (passed from parent). Falls back to built-in list when empty. */\n  @Input() headerNameOptions: EnvironmentOptionInput[] = [];\n\n  /** Form array for header rows; each item is FormGroup({ name, value }) for cqa-dynamic-select and value input */\n  headersFormArray!: FormArray;\n\n  /** Typed accessor for template (FormArray.controls is AbstractControl[]) */\n  get headerRows(): FormGroup[] {\n    return (this.headersFormArray?.controls ?? []) as FormGroup[];\n  }\n\n  /** Config for header name dropdown (updated when headerNameOptions changes to avoid new reference every CD) */\n  headerNameSelectConfig: DynamicSelectFieldConfig = {\n    key: 'name',\n    placeholder: 'Select header',\n    searchable: true,\n    allowCustomValue: true,\n    options: [],\n  };\n\n  private updateHeaderNameSelectConfig(): void {\n    const source =\n      this.headerNameOptions?.length > 0\n        ? this.headerNameOptions\n        : (ApiEditStepComponent.DEFAULT_HEADER_NAME_OPTIONS as EnvironmentOptionInput[]);\n    const baseOptions = source.map((h) => ApiEditStepComponent.toSelectOption(h));\n    const baseValues = new Set(baseOptions.map((o) => String(o.value ?? o.id ?? '').trim()).filter(Boolean));\n    const currentNamesFromForm = this.getCurrentHeaderNamesFromForm();\n    const extraOptions: SelectOption[] = [];\n    for (const name of currentNamesFromForm) {\n      const key = name.trim();\n      if (key && !baseValues.has(key)) {\n        baseValues.add(key);\n        extraOptions.push({ id: key, value: key, name: key, label: key });\n      }\n    }\n    const options = [...baseOptions, ...extraOptions];\n    this.headerNameSelectConfig = {\n      ...this.headerNameSelectConfig,\n      options,\n    };\n  }\n\n  /** Collects distinct non-empty header names currently in the headers form (for dynamic options). */\n  private getCurrentHeaderNamesFromForm(): string[] {\n    const names: string[] = [];\n    const seen = new Set<string>();\n    if (!this.headersFormArray?.controls?.length) return names;\n    for (const control of this.headersFormArray.controls) {\n      const name = (control as FormGroup).get('name')?.value;\n      const str = name != null ? String(name).trim() : '';\n      if (str && !seen.has(str)) {\n        seen.add(str);\n        names.push(str);\n      }\n    }\n    return names;\n  }\n\n  private readonly defaultHeaders: ApiEditHeaderRow[] = [\n    { name: 'Content-Type', type: 'string', value: 'application/json' },\n  ];\n\n  /** Form array for key-value rows (Body payload); each item is FormGroup({ key, value }) */\n  keyValueFormArray!: FormArray;\n\n  get keyValueRows(): FormGroup[] {\n    return (this.keyValueFormArray?.controls ?? []) as FormGroup[];\n  }\n\n  /** Form array for key-type-value rows; each item is FormGroup({ key, type, value }) */\n  keyTypeValueFormArray!: FormArray;\n\n  get keyTypeValueRows(): FormGroup[] {\n    return (this.keyTypeValueFormArray?.controls ?? []) as FormGroup[];\n  }\n\n  /** Form array for Params tab key-value rows; each item is FormGroup({ key, value }) */\n  paramsFormArray!: FormArray;\n\n  get paramsRows(): FormGroup[] {\n    return (this.paramsFormArray?.controls ?? []) as FormGroup[];\n  }\n\n  /** Config for Type dropdown in key-type-value rows (Text, File) */\n  readonly keyTypeValueTypeSelectConfig: DynamicSelectFieldConfig = {\n    key: 'type',\n    placeholder: 'Text',\n    searchable: false,\n    options: [\n      { id: 'text', value: 'text', name: 'Text', label: 'Text' },\n      { id: 'file', value: 'file', name: 'File', label: 'File' },\n    ],\n  };\n\n  /** Form array for response body verification rows; each item is FormGroup({ jsonPath, verification, dataType, expectedValue }) */\n  verificationFormArray!: FormArray;\n\n  get verificationRows(): FormGroup[] {\n    return (this.verificationFormArray?.controls ?? []) as FormGroup[];\n  }\n\n  /** Verification options: array of strings or objects (passed from parent). Falls back to built-in list when empty. */\n  @Input() verificationOptions: EnvironmentOptionInput[] = [];\n\n  private static readonly DEFAULT_VERIFICATION_OPTIONS: SelectOption[] = [\n    { id: 'equals', value: 'equals', name: 'Equals', label: 'Equals' },\n    { id: 'not-equal', value: 'not-equal', name: 'Not equal', label: 'Not equal' },\n    { id: 'less-than', value: 'less-than', name: 'Less than', label: 'Less than' },\n    { id: 'greater-than', value: 'greater-than', name: 'Greater than', label: 'Greater than' },\n    { id: 'is-null', value: 'is-null', name: 'Is null', label: 'Is null' },\n    { id: 'is-not-null', value: 'is-not-null', name: 'Is not null', label: 'Is not null' },\n  ];\n\n  /** Config for Verification dropdown (updated when verificationOptions changes, like Method dropdown) */\n  verificationSelectConfig: DynamicSelectFieldConfig = {\n    key: 'verification',\n    placeholder: 'Equals',\n    searchable: false,\n    options: [...ApiEditStepComponent.DEFAULT_VERIFICATION_OPTIONS],\n  };\n\n  private updateVerificationSelectConfig(): void {\n    const options =\n      this.verificationOptions?.length > 0\n        ? this.verificationOptions.map((v) => ApiEditStepComponent.toSelectOption(v))\n        : ApiEditStepComponent.DEFAULT_VERIFICATION_OPTIONS;\n    this.verificationSelectConfig = {\n      ...this.verificationSelectConfig,\n      options,\n    };\n  }\n\n  private getVerificationValues(): string[] {\n    const source =\n      this.verificationOptions?.length > 0\n        ? this.verificationOptions\n        : (ApiEditStepComponent.DEFAULT_VERIFICATION_OPTIONS as EnvironmentOptionInput[]);\n    return source\n      .map((v) => ApiEditStepComponent.getOptionValue(v as EnvironmentOptionInput))\n      .filter((v): v is string => v != null);\n  }\n\n  private getDefaultVerification(): string {\n    const values = this.getVerificationValues();\n    return values.length > 0 ? values[0] : 'equals';\n  }\n\n  /** Data Type options: array of strings or objects (passed from parent). Falls back to built-in list when empty. */\n  @Input() verificationDataTypeOptions: EnvironmentOptionInput[] = [];\n\n  private static readonly DEFAULT_DATA_TYPE_OPTIONS: SelectOption[] = [\n    { id: 'string', value: 'string', name: 'String', label: 'String' },\n    { id: 'number', value: 'number', name: 'Number', label: 'Number' },\n    { id: 'boolean', value: 'boolean', name: 'Boolean', label: 'Boolean' },\n    { id: 'array', value: 'array', name: 'Array', label: 'Array' },\n    { id: 'object', value: 'object', name: 'Object', label: 'Object' },\n  ];\n\n  /** Config for Data Type dropdown (updated when verificationDataTypeOptions changes, like Method dropdown) */\n  verificationDataTypeSelectConfig: DynamicSelectFieldConfig = {\n    key: 'dataType',\n    placeholder: 'String',\n    searchable: false,\n    options: [...ApiEditStepComponent.DEFAULT_DATA_TYPE_OPTIONS],\n  };\n\n  private updateVerificationDataTypeSelectConfig(): void {\n    const options =\n      this.verificationDataTypeOptions?.length > 0\n        ? this.verificationDataTypeOptions.map((d) => ApiEditStepComponent.toSelectOption(d))\n        : ApiEditStepComponent.DEFAULT_DATA_TYPE_OPTIONS;\n    this.verificationDataTypeSelectConfig = {\n      ...this.verificationDataTypeSelectConfig,\n      options,\n    };\n  }\n\n  private getDataTypeValues(): string[] {\n    const source =\n      this.verificationDataTypeOptions?.length > 0\n        ? this.verificationDataTypeOptions\n        : (ApiEditStepComponent.DEFAULT_DATA_TYPE_OPTIONS as EnvironmentOptionInput[]);\n    return source\n      .map((d) => ApiEditStepComponent.getOptionValue(d as EnvironmentOptionInput))\n      .filter((v): v is string => v != null);\n  }\n\n  private getDefaultDataType(): string {\n    const values = this.getDataTypeValues();\n    return values.length > 0 ? values[0] : 'string';\n  }\n\n  /** Config for Expected Value when Data Type is Boolean (true/false dropdown) */\n  readonly verificationExpectedValueBooleanSelectConfig: DynamicSelectFieldConfig = {\n    key: 'expectedValue',\n    placeholder: 'Select',\n    searchable: false,\n    options: [\n      { id: 'true', value: 'true', name: 'true', label: 'true' },\n      { id: 'false', value: 'false', name: 'false', label: 'false' },\n    ],\n  };\n\n  /** Form array for Status tab verification rows; each item is FormGroup({ verification, expectedValue }) */\n  statusVerificationFormArray!: FormArray;\n\n  get statusVerificationRows(): FormGroup[] {\n    return (this.statusVerificationFormArray?.controls ?? []) as FormGroup[];\n  }\n\n  /** Config for Status tab Verification dropdown (Equals, Not equal, Less than, Greater than) */\n  /** Status tab Verification options (Equals, Not equal, etc.). Falls back to built-in list when empty. */\n  @Input() statusVerificationOptions: EnvironmentOptionInput[] = [];\n\n  private static readonly DEFAULT_STATUS_VERIFICATION_OPTIONS: SelectOption[] = [\n    { id: 'equals', value: 'equals', name: 'Equals', label: 'Equals' },\n    { id: 'not-equal', value: 'not-equal', name: 'Not equal', label: 'Not equal' },\n    { id: 'less-than', value: 'less-than', name: 'Less than', label: 'Less than' },\n    { id: 'greater-than', value: 'greater-than', name: 'Greater than', label: 'Greater than' },\n  ];\n\n  /** Config for Status tab Verification dropdown (updated when statusVerificationOptions changes). */\n  statusVerificationSelectConfig: DynamicSelectFieldConfig = {\n    key: 'verification',\n    placeholder: 'Equals',\n    searchable: false,\n    options: [...ApiEditStepComponent.DEFAULT_STATUS_VERIFICATION_OPTIONS],\n  };\n\n  private updateStatusVerificationSelectConfig(): void {\n    const options =\n      this.statusVerificationOptions?.length > 0\n        ? this.statusVerificationOptions.map((o) => ApiEditStepComponent.toSelectOption(o))\n        : ApiEditStepComponent.DEFAULT_STATUS_VERIFICATION_OPTIONS;\n    this.statusVerificationSelectConfig = {\n      ...this.statusVerificationSelectConfig,\n      options,\n    };\n  }\n\n  private getStatusVerificationValues(): string[] {\n    const source =\n      this.statusVerificationOptions?.length > 0\n        ? this.statusVerificationOptions\n        : (ApiEditStepComponent.DEFAULT_STATUS_VERIFICATION_OPTIONS as EnvironmentOptionInput[]);\n    return source\n      .map((o) => ApiEditStepComponent.getOptionValue(o as EnvironmentOptionInput))\n      .filter((v): v is string => v != null);\n  }\n\n  private getDefaultStatusVerification(): string {\n    const values = this.getStatusVerificationValues();\n    return values.length > 0 ? values[0] : 'equals';\n  }\n\n  responsePreview = ``;\n\n  private methodChangesSub?: Subscription;\n  private formatChangesSub?: Subscription;\n  private headerNameOptionsChangesSub?: Subscription;\n  private environmentFormChangesSub?: Subscription;\n  private methodFormChangesSub?: Subscription;\n  private paramsFormArrayChangesSub?: Subscription;\n\n  constructor(\n    private readonly fb: FormBuilder,\n    private readonly cdr: ChangeDetectorRef,\n  ) {}\n\n  ngOnInit(): void {\n    this.applyInitialStep(this.initialStep);\n    this.updateMethodSelectConfig();\n    this.updateHeaderNameSelectConfig();\n    const firstMethodValue = this.httpMethodOptions?.length\n      ? ApiEditStepComponent.getOptionValue(this.httpMethodOptions[0])\n      : undefined;\n    const defaultMethod = this.initialMethod ?? firstMethodValue ?? 'GET';\n    this.currentMethodValue = typeof defaultMethod === 'string' ? defaultMethod : (ApiEditStepComponent.getOptionValue(defaultMethod as EnvironmentOptionInput) ?? '');\n    this.methodForm = this.fb.group({\n      method: [defaultMethod],\n    });\n    const firstValue = this.environmentOptions?.length\n      ? ApiEditStepComponent.getOptionValue(this.environmentOptions[0])\n      : undefined;\n    const defaultEnv = this.initialEnvironment ?? firstValue ?? 'Development';\n    this.currentEnvironmentValue = typeof defaultEnv === 'string' ? defaultEnv : (ApiEditStepComponent.getOptionValue(defaultEnv as EnvironmentOptionInput) ?? '');\n    this.environmentForm = this.fb.group({\n      environment: [defaultEnv],\n    });\n    this.updateAuthTypeSelectConfig();\n    const firstAuthValue = this.getAuthTypeValues()[0];\n    const defaultAuthType = this.initialAuthType ?? firstAuthValue ?? 'no-auth';\n    this.authTypeForm = this.fb.group({\n      authType: [defaultAuthType],\n    });\n    this.oauth2Form = this.fb.group({\n      grantType: ['client_credentials'],\n      accessTokenUrl: [''],\n      clientId: [''],\n      clientSecret: [''],\n      scope: [''],\n      clientAuthentication: ['basic'],\n    });\n    this.environmentFormChangesSub = this.environmentForm.get('environment')?.valueChanges?.subscribe((v: unknown) => {\n      const s = v != null && v !== '' ? (typeof v === 'object' ? ApiEditStepComponent.getOptionValue(v as EnvironmentOptionInput) : String(v)) : '';\n      this.currentEnvironmentValue = s ?? '';\n    });\n    this.methodFormChangesSub = this.methodForm.get('method')?.valueChanges?.subscribe((v: unknown) => {\n      const s = v != null && v !== '' ? (typeof v === 'object' ? ApiEditStepComponent.getOptionValue(v as EnvironmentOptionInput) : String(v)) : '';\n      this.currentMethodValue = s ?? '';\n    });\n    this.buildHeadersFormArray(\n      this.initialHeaders ?? [{ name: '', type: 'string', value: '' }]\n    );\n    this.headerNameOptionsChangesSub = this.headersFormArray?.valueChanges?.subscribe(() => {\n      this.updateHeaderNameSelectConfig();\n      this.headersChange.emit(this.headers);\n    });\n    this.updateHeaderNameSelectConfig();\n    this.headersChange.emit(this.headers);\n    this.updateEnvironmentSelectConfig();\n    this.updatePayloadFormatSelectConfig();\n    const firstFormatValue = this.getFormatValues()[0];\n    const defaultFormat = this.initialFormat ?? firstFormatValue ?? 'json';\n    this.payloadFormatForm = this.fb.group({ format: [defaultFormat] });\n    this.buildKeyValueFormArray();\n    this.buildKeyTypeValueFormArray();\n    this.buildParamsFormArray();\n    this.paramsFormArrayChangesSub = this.paramsFormArray.valueChanges?.subscribe(() => this.syncUrlFromParams());\n    if (this.initialUrl != null && this.initialUrl !== '') {\n      this._url = this.initialUrl;\n      this.syncParamsFromUrl();\n    }\n    // Initialize variableName from initialVariableName\n    if (this.initialVariableName != null && this.initialVariableName !== '') {\n      this.variableName = this.initialVariableName;\n    }\n    this.updateVerificationSelectConfig();\n    this.updateVerificationDataTypeSelectConfig();\n    this.buildVerificationFormArray();\n    this.updateStatusVerificationSelectConfig();\n    this.buildStatusVerificationFormArray();\n    this.methodChangesSub = this.methodForm.get('method')?.valueChanges?.subscribe((value: string) => {\n      const method = value != null ? String(value).toUpperCase() : '';\n      if (METHODS_WITHOUT_BODY.includes(method) && this.activePayloadTab !== 'headers') {\n        this.activePayloadTab = 'headers';\n        this.cdr.detectChanges();\n      }\n    });\n    this.formatChangesSub = this.payloadFormatForm.get('format')?.valueChanges?.subscribe(() => {\n      this.validatePayloadJson();\n    });\n    this.validatePayloadJson();\n  }\n\n  ngAfterViewInit(): void {\n    this.setupPayloadTextareaScrollSync();\n  }\n\n  ngOnDestroy(): void {\n    this.methodChangesSub?.unsubscribe();\n    this.formatChangesSub?.unsubscribe();\n    this.headerNameOptionsChangesSub?.unsubscribe();\n    this.environmentFormChangesSub?.unsubscribe();\n    this.methodFormChangesSub?.unsubscribe();\n    this.paramsFormArrayChangesSub?.unsubscribe();\n  }\n\n  /** Sync line numbers column scroll with payload textarea scroll (Postman-style). */\n  private setupPayloadTextareaScrollSync(): void {\n    setTimeout(() => {\n      const host = this.payloadEditorWithLinesRef?.nativeElement;\n      if (!host) return;\n      const lineNumbersEl = host.querySelector('.cqa-api-edit-step-payload-line-numbers') as HTMLElement | null;\n      const textarea = host.querySelector('textarea') as HTMLTextAreaElement | null;\n      if (!lineNumbersEl || !textarea) return;\n      textarea.addEventListener('scroll', () => {\n        lineNumbersEl.scrollTop = textarea.scrollTop;\n      });\n      lineNumbersEl.addEventListener('scroll', () => {\n        textarea.scrollTop = lineNumbersEl.scrollTop;\n      });\n    }, 0);\n  }\n\n  private buildKeyValueFormArray(rows?: { key: string; value: string }[]): void {\n    const initial = rows ?? [{ key: '', value: '' }];\n    const groups = initial.map((r) => this.fb.group({ key: [r.key], value: [r.value] }));\n    this.keyValueFormArray = this.fb.array(groups);\n  }\n\n  private buildKeyTypeValueFormArray(rows?: { key: string; type: string; value: string }[]): void {\n    const initial = rows ?? [{ key: '', type: 'text', value: '' }];\n    const groups = initial.map((r) => this.fb.group({ key: [r.key], type: [r.type], value: [r.value] }));\n    this.keyTypeValueFormArray = this.fb.array(groups);\n  }\n\n  private buildParamsFormArray(rows?: { key: string; value: string }[]): void {\n    const initial = rows ?? [{ key: '', value: '' }];\n    const groups = initial.map((r) => this.fb.group({ key: [r.key], value: [r.value] }));\n    if (this.paramsFormArray) {\n      this.paramsFormArray.clear();\n      groups.forEach((g) => this.paramsFormArray.push(g));\n    } else {\n      this.paramsFormArray = this.fb.array(groups);\n    }\n  }\n\n  /** Parse URL into base (without query/fragment) and query key-value pairs. Preserves relative URLs. */\n  private parseQueryParamsFromUrl(urlStr: string): { baseUrl: string; rows: { key: string; value: string }[] } {\n    const empty = { baseUrl: urlStr, rows: [{ key: '', value: '' }] };\n    if (!urlStr || !urlStr.trim()) return empty;\n    try {\n      const isAbsolute = /^https?:\\/\\//i.test(urlStr.trim());\n      const url = new URL(urlStr, 'http://localhost');\n      const baseUrl = isAbsolute ? url.origin + url.pathname : url.pathname;\n      const rows: { key: string; value: string }[] = [];\n      url.searchParams.forEach((value, key) => {\n        rows.push({ key, value });\n      });\n      if (rows.length === 0) rows.push({ key: '', value: '' });\n      return { baseUrl, rows };\n    } catch {\n      return empty;\n    }\n  }\n\n  /** Get base URL (without query/fragment) for building URL from params. Preserves relative URLs. */\n  private getBaseUrl(urlStr: string): string {\n    if (!urlStr || !urlStr.trim()) return urlStr;\n    try {\n      const isAbsolute = /^https?:\\/\\//i.test(urlStr.trim());\n      const url = new URL(urlStr, 'http://localhost');\n      return isAbsolute ? url.origin + url.pathname : url.pathname;\n    } catch {\n      return urlStr;\n    }\n  }\n\n  /** Parse application/x-www-form-urlencoded body (key=value&...) into key-value rows. */\n  private parseFormUrlEncodedBody(body: string): { key: string; value: string }[] {\n    const trimmed = (body ?? '').trim();\n    if (!trimmed) return [];\n    try {\n      const params = new URLSearchParams(trimmed);\n      const rows: { key: string; value: string }[] = [];\n      params.forEach((value, key) => rows.push({ key, value }));\n      return rows;\n    } catch {\n      return [];\n    }\n  }\n\n  /**\n   * If form body has a single key whose value is URL-decoded JSON, return it pretty-printed for Raw body.\n   * Otherwise return null (caller keeps x-www-form-urlencoded view).\n   */\n  private tryFormBodyValueAsRawJson(rows: { key: string; value: string }[]): string | null {\n    if (rows.length !== 1 || !rows[0].value?.trim()) return null;\n    const value = rows[0].value.trim();\n    if (!(value.startsWith('{') || value.startsWith('['))) return null;\n    try {\n      const parsed = JSON.parse(value);\n      return JSON.stringify(parsed, null, 2);\n    } catch {\n      return null;\n    }\n  }\n\n  /** Update Params table from current URL query string (Postman-style). */\n  private syncParamsFromUrl(): void {\n    const { baseUrl: _b, rows } = this.parseQueryParamsFromUrl(this._url);\n    this.buildParamsFormArray(rows);\n    this.cdr.markForCheck();\n  }\n\n  /** Update URL query string from Params table (Postman-style). */\n  private syncUrlFromParams(): void {\n    if (this.paramsSyncingFromUrl || !this.paramsFormArray) return;\n    const baseUrl = this.getBaseUrl(this._url);\n    const params = new URLSearchParams();\n    for (const c of this.paramsFormArray.controls) {\n      const key = ((c as FormGroup).get('key')?.value ?? '').trim();\n      const value = (c as FormGroup).get('value')?.value ?? '';\n      if (key !== '') params.set(key, value);\n    }\n    const queryString = params.toString();\n    const newUrl = queryString ? `${baseUrl}?${queryString}` : baseUrl;\n    if (this._url !== newUrl) {\n      this._url = newUrl;\n      this.cdr.markForCheck();\n    }\n  }\n\n  private buildVerificationFormArray(rows?: { jsonPath: string; verification: string; dataType: string; expectedValue: string }[]): void {\n    const defaultVerification = this.getDefaultVerification();\n    const defaultDataType = this.getDefaultDataType();\n    const initial = rows ?? [{ jsonPath: '', verification: defaultVerification, dataType: defaultDataType, expectedValue: '' }];\n    const groups = initial.map((r) =>\n      this.fb.group({\n        jsonPath: [r.jsonPath],\n        verification: [r.verification],\n        dataType: [r.dataType],\n        expectedValue: [r.expectedValue],\n      })\n    );\n    this.verificationFormArray = this.fb.array(groups);\n  }\n\n  private buildStatusVerificationFormArray(rows?: { verification: string; expectedValue: string }[]): void {\n    const defaultVerification = this.getDefaultStatusVerification();\n    const initial = rows ?? [{ verification: defaultVerification, expectedValue: '' }];\n    const groups = initial.map((r) =>\n      this.fb.group({\n        verification: [r.verification],\n        expectedValue: [r.expectedValue],\n      })\n    );\n    this.statusVerificationFormArray = this.fb.array(groups);\n  }\n\n  private buildHeadersFormArray(rows: ApiEditHeaderRow[]): void {\n    const groups = rows.map((h) =>\n      this.fb.group({\n        name: [h.name],\n        value: [h.value],\n      })\n    );\n    if (this.headersFormArray) {\n      this.headersFormArray.clear();\n      groups.forEach((g) => this.headersFormArray.push(g));\n    } else {\n      this.headersFormArray = this.fb.array(groups);\n    }\n  }\n\n  /** Reset all three steps and all entered data to initial/default state. Used when user cancels on step 1. */\n  private resetAllStepsAndData(): void {\n    this.currentStep = 1;\n\n    const firstMethodValue = this.httpMethodOptions?.length\n      ? ApiEditStepComponent.getOptionValue(this.httpMethodOptions[0])\n      : undefined;\n    const defaultMethod = this.initialMethod ?? firstMethodValue ?? 'GET';\n    const methodVal = typeof defaultMethod === 'string' ? defaultMethod : (ApiEditStepComponent.getOptionValue(defaultMethod as EnvironmentOptionInput) ?? '');\n    this.currentMethodValue = methodVal ?? '';\n    if (this.methodForm) this.methodForm.patchValue({ method: defaultMethod });\n\n    const firstEnvValue = this.environmentOptions?.length\n      ? ApiEditStepComponent.getOptionValue(this.environmentOptions[0])\n      : undefined;\n    const defaultEnv = this.initialEnvironment ?? firstEnvValue ?? 'Development';\n    const envVal = typeof defaultEnv === 'string' ? defaultEnv : (ApiEditStepComponent.getOptionValue(defaultEnv as EnvironmentOptionInput) ?? '');\n    this.currentEnvironmentValue = envVal ?? '';\n    if (this.environmentForm) this.environmentForm.patchValue({ environment: defaultEnv });\n\n    this.url = this.initialUrl ?? '';\n    this.buildHeadersFormArray(this.initialHeaders ?? [{ name: '', type: 'string', value: '' }]);\n    this.updateHeaderNameSelectConfig();\n    this.headersChange.emit(this.headers);\n\n    this.bodyView = 'headers';\n    this.activePayloadTab = 'headers';\n    this.payloadType = 'raw';\n    this.payloadText = '';\n    this.payloadJsonError = null;\n    const defaultFormat = this.initialFormat ?? this.getFormatValues()[0] ?? 'json';\n    if (this.payloadFormatForm) this.payloadFormatForm.patchValue({ format: defaultFormat });\n    this.buildKeyValueFormArray();\n    this.buildKeyTypeValueFormArray();\n    this.buildParamsFormArray();\n    this.importCurlControl.setValue('');\n\n    this.variableName = '';\n    this.variableNameError = '';\n\n    this.buildVerificationFormArray();\n    this.buildStatusVerificationFormArray();\n    this.activeResponseVerificationTab = 'response-body';\n\n    this.validatePayloadJson();\n    this.cdr.detectChanges();\n  }\n\n  /** Handler: show import cURL panel (called when user clicks \"Import API cURL\"). Resets textarea so it is cleared each time. */\n  openImportCurlPanel(): void {\n    this.importCurlControl.setValue('');\n    this.bodyView = 'import-curl';\n    this.cdr.detectChanges();\n  }\n\n  /** Reset URL, method, headers, body, and params to empty/default before applying imported cURL. */\n  private resetRequestFieldsBeforeCurlImport(): void {\n    const firstMethodValue = this.httpMethodOptions?.length\n      ? ApiEditStepComponent.getOptionValue(this.httpMethodOptions[0])\n      : undefined;\n    const defaultMethod = this.initialMethod ?? firstMethodValue ?? 'GET';\n    this.selectedMethod = typeof defaultMethod === 'string' ? defaultMethod : (ApiEditStepComponent.getOptionValue(defaultMethod as EnvironmentOptionInput) ?? '') ?? 'GET';\n    this.currentMethodValue = this.selectedMethod;\n    if (this.methodForm) this.methodForm.patchValue({ method: defaultMethod });\n\n    this.url = '';\n\n    this.buildHeadersFormArray([{ name: '', type: 'string', value: '' }]);\n    this.updateHeaderNameSelectConfig();\n    this.headersChange.emit(this.headers);\n\n    this.payloadType = 'raw';\n    this.payloadText = '';\n    this.payloadJsonError = null;\n    const defaultFormat = this.initialFormat ?? this.getFormatValues()[0] ?? 'json';\n    if (this.payloadFormatForm) this.payloadFormatForm.patchValue({ format: defaultFormat });\n    this.buildKeyValueFormArray([{ key: '', value: '' }]);\n    this.buildKeyTypeValueFormArray([{ key: '', type: 'text', value: '' }]);\n    this.buildParamsFormArray([{ key: '', value: '' }]);\n\n    this.validatePayloadJson();\n    this.cdr.detectChanges();\n  }\n\n  /** Handler: parse cURL from control, bind to form fields, emit and close panel. Called when user clicks Import button. */\n  onImportCurlConfirm(): void {\n    const value = this.importCurlControl.value ?? '';\n    const curlStr = typeof value === 'string' ? value : '';\n    this.importCurl.emit(curlStr);\n\n    this.resetRequestFieldsBeforeCurlImport();\n\n    const parsed = parseCurl(curlStr);\n    if (parsed) {\n      const methodValue = parsed.method && this.getMethodValues().includes(parsed.method)\n        ? parsed.method\n        : parsed.method || 'GET';\n      this.selectedMethod = methodValue;\n      this.currentMethodValue = methodValue;\n      if (parsed.url) this.url = parsed.url;\n\n      // Bind Authorization header to Authorization section when present (Bearer or other scheme)\n      let headerRows: ApiEditHeaderRow[] = parsed.headers;\n      const authHeader = headerRows.find((h) => h.name.toLowerCase() === 'authorization');\n      if (authHeader?.value?.trim()) {\n        const authValue = authHeader.value.trim();\n        const bearerMatch = /^Bearer\\s+(.+)$/i.exec(authValue);\n        if (bearerMatch) {\n          const token = bearerMatch[1].trim();\n          if (this.getAuthTypeValues().includes('bearer') && this.authTypeForm) {\n            this.authTypeForm.patchValue({ authType: 'bearer' });\n            this.bearerToken = token;\n          }\n          headerRows = headerRows.filter((h) => h.name.toLowerCase() !== 'authorization');\n        }\n      }\n\n      headerRows = headerRows.length > 0 ? headerRows : [{ name: '', type: 'string', value: '' }];\n      this.buildHeadersFormArray(headerRows);\n      this.updateHeaderNameSelectConfig();\n      this.headersChange.emit(this.headers);\n\n      if (parsed.body) {\n        const contentType = parsed.headers\n          .find((h) => h.name.toLowerCase() === 'content-type')\n          ?.value?.toLowerCase() ?? '';\n        const isFormUrlEncoded = contentType.includes('application/x-www-form-urlencoded');\n\n        if (isFormUrlEncoded) {\n          const rows = this.parseFormUrlEncodedBody(parsed.body);\n          this.buildKeyValueFormArray(rows.length > 0 ? rows : [{ key: '', value: '' }]);\n          const decodedAsJson = this.tryFormBodyValueAsRawJson(rows);\n          if (decodedAsJson != null) {\n            this.payloadType = 'raw';\n            this.payloadText = decodedAsJson;\n            if (this.payloadFormatForm) this.payloadFormatForm.patchValue({ format: 'json' });\n            this.validatePayloadJson();\n            this.payloadJsonError = null;\n          } else {\n            this.payloadType = 'x-www-form-urlencoded';\n            this.payloadText = '';\n            this.payloadJsonError = null;\n          }\n        } else {\n          this.payloadText = parsed.body;\n          this.validatePayloadJson();\n          const trimmed = parsed.body.trim();\n          if ((trimmed.startsWith('{') && trimmed.endsWith('}')) || (trimmed.startsWith('[') && trimmed.endsWith(']'))) {\n            const formatValues = this.getFormatValues();\n            if (formatValues.includes('json') && this.payloadFormatForm) {\n              this.payloadFormatForm.patchValue({ format: 'json' });\n            }\n          }\n        }\n      }\n      this.cdr.detectChanges();\n    }\n\n    this.closeImportCurlPanel();\n  }\n\n  /** Handler: emit cancel and close panel. Called when user clicks Cancel in import cURL panel. */\n  onCancelImportCurl(): void {\n    this.importCurlCancel.emit();\n    this.closeImportCurlPanel();\n  }\n\n  /** Handler: show headers section (called from Cancel or after Import in import panel). */\n  closeImportCurlPanel(): void {\n    this.bodyView = 'headers';\n    this.cdr.detectChanges();\n  }\n\n  onSendRequest(): void {\n    const environment = this.selectedEnvironment != null ? String(this.selectedEnvironment) : '';\n    const method = this.selectedMethod != null ? String(this.selectedMethod) : '';\n    this.sendRequest.emit({\n      environment,\n      method,\n      url: this.url ?? '',\n      headers: this.headers,\n    });\n  }\n\n  onVariableNameChange(): void {\n    this.variableNameError = '';\n  }\n\n  onBack(): void {\n    if (this.currentStep > 1) {\n      this.setStep(this.currentStep - 1);\n    } else {\n      this.resetAllStepsAndData();\n      this.back.emit();\n    }\n  }\n\n  /** Called when user clicks the Cancel button (step 1). Emits cancel then runs normal back flow. */\n  onCancel(): void {\n    this.cancel.emit();\n    this.onBack();\n  }\n\n  onNext(): void {\n    if (this.currentStep === 2 && !this.variableName?.trim()) {\n      this.variableNameError = 'Variable Name is required.';\n      return;\n    }\n    this.variableNameError = '';\n    if (this.currentStep < this.stepLabels.length) {\n      this.setStep(this.currentStep + 1);\n    } else {\n      this.next.emit();\n    }\n  }\n\n  setPayloadTab(value: ApiEditPayloadTab): void {\n    this.activePayloadTab = value;\n  }\n\n  setResponseVerificationTab(value: 'response-body' | 'status'): void {\n    this.activeResponseVerificationTab = value;\n  }\n\n  addHeader(): void {\n    this.headersFormArray.push(\n      this.fb.group({ name: [''], value: [''] })\n    );\n  }\n\n  removeHeader(index: number): void {\n    this.headersFormArray.removeAt(index);\n  }\n\n  /** When user adds a custom header name via the dropdown \"Add '…'\" option, set the control value. */\n  onHeaderNameAddCustomValue(event: { key: string; value: string }, row: FormGroup): void {\n    const control = row.get(event.key);\n    if (control && event.value != null) {\n      control.setValue(event.value.trim());\n    }\n  }\n\n  trackByHeader(index: number): number {\n    return index;\n  }\n\n  addKeyValueRow(): void {\n    this.keyValueFormArray.push(this.fb.group({ key: [''], value: [''] }));\n  }\n\n  removeKeyValueRow(index: number): void {\n    this.keyValueFormArray.removeAt(index);\n  }\n\n  trackByKeyValue(index: number): number {\n    return index;\n  }\n\n  addKeyTypeValueRow(): void {\n    this.keyTypeValueFormArray.push(this.fb.group({ key: [''], type: ['text'], value: [''] }));\n  }\n\n  removeKeyTypeValueRow(index: number): void {\n    this.keyTypeValueFormArray.removeAt(index);\n  }\n\n  trackByKeyTypeValue(index: number): number {\n    return index;\n  }\n\n  addParamsRow(): void {\n    this.paramsFormArray.push(this.fb.group({ key: [''], value: [''] }));\n  }\n\n  removeParamsRow(index: number): void {\n    this.paramsFormArray.removeAt(index);\n  }\n\n  trackByParams(index: number): number {\n    return index;\n  }\n\n  addVerificationRow(): void {\n    this.verificationFormArray.push(\n      this.fb.group({\n        jsonPath: [''],\n        verification: [this.getDefaultVerification()],\n        dataType: [this.getDefaultDataType()],\n        expectedValue: [''],\n      })\n    );\n  }\n\n  removeVerificationRow(index: number): void {\n    this.verificationFormArray.removeAt(index);\n  }\n\n  trackByVerification(index: number): number {\n    return index;\n  }\n\n  /** When Data Type changes in Response Body verification, reset Expected Value for that row. */\n  onVerificationDataTypeChange(row: FormGroup, event: { key: string; value: unknown }): void {\n    if (event.key === 'dataType') {\n      row.get('expectedValue')?.setValue('', { emitEvent: false });\n    }\n  }\n\n  addStatusVerificationRow(): void {\n    this.statusVerificationFormArray.push(\n      this.fb.group({ verification: [this.getDefaultStatusVerification()], expectedValue: [''] })\n    );\n  }\n\n  removeStatusVerificationRow(index: number): void {\n    this.statusVerificationFormArray.removeAt(index);\n  }\n\n  trackByStatusVerification(index: number): number {\n    return index;\n  }\n\n  /** Emit all entered details (environment, HTTP method, URL, headers, body, step2 variable, step3 verifications) when user clicks Create. */\n  onCreate(): void {\n    console.log('9999999');\n    \n    try {\n      const payload = this.getCreatePayload();\n      console.log('9999999 payload', payload);\n      this.create.emit(payload);\n    } catch (err) {\n      console.error('ApiEditStep getCreatePayload error:', err);\n      this.create.emit(this.getCreatePayloadFallback());\n    }\n  }\n\n  /** Minimal payload when getCreatePayload throws (so create always emits). */\n  private getCreatePayloadFallback(): ApiEditCreatePayload {\n    const authType = this.selectedAuthType;\n    const bearerToken = authType === 'bearer' ? (this.bearerToken ?? '') : undefined;\n    let oauth2: ApiEditOAuth2Payload | undefined;\n    if (authType === 'oauth2' && this.oauth2Form) {\n      const grantType = ApiEditStepComponent.getControlValue(this.oauth2Form.get('grantType') as { value: unknown } | null);\n      const clientAuth = ApiEditStepComponent.getControlValue(this.oauth2Form.get('clientAuthentication') as { value: unknown } | null);\n      oauth2 = {\n        grantType: grantType !== '' ? grantType : 'client_credentials',\n        accessTokenUrl: (this.oauth2Form.get('accessTokenUrl')?.value ?? '') as string,\n        clientId: (this.oauth2Form.get('clientId')?.value ?? '') as string,\n        clientSecret: (this.oauth2Form.get('clientSecret')?.value ?? '') as string,\n        scope: (this.oauth2Form.get('scope')?.value ?? '') as string,\n        clientAuthentication: clientAuth !== '' ? clientAuth : 'basic',\n      };\n    }\n    return {\n      step1: {\n        environment: '',\n        method: '',\n        url: this.url ?? '',\n        headers: [],\n        authType,\n        ...(bearerToken !== undefined && { bearerToken }),\n        ...(oauth2 !== undefined && { oauth2 }),\n        activePayloadTab: this.activePayloadTab,\n        payloadType: this.payloadType,\n        payloadFormat: '',\n        payloadText: this.payloadText ?? '',\n        keyValueRows: [],\n        keyTypeValueRows: [],\n        paramsRows: [],\n      },\n      step2: { variableName: this.variableName ?? '' },\n      step3: {\n        activeResponseVerificationTab: this.activeResponseVerificationTab,\n        responseBodyVerifications: [],\n        statusVerifications: [],\n      },\n    };\n  }\n\n  /** Normalize form control value to string (handles object or string). */\n  private static getControlValue(control: { value: unknown } | null | undefined): string {\n    const v = control?.value;\n    if (v == null || v === '') return '';\n    return typeof v === 'object' ? (ApiEditStepComponent.getOptionValue(v as EnvironmentOptionInput) ?? '') : String(v);\n  }\n\n  /** Build full create payload: environment, HTTP method, URL, headers, body (step1), variable name (step2), verifications (step3). */\n  private getCreatePayload(): ApiEditCreatePayload {\n    const envFromForm = ApiEditStepComponent.getControlValue(this.environmentForm?.get('environment') as { value: unknown } | null);\n    const environment =\n      envFromForm !== '' ? envFromForm : (this.currentEnvironmentValue !== '' ? this.currentEnvironmentValue : this.selectedEnvironment);\n    const methodFromForm = ApiEditStepComponent.getControlValue(this.methodForm?.get('method') as { value: unknown } | null);\n    const method =\n      methodFromForm !== '' ? methodFromForm : (this.currentMethodValue !== '' ? this.currentMethodValue : this.selectedMethod);\n    const format = this.payloadFormatForm?.get('format')?.value ?? '';\n    const keyValueFormArray = this.keyValueFormArray;\n    const keyValueRows = (keyValueFormArray?.controls ?? []).map((c) => ({\n      key: (c as FormGroup).get('key')?.value ?? '',\n      value: (c as FormGroup).get('value')?.value ?? '',\n    }));\n    const keyTypeValueFormArray = this.keyTypeValueFormArray;\n    const keyTypeValueRows = (keyTypeValueFormArray?.controls ?? []).map((c) => ({\n      key: (c as FormGroup).get('key')?.value ?? '',\n      type: (c as FormGroup).get('type')?.value ?? 'text',\n      value: (c as FormGroup).get('value')?.value ?? '',\n    }));\n    const paramsFormArray = this.paramsFormArray;\n    const paramsRows = (paramsFormArray?.controls ?? []).map((c) => ({\n      key: (c as FormGroup).get('key')?.value ?? '',\n      value: (c as FormGroup).get('value')?.value ?? '',\n    }));\n    const verificationFormArray = this.verificationFormArray;\n    const responseBodyVerifications = (verificationFormArray?.controls ?? []).map((c) => ({\n      jsonPath: (c as FormGroup).get('jsonPath')?.value ?? '',\n      verification: (c as FormGroup).get('verification')?.value ?? '',\n      dataType: (c as FormGroup).get('dataType')?.value ?? '',\n      expectedValue: (c as FormGroup).get('expectedValue')?.value ?? '',\n    }));\n    const statusVerificationFormArray = this.statusVerificationFormArray;\n    const statusVerifications = (statusVerificationFormArray?.controls ?? []).map((c) => ({\n      verification: (c as FormGroup).get('verification')?.value ?? '',\n      expectedValue: (c as FormGroup).get('expectedValue')?.value ?? '',\n    }));\n    const authType = this.selectedAuthType;\n    const bearerToken = authType === 'bearer' ? (this.bearerToken ?? '') : undefined;\n    let oauth2: ApiEditOAuth2Payload | undefined;\n    if (authType === 'oauth2' && this.oauth2Form) {\n      const grantType = ApiEditStepComponent.getControlValue(this.oauth2Form.get('grantType') as { value: unknown } | null);\n      const clientAuth = ApiEditStepComponent.getControlValue(this.oauth2Form.get('clientAuthentication') as { value: unknown } | null);\n      oauth2 = {\n        grantType: grantType !== '' ? grantType : 'client_credentials',\n        accessTokenUrl: (this.oauth2Form.get('accessTokenUrl')?.value ?? '') as string,\n        clientId: (this.oauth2Form.get('clientId')?.value ?? '') as string,\n        clientSecret: (this.oauth2Form.get('clientSecret')?.value ?? '') as string,\n        scope: (this.oauth2Form.get('scope')?.value ?? '') as string,\n        clientAuthentication: clientAuth !== '' ? clientAuth : 'basic',\n      };\n    }\n    return {\n      step1: {\n        environment,\n        method,\n        url: this.url ?? '',\n        headers: this.headers,\n        authType,\n        ...(bearerToken !== undefined && { bearerToken }),\n        ...(oauth2 !== undefined && { oauth2 }),\n        activePayloadTab: this.activePayloadTab,\n        payloadType: this.payloadType,\n        payloadFormat: format,\n        payloadText: this.payloadText ?? '',\n        keyValueRows,\n        keyTypeValueRows,\n        paramsRows,\n      },\n      step2: {\n        variableName: this.variableName ?? '',\n      },\n      step3: {\n        activeResponseVerificationTab: this.activeResponseVerificationTab,\n        responseBodyVerifications,\n        statusVerifications,\n      },\n    };\n  }\n\n  /** Current header rows from form (for consumers that read headers) */\n  get headers(): ApiEditHeaderRow[] {\n    if (!this.headersFormArray) return [];\n    return this.headersFormArray.controls.map((c) => ({\n      name: (c as FormGroup).get('name')?.value ?? '',\n      type: 'string',\n      value: (c as FormGroup).get('value')?.value ?? '',\n    }));\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes['initialMethod']?.currentValue != null && this.methodForm) {\n      const v = changes['initialMethod'].currentValue;\n      this.currentMethodValue = typeof v === 'string' ? v : (ApiEditStepComponent.getOptionValue(v as EnvironmentOptionInput) ?? '');\n      this.methodForm.patchValue({ method: v });\n    }\n    if (changes['httpMethodOptions']) {\n      this.updateMethodSelectConfig();\n      if (this.methodForm && this.httpMethodOptions?.length) {\n        const current = this.methodForm.get('method')?.value;\n        const values = this.getMethodValues();\n        const valid = values.includes(current);\n        if (!valid) {\n          const firstValue = ApiEditStepComponent.getOptionValue(this.httpMethodOptions[0]);\n          if (firstValue != null) {\n            this.currentMethodValue = firstValue;\n            this.methodForm.patchValue({ method: firstValue });\n          }\n        }\n      }\n    }\n    if (changes['initialEnvironment']?.currentValue != null && this.environmentForm) {\n      const v = changes['initialEnvironment'].currentValue;\n      this.currentEnvironmentValue = typeof v === 'string' ? v : (ApiEditStepComponent.getOptionValue(v as EnvironmentOptionInput) ?? '');\n      this.environmentForm.patchValue({ environment: v });\n    }\n    if (changes['environmentOptions']) {\n      this.updateEnvironmentSelectConfig();\n      if (this.environmentForm && this.environmentOptions?.length) {\n        const current = this.environmentForm.get('environment')?.value;\n        const values = this.getEnvironmentValues();\n        const valid = values.includes(current);\n        if (!valid) {\n          const firstValue = ApiEditStepComponent.getOptionValue(this.environmentOptions[0]);\n          if (firstValue != null) {\n            this.currentEnvironmentValue = firstValue;\n            this.environmentForm.patchValue({ environment: firstValue });\n          }\n        }\n      }\n    }\n    if (changes['initialAuthType']?.currentValue != null && this.authTypeForm) {\n      const v = changes['initialAuthType'].currentValue;\n      const resolved =\n        typeof v === 'string' ? v : ApiEditStepComponent.getOptionValue(v as EnvironmentOptionInput);\n      if (resolved != null) this.authTypeForm.patchValue({ authType: v });\n    }\n    if (changes['authTypeOptions']) {\n      this.updateAuthTypeSelectConfig();\n      if (this.authTypeForm) {\n        const values = this.getAuthTypeValues();\n        if (values.length > 0) {\n          const current = this.authTypeForm.get('authType')?.value;\n          const currentVal =\n            current != null && current !== ''\n              ? typeof current === 'object'\n                ? ApiEditStepComponent.getOptionValue(current as EnvironmentOptionInput)\n                : String(current)\n              : null;\n          const valid = currentVal != null && values.includes(currentVal);\n          if (!valid) {\n            const firstValue = values[0];\n            if (firstValue != null) {\n              this.authTypeForm.patchValue({ authType: firstValue });\n            }\n          }\n        }\n      }\n    }\n    if (changes['initialStep']) {\n      this.applyInitialStep(changes['initialStep'].currentValue);\n    }\n    if (changes['initialUrl']?.currentValue != null) {\n      this.url = changes['initialUrl'].currentValue;\n    }\n    if (changes['initialPayloadTab']?.currentValue != null) {\n      this.activePayloadTab = changes['initialPayloadTab'].currentValue;\n    }\n    if (changes['headerNameOptions']) {\n      this.updateHeaderNameSelectConfig();\n    }\n    if (changes['initialHeaders']?.currentValue != null) {\n      this.buildHeadersFormArray(changes['initialHeaders'].currentValue as ApiEditHeaderRow[]);\n      this.updateHeaderNameSelectConfig();\n    }\n    if (changes['initialResponsePreview']?.currentValue != null) {\n      this.responsePreview = changes['initialResponsePreview'].currentValue;\n    }\n    if (changes['initialFormat']?.currentValue != null && this.payloadFormatForm) {\n      this.payloadFormatForm.patchValue({ format: changes['initialFormat'].currentValue });\n    }\n    if (changes['initialVariableName']?.currentValue != null) {\n      this.variableName = changes['initialVariableName'].currentValue;\n    }\n    if (changes['formatOptions']) {\n      this.updatePayloadFormatSelectConfig();\n      if (this.payloadFormatForm) {\n        const current = this.payloadFormatForm.get('format')?.value;\n        const values = this.getFormatValues();\n        const valid = values.includes(current);\n        if (!valid && values.length > 0) {\n          const firstValue = values[0];\n          this.payloadFormatForm.patchValue({ format: firstValue });\n        }\n      }\n    }\n    if (changes['verificationOptions']) {\n      this.updateVerificationSelectConfig();\n      const values = this.getVerificationValues();\n      const defaultVerification = this.getDefaultVerification();\n      if (this.verificationFormArray && values.length > 0) {\n        this.verificationFormArray.controls.forEach((control) => {\n          const current = (control as FormGroup).get('verification')?.value;\n          if (current && !values.includes(current)) {\n            (control as FormGroup).patchValue({ verification: defaultVerification });\n          }\n        });\n      }\n    }\n    if (changes['verificationDataTypeOptions']) {\n      this.updateVerificationDataTypeSelectConfig();\n      const values = this.getDataTypeValues();\n      const defaultDataType = this.getDefaultDataType();\n      if (this.verificationFormArray && values.length > 0) {\n        this.verificationFormArray.controls.forEach((control) => {\n          const current = (control as FormGroup).get('dataType')?.value;\n          if (current && !values.includes(current)) {\n            (control as FormGroup).patchValue({ dataType: defaultDataType });\n          }\n        });\n      }\n    }\n    if (changes['statusVerificationOptions']) {\n      this.updateStatusVerificationSelectConfig();\n      const values = this.getStatusVerificationValues();\n      const defaultVerification = this.getDefaultStatusVerification();\n      if (this.statusVerificationFormArray && values.length > 0) {\n        this.statusVerificationFormArray.controls.forEach((control) => {\n          const current = (control as FormGroup).get('verification')?.value;\n          if (current && !values.includes(current)) {\n            (control as FormGroup).patchValue({ verification: defaultVerification });\n          }\n        });\n      }\n    }\n  }\n}\n","<div class=\"cqa-api-edit-step-container cqa-bg-[#ffffff] cqa-flex cqa-flex-col cqa-w-full cqa-h-full cqa-p-[16px] cqa-gap-[12px] cqa-overflow-y-auto cqa-overflow-x-hidden cqa-box-border\">\n\n  <h2 class=\"cqa-api-edit-step-title cqa-font-inter cqa-text-[12px] cqa-font-semibold cqa-leading-[100%] cqa-tracking-normal cqa-text-[#000000] cqa-m-0\">\n    {{ editMode ? 'Update API Test Step' : 'Create API Test Step' }}\n  </h2>\n\n  <div class=\"cqa-api-edit-step-indicator cqa-flex cqa-items-center cqa-gap-0 cqa-max-[767px]:cqa-flex-wrap cqa-max-[767px]:cqa-gap-2 cqa-max-[767px]:cqa-justify-start\"\n    [class.cqa-justify-start]=\"stepLabels.length === 1\"\n    [class.cqa-justify-between]=\"stepLabels.length !== 1\">\n    <ng-container *ngFor=\"let step of stepLabels; let i = index\">\n      <cqa-button type=\"button\" variant=\"text\"\n        customClass=\"cqa-api-edit-step-indicator-item cqa-api-edit-step-indicator-item--clickable cqa-flex cqa-items-center cqa-gap-[10px] cqa-cursor-pointer cqa-border-none cqa-p-0 cqa-font-inherit cqa-text-inherit cqa-text-left !cqa-bg-transparent\"\n        [attr.aria-label]=\"'Step ' + step.index + ': ' + step.label\" [attr.aria-pressed]=\"step.index === currentStep\"\n        (clicked)=\"setStep(step.index)\">\n        <span class=\"cqa-api-edit-step-indicator-circle cqa-w-8 cqa-h-8 cqa-rounded-full cqa-inline-flex cqa-items-center cqa-justify-center cqa-text-sm cqa-font-medium cqa-leading-none cqa-border-none cqa-shrink-0\"\n          [ngClass]=\"step.index === currentStep ? 'cqa-bg-[#4F46E5] cqa-text-white' : 'cqa-bg-[#E0E0E0] cqa-text-[#666666]'\">\n          {{ step.index }}\n        </span>\n        <span class=\"cqa-api-edit-step-indicator-label cqa-text-sm cqa-leading-[18px] cqa-font-normal cqa-max-[767px]:cqa-text-xs\"\n          [ngClass]=\"step.index === currentStep ? 'cqa-text-[#4F46E5]' : 'cqa-text-[#666666]'\">\n          {{ step.label }}\n        </span>\n        <div *ngIf=\"i < stepLabels.length - 1\" class=\"cqa-api-edit-step-indicator-line cqa-w-[96px] cqa-h-[2px] cqa-bg-[#E0E0E0] cqa-my-0 cqa-mx-[6px] cqa-shrink-0 cqa-self-center cqa-max-[767px]:cqa-w-[24px] cqa-max-[767px]:cqa-mx-1\" aria-hidden=\"true\"></div>\n      </cqa-button>\n    </ng-container>\n  </div>\n\n  <!-- Step content viewport: only the active step body is shown (*ngIf) -->\n  <div class=\"cqa-api-edit-step-viewport cqa-w-full\">\n    <!-- Step 1: Environment, request, body, response -->\n    <div *ngIf=\"currentStep === 1\" class=\"cqa-api-edit-step-panel cqa-flex cqa-flex-col cqa-gap-6 cqa-box-border cqa-w-full\">\n        <!-- Environment row: new line, select aligned right -->\n        <div class=\"cqa-api-edit-step-environment-row cqa-flex cqa-justify-end cqa-items-center\">\n          <cqa-dynamic-select *ngIf=\"environmentForm\" [form]=\"environmentForm\" [config]=\"environmentSelectConfig\"\n            class=\"cqa-api-edit-step-environment-select cqa-shrink-0 cqa-w-auto cqa-min-w-[315px] cqa-max-w-[315px] cqa-max-[767px]:cqa-min-w-0 cqa-max-[767px]:cqa-max-w-full cqa-max-[767px]:cqa-w-full [&_.mat-form-field-wrapper]:cqa-pb-0\" aria-label=\"Environment\"\n            (selectionChange)=\"onEnvironmentSelectionChange($event)\">\n          </cqa-dynamic-select>\n        </div>\n\n        <!-- Request row: method, URL, buttons -->\n        <div class=\"cqa-api-edit-step-request-row cqa-flex cqa-items-center cqa-gap-3 cqa-flex-wrap cqa-max-[767px]:cqa-flex-col cqa-max-[767px]:cqa-items-stretch cqa-max-[767px]:cqa-gap-2.5\">\n          <cqa-dynamic-select *ngIf=\"methodForm\" [form]=\"methodForm\" [config]=\"methodSelectConfig\"\n            class=\"cqa-api-edit-step-method-select cqa-shrink-0 cqa-w-auto cqa-min-w-[152px] cqa-max-w-[152px] cqa-max-[767px]:cqa-min-w-0 cqa-max-[767px]:cqa-max-w-full cqa-max-[767px]:cqa-w-full\" aria-label=\"HTTP method\"\n            (selectionChange)=\"onMethodSelectionChange($event)\">\n          </cqa-dynamic-select>\n          <div class=\"cqa-api-edit-step-url-wrap cqa-flex-1 cqa-min-w-[200px] cqa-max-[767px]:cqa-min-w-0 cqa-max-[767px]:cqa-w-full [&_cqa-custom-input_.cqa-relative_input]:cqa-h-[40px] [&_cqa-custom-input_.cqa-relative_input]:cqa-bg-white [&_cqa-custom-input_.cqa-relative_input]:cqa-border [&_cqa-custom-input_.cqa-relative_input]:cqa-border-solid [&_cqa-custom-input_.cqa-relative_input]:cqa-border-[#D1D5DB] [&_cqa-custom-input_.cqa-relative_input]:cqa-rounded-md [&_cqa-custom-input_.cqa-relative_input]:cqa-text-sm [&_cqa-custom-input_.cqa-relative_input]:cqa-text-[#374151]\">\n            <cqa-custom-input [(value)]=\"url\" [label]=\"''\" placeholder=\"\" [fullWidth]=\"true\" size=\"md\">\n            </cqa-custom-input>\n          </div>\n          <div class=\"cqa-api-edit-step-import-curl-trigger cqa-contents cqa-max-[767px]:cqa-w-full cqa-max-[767px]:!cqa-flex\" (click)=\"openImportCurlPanel()\">\n            <cqa-button type=\"button\" variant=\"outlined\" btnSize=\"lg\" text=\"Import API cURL\"\n              customClass=\"cqa-api-edit-step-btn-outline !cqa-bg-white !cqa-border !cqa-border-solid !cqa-border-[#6B7280] cqa-text-[#414146] cqa-font-inter cqa-text-[14px] cqa-font-semibold cqa-leading-[100%] cqa-tracking-normal hover:!cqa-bg-[#F9FAFB] hover:!cqa-text-[#414146] cqa-max-[767px]:cqa-w-full\">\n            </cqa-button>\n          </div>\n          <cqa-button variant=\"filled\" btnSize=\"lg\" text=\"Send Request\" (clicked)=\"onSendRequest()\"\n            customClass=\"cqa-api-edit-step-btn-primary cqa-font-inter cqa-text-[14px] cqa-font-semibold cqa-leading-[100%] cqa-tracking-normal !cqa-bg-[#3F43EE] cqa-text-[#FBFCFF] !cqa-border-none cqa-py-2.5 cqa-px-6 cqa-gap-2 cqa-rounded-lg cqa-min-h-[37px] cqa-box-border hover:!cqa-bg-[#1B1FEB] cqa-max-[767px]:cqa-w-full\">\n          </cqa-button>\n        </div>\n\n\n\n        <!-- Body content: header section (default) OR import cURL section -->\n        <ng-container *ngIf=\"bodyView === 'import-curl'\">\n          <div class=\"cqa-api-edit-step-import-curl-panel cqa-flex cqa-flex-col cqa-bg-white cqa-rounded-lg cqa-border cqa-border-solid cqa-border-[#E5E7EB] cqa-shadow-[0_1px_3px_rgba(0,0,0,0.08)] cqa-overflow-hidden\">\n            <div class=\"cqa-api-edit-step-import-curl-header cqa-flex cqa-items-center cqa-justify-between cqa-py-3 cqa-px-5 cqa-border-b cqa-border-solid cqa-border-[#E2E8F0] cqa-bg-[#F9FAFB] cqa-rounded-t-lg cqa-max-[767px]:cqa-px-4\">\n              <h3 class=\"cqa-api-edit-step-import-curl-title cqa-m-0 cqa-text-xs cqa-font-bold cqa-leading-[18px] cqa-text-[#374151]\">Import API cURL</h3>\n            </div>\n            <div class=\"cqa-api-edit-step-import-curl-separator cqa-h-px cqa-bg-[#E2E8F0] cqa-my-0 cqa-mx-5\"></div>\n            <div class=\"cqa-api-edit-step-import-curl-body\">\n              <cqa-custom-textarea [value]=\"importCurlControl.value\"\n                (valueChange)=\"importCurlControl.setValue($event)\"\n                placeholder=\"Paste your cURL command here (e.g., curl -X POST https://api.example.com/users)\"\n                [fullWidth]=\"true\" [rows]=\"8\" resize=\"vertical\" size=\"md\"\n                class=\"cqa-api-edit-step-import-curl-textarea\">\n              </cqa-custom-textarea>\n            </div>\n            <div class=\"cqa-api-edit-step-import-curl-footer\">\n              <cqa-button type=\"button\" variant=\"outlined\" btnSize=\"lg\" text=\"Cancel\"\n                customClass=\"cqa-api-edit-step-import-curl-btn-cancel\" (clicked)=\"onCancelImportCurl()\"></cqa-button>\n              <cqa-button type=\"button\" variant=\"filled\" btnSize=\"lg\" text=\"Import\"\n                customClass=\"cqa-api-edit-step-import-curl-btn-import\" (clicked)=\"onImportCurlConfirm()\"></cqa-button>\n            </div>\n          </div>\n        </ng-container>\n\n        <ng-container *ngIf=\"bodyView === 'headers'\">\n          <div class=\"cqa-api-edit-step-tabs-wrapper\">\n            <div class=\"cqa-api-edit-step-tabs\">\n              <cqa-button *ngFor=\"let tab of payloadTabs\" type=\"button\" variant=\"text\" [text]=\"tab.label\"\n                [customClass]=\"'cqa-api-edit-step-tab' + (activePayloadTab === tab.value ? ' cqa-api-edit-step-tab--active' : '') + (isMethodWithoutBody && (tab.value === 'body' || tab.value === 'params') ? ' cqa-api-edit-step-tab--disabled' : '')\"\n                [disabled]=\"isMethodWithoutBody && (tab.value === 'body' || tab.value === 'params')\"\n                (clicked)=\"setPayloadTab(tab.value)\">\n              </cqa-button>\n            </div>\n\n            <!-- Payload content (Authorization) -->\n            <div *ngIf=\"activePayloadTab === 'authorization'\" class=\"cqa-api-edit-step-payload\"\n              [attr.style]=\"'padding: 20px; min-height: 200px;'\">\n              <div [attr.style]=\"'display: flex; flex-direction: column; gap: 20px;'\">\n                <div [attr.style]=\"'display: flex; flex-direction: column; gap: 8px; width: fit-content;'\">\n                  <span [attr.style]=\"'font-size: 11px; font-weight: 600; letter-spacing: 0.02em; color: #6B7280; text-transform: uppercase; line-height: 1.25;'\">AUTH TYPE</span>\n                  <cqa-dynamic-select *ngIf=\"authTypeForm\" [form]=\"authTypeForm\" [config]=\"authTypeSelectConfig\"\n                    class=\"cqa-api-edit-step-auth-type-select\" aria-label=\"Auth type\"\n                    [attr.style]=\"'min-width: 160px;'\">\n                  </cqa-dynamic-select>\n                </div>\n                <!-- No Auth: centered message -->\n                <div *ngIf=\"selectedAuthType === 'no-auth'\"\n                  [attr.style]=\"'flex: 1; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 12px; min-width: 0; text-align: center;'\">\n                  <div aria-hidden=\"true\"\n                    [attr.style]=\"'width: 48px; height: 48px; border-radius: 10px; background: #F3F4F6; display: flex; align-items: center; justify-content: center; flex-shrink: 0;'\">\n                    <svg width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\" style=\"display: block;\">\n                      <rect x=\"5\" y=\"11\" width=\"14\" height=\"2\" rx=\"1\" fill=\"#9CA3AF\"/>\n                    </svg>\n                  </div>\n                  <span [attr.style]=\"'font-size: 16px; font-weight: 600; color: #374151; line-height: 1.25;'\">No Auth</span>\n                  <div [attr.style]=\"'display: flex; align-items: center; justify-content: center; gap: 6px; flex-wrap: wrap;'\">\n                    <span [attr.style]=\"'font-size: 14px; font-weight: 400; color: #9CA3AF; line-height: 1.4;'\">This request does not use any authorization.</span>\n                    <span role=\"img\" aria-label=\"More information\" title=\"This request does not use any authorization.\"\n                      [attr.style]=\"'display: inline-flex; align-items: center; justify-content: center; width: 18px; height: 18px; color: #9CA3AF; flex-shrink: 0;'\">\n                      <svg width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\" style=\"display: block;\">\n                        <circle cx=\"8\" cy=\"8\" r=\"7\" stroke=\"#9CA3AF\" stroke-width=\"1.5\" fill=\"none\"/>\n                        <path d=\"M8 7v4M8 5v.5\" stroke=\"#9CA3AF\" stroke-width=\"1.5\" stroke-linecap=\"round\"/>\n                      </svg>\n                    </span>\n                  </div>\n                </div>\n                <!-- Bearer Token: Token label + textarea -->\n                <div *ngIf=\"selectedAuthType === 'bearer'\"\n                  [attr.style]=\"'flex: 1; display: flex; flex-direction: column; gap: 10px; min-width: 0;'\">\n                  <span [attr.style]=\"'font-size: 12px; font-weight: 600; color: #374151; line-height: 1.25;'\">Token</span>\n                  <cqa-custom-textarea [(value)]=\"bearerToken\"\n                    placeholder=\"Enter bearer token\"\n                    [fullWidth]=\"true\" [rows]=\"6\" resize=\"vertical\" size=\"md\"\n                    class=\"cqa-api-edit-step-auth-token-textarea\" ariaLabel=\"Bearer token\">\n                  </cqa-custom-textarea>\n                </div>\n                <!-- OAuth 2.0: Grant Type, Access Token URL, Client ID, Client Secret, Scope, Client Authentication -->\n                <div *ngIf=\"selectedAuthType === 'oauth2' && oauth2Form\"\n                  class=\"cqa-api-edit-step-oauth2-grid\"\n                  [attr.style]=\"'display: grid; grid-template-columns: 1fr 1fr; gap: 16px 24px; width: 100%;'\">\n                  <div [attr.style]=\"'display: flex; flex-direction: column; gap: 6px; min-width: 0;'\">\n                    <span [attr.style]=\"'font-size: 12px; font-weight: 600; color: #374151; line-height: 1.25;'\">Grant Type</span>\n                    <cqa-dynamic-select *ngIf=\"oauth2Form\" [form]=\"oauth2Form\" [config]=\"oauth2GrantTypeSelectConfig\"\n                      class=\"cqa-api-edit-step-auth-oauth-select\" aria-label=\"OAuth grant type\"\n                      [attr.style]=\"'min-width: 0; width: 100%;'\">\n                    </cqa-dynamic-select>\n                    <span [attr.style]=\"'font-size: 11px; font-style: italic; color: #6B7280; line-height: 1.3;'\">OAuth grant type</span>\n                  </div>\n                  <div [attr.style]=\"'display: flex; flex-direction: column; gap: 6px; min-width: 0;'\">\n                    <span [attr.style]=\"'font-size: 12px; font-weight: 600; color: #374151; line-height: 1.25;'\">Access Token URL</span>\n                    <cqa-custom-input [value]=\"oauth2Form.get('accessTokenUrl')?.value\"\n                      (valueChange)=\"oauth2Form.get('accessTokenUrl')?.setValue($event)\"\n                      [label]=\"''\" placeholder=\"Enter OAuth token endpoint\" [fullWidth]=\"true\" size=\"md\"\n                      ariaLabel=\"Access Token URL\">\n                    </cqa-custom-input>\n                    <span [attr.style]=\"'font-size: 11px; font-style: italic; color: #6B7280; line-height: 1.3;'\">OAuth token endpoint</span>\n                  </div>\n                  <div [attr.style]=\"'display: flex; flex-direction: column; gap: 6px; min-width: 0;'\">\n                    <span [attr.style]=\"'font-size: 12px; font-weight: 600; color: #374151; line-height: 1.25;'\">Client ID</span>\n                    <cqa-custom-input [value]=\"oauth2Form.get('clientId')?.value\"\n                      (valueChange)=\"oauth2Form.get('clientId')?.setValue($event)\"\n                      [label]=\"''\" placeholder=\"Enter OAuth client identifier\" [fullWidth]=\"true\" size=\"md\"\n                      ariaLabel=\"Client ID\">\n                    </cqa-custom-input>\n                    <span [attr.style]=\"'font-size: 11px; font-style: italic; color: #6B7280; line-height: 1.3;'\">OAuth client identifier</span>\n                  </div>\n                  <div [attr.style]=\"'display: flex; flex-direction: column; gap: 6px; min-width: 0;'\">\n                    <span [attr.style]=\"'font-size: 12px; font-weight: 600; color: #374151; line-height: 1.25;'\">Client Secret</span>\n                    <cqa-custom-input [value]=\"oauth2Form.get('clientSecret')?.value\"\n                      (valueChange)=\"oauth2Form.get('clientSecret')?.setValue($event)\"\n                      type=\"password\" [label]=\"''\" placeholder=\"Enter OAuth client secret\" [fullWidth]=\"true\" size=\"md\"\n                      ariaLabel=\"Client Secret\">\n                    </cqa-custom-input>\n                    <span [attr.style]=\"'font-size: 11px; font-style: italic; color: #6B7280; line-height: 1.3;'\">OAuth client secret</span>\n                  </div>\n                  <div [attr.style]=\"'display: flex; flex-direction: column; gap: 6px; min-width: 0;'\">\n                    <span [attr.style]=\"'font-size: 12px; font-weight: 600; color: #374151; line-height: 1.25;'\">Scope</span>\n                    <cqa-custom-input [value]=\"oauth2Form.get('scope')?.value\"\n                      (valueChange)=\"oauth2Form.get('scope')?.setValue($event)\"\n                      [label]=\"''\" placeholder=\"Enter space-separated scopes\" [fullWidth]=\"true\" size=\"md\"\n                      ariaLabel=\"Scope\">\n                    </cqa-custom-input>\n                    <span [attr.style]=\"'font-size: 11px; font-style: italic; color: #6B7280; line-height: 1.3;'\">Space-separated scopes</span>\n                  </div>\n                  <div [attr.style]=\"'display: flex; flex-direction: column; gap: 6px; min-width: 0;'\">\n                    <span [attr.style]=\"'font-size: 12px; font-weight: 600; color: #374151; line-height: 1.25;'\">Client Authentication</span>\n                    <cqa-dynamic-select *ngIf=\"oauth2Form\" [form]=\"oauth2Form\" [config]=\"oauth2ClientAuthSelectConfig\"\n                      class=\"cqa-api-edit-step-auth-oauth-select\" aria-label=\"Client authentication method\"\n                      [attr.style]=\"'min-width: 0; width: 100%;'\">\n                    </cqa-dynamic-select>\n                    <span [attr.style]=\"'font-size: 11px; font-style: italic; color: #6B7280; line-height: 1.3;'\">Client authentication method</span>\n                  </div>\n                </div>\n              </div>\n            </div>\n\n            <!-- Payload content (Headers) -->\n            <div *ngIf=\"activePayloadTab === 'headers'\" class=\"cqa-api-edit-step-payload\">\n              <div class=\"cqa-api-edit-step-headers-grid\">\n                <span class=\"cqa-api-edit-step-headers-label\">Header Name</span>\n                <span class=\"cqa-api-edit-step-headers-label\">Header Value</span>\n                <span class=\"cqa-api-edit-step-headers-label cqa-api-edit-step-headers-label--empty\"\n                  aria-hidden=\"true\"></span>\n              </div>\n              <div *ngFor=\"let row of headerRows; let i = index; trackBy: trackByHeader\" [formGroup]=\"row\"\n                class=\"cqa-api-edit-step-header-row\">\n                <cqa-dynamic-select [form]=\"row\" [config]=\"headerNameSelectConfig\"\n                  (addCustomValue)=\"onHeaderNameAddCustomValue($event, row)\"\n                  class=\"cqa-api-edit-step-header-type-select cqa-w-full\">\n                </cqa-dynamic-select>\n                <cqa-custom-input [value]=\"row.get('value')?.value ?? ''\"\n                  (valueChange)=\"row.get('value')?.setValue($event)\" placeholder=\"Value\" [fullWidth]=\"true\" size=\"sm\"\n                  class=\"cqa-api-edit-step-header-value-input\" ariaLabel=\"Header value\">\n                </cqa-custom-input>\n                <cqa-button type=\"button\" variant=\"text\" [customClass]=\"'cqa-api-edit-step-header-delete'\"\n                  [tooltip]=\"'Remove header'\" (clicked)=\"removeHeader(i)\">\n                  <svg class=\"cqa-api-edit-step-header-delete-icon\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\"\n                    fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\" aria-hidden=\"true\">\n                    <path\n                      d=\"M10.6663 6V12.6667H5.33301V6H10.6663ZM9.66634 2H6.33301L5.66634 2.66667H3.33301V4H12.6663V2.66667H10.333L9.66634 2ZM11.9997 4.66667H3.99967V12.6667C3.99967 13.4 4.59967 14 5.33301 14H10.6663C11.3997 14 11.9997 13.4 11.9997 12.6667V4.66667Z\"\n                      fill=\"#F9BFBF\" />\n                  </svg>\n                </cqa-button>\n              </div>\n              <div class=\"cqa-api-edit-step-add-header-wrap\">\n                <cqa-button type=\"button\" variant=\"text\" text=\"+ Add Header\"\n                  [customClass]=\"'cqa-api-edit-step-add-header-link'\" (clicked)=\"addHeader()\">\n                </cqa-button>\n              </div>\n            </div>\n\n            <!-- Payload content (Params): Key–Value table with add/delete rows -->\n            <div *ngIf=\"activePayloadTab === 'params'\" class=\"cqa-api-edit-step-payload\">\n              <div class=\"cqa-api-edit-step-key-value-grid cqa-api-edit-step-key-value-header\">\n                <span class=\"cqa-api-edit-step-key-value-label\">Key</span>\n                <span class=\"cqa-api-edit-step-key-value-label\">Value</span>\n                <span class=\"cqa-api-edit-step-key-value-label cqa-api-edit-step-key-value-label--empty\"\n                  aria-hidden=\"true\"></span>\n              </div>\n              <div *ngFor=\"let row of paramsRows; let i = index; trackBy: trackByParams\" [formGroup]=\"row\"\n                class=\"cqa-api-edit-step-key-value-row\">\n                <cqa-custom-input [value]=\"row.get('key')?.value ?? ''\"\n                  (valueChange)=\"row.get('key')?.setValue($event)\" placeholder=\"Key\" [fullWidth]=\"true\" size=\"sm\"\n                  class=\"cqa-api-edit-step-key-value-input\" ariaLabel=\"Key\">\n                </cqa-custom-input>\n                <cqa-custom-input [value]=\"row.get('value')?.value ?? ''\"\n                  (valueChange)=\"row.get('value')?.setValue($event)\" placeholder=\"Value\" [fullWidth]=\"true\" size=\"sm\"\n                  class=\"cqa-api-edit-step-key-value-input\" ariaLabel=\"Value\">\n                </cqa-custom-input>\n                <cqa-button type=\"button\" variant=\"text\" [customClass]=\"'cqa-api-edit-step-key-value-delete'\"\n                  [tooltip]=\"'Remove row'\" (clicked)=\"removeParamsRow(i)\">\n                  <svg class=\"cqa-api-edit-step-key-value-delete-icon\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\"\n                    fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\" aria-hidden=\"true\">\n                    <path\n                      d=\"M10.6663 6V12.6667H5.33301V6H10.6663ZM9.66634 2H6.33301L5.66634 2.66667H3.33301V4H12.6663V2.66667H10.333L9.66634 2ZM11.9997 4.66667H3.99967V12.6667C3.99967 13.4 4.59967 14 5.33301 14H10.6663C11.3997 14 11.9997 13.4 11.9997 12.6667V4.66667Z\"\n                      fill=\"#F9BFBF\" />\n                  </svg>\n                </cqa-button>\n              </div>\n              <div class=\"cqa-api-edit-step-key-value-add-wrap\">\n                <cqa-button type=\"button\" variant=\"filled\" btnSize=\"lg\" text=\"+ Add Row\"\n                  customClass=\"cqa-api-edit-step-key-value-add-btn\" (clicked)=\"addParamsRow()\">\n                </cqa-button>\n              </div>\n            </div>\n\n            <!-- Payload content (Body only): type, format, text area, Back/Next -->\n            <div *ngIf=\"activePayloadTab === 'body'\"\n              class=\"cqa-api-edit-step-payload cqa-api-edit-step-payload-editor\">\n              <div class=\"cqa-api-edit-step-payload-type-row\">\n                <span class=\"cqa-api-edit-step-payload-type-label\">Type</span>\n                <div class=\"cqa-api-edit-step-payload-type-radios\">\n                  <cqa-segment-control [value]=\"payloadType\" [segments]=\"payloadTypeSegments\"\n                    (valueChange)=\"onPayloadTypeChange($event)\"\n                    class=\"cqa-api-edit-step-payload-type-segment\">\n                  </cqa-segment-control>\n                </div>\n                <div *ngIf=\"payloadType === 'raw'\" class=\"cqa-api-edit-step-payload-format-wrap\">\n                  <span class=\"cqa-api-edit-step-payload-format-label\">Format:</span>\n                  <cqa-dynamic-select *ngIf=\"payloadFormatForm\" [form]=\"payloadFormatForm\"\n                    [config]=\"payloadFormatSelectConfig\" class=\"cqa-api-edit-step-payload-format-select\"\n                    aria-label=\"Format\">\n                  </cqa-dynamic-select>\n                </div>\n              </div>\n              <!-- Raw: text area with line numbers (Postman-style payload body) -->\n              <div *ngIf=\"payloadType === 'raw'\" class=\"cqa-api-edit-step-payload-body\" #payloadEditorWithLinesRef>\n                <div class=\"cqa-api-edit-step-payload-editor-with-lines\">\n                  <div class=\"cqa-api-edit-step-payload-line-numbers\" aria-hidden=\"true\">\n                    <span *ngFor=\"let n of payloadLineNumbers\" class=\"cqa-api-edit-step-payload-line-num\">\n                      <span *ngIf=\"payloadJsonError && payloadJsonError.line === n\"\n                        class=\"cqa-api-edit-step-payload-line-error-icon\" [title]=\"payloadJsonErrorTooltip\"\n                        aria-label=\"Parse error on this line\">\n                        <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"14\" height=\"14\" viewBox=\"0 0 14 14\" fill=\"none\" aria-hidden=\"true\">\n                          <circle cx=\"7\" cy=\"7\" r=\"6\" fill=\"#EF4444\"/>\n                          <path d=\"M4 4l6 6M10 4l-6 6\" stroke=\"white\" stroke-width=\"1.5\" stroke-linecap=\"round\"/>\n                        </svg>\n                      </span>\n                      <span class=\"cqa-api-edit-step-payload-line-num-text\">{{ n }}</span>\n                    </span>\n                  </div>\n                  <div class=\"cqa-api-edit-step-payload-textarea-cell\">\n                    <div class=\"cqa-api-edit-step-payload-textarea cqa-w-full cqa-flex cqa-flex-col cqa-min-h-0\"\n                      [ngClass]=\"{'cqa-api-edit-step-payload-textarea--error': payloadJsonError}\">\n                      <textarea #payloadTextareaRef\n                        class=\"cqa-api-edit-step-payload-textarea-input cqa-w-full cqa-outline-none cqa-box-border\"\n                        [ngClass]=\"{'cqa-api-edit-step-payload-textarea-input--error': payloadJsonError}\"\n                        [value]=\"payloadText\"\n                        placeholder=\"\"\n                        [attr.aria-label]=\"'Payload'\"\n                        [attr.aria-invalid]=\"!!payloadJsonError\"\n                        (input)=\"onPayloadInput($event)\"\n                        (keydown)=\"onPayloadKeydown($event)\">\n                      </textarea>\n                    </div>\n                  </div>\n                </div>\n                <p *ngIf=\"payloadJsonError\" class=\"cqa-api-edit-step-payload-json-error-msg\">\n                  Invalid JSON format. Please check your syntax.\n                </p>\n              </div>\n\n              <!-- x-www-form-urlencoded: Key–Value rows, add/remove dynamically -->\n              <div *ngIf=\"payloadType === 'x-www-form-urlencoded'\" class=\"cqa-api-edit-step-key-value\">\n                <div class=\"cqa-api-edit-step-key-value-grid cqa-api-edit-step-key-value-header\">\n                  <span class=\"cqa-api-edit-step-key-value-label\">Key</span>\n                  <span class=\"cqa-api-edit-step-key-value-label\">Value</span>\n                  <span class=\"cqa-api-edit-step-key-value-label cqa-api-edit-step-key-value-label--empty\"\n                    aria-hidden=\"true\"></span>\n                </div>\n                <div *ngFor=\"let row of keyValueRows; let i = index; trackBy: trackByKeyValue\" [formGroup]=\"row\"\n                  class=\"cqa-api-edit-step-key-value-row\">\n                  <cqa-custom-input [value]=\"row.get('key')?.value ?? ''\"\n                    (valueChange)=\"row.get('key')?.setValue($event)\" placeholder=\"Key\" [fullWidth]=\"true\" size=\"sm\"\n                    class=\"cqa-api-edit-step-key-value-input\" ariaLabel=\"Key\">\n                  </cqa-custom-input>\n                  <cqa-custom-input [value]=\"row.get('value')?.value ?? ''\"\n                    (valueChange)=\"row.get('value')?.setValue($event)\" placeholder=\"Value\" [fullWidth]=\"true\" size=\"sm\"\n                    class=\"cqa-api-edit-step-key-value-input\" ariaLabel=\"Value\">\n                  </cqa-custom-input>\n                  <cqa-button type=\"button\" variant=\"text\" [customClass]=\"'cqa-api-edit-step-key-value-delete'\"\n                    [tooltip]=\"'Remove row'\" (clicked)=\"removeKeyValueRow(i)\">\n                    <svg class=\"cqa-api-edit-step-key-value-delete-icon\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\"\n                      fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\" aria-hidden=\"true\">\n                      <path\n                        d=\"M10.6663 6V12.6667H5.33301V6H10.6663ZM9.66634 2H6.33301L5.66634 2.66667H3.33301V4H12.6663V2.66667H10.333L9.66634 2ZM11.9997 4.66667H3.99967V12.6667C3.99967 13.4 4.59967 14 5.33301 14H10.6663C11.3997 14 11.9997 13.4 11.9997 12.6667V4.66667Z\"\n                        fill=\"#F9BFBF\" />\n                    </svg>\n                  </cqa-button>\n                </div>\n                <div class=\"cqa-api-edit-step-key-value-add-wrap\">\n                  <cqa-button type=\"button\" variant=\"filled\" btnSize=\"lg\" text=\"+ Add Row\"\n                    customClass=\"cqa-api-edit-step-key-value-add-btn\" (clicked)=\"addKeyValueRow()\">\n                  </cqa-button>\n                </div>\n              </div>\n\n              <!-- Form Data: Key–Type–Value rows; Type is a dropdown (Text/File), add/remove dynamically -->\n              <div *ngIf=\"payloadType === 'form-data'\" class=\"cqa-api-edit-step-key-type-value\">\n                <div class=\"cqa-api-edit-step-key-type-value-header\">\n                  <span class=\"cqa-api-edit-step-key-type-value-label\">Key</span>\n                  <span class=\"cqa-api-edit-step-key-type-value-label\">Type</span>\n                  <span class=\"cqa-api-edit-step-key-type-value-label\">Value</span>\n                  <span class=\"cqa-api-edit-step-key-type-value-label cqa-api-edit-step-key-type-value-label--empty\"\n                    aria-hidden=\"true\"></span>\n                </div>\n                <div *ngFor=\"let row of keyTypeValueRows; let i = index; trackBy: trackByKeyTypeValue\" [formGroup]=\"row\"\n                  class=\"cqa-api-edit-step-key-type-value-row\">\n                  <cqa-custom-input [value]=\"row.get('key')?.value ?? ''\"\n                    (valueChange)=\"row.get('key')?.setValue($event)\" placeholder=\"Key\" [fullWidth]=\"true\" size=\"sm\"\n                    class=\"cqa-api-edit-step-key-type-value-input\" ariaLabel=\"Key\">\n                  </cqa-custom-input>\n                  <cqa-dynamic-select [form]=\"row\" [config]=\"keyTypeValueTypeSelectConfig\"\n                    class=\"cqa-api-edit-step-key-type-value-type-select cqa-w-full\">\n                  </cqa-dynamic-select>\n                  <cqa-custom-input [value]=\"row.get('value')?.value ?? ''\"\n                    (valueChange)=\"row.get('value')?.setValue($event)\" placeholder=\"Value\" [fullWidth]=\"true\" size=\"sm\"\n                    class=\"cqa-api-edit-step-key-type-value-input\" ariaLabel=\"Value\">\n                  </cqa-custom-input>\n                  <cqa-button type=\"button\" variant=\"text\" [customClass]=\"'cqa-api-edit-step-key-type-value-delete'\"\n                    [tooltip]=\"'Remove row'\" (clicked)=\"removeKeyTypeValueRow(i)\">\n                    <svg class=\"cqa-api-edit-step-key-type-value-delete-icon\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\"\n                      fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\" aria-hidden=\"true\">\n                      <path\n                        d=\"M10.6663 6V12.6667H5.33301V6H10.6663ZM9.66634 2H6.33301L5.66634 2.66667H3.33301V4H12.6663V2.66667H10.333L9.66634 2ZM11.9997 4.66667H3.99967V12.6667C3.99967 13.4 4.59967 14 5.33301 14H10.6663C11.3997 14 11.9997 13.4 11.9997 12.6667V4.66667Z\"\n                        fill=\"#F9BFBF\" />\n                    </svg>\n                  </cqa-button>\n                </div>\n                <div class=\"cqa-api-edit-step-key-type-value-add-wrap\">\n                  <cqa-button type=\"button\" variant=\"filled\" btnSize=\"lg\" text=\"+ Add Row\"\n                    customClass=\"cqa-api-edit-step-key-type-value-add-btn\" (clicked)=\"addKeyTypeValueRow()\">\n                  </cqa-button>\n                </div>\n              </div>\n            </div>\n          </div>\n        </ng-container>\n\n    </div>\n    <!-- Step 2: Variable Name: input, validation, Back / Next -->\n    <div *ngIf=\"currentStep === 2\" class=\"cqa-api-edit-step-panel cqa-flex cqa-flex-col cqa-gap-6 cqa-box-border cqa-w-full\">\n        <div class=\"cqa-api-edit-step-variable-section\">\n          <div class=\"cqa-api-edit-step-variable-input-wrap\">\n            <cqa-custom-input [(value)]=\"variableName\" [label]=\"''\" placeholder=\"Variable Name\" [fullWidth]=\"true\"\n              size=\"md\" (valueChange)=\"onVariableNameChange()\" aria-label=\"Variable Name\">\n            </cqa-custom-input>\n          </div>\n          <p *ngIf=\"variableNameError\" class=\"cqa-api-edit-step-variable-error\" role=\"alert\">{{ variableNameError }}</p>\n        </div>\n    </div>\n    <!-- Step 3: Response Body / Status tabs -->\n    <div *ngIf=\"currentStep === 3\" class=\"cqa-api-edit-step-panel cqa-flex cqa-flex-col cqa-gap-6 cqa-box-border cqa-w-full\">\n        <div class=\"cqa-api-edit-step-tabs-wrapper\">\n          <div class=\"cqa-api-edit-step-tabs\">\n            <cqa-button *ngFor=\"let tab of responseVerificationTabs\" type=\"button\" variant=\"text\" [text]=\"tab.label\"\n              [customClass]=\"'cqa-api-edit-step-tab' + (activeResponseVerificationTab === tab.value ? ' cqa-api-edit-step-tab--active' : '')\"\n              (clicked)=\"setResponseVerificationTab(tab.value)\">\n            </cqa-button>\n          </div>\n\n          <!-- Response Body tab content: verification grid -->\n          <div *ngIf=\"activeResponseVerificationTab === 'response-body'\" class=\"cqa-api-edit-step-step3-content\">\n            <div class=\"cqa-api-edit-step-verification-header-row\">\n              <span></span>\n              <cqa-button type=\"button\" variant=\"text\" text=\"Add Verification\"\n                customClass=\"cqa-api-edit-step-verification-add-link\" (clicked)=\"addVerificationRow()\">\n              </cqa-button>\n            </div>\n            <div class=\"cqa-api-edit-step-verification\">\n              <div class=\"cqa-api-edit-step-verification-grid cqa-api-edit-step-verification-grid-header\">\n                <span class=\"cqa-api-edit-step-verification-label\">S.no</span>\n                <span class=\"cqa-api-edit-step-verification-label\">JSON Path</span>\n                <span class=\"cqa-api-edit-step-verification-label\">Verification</span>\n                <span class=\"cqa-api-edit-step-verification-label\">Data Type</span>\n                <span class=\"cqa-api-edit-step-verification-label\">Expected Value</span>\n                <span class=\"cqa-api-edit-step-verification-label cqa-api-edit-step-verification-label--empty\"\n                  aria-hidden=\"true\"></span>\n              </div>\n              <div *ngFor=\"let row of verificationRows; let i = index; trackBy: trackByVerification\" [formGroup]=\"row\"\n                class=\"cqa-api-edit-step-verification-row\">\n                <span class=\"cqa-api-edit-step-verification-sno\">{{ i + 1 }}</span>\n                <cqa-custom-input [value]=\"row.get('jsonPath')?.value ?? ''\"\n                  (valueChange)=\"row.get('jsonPath')?.setValue($event)\" placeholder=\"Json Path\" [fullWidth]=\"true\"\n                  size=\"sm\" class=\"cqa-api-edit-step-verification-input\" ariaLabel=\"JSON Path\">\n                </cqa-custom-input>\n                <cqa-dynamic-select [form]=\"row\" [config]=\"verificationSelectConfig\"\n                  class=\"cqa-api-edit-step-verification-select cqa-w-full\">\n                </cqa-dynamic-select>\n                <cqa-dynamic-select [form]=\"row\" [config]=\"verificationDataTypeSelectConfig\"\n                  class=\"cqa-api-edit-step-verification-select cqa-w-full\"\n                  (selectionChange)=\"onVerificationDataTypeChange(row, $event)\">\n                </cqa-dynamic-select>\n                <!-- Expected Value: text for String/Array/Object, number for Number, dropdown for Boolean -->\n                <ng-container [ngSwitch]=\"row.get('dataType')?.value\">\n                  <cqa-dynamic-select *ngSwitchCase=\"'boolean'\" [form]=\"row\"\n                    [config]=\"verificationExpectedValueBooleanSelectConfig\"\n                    class=\"cqa-api-edit-step-verification-select cqa-api-edit-step-verification-expected-select cqa-w-full\">\n                  </cqa-dynamic-select>\n                  <cqa-custom-input *ngSwitchCase=\"'number'\" [value]=\"row.get('expectedValue')?.value ?? ''\"\n                    (valueChange)=\"row.get('expectedValue')?.setValue($event)\" placeholder=\"Expected Value (number)\"\n                    type=\"number\" [fullWidth]=\"true\" size=\"sm\"\n                    class=\"cqa-api-edit-step-verification-input cqa-api-edit-step-verification-expected-number\"\n                    ariaLabel=\"Expected Value\">\n                  </cqa-custom-input>\n                  <cqa-custom-input *ngSwitchDefault [value]=\"row.get('expectedValue')?.value ?? ''\"\n                    (valueChange)=\"row.get('expectedValue')?.setValue($event)\"\n                    placeholder=\"Expected Value in String\" [fullWidth]=\"true\" size=\"sm\"\n                    class=\"cqa-api-edit-step-verification-input\" ariaLabel=\"Expected Value\">\n                  </cqa-custom-input>\n                </ng-container>\n                <cqa-button type=\"button\" variant=\"text\" [customClass]=\"'cqa-api-edit-step-verification-delete'\"\n                  [tooltip]=\"'Remove row'\" (clicked)=\"removeVerificationRow(i)\">\n                  <svg class=\"cqa-api-edit-step-verification-delete-icon\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\"\n                    fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\" aria-hidden=\"true\">\n                    <path\n                      d=\"M10.6663 6V12.6667H5.33301V6H10.6663ZM9.66634 2H6.33301L5.66634 2.66667H3.33301V4H12.6663V2.66667H10.333L9.66634 2ZM11.9997 4.66667H3.99967V12.6667C3.99967 13.4 4.59967 14 5.33301 14H10.6663C11.3997 14 11.9997 13.4 11.9997 12.6667V4.66667Z\"\n                      fill=\"#F9BFBF\" />\n                  </svg>\n                </cqa-button>\n              </div>\n            </div>\n          </div>\n\n          <!-- Status tab content: S.no, Verification dropdown, Expected Value, add/remove rows -->\n          <div *ngIf=\"activeResponseVerificationTab === 'status'\" class=\"cqa-api-edit-step-step3-content\">\n            <div class=\"cqa-api-edit-step-verification-header-row\">\n              <span></span>\n              <cqa-button type=\"button\" variant=\"text\" text=\"Add Verification\"\n                customClass=\"cqa-api-edit-step-verification-add-link\" (clicked)=\"addStatusVerificationRow()\">\n              </cqa-button>\n            </div>\n            <div class=\"cqa-api-edit-step-status-verification\">\n              <div class=\"cqa-api-edit-step-status-verification-header\">\n                <span class=\"cqa-api-edit-step-verification-label\">S.no</span>\n                <span class=\"cqa-api-edit-step-verification-label\">Verification</span>\n                <span class=\"cqa-api-edit-step-verification-label\">Expected Value</span>\n                <span class=\"cqa-api-edit-step-verification-label cqa-api-edit-step-verification-label--empty\"\n                  aria-hidden=\"true\"></span>\n              </div>\n              <div *ngFor=\"let row of statusVerificationRows; let i = index; trackBy: trackByStatusVerification\"\n                [formGroup]=\"row\" class=\"cqa-api-edit-step-status-verification-row\">\n                <span class=\"cqa-api-edit-step-verification-sno\">{{ i + 1 }}</span>\n                <cqa-dynamic-select [form]=\"row\" [config]=\"statusVerificationSelectConfig\"\n                  class=\"cqa-api-edit-step-status-verification-select cqa-w-full\">\n                </cqa-dynamic-select>\n                <cqa-custom-input [value]=\"row.get('expectedValue')?.value ?? ''\"\n                  (valueChange)=\"row.get('expectedValue')?.setValue($event)\" placeholder=\"Expected Value\"\n                  type=\"number\" [fullWidth]=\"true\" size=\"sm\" class=\"cqa-api-edit-step-verification-input\"\n                  ariaLabel=\"Expected Value\">\n                </cqa-custom-input>\n                <cqa-button type=\"button\" variant=\"text\" [customClass]=\"'cqa-api-edit-step-verification-delete'\"\n                  [tooltip]=\"'Remove row'\" (clicked)=\"removeStatusVerificationRow(i)\">\n                  <svg class=\"cqa-api-edit-step-verification-delete-icon\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\"\n                    fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\" aria-hidden=\"true\">\n                    <path\n                      d=\"M10.6663 6V12.6667H5.33301V6H10.6663ZM9.66634 2H6.33301L5.66634 2.66667H3.33301V4H12.6663V2.66667H10.333L9.66634 2ZM11.9997 4.66667H3.99967V12.6667C3.99967 13.4 4.59967 14 5.33301 14H10.6663C11.3997 14 11.9997 13.4 11.9997 12.6667V4.66667Z\"\n                      fill=\"#F9BFBF\" />\n                  </svg>\n                </cqa-button>\n              </div>\n            </div>\n          </div>\n        </div>\n    </div>\n  </div>\n\n  <!-- Response Preview -->\n  <div class=\"cqa-api-edit-step-response\">\n    <h3 class=\"cqa-api-edit-step-response-title cqa-text-[14px] cqa-font-bold cqa-leading-[20px] cqa-text-[#111827] cqa-m-0 cqa-mb-[12px] cqa-shrink-0\">Response Preview</h3>\n    <pre class=\"cqa-api-edit-step-response-content\">{{ responsePreview }}</pre>\n  </div>\n\n  <!-- Step actions: one row, full width. Step 1: Cancel + Next; Step 2: Back + Next; Step 3: Back + Create -->\n  <div class=\"cqa-api-edit-step-actions\">\n    <ng-container [ngSwitch]=\"currentStep\">\n      <ng-container *ngSwitchCase=\"1\">\n        <cqa-button type=\"button\" variant=\"outlined\" btnSize=\"lg\" text=\"Cancel\"\n          customClass=\"cqa-api-edit-step-actions-btn-cancel\" (clicked)=\"onCancel()\">\n        </cqa-button>\n        <cqa-button type=\"button\" variant=\"filled\" btnSize=\"lg\" text=\"Next\"\n          customClass=\"cqa-api-edit-step-actions-btn-next\" (clicked)=\"onNext()\">\n        </cqa-button>\n      </ng-container>\n      <ng-container *ngSwitchCase=\"2\">\n        <cqa-button type=\"button\" variant=\"outlined\" btnSize=\"lg\" text=\"Back\"\n          customClass=\"cqa-api-edit-step-actions-btn-back\" (clicked)=\"onBack()\">\n        </cqa-button>\n        <cqa-button type=\"button\" variant=\"filled\" btnSize=\"lg\" text=\"Next\"\n          customClass=\"cqa-api-edit-step-actions-btn-next\" (clicked)=\"onNext()\">\n        </cqa-button>\n      </ng-container>\n      <ng-container *ngSwitchCase=\"3\">\n        <cqa-button type=\"button\" variant=\"outlined\" btnSize=\"lg\" text=\"Back\"\n          customClass=\"cqa-api-edit-step-actions-btn-back\" (clicked)=\"onBack()\">\n        </cqa-button>\n        <cqa-button type=\"button\" variant=\"filled\" btnSize=\"lg\" [text]=\"editMode ? 'Update' : 'Create'\"\n          customClass=\"cqa-api-edit-step-actions-btn-create\" (clicked)=\"onCreate()\">\n        </cqa-button>\n      </ng-container>\n    </ng-container>\n  </div>\n</div>"]}