@cqa-lib/cqa-ui 1.1.192 → 1.1.193

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.
Files changed (30) hide show
  1. package/esm2020/lib/autocomplete/autocomplete.component.mjs +156 -0
  2. package/esm2020/lib/autocomplete/autocomplete.model.mjs +2 -0
  3. package/esm2020/lib/test-case-details/condition-step/condition-step.component.mjs +505 -17
  4. package/esm2020/lib/test-case-details/delete-steps/delete-steps.component.mjs +32 -11
  5. package/esm2020/lib/test-case-details/loop-step/loop-step.component.mjs +131 -9
  6. package/esm2020/lib/test-case-details/step-details-drawer/step-details-drawer-data.mjs +67 -1
  7. package/esm2020/lib/test-case-details/step-details-drawer/step-details-drawer-field.config.mjs +66 -1
  8. package/esm2020/lib/test-case-details/step-details-drawer/step-details-drawer.component.mjs +112 -191
  9. package/esm2020/lib/test-case-details/step-group/step-group.component.mjs +31 -3
  10. package/esm2020/lib/test-case-details/test-case-details-renderer/test-case-details-renderer.component.mjs +114 -5
  11. package/esm2020/lib/ui-kit.module.mjs +6 -1
  12. package/esm2020/public-api.mjs +3 -1
  13. package/fesm2015/cqa-lib-cqa-ui.mjs +1423 -444
  14. package/fesm2015/cqa-lib-cqa-ui.mjs.map +1 -1
  15. package/fesm2020/cqa-lib-cqa-ui.mjs +1415 -440
  16. package/fesm2020/cqa-lib-cqa-ui.mjs.map +1 -1
  17. package/lib/autocomplete/autocomplete.component.d.ts +48 -0
  18. package/lib/autocomplete/autocomplete.model.d.ts +10 -0
  19. package/lib/test-case-details/condition-step/condition-step.component.d.ts +73 -4
  20. package/lib/test-case-details/delete-steps/delete-steps.component.d.ts +18 -2
  21. package/lib/test-case-details/loop-step/loop-step.component.d.ts +34 -4
  22. package/lib/test-case-details/step-details-drawer/step-details-drawer-data.d.ts +56 -0
  23. package/lib/test-case-details/step-details-drawer/step-details-drawer-field.config.d.ts +6 -0
  24. package/lib/test-case-details/step-details-drawer/step-details-drawer.component.d.ts +33 -27
  25. package/lib/test-case-details/step-group/step-group.component.d.ts +15 -1
  26. package/lib/test-case-details/test-case-details-renderer/test-case-details-renderer.component.d.ts +27 -4
  27. package/lib/ui-kit.module.d.ts +127 -126
  28. package/package.json +1 -1
  29. package/public-api.d.ts +2 -0
  30. package/styles.css +1 -1
@@ -1,37 +1,65 @@
1
1
  import { Component, Input, Output, EventEmitter } from '@angular/core';
2
+ import { FormControl } from '@angular/forms';
2
3
  import { StepTypes } from '../test-case-step.models';
3
4
  import { STEP_ROW_ACTIONS_STYLES } from '../step-row-actions.styles';
4
5
  import * as i0 from "@angular/core";
5
6
  import * as i1 from "@angular/forms";
6
- import * as i2 from "../../custom-input/custom-input.component";
7
- import * as i3 from "../../dynamic-select/dynamic-select-field.component";
8
- import * as i4 from "../../button/button.component";
9
- import * as i5 from "../test-case-details-renderer/test-case-details-renderer.component";
10
- import * as i6 from "@angular/common";
11
- import * as i7 from "ngx-drag-drop";
7
+ import * as i2 from "../../autocomplete/autocomplete.component";
8
+ import * as i3 from "@angular/material/slide-toggle";
9
+ import * as i4 from "../../dynamic-select/dynamic-select-field.component";
10
+ import * as i5 from "../../custom-input/custom-input.component";
11
+ import * as i6 from "../../button/button.component";
12
+ import * as i7 from "../test-case-details-renderer/test-case-details-renderer.component";
13
+ import * as i8 from "@angular/common";
14
+ import * as i9 from "ngx-drag-drop";
12
15
  export class TestCaseConditionStepComponent {
13
- constructor(fb) {
16
+ constructor(fb, cdr) {
14
17
  this.fb = fb;
18
+ this.cdr = cdr;
15
19
  this.branches = [];
16
20
  this.expanded = true;
17
21
  this.isNested = false;
18
22
  this.isInsideLoop = false;
19
23
  this.isReorder = false;
24
+ /** Options for the data profile dropdown */
25
+ this.dataProfileOptions = [];
26
+ /** Indicates if more data profiles are available for loading */
27
+ this.hasMoreDataProfiles = false;
28
+ /** Loading state for data profiles */
29
+ this.isLoadingDataProfiles = false;
30
+ /** Natural text actions options for while loop condition */
31
+ this.naturalTextActionsOptions = [];
32
+ /** Function to process template variables (similar to step-builder-condition) */
33
+ this.setConditionTemplateVariables = () => [];
20
34
  /** When true, header shows inline edit form (fields, operator select, Cancel/Apply) */
21
35
  this.isEditing = false;
36
+ /** Array of ELSE IF branches in edit mode */
37
+ this.elseIfBranches = [];
22
38
  /** Snapshot for Cancel revert */
23
39
  this.editSnapshot = {};
40
+ /** Selected template for IF condition */
41
+ this.selectedTemplate = null;
42
+ /** Template variables for IF condition */
43
+ this.templateVariables = [];
24
44
  this.toggleExpanded = new EventEmitter();
25
45
  this.conditionChange = new EventEmitter();
26
46
  this.branchStepChange = new EventEmitter();
27
47
  this.addStep = new EventEmitter();
28
48
  this.deleteStep = new EventEmitter();
29
49
  this.addBranch = new EventEmitter();
50
+ /** Emitted when user clicks "Add Else" so the parent can call POST test_steps with conditionType CONDITION_ELSE */
51
+ this.addElse = new EventEmitter();
30
52
  this.deleteBranch = new EventEmitter();
31
53
  this.duplicate = new EventEmitter();
32
54
  this.delete = new EventEmitter();
33
55
  this.moreOptions = new EventEmitter();
34
56
  this.dndDropInZone = new EventEmitter();
57
+ /** Emit when more data profiles need to be loaded */
58
+ this.loadMoreDataProfiles = new EventEmitter();
59
+ /** Emit when data profile search query changes */
60
+ this.searchDataProfiles = new EventEmitter();
61
+ /** Emit when a nested step is updated (e.g., Apply button clicked in loop-step edit mode) */
62
+ this.stepUpdate = new EventEmitter();
35
63
  }
36
64
  onDndDrop(event, branch) {
37
65
  this.dndDropInZone.emit({ event, targetList: branch.nestedSteps });
@@ -46,14 +74,101 @@ export class TestCaseConditionStepComponent {
46
74
  }
47
75
  this.buildEditForm();
48
76
  this.buildOperatorSelectConfig();
77
+ this.updateConditionLeftSelectConfig();
78
+ }
79
+ ngOnChanges(changes) {
80
+ if (changes['naturalTextActionsOptions']) {
81
+ this.updateConditionLeftSelectConfig();
82
+ // Rebuild form when options are loaded to populate initial value from naturalTextActionId
83
+ if (this.editForm && this.naturalTextActionsOptions && this.naturalTextActionsOptions.length > 0) {
84
+ this.rebuildEditFormWithNaturalTextAction();
85
+ }
86
+ }
87
+ }
88
+ /** Rebuild edit form when naturalTextActionsOptions are loaded to populate from naturalTextActionId */
89
+ rebuildEditFormWithNaturalTextAction() {
90
+ if (!this.editForm) {
91
+ return;
92
+ }
93
+ const configWithId = this.config;
94
+ if (configWithId.naturalTextActionId && this.naturalTextActionsOptions && this.naturalTextActionsOptions.length > 0) {
95
+ const matchingOption = this.naturalTextActionsOptions.find((option) => String(option.id) === String(configWithId.naturalTextActionId));
96
+ if (matchingOption) {
97
+ const naturalText = matchingOption.naturalText ?? matchingOption.name ?? matchingOption.value ?? '';
98
+ if (naturalText) {
99
+ const currentValue = this.editForm.get('conditionLeft')?.value ?? '';
100
+ // Only update if current value is empty or doesn't match
101
+ if (!currentValue || currentValue !== naturalText) {
102
+ this.editForm.get('conditionLeft')?.setValue(naturalText);
103
+ }
104
+ }
105
+ // Get the full template object (NaturalTextActions) from the option
106
+ const fullTemplate = matchingOption.template || matchingOption;
107
+ // Store selected template and get variables
108
+ this.selectedTemplate = fullTemplate;
109
+ if (fullTemplate && fullTemplate.variables) {
110
+ this.templateVariables = this.setConditionTemplateVariables(fullTemplate);
111
+ this.buildTemplateVariablesForm();
112
+ }
113
+ }
114
+ }
49
115
  }
50
116
  buildEditForm() {
51
- const { left, operator, right } = this.parseCondition(this.condition);
117
+ // If config has naturalTextActionId, find the matching natural text action
118
+ let conditionLeftValue = '';
119
+ const configWithId = this.config;
120
+ if (configWithId.naturalTextActionId && this.naturalTextActionsOptions && this.naturalTextActionsOptions.length > 0) {
121
+ const matchingOption = this.naturalTextActionsOptions.find((option) => String(option.id) === String(configWithId.naturalTextActionId));
122
+ if (matchingOption) {
123
+ // Use naturalText exactly as received from API
124
+ conditionLeftValue = matchingOption.naturalText ?? matchingOption.name ?? matchingOption.value ?? '';
125
+ // Get the full template object (NaturalTextActions) from the option
126
+ const fullTemplate = matchingOption.template || matchingOption;
127
+ // Store selected template and get variables
128
+ this.selectedTemplate = fullTemplate;
129
+ if (fullTemplate && fullTemplate.variables) {
130
+ this.templateVariables = this.setConditionTemplateVariables(fullTemplate);
131
+ this.buildTemplateVariablesForm();
132
+ }
133
+ }
134
+ }
135
+ // If no naturalTextActionId match found, parse from condition string
136
+ if (!conditionLeftValue) {
137
+ const { left } = this.parseCondition(this.condition);
138
+ conditionLeftValue = left;
139
+ }
140
+ const { operator, right } = this.parseCondition(this.condition);
52
141
  this.editForm = this.fb.group({
142
+ conditionLeft: [conditionLeftValue],
143
+ conditionOperator: [operator],
144
+ conditionRight: [right],
145
+ });
146
+ // Initialize template variables form if not already initialized
147
+ if (!this.templateVariablesForm) {
148
+ this.templateVariablesForm = this.fb.group({});
149
+ }
150
+ }
151
+ buildElseIfBranch(index) {
152
+ // Initialize ELSE IF form with empty values or from existing ELSE IF branch if available
153
+ const elseIfBranches = this.branches?.filter(b => b.type === 'else-if') || [];
154
+ const branchIndex = index !== undefined ? index : elseIfBranches.length;
155
+ const elseIfBranch = elseIfBranches[branchIndex];
156
+ const elseCondition = elseIfBranch?.action || '';
157
+ const { left, operator, right } = this.parseCondition(elseCondition);
158
+ const form = this.fb.group({
53
159
  conditionLeft: [left],
54
160
  conditionOperator: [operator],
55
161
  conditionRight: [right],
56
162
  });
163
+ const templateVariablesForm = this.fb.group({});
164
+ return {
165
+ id: `else-if-${Date.now()}-${Math.random()}`,
166
+ form,
167
+ selectedTemplate: null,
168
+ templateVariables: [],
169
+ templateVariablesForm,
170
+ snapshot: { conditionLeft: left, conditionOperator: operator, conditionRight: right }
171
+ };
57
172
  }
58
173
  buildOperatorSelectConfig() {
59
174
  const options = [
@@ -71,6 +186,186 @@ export class TestCaseConditionStepComponent {
71
186
  options,
72
187
  };
73
188
  }
189
+ /** Update condition left select config with filtered natural text actions (IF_CONDITION only) */
190
+ updateConditionLeftSelectConfig() {
191
+ // Filter natural text actions to only include those with stepActionType === "IF_CONDITION"
192
+ const filteredOptions = (this.naturalTextActionsOptions || []).filter((option) => {
193
+ return option.stepActionType === 'IF_CONDITION';
194
+ });
195
+ this.conditionLeftSelectConfig = {
196
+ key: 'conditionLeft',
197
+ placeholder: 'Select condition',
198
+ searchable: true,
199
+ options: filteredOptions,
200
+ };
201
+ }
202
+ /** Options for the condition left autocomplete (IF_CONDITION natural text actions) */
203
+ get conditionLeftAutocompleteOptions() {
204
+ const opts = this.conditionLeftSelectConfig?.options ?? [];
205
+ return opts.map((option) => {
206
+ // Use naturalText exactly as received from API, fallback to name/value/id
207
+ const naturalText = option.naturalText ?? option.name ?? option.value ?? String(option.id ?? '');
208
+ return {
209
+ value: naturalText,
210
+ label: naturalText,
211
+ // Store the full template object (NaturalTextActions) for template variables processing
212
+ // Use option.template if available (full NaturalTextActions), otherwise use option itself
213
+ template: option.template || option,
214
+ };
215
+ });
216
+ }
217
+ onConditionLeftSelect(option) {
218
+ this.editForm?.get('conditionLeft')?.setValue(option.value);
219
+ // Get template from option - option.template should contain the full NaturalTextActions object
220
+ const matchingTemplate = option.template;
221
+ // If template not in option, try to find from naturalTextActionsOptions by matching naturalText
222
+ let fullTemplate = matchingTemplate;
223
+ if (!fullTemplate || !fullTemplate.variables) {
224
+ const matchingOption = this.naturalTextActionsOptions.find((opt) => opt.naturalText === option.value || opt.name === option.value || opt.value === option.value);
225
+ // Use template property from option if available, otherwise use the option itself
226
+ fullTemplate = matchingOption?.template || matchingOption;
227
+ }
228
+ if (fullTemplate && fullTemplate.variables) {
229
+ // Store the full template for reference
230
+ this.selectedTemplate = fullTemplate;
231
+ // Get template variables using the provided function
232
+ // Pass the full NaturalTextActions object which has the variables property
233
+ const variables = this.setConditionTemplateVariables(fullTemplate);
234
+ console.log('Template variables loaded:', variables, 'from template:', fullTemplate);
235
+ this.templateVariables = variables || [];
236
+ // Build form for template variables
237
+ this.buildTemplateVariablesForm();
238
+ // Trigger change detection to update the template
239
+ this.cdr.detectChanges();
240
+ }
241
+ else {
242
+ console.log('No matching template found or template has no variables', {
243
+ fullTemplate,
244
+ hasVariables: fullTemplate?.variables,
245
+ optionValue: option.value,
246
+ optionTemplate: option.template
247
+ });
248
+ this.selectedTemplate = null;
249
+ this.templateVariables = [];
250
+ if (!this.templateVariablesForm) {
251
+ this.templateVariablesForm = this.fb.group({});
252
+ }
253
+ // Trigger change detection to update the template
254
+ this.cdr.detectChanges();
255
+ }
256
+ }
257
+ buildTemplateVariablesForm() {
258
+ if (!this.templateVariablesForm) {
259
+ this.templateVariablesForm = this.fb.group({});
260
+ }
261
+ // Clear existing form controls
262
+ Object.keys(this.templateVariablesForm.controls).forEach(key => {
263
+ this.templateVariablesForm.removeControl(key);
264
+ });
265
+ // Get existing template variables data from config if available
266
+ const configWithData = this.config;
267
+ const existingData = configWithData.templateVariablesData || {};
268
+ // Add form controls for each variable
269
+ this.templateVariables.forEach(variable => {
270
+ // Try to get value from existing data first, then from variable default
271
+ let defaultValue;
272
+ if (existingData.hasOwnProperty(variable.name)) {
273
+ defaultValue = existingData[variable.name];
274
+ }
275
+ else {
276
+ defaultValue = variable.type === 'boolean'
277
+ ? (variable.value === true || variable.value === 'true' || variable.value === 1)
278
+ : (variable.value || '');
279
+ }
280
+ // Convert boolean string to boolean
281
+ if (variable.type === 'boolean' && typeof defaultValue === 'string') {
282
+ defaultValue = defaultValue === 'true' || defaultValue === '1';
283
+ }
284
+ this.templateVariablesForm.addControl(variable.name, new FormControl(defaultValue));
285
+ });
286
+ }
287
+ onElseConditionLeftSelect(option, branchId) {
288
+ const branch = this.elseIfBranches.find(b => b.id === branchId);
289
+ if (!branch)
290
+ return;
291
+ branch.form?.get('conditionLeft')?.setValue(option.value);
292
+ // Get template from option - option.template should contain the full NaturalTextActions object
293
+ const matchingTemplate = option.template;
294
+ // If template not in option, try to find from naturalTextActionsOptions by matching naturalText
295
+ let fullTemplate = matchingTemplate;
296
+ if (!fullTemplate || !fullTemplate.variables) {
297
+ const matchingOption = this.naturalTextActionsOptions.find((opt) => opt.naturalText === option.value || opt.name === option.value || opt.value === option.value);
298
+ // Use template property from option if available, otherwise use the option itself
299
+ fullTemplate = matchingOption?.template || matchingOption;
300
+ }
301
+ if (fullTemplate && fullTemplate.variables) {
302
+ // Store the full template for reference
303
+ branch.selectedTemplate = fullTemplate;
304
+ // Get template variables using the provided function
305
+ branch.templateVariables = this.setConditionTemplateVariables(fullTemplate);
306
+ // Build form for template variables
307
+ this.buildElseTemplateVariablesForm(branch);
308
+ // Trigger change detection to update the template
309
+ this.cdr.detectChanges();
310
+ }
311
+ else {
312
+ branch.selectedTemplate = null;
313
+ branch.templateVariables = [];
314
+ if (!branch.templateVariablesForm) {
315
+ branch.templateVariablesForm = this.fb.group({});
316
+ }
317
+ // Trigger change detection to update the template
318
+ this.cdr.detectChanges();
319
+ }
320
+ }
321
+ buildElseTemplateVariablesForm(branch) {
322
+ if (!branch.templateVariablesForm) {
323
+ branch.templateVariablesForm = this.fb.group({});
324
+ }
325
+ // Clear existing form controls
326
+ Object.keys(branch.templateVariablesForm.controls).forEach(key => {
327
+ branch.templateVariablesForm.removeControl(key);
328
+ });
329
+ // Get existing template variables data from config if available (for ELSE IF branch)
330
+ const configWithData = this.config;
331
+ const existingData = configWithData.elseTemplateVariablesData || {};
332
+ // Add form controls for each variable
333
+ branch.templateVariables.forEach(variable => {
334
+ // Try to get value from existing data first, then from variable default
335
+ let defaultValue;
336
+ if (existingData.hasOwnProperty(variable.name)) {
337
+ defaultValue = existingData[variable.name];
338
+ }
339
+ else {
340
+ defaultValue = variable.type === 'boolean'
341
+ ? (variable.value === true || variable.value === 'true' || variable.value === 1)
342
+ : (variable.value || '');
343
+ }
344
+ // Convert boolean string to boolean
345
+ if (variable.type === 'boolean' && typeof defaultValue === 'string') {
346
+ defaultValue = defaultValue === 'true' || defaultValue === '1';
347
+ }
348
+ branch.templateVariablesForm.addControl(variable.name, new FormControl(defaultValue));
349
+ });
350
+ }
351
+ onAddElse() {
352
+ // Add a new ELSE IF branch (UI row only; APIs are called when user clicks Apply)
353
+ const newBranch = this.buildElseIfBranch();
354
+ this.elseIfBranches.push(newBranch);
355
+ }
356
+ onAddElseBranch() {
357
+ // Emit so parent can call POST test_steps with conditionType CONDITION_ELSE
358
+ if (this.config) {
359
+ this.addElse.emit({ conditionStepConfig: this.config });
360
+ }
361
+ }
362
+ onRemoveElse(branchId) {
363
+ // Remove the ELSE IF branch with the given ID
364
+ const index = this.elseIfBranches.findIndex(b => b.id === branchId);
365
+ if (index !== -1) {
366
+ this.elseIfBranches.splice(index, 1);
367
+ }
368
+ }
74
369
  /** Parse condition string into left, operator, right (e.g. "Usertype is Premium") */
75
370
  parseCondition(c) {
76
371
  if (!c || typeof c !== 'string') {
@@ -92,9 +387,29 @@ export class TestCaseConditionStepComponent {
92
387
  }
93
388
  /** Build condition string from form values */
94
389
  buildConditionFromForm() {
95
- const left = this.editForm.get('conditionLeft')?.value ?? '';
390
+ let left = this.editForm.get('conditionLeft')?.value ?? '';
96
391
  const op = this.editForm.get('conditionOperator')?.value ?? 'is';
97
392
  const right = this.editForm.get('conditionRight')?.value ?? '';
393
+ // If left is an ID (number), find the naturalText from options
394
+ if (left && this.naturalTextActionsOptions && this.naturalTextActionsOptions.length > 0) {
395
+ const leftValue = String(left);
396
+ // Check if it's a number (ID) or if we need to find the naturalText
397
+ const isNumericId = !isNaN(Number(leftValue)) && leftValue.trim() !== '';
398
+ if (isNumericId) {
399
+ // Find the option by ID and use its naturalText
400
+ const selectedAction = this.naturalTextActionsOptions.find((option) => String(option.id) === leftValue);
401
+ if (selectedAction && selectedAction.naturalText) {
402
+ left = String(selectedAction.naturalText);
403
+ }
404
+ }
405
+ else {
406
+ // Check if it's already a naturalText or needs to be found
407
+ const selectedAction = this.naturalTextActionsOptions.find((option) => option.naturalText === left || option.name === left || option.value === left);
408
+ if (selectedAction && selectedAction.naturalText) {
409
+ left = String(selectedAction.naturalText);
410
+ }
411
+ }
412
+ }
98
413
  return [left, op, right].filter(Boolean).join(' ');
99
414
  }
100
415
  onEditFormFieldChange(controlName, value) {
@@ -220,21 +535,146 @@ export class TestCaseConditionStepComponent {
220
535
  conditionOperator: this.editForm?.get('conditionOperator')?.value,
221
536
  conditionRight: this.editForm?.get('conditionRight')?.value,
222
537
  };
223
- const { left, operator, right } = this.parseCondition(this.condition);
224
- this.editForm?.get('conditionLeft')?.setValue(left);
538
+ // If config has naturalTextActionId, find the matching natural text action
539
+ let conditionLeftValue = '';
540
+ const configWithId = this.config;
541
+ if (configWithId.naturalTextActionId && this.naturalTextActionsOptions && this.naturalTextActionsOptions.length > 0) {
542
+ const matchingAction = this.naturalTextActionsOptions.find((option) => String(option.id) === String(configWithId.naturalTextActionId));
543
+ if (matchingAction) {
544
+ // Use naturalText exactly as received from API
545
+ conditionLeftValue = matchingAction.naturalText ?? matchingAction.name ?? matchingAction.value ?? '';
546
+ }
547
+ }
548
+ // If no naturalTextActionId match found, parse from condition string
549
+ if (!conditionLeftValue) {
550
+ const { left } = this.parseCondition(this.condition);
551
+ conditionLeftValue = left;
552
+ }
553
+ const { operator, right } = this.parseCondition(this.condition);
554
+ this.editForm?.get('conditionLeft')?.setValue(conditionLeftValue);
225
555
  this.editForm?.get('conditionOperator')?.setValue(operator);
226
556
  this.editForm?.get('conditionRight')?.setValue(right);
227
557
  this.isEditing = true;
558
+ // Do not pre-populate ELSE IF branches in edit mode; they are shown only when user clicks "Add ELSE IF"
559
+ this.elseIfBranches = [];
228
560
  }
229
561
  onEditCancel() {
230
562
  this.editForm?.get('conditionLeft')?.setValue(this.editSnapshot.conditionLeft ?? '');
231
563
  this.editForm?.get('conditionOperator')?.setValue(this.editSnapshot.conditionOperator ?? 'is');
232
564
  this.editForm?.get('conditionRight')?.setValue(this.editSnapshot.conditionRight ?? '');
565
+ // Reset all ELSE IF branches to their snapshots
566
+ this.elseIfBranches.forEach(branch => {
567
+ branch.form?.get('conditionLeft')?.setValue(branch.snapshot.conditionLeft ?? '');
568
+ branch.form?.get('conditionOperator')?.setValue(branch.snapshot.conditionOperator ?? 'is');
569
+ branch.form?.get('conditionRight')?.setValue(branch.snapshot.conditionRight ?? '');
570
+ });
571
+ // Clear all ELSE IF branches
572
+ this.elseIfBranches = [];
233
573
  this.isEditing = false;
234
574
  }
575
+ /**
576
+ * Build payload for one ELSE IF branch (action, naturalTextActionId, templateVariablesData, testDataList)
577
+ * so the parent can create the step via POST then PUT when Apply is clicked.
578
+ */
579
+ buildElseIfBranchPayload(branch) {
580
+ const conditionLeft = branch.form?.get('conditionLeft')?.value ?? '';
581
+ const conditionOperator = branch.form?.get('conditionOperator')?.value ?? 'is';
582
+ const conditionRight = branch.form?.get('conditionRight')?.value ?? '';
583
+ let naturalTextActionId;
584
+ let naturalTextValue = conditionLeft;
585
+ if (conditionLeft && this.naturalTextActionsOptions && this.naturalTextActionsOptions.length > 0) {
586
+ const leftValue = String(conditionLeft);
587
+ const isNumericId = !isNaN(Number(leftValue)) && leftValue.trim() !== '';
588
+ const selectedAction = isNumericId
589
+ ? this.naturalTextActionsOptions.find((opt) => String(opt.id) === leftValue)
590
+ : this.naturalTextActionsOptions.find((opt) => opt.naturalText === conditionLeft || opt.name === conditionLeft || opt.value === conditionLeft);
591
+ if (selectedAction) {
592
+ naturalTextActionId = selectedAction.id;
593
+ naturalTextValue = selectedAction.naturalText || selectedAction.name || selectedAction.value || conditionLeft;
594
+ }
595
+ }
596
+ const templateVariablesData = {};
597
+ const testDataList = [];
598
+ if (branch.templateVariablesForm && branch.templateVariables && branch.templateVariables.length > 0) {
599
+ branch.templateVariables.forEach((variable) => {
600
+ const value = branch.templateVariablesForm.get(variable.name)?.value;
601
+ if (value !== undefined && value !== null && value !== '') {
602
+ templateVariablesData[variable.name] = value;
603
+ testDataList.push({ testData: String(value), testDataType: 'raw' });
604
+ }
605
+ });
606
+ }
607
+ const action = [naturalTextValue, conditionOperator, conditionRight].filter(Boolean).join(' ');
608
+ return {
609
+ action: action || (branch.selectedTemplate?.naturalText ?? ''),
610
+ ...(naturalTextActionId !== undefined && { naturalTextActionId }),
611
+ ...(Object.keys(templateVariablesData).length > 0 && { templateVariablesData }),
612
+ ...(testDataList.length > 0 && { testDataList }),
613
+ };
614
+ }
235
615
  onEditApply() {
236
- this.condition = this.buildConditionFromForm();
616
+ const formValues = this.editForm.value;
617
+ const conditionLeft = formValues.conditionLeft ?? '';
618
+ const conditionOperator = formValues.conditionOperator ?? 'is';
619
+ const conditionRight = formValues.conditionRight ?? '';
620
+ // Find the selected natural text action and get naturalText (not ID)
621
+ let naturalTextActionId;
622
+ let naturalTextValue = conditionLeft; // Default to conditionLeft
623
+ if (conditionLeft && this.naturalTextActionsOptions && this.naturalTextActionsOptions.length > 0) {
624
+ const leftValue = String(conditionLeft);
625
+ const isNumericId = !isNaN(Number(leftValue)) && leftValue.trim() !== '';
626
+ let selectedAction;
627
+ if (isNumericId) {
628
+ // Find by ID and get naturalText
629
+ selectedAction = this.naturalTextActionsOptions.find((option) => String(option.id) === leftValue);
630
+ }
631
+ else {
632
+ // Find by naturalText, name, or value
633
+ selectedAction = this.naturalTextActionsOptions.find((option) => option.naturalText === conditionLeft || option.name === conditionLeft || option.value === conditionLeft);
634
+ }
635
+ if (selectedAction) {
636
+ naturalTextActionId = selectedAction.id;
637
+ // Use naturalText if available, otherwise fall back to name or value
638
+ naturalTextValue = selectedAction.naturalText || selectedAction.name || selectedAction.value || conditionLeft;
639
+ }
640
+ }
641
+ // Collect template variables values for event object
642
+ const templateVariablesData = {};
643
+ // Build testDataList array in the order of template variables
644
+ const testDataList = [];
645
+ if (this.templateVariablesForm && this.templateVariables.length > 0) {
646
+ this.templateVariables.forEach(variable => {
647
+ const value = this.templateVariablesForm.get(variable.name)?.value;
648
+ if (value !== undefined && value !== null && value !== '') {
649
+ // Add to event object (e.g., source_value, target_value)
650
+ templateVariablesData[variable.name] = value;
651
+ // Add to testDataList array (order matters - maintain template variable order)
652
+ testDataList.push({
653
+ testData: String(value),
654
+ testDataType: 'raw'
655
+ });
656
+ }
657
+ });
658
+ }
659
+ // Build condition string using naturalText (not ID)
660
+ this.condition = [naturalTextValue, conditionOperator, conditionRight].filter(Boolean).join(' ');
661
+ // Build payload for each newly added ELSE IF (so parent can call POST then PUT when Apply is clicked)
662
+ const newElseIfBranches = this.elseIfBranches.map(b => this.buildElseIfBranchPayload(b));
663
+ // Update config with new values
664
+ const updatedConfig = {
665
+ ...this.config,
666
+ condition: this.condition,
667
+ stepType: this.config.stepType || StepTypes.CONDITION_IF,
668
+ ...(naturalTextActionId !== undefined && { naturalTextActionId }),
669
+ ...(Object.keys(templateVariablesData).length > 0 && { templateVariablesData }),
670
+ ...(testDataList.length > 0 && { testDataList }),
671
+ ...(newElseIfBranches.length > 0 && { newElseIfBranches }),
672
+ };
673
+ // Emit individual change event
237
674
  this.conditionChange.emit(this.condition);
675
+ // Emit step update event with full config (includes newElseIfBranches so parent can create steps on Apply)
676
+ console.log('Condition-step: Emitting stepUpdate event', updatedConfig);
677
+ this.stepUpdate.emit(updatedConfig);
238
678
  this.isEditing = false;
239
679
  }
240
680
  onEditInDepth() {
@@ -252,13 +692,43 @@ export class TestCaseConditionStepComponent {
252
692
  onMoreOptions() {
253
693
  this.moreOptions.emit();
254
694
  }
695
+ /** Get select config for a template variable */
696
+ getSelectConfigForVariable(variable, branchIdOrIsElse = false) {
697
+ const options = (variable.options || []).map((opt) => ({
698
+ id: opt,
699
+ value: opt,
700
+ name: opt,
701
+ label: opt
702
+ }));
703
+ // If branchIdOrIsElse is a string, it's a branch ID; otherwise it's a boolean for backward compatibility
704
+ let form;
705
+ if (typeof branchIdOrIsElse === 'string') {
706
+ const branch = this.elseIfBranches.find(b => b.id === branchIdOrIsElse);
707
+ form = branch?.templateVariablesForm || this.fb.group({});
708
+ }
709
+ else {
710
+ form = branchIdOrIsElse ? (this.elseIfBranches[0]?.templateVariablesForm || this.fb.group({})) : this.templateVariablesForm;
711
+ }
712
+ return {
713
+ key: variable.name,
714
+ placeholder: `Select ${variable.label}`,
715
+ multiple: false,
716
+ searchable: false,
717
+ options: options,
718
+ onChange: (value) => {
719
+ if (form && form.get(variable.name)) {
720
+ form.get(variable.name)?.setValue(value);
721
+ }
722
+ }
723
+ };
724
+ }
255
725
  }
256
- TestCaseConditionStepComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: TestCaseConditionStepComponent, deps: [{ token: i1.FormBuilder }], target: i0.ɵɵFactoryTarget.Component });
257
- TestCaseConditionStepComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.4.0", type: TestCaseConditionStepComponent, selector: "cqa-test-case-condition-step", inputs: { config: "config", id: "id", stepNumber: "stepNumber", condition: "condition", branches: "branches", expanded: "expanded", isNested: "isNested", isInsideLoop: "isInsideLoop", isReorder: "isReorder" }, outputs: { toggleExpanded: "toggleExpanded", conditionChange: "conditionChange", branchStepChange: "branchStepChange", addStep: "addStep", deleteStep: "deleteStep", addBranch: "addBranch", deleteBranch: "deleteBranch", duplicate: "duplicate", delete: "delete", moreOptions: "moreOptions", dndDropInZone: "dndDropInZone" }, host: { classAttribute: "cqa-ui-root" }, ngImport: i0, template: "<div [class]=\"'cqa-flex cqa-flex-col cqa-border cqa-border-solid cqa-border-[#E5E7EB] ' + (isNested ? ' cqa-pl-[24px]' : '')\">\n <!-- Inline Edit Mode: CONDITION tag, three fields, IF/ELSE chips, Edit In depth, Cancel/Apply -->\n <div *ngIf=\"isEditing\" class=\"cqa-py-2.5 cqa-px-4 cqa-flex cqa-items-center cqa-gap-3 cqa-justify-between\">\n <div class=\"cqa-flex cqa-items-center cqa-gap-3 cqa-flex-grow\">\n <!-- CONDITION Tag (orange) -->\n <span class=\"cqa-px-1.5 cqa-rounded-md cqa-text-[#EA580C] cqa-text-[10px] cqa-leading-[15px] cqa-font-medium cqa-bg-[#FFEDD5]\">\n CONDITION\n </span>\n\n <!-- First field: left operand (e.g. Usertype) -->\n <cqa-custom-input\n [value]=\"editForm.get('conditionLeft')?.value ?? ''\"\n (valueChange)=\"onEditFormFieldChange('conditionLeft', $event)\"\n placeholder=\"Usertype\"\n class=\"cqa-w-full cqa-max-w-[216px]\"\n size=\"sm\">\n </cqa-custom-input>\n\n <!-- Operator: dynamic-select (IS, IS NOT, etc.) -->\n <cqa-dynamic-select [form]=\"editForm\" [config]=\"operatorSelectConfig\" class=\"cqa-w-full cqa-max-w-[216px]\"></cqa-dynamic-select>\n\n <!-- Third field: right operand (e.g. Premium) -->\n <cqa-custom-input\n [value]=\"editForm.get('conditionRight')?.value ?? ''\"\n (valueChange)=\"onEditFormFieldChange('conditionRight', $event)\"\n placeholder=\"Premium\"\n class=\"cqa-w-full cqa-max-w-[216px]\"\n size=\"sm\">\n </cqa-custom-input>\n\n <!-- IF / ELSE indicators -->\n <span class=\"cqa-px-2 cqa-py-[2px] cqa-rounded-[4px] cqa-text-[8px] cqa-leading-[12px] cqa-bg-[#DCFCE7] cqa-text-[#008236] cqa-border cqa-border-solid cqa-border-[#B9F8CF] cqa-flex cqa-items-center cqa-gap-1.5\">\n <svg width=\"8\" height=\"8\" viewBox=\"0 0 8 8\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M6.66634 2L2.99967 5.66667L1.33301 4\" stroke=\"#008236\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/></svg>\n IF\n </span>\n <span class=\"cqa-px-2 cqa-py-[2px] cqa-rounded-[4px] cqa-text-[8px] cqa-leading-[12px] cqa-bg-[#F3F4F6] cqa-text-[#99A1AF] cqa-border cqa-border-solid cqa-border-[#E5E7EB] cqa-flex cqa-items-center cqa-gap-1.5\">\n Add ELSE\n </span>\n\n <!-- Edit In depth link -->\n <a href=\"#\" (click)=\"onEditInDepth(); $event.preventDefault()\"\n class=\"cqa-text-[#3F43EE] cqa-text-[10px] cqa-leading-[15px] cqa-font-medium cqa-flex cqa-items-center cqa-gap-[2px] cqa-no-underline\">\n Edit In depth\n <svg width=\"8\" height=\"8\" viewBox=\"0 0 8 8\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M2.03809 6.74329L2.62809 7.33329L5.96142 3.99996L2.62809 0.666626L2.03809 1.25663L4.78142 3.99996L2.03809 6.74329Z\" fill=\"#3F43EE\"/></svg>\n </a> \n </div>\n <!-- Cancel / Apply -->\n <cqa-button variant=\"outlined\" btnSize=\"lg\" [customClass]=\"'cqa-text-[14px] cqa-py-[9px]'\" [text]=\"'Cancel'\" (clicked)=\"onEditCancel()\"></cqa-button>\n <cqa-button variant=\"filled\" btnSize=\"lg\" [customClass]=\"'cqa-text-[14px] cqa-py-[9px]'\" [text]=\"'Apply'\" (clicked)=\"onEditApply()\"></cqa-button>\n </div>\n\n <!-- Condition Header (normal view when not editing) -->\n <div *ngIf=\"!isEditing\" [class]=\"'step-row cqa-flex cqa-items-center cqa-gap-3 cqa-py-2 ' + (isInsideLoop ? 'cqa-pl-10 cqa-pr-4' : 'cqa-px-4')\">\n <!-- Expand/Collapse Icon -->\n <button type=\"button\" (click)=\"onToggleExpanded()\" class=\"cqa-p-0\">\n <svg [class.cqa-rotate-180]=\"!expanded\" class=\"cqa-transition-transform\" width=\"16\" height=\"16\"\n viewBox=\"0 0 16 16\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n <path d=\"M12 10L8 6L4 10\" stroke=\"#6B7280\" stroke-width=\"1.33333\" stroke-linecap=\"round\"\n stroke-linejoin=\"round\" />\n </svg>\n </button>\n\n <!-- IF/ELSE Icon -->\n <div><svg width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n <path d=\"M4 2V10\" stroke=\"#7B3306\" stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n <path\n d=\"M12 6C13.1046 6 14 5.10457 14 4C14 2.89543 13.1046 2 12 2C10.8954 2 10 2.89543 10 4C10 5.10457 10.8954 6 12 6Z\"\n stroke=\"#7B3306\" stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n <path\n d=\"M4 14C5.10457 14 6 13.1046 6 12C6 10.8954 5.10457 10 4 10C2.89543 10 2 10.8954 2 12C2 13.1046 2.89543 14 4 14Z\"\n stroke=\"#7B3306\" stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n <path d=\"M12 6C12 7.5913 11.3679 9.11742 10.2426 10.2426C9.11742 11.3679 7.5913 12 6 12\" stroke=\"#7B3306\"\n stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n </svg></div>\n\n <!-- IF/ELSE Label -->\n <span class=\"cqa-font-semibold cqa-text-[#7B3306] cqa-text-[12px] cqa-leading-none\">\n IF / ELSE\n </span>\n\n <!-- Condition Input -->\n <div class=\"cqa-flex cqa-items-center cqa-gap-3 cqa-ml-2 cqa-flex-1\">\n <span [innerHTML]=\"condition\"></span>\n <!-- <span class=\"cqa-text-[#6B7280] cqa-text-[14px] cqa-leading-[18px]\">\n If\n </span>\n <span\n class=\"cqa-py-0.5 cqa-px-2 cqa-text-[#3F43EE] cqa-text-[14px] cqa-leading-[17px] cqa-font-semibold cqa-border cqa-border-solid cqa-border-[#8A8CF4] cqa-rounded cqa-bg-[#D8D9FC]\">.success-message</span>\n <span class=\"cqa-text-[#6B7280] cqa-text-[14px] cqa-leading-[18px]\">\n is visible\n </span> -->\n <!-- <input\n type=\"text\"\n [value]=\"condition\"\n (input)=\"onConditionChange($any($event.target).value)\"\n placeholder=\"element `.success-message` is visible\"\n class=\"cqa-px-3 cqa-py-1.5 cqa-rounded-lg cqa-border cqa-border-gray-300 cqa-bg-white cqa-text-gray-900 cqa-text-sm cqa-flex-1 cqa-max-w-md cqa-outline-none focus:cqa-ring-2 focus:cqa-ring-primary focus:cqa-ring-opacity-50\"\n /> -->\n </div>\n\n <!-- Steps Summary -->\n <div\n class=\"cqa-ml-auto cqa-border cqa-border-solid cqa-border-[#E5E5E5] cqa-rounded-lg cqa-py-0.5 cqa-px-2 cqa-text-[#0A0A0A] cqa-text-[12px] cqa-leading-[15px]\">\n {{ getStepsSummary() }}\n </div>\n\n <!-- Action Icons: Edit, Link, Duplicate, Delete (show on hover) -->\n <div class=\"step-actions cqa-flex cqa-items-center cqa-gap-3 cqa-px-[7px]\">\n <button type=\"button\" (click)=\"onEdit(); $event.stopPropagation()\" title=\"Edit\" class=\"cqa-p-0 cqa-text-[#99A1Af] hover:cqa-text-[#1447E6]\">\n <svg width=\"14\" height=\"14\" viewBox=\"0 0 14 14\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M7 11.6666H12.25\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M9.55208 2.1128C9.7843 1.88058 10.0993 1.75012 10.4277 1.75012C10.7561 1.75012 11.071 1.88058 11.3033 2.1128C11.5355 2.34502 11.6659 2.65998 11.6659 2.98838C11.6659 3.31679 11.5355 3.63175 11.3033 3.86397L4.29742 10.8704C4.15864 11.0092 3.9871 11.1107 3.79867 11.1656L2.12333 11.6544C2.07314 11.669 2.01993 11.6699 1.96928 11.6569C1.91863 11.6439 1.8724 11.6176 1.83543 11.5806C1.79846 11.5437 1.7721 11.4974 1.75913 11.4468C1.74615 11.3961 1.74703 11.3429 1.76167 11.2927L2.2505 9.61738C2.30546 9.42916 2.40698 9.25783 2.54567 9.11922L9.55208 2.1128Z\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/></svg>\n </button>\n <button type=\"button\" (click)=\"onLink(); $event.stopPropagation()\" title=\"Link\" class=\"cqa-p-0 cqa-text-[#99A1Af] hover:cqa-text-[#1447E6]\">\n <svg width=\"14\" height=\"14\" viewBox=\"0 0 14 14\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M5.00065 9.91671H3.66732C2.78326 9.91671 1.93542 9.60942 1.3103 9.06244C0.685174 8.51545 0.333984 7.77359 0.333984 7.00004C0.333984 6.22649 0.685174 5.48463 1.3103 4.93765C1.93542 4.39066 2.78326 4.08337 3.66732 4.08337H5.00065\" stroke=\"currentColor\" stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M9 4.08337H10.3333C11.2174 4.08337 12.0652 4.39066 12.6904 4.93765C13.3155 5.48463 13.6667 6.22649 13.6667 7.00004C13.6667 7.77359 13.3155 8.51545 12.6904 9.06244C12.0652 9.60942 11.2174 9.91671 10.3333 9.91671H9\" stroke=\"currentColor\" stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M4.33398 7H9.66732\" stroke=\"currentColor\" stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/></svg>\n </button>\n <button type=\"button\" (click)=\"onDuplicate(); $event.stopPropagation()\" title=\"Duplicate\" class=\"cqa-p-0 cqa-text-[#99A1Af] hover:cqa-text-[#1447E6]\">\n <svg width=\"14\" height=\"14\" viewBox=\"0 0 14 14\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M11.666 4.66663H5.83268C5.18835 4.66663 4.66602 5.18896 4.66602 5.83329V11.6666C4.66602 12.311 5.18835 12.8333 5.83268 12.8333H11.666C12.3103 12.8333 12.8327 12.311 12.8327 11.6666V5.83329C12.8327 5.18896 12.3103 4.66663 11.666 4.66663Z\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M2.33268 9.33329C1.69102 9.33329 1.16602 8.80829 1.16602 8.16663V2.33329C1.16602 1.69163 1.69102 1.16663 2.33268 1.16663H8.16602C8.80768 1.16663 9.33268 1.69163 9.33268 2.33329\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/></svg>\n </button>\n <button type=\"button\" (click)=\"onDelete(); $event.stopPropagation()\" title=\"Delete\" class=\"cqa-p-0 cqa-text-[#ff6467] hover:cqa-text-[#C63535]\">\n <svg width=\"14\" height=\"14\" viewBox=\"0 0 14 14\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M1.75 3.5H12.25\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M11.0827 3.5V11.6667C11.0827 12.25 10.4993 12.8333 9.91602 12.8333H4.08268C3.49935 12.8333 2.91602 12.25 2.91602 11.6667V3.5\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M4.66602 3.49996V2.33329C4.66602 1.74996 5.24935 1.16663 5.83268 1.16663H8.16602C8.74935 1.16663 9.33268 1.74996 9.33268 2.33329V3.49996\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M5.83398 6.41663V9.91663\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M8.16602 6.41663V9.91663\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/></svg>\n </button>\n </div>\n </div>\n\n <!-- Expanded Content with Branches -->\n <div *ngIf=\"expanded\" class=\"cqa-flex cqa-flex-col\">\n <!-- Branches (IF TRUE, ELSE IF, ELSE) -->\n <div *ngFor=\"let branch of branches\" class=\"cqa-flex cqa-flex-col\">\n <!-- Branch Header -->\n <div\n [class]=\"'cqa-px-4 cqa-py-2 cqa-text-[12px] cqa-leading-[15px] cqa-flex cqa-items-center cqa-gap-2 ' + getBranchTextColor(branch) + ' ' + getBranchColorClass(branch)\">\n <span>{{ getBranchLabel(branch) }}</span>\n <span *ngIf=\"branch.action\" [innerHTML]=\"branch.action\" class=\"cqa-text-[#111827]\"></span>\n </div>\n\n <!-- Branch Content (Nested Steps \u2013 renderer dispatches by step type, n-level nesting) -->\n <div *ngIf=\"!isReorder\" class=\"cqa-flex cqa-flex-col\">\n <cqa-test-case-details-renderer\n *ngFor=\"let step of branch.nestedSteps; let i = index\"\n [step]=\"step\"\n [index]=\"i\"\n [branch]=\"branch\"\n [isNested]=\"true\"\n [isReorder]=\"isReorder\"\n (branchStepChange)=\"onBranchStepChange($event.branch, $event.step, $event.stepIndex)\"\n (addStepForBranch)=\"onAddStep($event.branch)\"\n (deleteStepWithBranch)=\"onDeleteStep($event.branch, $event.stepIndex)\"\n (toggleExpanded)=\"onNestedToggleExpanded($event, branch, step, i)\"\n (groupNameChange)=\"$any(step).groupName = $event; onBranchStepChange(branch, step, i)\"\n (descriptionChange)=\"$any(step).description = $event; onBranchStepChange(branch, step, i)\"\n (reusableChange)=\"$any(step).reusable = $event; onBranchStepChange(branch, step, i)\"\n (openExternal)=\"onBranchStepChange(branch, step, i)\"\n (edit)=\"onBranchStepChange(branch, step, i)\"\n (link)=\"onBranchStepChange(branch, step, i)\"\n (duplicate)=\"onBranchStepChange(branch, step, i)\"\n (conditionChange)=\"$any(step).condition = $event; onBranchStepChange(branch, step, i)\"\n (addBranch)=\"onNestedConditionAddBranch($any(step)); onBranchStepChange(branch, step, i)\"\n (deleteBranch)=\"onNestedConditionDeleteBranch($any(step), $event); onBranchStepChange(branch, step, i)\"\n (testDataProfileChange)=\"$any(step).testDataProfile = $event; onBranchStepChange(branch, step, i)\"\n (startStepChange)=\"$any(step).startStep = $event; onBranchStepChange(branch, step, i)\"\n (endStepChange)=\"$any(step).endStep = $event; onBranchStepChange(branch, step, i)\"\n (maxIterationsChange)=\"$any(step).maxIterations = $event; onBranchStepChange(branch, step, i)\"\n (eventTypeChange)=\"$any(step).eventType = $event; onBranchStepChange(branch, step, i)\"\n (parameterChange)=\"onBranchStepChange(branch, step, i)\"\n (selectionChange)=\"$any(step).selected = $event; onBranchStepChange(branch, step, i)\"\n (dndDropInZone)=\"dndDropInZone.emit($event)\"\n >\n </cqa-test-case-details-renderer>\n </div>\n <div *ngIf=\"isReorder\" class=\"cqa-flex cqa-flex-col nested-step-drop-list\"\n [dndDropzone]=\"['step']\"\n dndEffectAllowed=\"move\"\n dndDragoverClass=\"dndDragover\"\n (dndDrop)=\"onDndDrop($event, branch)\">\n <div dndPlaceholderRef class=\"step-drag-placeholder-nested cqa-my-1 cqa-min-h-[50px] cqa-border-2 cqa-border-dashed cqa-border-[#3F43EE] cqa-rounded cqa-bg-[rgba(63,67,238,0.08)] cqa-flex cqa-items-center cqa-justify-center cqa-text-[#3F43EE] cqa-text-xs\">Drop here</div>\n <div *ngFor=\"let step of branch.nestedSteps; let i = index\" class=\"nested-step-drag-item\"\n [dndDraggable]=\"step\"\n dndEffectAllowed=\"move\"\n dndType=\"step\">\n <cqa-test-case-details-renderer\n [step]=\"step\"\n [index]=\"i\"\n [branch]=\"branch\"\n [isNested]=\"true\"\n [isReorder]=\"isReorder\"\n (branchStepChange)=\"onBranchStepChange($event.branch, $event.step, $event.stepIndex)\"\n (addStepForBranch)=\"onAddStep($event.branch)\"\n (deleteStepWithBranch)=\"onDeleteStep($event.branch, $event.stepIndex)\"\n (toggleExpanded)=\"onNestedToggleExpanded($event, branch, step, i)\"\n (groupNameChange)=\"$any(step).groupName = $event; onBranchStepChange(branch, step, i)\"\n (descriptionChange)=\"$any(step).description = $event; onBranchStepChange(branch, step, i)\"\n (reusableChange)=\"$any(step).reusable = $event; onBranchStepChange(branch, step, i)\"\n (openExternal)=\"onBranchStepChange(branch, step, i)\"\n (edit)=\"onBranchStepChange(branch, step, i)\"\n (link)=\"onBranchStepChange(branch, step, i)\"\n (duplicate)=\"onBranchStepChange(branch, step, i)\"\n (conditionChange)=\"$any(step).condition = $event; onBranchStepChange(branch, step, i)\"\n (addBranch)=\"onNestedConditionAddBranch($any(step)); onBranchStepChange(branch, step, i)\"\n (deleteBranch)=\"onNestedConditionDeleteBranch($any(step), $event); onBranchStepChange(branch, step, i)\"\n (testDataProfileChange)=\"$any(step).testDataProfile = $event; onBranchStepChange(branch, step, i)\"\n (startStepChange)=\"$any(step).startStep = $event; onBranchStepChange(branch, step, i)\"\n (endStepChange)=\"$any(step).endStep = $event; onBranchStepChange(branch, step, i)\"\n (maxIterationsChange)=\"$any(step).maxIterations = $event; onBranchStepChange(branch, step, i)\"\n (eventTypeChange)=\"$any(step).eventType = $event; onBranchStepChange(branch, step, i)\"\n (parameterChange)=\"onBranchStepChange(branch, step, i)\"\n (selectionChange)=\"$any(step).selected = $event; onBranchStepChange(branch, step, i)\"\n (dndDropInZone)=\"dndDropInZone.emit($event)\"\n >\n </cqa-test-case-details-renderer>\n </div>\n </div>\n </div>\n\n <!-- END IF Marker -->\n <div [class]=\"'cqa-pl-4 cqa-py-1 cqa-text-[#7B3306] cqa-text-[10px] cqa-leading-[15px] cqa-font-medium'\" style=\"border-top: 1px solid #E5E7EB;\">\n END IF\n </div>\n </div>\n</div>", styles: [".step-actions{opacity:0;transition:opacity .15s ease}.step-row:hover .step-actions{opacity:1}\n"], components: [{ type: i2.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: i3.DynamicSelectFieldComponent, selector: "cqa-dynamic-select", inputs: ["form", "config"], outputs: ["selectionChange", "selectClick", "searchChange", "loadMore", "addCustomValue"] }, { type: i4.ButtonComponent, selector: "cqa-button", inputs: ["variant", "btnSize", "disabled", "icon", "iconPosition", "fullWidth", "iconColor", "type", "text", "customClass", "inlineStyles", "tooltip", "tooltipPosition"], outputs: ["clicked"] }, { type: i5.TestCaseDetailsRendererComponent, selector: "cqa-test-case-details-renderer", inputs: ["step", "index", "isNested", "isInsideLoop", "branch", "isReorder", "addStepBetween"], outputs: ["nestedStepChange", "addStep", "deleteStep", "toggleExpanded", "groupNameChange", "descriptionChange", "reusableChange", "openExternal", "edit", "link", "duplicate", "delete", "viewDetails", "selectionChange", "conditionChange", "branchStepChange", "addStepForBranch", "deleteStepWithBranch", "addBranch", "deleteBranch", "testDataProfileChange", "startStepChange", "endStepChange", "maxIterationsChange", "eventTypeChange", "parameterChange", "clickAction", "dndDropInZone", "addStepBetweenClick"] }], directives: [{ type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i6.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i7.DndDropzoneDirective, selector: "[dndDropzone]", inputs: ["dndDropzone", "dndEffectAllowed", "dndAllowExternal", "dndHorizontal", "dndDragoverClass", "dndDropzoneDisabledClass", "dndDisableIf", "dndDisableDropIf"], outputs: ["dndDragover", "dndDrop"] }, { type: i7.DndPlaceholderRefDirective, selector: "[dndPlaceholderRef]" }, { type: i7.DndDraggableDirective, selector: "[dndDraggable]", inputs: ["dndDraggable", "dndEffectAllowed", "dndType", "dndDraggingClass", "dndDraggingSourceClass", "dndDraggableDisabledClass", "dndDragImageOffsetFunction", "dndDisableIf", "dndDisableDragIf"], outputs: ["dndStart", "dndDrag", "dndEnd", "dndMoved", "dndCopied", "dndLinked", "dndCanceled"] }] });
726
+ TestCaseConditionStepComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: TestCaseConditionStepComponent, deps: [{ token: i1.FormBuilder }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
727
+ TestCaseConditionStepComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.4.0", type: TestCaseConditionStepComponent, selector: "cqa-test-case-condition-step", inputs: { config: "config", id: "id", stepNumber: "stepNumber", condition: "condition", branches: "branches", expanded: "expanded", isNested: "isNested", isInsideLoop: "isInsideLoop", isReorder: "isReorder", dataProfileOptions: "dataProfileOptions", hasMoreDataProfiles: "hasMoreDataProfiles", isLoadingDataProfiles: "isLoadingDataProfiles", naturalTextActionsOptions: "naturalTextActionsOptions", setConditionTemplateVariables: "setConditionTemplateVariables" }, outputs: { toggleExpanded: "toggleExpanded", conditionChange: "conditionChange", branchStepChange: "branchStepChange", addStep: "addStep", deleteStep: "deleteStep", addBranch: "addBranch", addElse: "addElse", deleteBranch: "deleteBranch", duplicate: "duplicate", delete: "delete", moreOptions: "moreOptions", dndDropInZone: "dndDropInZone", loadMoreDataProfiles: "loadMoreDataProfiles", searchDataProfiles: "searchDataProfiles", stepUpdate: "stepUpdate" }, host: { classAttribute: "cqa-ui-root" }, usesOnChanges: true, ngImport: i0, template: "<div [class]=\"'cqa-flex cqa-flex-col cqa-border cqa-border-solid cqa-border-[#E5E7EB] ' + (isNested ? ' cqa-pl-[24px]' : '')\">\n <!-- Inline Edit Mode: CONDITION tag, three fields, IF/ELSE chips, Edit In depth, Cancel/Apply -->\n <div *ngIf=\"isEditing\" class=\"cqa-py-2.5 cqa-px-4 cqa-flex cqa-flex-col cqa-gap-3\">\n <!-- First Row: CONDITION tag, autocomplete, IF/ELSE indicators, Edit In depth, Cancel/Apply -->\n <div class=\"cqa-flex cqa-items-center cqa-gap-3 cqa-justify-between\">\n <div class=\"cqa-flex cqa-items-center cqa-gap-3 cqa-flex-grow\">\n <!-- CONDITION Tag (orange) -->\n <span class=\"cqa-px-1.5 cqa-rounded-md cqa-text-[#EA580C] cqa-text-[10px] cqa-leading-[15px] cqa-font-medium cqa-bg-[#FFEDD5]\">\n CONDITION\n </span>\n\n <!-- First field: left operand (e.g. Usertype) - autocomplete with IF_CONDITION natural text actions -->\n <cqa-autocomplete\n *ngIf=\"editForm\"\n [options]=\"conditionLeftAutocompleteOptions\"\n [value]=\"editForm.get('conditionLeft')?.value ?? ''\"\n (valueChange)=\"onEditFormFieldChange('conditionLeft', $event)\"\n (optionSelect)=\"onConditionLeftSelect($event)\"\n placeholder=\"Select condition\"\n [fullWidth]=\"true\"\n class=\"cqa-w-full cqa-max-w-[216px]\"></cqa-autocomplete>\n\n <!-- Second Row: Template Variables Section (shown when template is selected, inline before Edit In depth) -->\n <div *ngIf=\"selectedTemplate && templateVariables && templateVariables.length > 0\" class=\"cqa-flex cqa-flex-row cqa-flex-wrap cqa-gap-3\">\n <ng-container *ngFor=\"let variable of templateVariables\">\n <!-- Boolean variables with mat-slide-toggle -->\n <ng-container *ngIf=\"variable.type === 'boolean'\">\n <div class=\"cqa-flex cqa-items-center cqa-gap-2\">\n <label class=\"cqa-text-[12px] cqa-font-medium cqa-text-gray-700\">\n {{ variable.label }}\n </label>\n <mat-slide-toggle\n [checked]=\"templateVariablesForm.get(variable.name)?.value || variable.value || false\"\n (change)=\"templateVariablesForm.get(variable.name)?.setValue($event.checked)\"\n color=\"primary\">\n </mat-slide-toggle>\n </div>\n </ng-container>\n \n <!-- Non-boolean variables -->\n <ng-container *ngIf=\"variable.type !== 'boolean' && variable.name !== 'custom_code'\">\n <!-- Dropdown for select variables -->\n <ng-container *ngIf=\"variable.name === 'type' || variable.name === 'scrollTo' || variable.options\">\n <div class=\"cqa-flex cqa-flex-col\" style=\"min-width: 150px;\">\n <!-- <label class=\"cqa-text-[12px] cqa-font-medium cqa-text-gray-700 cqa-mb-1\">\n {{ variable.label }}\n </label> -->\n <cqa-dynamic-select \n [form]=\"templateVariablesForm\"\n [config]=\"getSelectConfigForVariable(variable, false)\">\n </cqa-dynamic-select>\n </div>\n </ng-container>\n <!-- Text Input for other variables -->\n <ng-container *ngIf=\"variable.name !== 'type' && variable.name !== 'scrollTo' && !variable.options\">\n <div class=\"cqa-flex cqa-flex-col\" style=\"min-width: 150px;\">\n <!-- <label class=\"cqa-text-[12px] cqa-font-medium cqa-text-gray-700 cqa-mb-1\">\n {{ variable.label }}\n </label> -->\n <cqa-custom-input\n [placeholder]=\"'Enter ' + variable.label\"\n [value]=\"templateVariablesForm.get(variable.name)?.value || variable.value || ''\"\n [fullWidth]=\"true\"\n (valueChange)=\"templateVariablesForm.get(variable.name)?.setValue($event)\">\n </cqa-custom-input>\n </div>\n </ng-container>\n </ng-container>\n </ng-container>\n </div>\n\n <!-- IF / ELSE indicators -->\n <span class=\"cqa-px-2 cqa-py-[2px] cqa-rounded-[4px] cqa-text-[8px] cqa-leading-[12px] cqa-bg-[#DCFCE7] cqa-text-[#008236] cqa-border cqa-border-solid cqa-border-[#B9F8CF] cqa-flex cqa-items-center cqa-gap-1.5\">\n <svg width=\"8\" height=\"8\" viewBox=\"0 0 8 8\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M6.66634 2L2.99967 5.66667L1.33301 4\" stroke=\"#008236\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/></svg>\n IF\n </span>\n <!-- Add ELSE IF button - always visible -->\n <button\n type=\"button\"\n (click)=\"onAddElse()\"\n class=\"cqa-px-2 cqa-py-[2px] cqa-rounded-[4px] cqa-text-[8px] cqa-leading-[12px] cqa-bg-[#F3F4F6] cqa-text-[#99A1AF] cqa-border cqa-border-solid cqa-border-[#E5E7EB] cqa-flex cqa-items-center cqa-gap-1.5 cqa-cursor-pointer hover:cqa-bg-[#E5E7EB] cqa-transition-colors\">\n Add ELSE IF\n </button>\n <!-- Add Else button - calls API to create CONDITION_ELSE step -->\n <button\n type=\"button\"\n (click)=\"onAddElseBranch()\"\n class=\"cqa-px-2 cqa-py-[2px] cqa-rounded-[4px] cqa-text-[8px] cqa-leading-[12px] cqa-bg-[#F3F4F6] cqa-text-[#99A1AF] cqa-border cqa-border-solid cqa-border-[#E5E7EB] cqa-flex cqa-items-center cqa-gap-1.5 cqa-cursor-pointer hover:cqa-bg-[#E5E7EB] cqa-transition-colors\">\n Add Else\n </button>\n\n <!-- Edit In depth link -->\n <a href=\"#\" (click)=\"onEditInDepth(); $event.preventDefault()\"\n class=\"cqa-text-[#3F43EE] cqa-text-[10px] cqa-leading-[15px] cqa-font-medium cqa-flex cqa-items-center cqa-gap-[2px] cqa-no-underline\">\n Edit In depth\n <svg width=\"8\" height=\"8\" viewBox=\"0 0 8 8\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M2.03809 6.74329L2.62809 7.33329L5.96142 3.99996L2.62809 0.666626L2.03809 1.25663L4.78142 3.99996L2.03809 6.74329Z\" fill=\"#3F43EE\"/></svg>\n </a> \n </div>\n <!-- Cancel / Apply buttons - shown on IF row when no ELSE IF branches are present -->\n <div *ngIf=\"elseIfBranches.length === 0\" class=\"cqa-flex cqa-items-center cqa-gap-2\">\n <cqa-button variant=\"outlined\" btnSize=\"lg\" [customClass]=\"'cqa-text-[14px] cqa-py-[9px]'\" [text]=\"'Cancel'\" (clicked)=\"onEditCancel()\"></cqa-button>\n <cqa-button variant=\"filled\" btnSize=\"lg\" [customClass]=\"'cqa-text-[14px] cqa-py-[9px]'\" [text]=\"'Apply'\" (clicked)=\"onEditApply()\"></cqa-button>\n </div>\n </div>\n \n \n </div>\n\n <!-- ELSE IF Sections in Edit Mode - Loop through all ELSE IF branches -->\n <ng-container *ngFor=\"let branch of elseIfBranches; let i = index\">\n <div *ngIf=\"isEditing\" class=\"cqa-py-2.5 cqa-px-4 cqa-flex cqa-flex-col cqa-gap-3 cqa-border-t cqa-border-solid cqa-border-[#E5E7EB]\">\n <!-- First Row: Remove ELSE IF button, autocomplete, Edit In depth, Cancel/Apply -->\n <div class=\"cqa-flex cqa-items-center cqa-gap-3 cqa-justify-between\">\n <div class=\"cqa-flex cqa-items-center cqa-gap-3 cqa-flex-grow\">\n <!-- Remove ELSE IF button -->\n <button\n type=\"button\"\n (click)=\"onRemoveElse(branch.id)\"\n class=\"cqa-px-2 cqa-py-[2px] cqa-rounded-[4px] cqa-text-[8px] cqa-leading-[12px] cqa-bg-[#F3F4F6] cqa-text-[#99A1AF] cqa-border cqa-border-solid cqa-border-[#E5E7EB] cqa-cursor-pointer hover:cqa-bg-[#E5E7EB] cqa-transition-colors\">\n Remove ELSE IF\n </button>\n\n <!-- ELSE IF autocomplete field: same as IF condition -->\n <cqa-autocomplete\n *ngIf=\"branch.form\"\n [options]=\"conditionLeftAutocompleteOptions\"\n [value]=\"branch.form.get('conditionLeft')?.value ?? ''\"\n (valueChange)=\"branch.form.get('conditionLeft')?.setValue($event)\"\n (optionSelect)=\"onElseConditionLeftSelect($event, branch.id)\"\n placeholder=\"Select condition\"\n [fullWidth]=\"true\"\n class=\"cqa-w-full cqa-max-w-[216px]\"></cqa-autocomplete>\n \n <!-- Second Row: ELSE IF Template Variables Section (shown when template is selected, inline before Edit In depth) -->\n <div *ngIf=\"branch.selectedTemplate && branch.templateVariables && branch.templateVariables.length > 0\" class=\"cqa-flex cqa-flex-row cqa-flex-wrap cqa-gap-3\">\n <ng-container *ngFor=\"let variable of branch.templateVariables\">\n <!-- Boolean variables with mat-slide-toggle -->\n <ng-container *ngIf=\"variable.type === 'boolean'\">\n <div class=\"cqa-flex cqa-items-center cqa-gap-2\">\n <!-- <label class=\"cqa-text-[12px] cqa-font-medium cqa-text-gray-700\">\n {{ variable.label }}\n </label> -->\n <mat-slide-toggle\n [checked]=\"branch.templateVariablesForm.get(variable.name)?.value || variable.value || false\"\n (change)=\"branch.templateVariablesForm.get(variable.name)?.setValue($event.checked)\"\n color=\"primary\">\n </mat-slide-toggle>\n </div>\n </ng-container>\n \n <!-- Non-boolean variables -->\n <ng-container *ngIf=\"variable.type !== 'boolean' && variable.name !== 'custom_code'\">\n <!-- Dropdown for select variables -->\n <ng-container *ngIf=\"variable.name === 'type' || variable.name === 'scrollTo' || variable.options\">\n <div class=\"cqa-flex cqa-flex-col\" style=\"min-width: 150px;\">\n <!-- <label class=\"cqa-text-[12px] cqa-font-medium cqa-text-gray-700 cqa-mb-1\">\n {{ variable.label }}\n </label> -->\n <cqa-dynamic-select \n [form]=\"branch.templateVariablesForm\"\n [config]=\"getSelectConfigForVariable(variable, branch.id)\">\n </cqa-dynamic-select>\n </div>\n </ng-container>\n \n <!-- Text Input for other variables -->\n <ng-container *ngIf=\"variable.name !== 'type' && variable.name !== 'scrollTo' && !variable.options\">\n <div class=\"cqa-flex cqa-flex-col\" style=\"min-width: 150px;\">\n <!-- <label class=\"cqa-text-[12px] cqa-font-medium cqa-text-gray-700 cqa-mb-1\">\n {{ variable.label }}\n </label> -->\n <cqa-custom-input\n [value]=\"branch.templateVariablesForm.get(variable.name)?.value || variable.value || ''\"\n (valueChange)=\"branch.templateVariablesForm.get(variable.name)?.setValue($event)\"\n [placeholder]=\"variable.label\">\n </cqa-custom-input>\n </div>\n </ng-container>\n </ng-container>\n </ng-container>\n </div>\n\n <!-- Edit In depth link -->\n <a href=\"#\" (click)=\"onEditInDepth(); $event.preventDefault()\"\n class=\"cqa-text-[#3F43EE] cqa-text-[10px] cqa-leading-[15px] cqa-font-medium cqa-flex cqa-items-center cqa-gap-[2px] cqa-no-underline\">\n Edit In depth\n <svg width=\"8\" height=\"8\" viewBox=\"0 0 8 8\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M2.03809 6.74329L2.62809 7.33329L5.96142 3.99996L2.62809 0.666626L2.03809 1.25663L4.78142 3.99996L2.03809 6.74329Z\" fill=\"#3F43EE\"/></svg>\n </a>\n </div>\n <!-- Cancel / Apply buttons - shown in last ELSE IF row -->\n <div *ngIf=\"i === elseIfBranches.length - 1\" class=\"cqa-flex cqa-items-center cqa-gap-2\">\n <cqa-button variant=\"outlined\" btnSize=\"lg\" [customClass]=\"'cqa-text-[14px] cqa-py-[9px]'\" [text]=\"'Cancel'\" (clicked)=\"onEditCancel()\"></cqa-button>\n <cqa-button variant=\"filled\" btnSize=\"lg\" [customClass]=\"'cqa-text-[14px] cqa-py-[9px]'\" [text]=\"'Apply'\" (clicked)=\"onEditApply()\"></cqa-button>\n </div>\n </div>\n </div>\n </ng-container>\n\n <!-- Condition Header (normal view when not editing) -->\n <div *ngIf=\"!isEditing\" [class]=\"'step-row cqa-flex cqa-items-center cqa-gap-3 cqa-py-2 ' + (isInsideLoop ? 'cqa-pl-10 cqa-pr-4' : 'cqa-px-4')\">\n <!-- Expand/Collapse Icon -->\n <button type=\"button\" (click)=\"onToggleExpanded()\" class=\"cqa-p-0\">\n <svg [class.cqa-rotate-180]=\"!expanded\" class=\"cqa-transition-transform\" width=\"16\" height=\"16\"\n viewBox=\"0 0 16 16\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n <path d=\"M12 10L8 6L4 10\" stroke=\"#6B7280\" stroke-width=\"1.33333\" stroke-linecap=\"round\"\n stroke-linejoin=\"round\" />\n </svg>\n </button>\n\n <!-- IF/ELSE Icon -->\n <div><svg width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n <path d=\"M4 2V10\" stroke=\"#7B3306\" stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n <path\n d=\"M12 6C13.1046 6 14 5.10457 14 4C14 2.89543 13.1046 2 12 2C10.8954 2 10 2.89543 10 4C10 5.10457 10.8954 6 12 6Z\"\n stroke=\"#7B3306\" stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n <path\n d=\"M4 14C5.10457 14 6 13.1046 6 12C6 10.8954 5.10457 10 4 10C2.89543 10 2 10.8954 2 12C2 13.1046 2.89543 14 4 14Z\"\n stroke=\"#7B3306\" stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n <path d=\"M12 6C12 7.5913 11.3679 9.11742 10.2426 10.2426C9.11742 11.3679 7.5913 12 6 12\" stroke=\"#7B3306\"\n stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n </svg></div>\n\n <!-- IF/ELSE Label -->\n <span class=\"cqa-font-semibold cqa-text-[#7B3306] cqa-text-[12px] cqa-leading-none\">\n IF / ELSE\n </span>\n\n <!-- Condition Input -->\n <div class=\"cqa-flex cqa-items-center cqa-gap-3 cqa-ml-2 cqa-flex-1\">\n <span [innerHTML]=\"condition\"></span>\n <!-- <span class=\"cqa-text-[#6B7280] cqa-text-[14px] cqa-leading-[18px]\">\n If\n </span>\n <span\n class=\"cqa-py-0.5 cqa-px-2 cqa-text-[#3F43EE] cqa-text-[14px] cqa-leading-[17px] cqa-font-semibold cqa-border cqa-border-solid cqa-border-[#8A8CF4] cqa-rounded cqa-bg-[#D8D9FC]\">.success-message</span>\n <span class=\"cqa-text-[#6B7280] cqa-text-[14px] cqa-leading-[18px]\">\n is visible\n </span> -->\n <!-- <input\n type=\"text\"\n [value]=\"condition\"\n (input)=\"onConditionChange($any($event.target).value)\"\n placeholder=\"element `.success-message` is visible\"\n class=\"cqa-px-3 cqa-py-1.5 cqa-rounded-lg cqa-border cqa-border-gray-300 cqa-bg-white cqa-text-gray-900 cqa-text-sm cqa-flex-1 cqa-max-w-md cqa-outline-none focus:cqa-ring-2 focus:cqa-ring-primary focus:cqa-ring-opacity-50\"\n /> -->\n </div>\n\n <!-- Steps Summary -->\n <div\n class=\"cqa-ml-auto cqa-border cqa-border-solid cqa-border-[#E5E5E5] cqa-rounded-lg cqa-py-0.5 cqa-px-2 cqa-text-[#0A0A0A] cqa-text-[12px] cqa-leading-[15px]\">\n {{ getStepsSummary() }}\n </div>\n\n <!-- Action Icons: Edit, Link, Duplicate, Delete (show on hover) -->\n <div class=\"step-actions cqa-flex cqa-items-center cqa-gap-3 cqa-px-[7px]\">\n <button type=\"button\" (click)=\"onEdit(); $event.stopPropagation()\" title=\"Edit\" class=\"cqa-p-0 cqa-text-[#99A1Af] hover:cqa-text-[#1447E6]\">\n <svg width=\"14\" height=\"14\" viewBox=\"0 0 14 14\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M7 11.6666H12.25\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M9.55208 2.1128C9.7843 1.88058 10.0993 1.75012 10.4277 1.75012C10.7561 1.75012 11.071 1.88058 11.3033 2.1128C11.5355 2.34502 11.6659 2.65998 11.6659 2.98838C11.6659 3.31679 11.5355 3.63175 11.3033 3.86397L4.29742 10.8704C4.15864 11.0092 3.9871 11.1107 3.79867 11.1656L2.12333 11.6544C2.07314 11.669 2.01993 11.6699 1.96928 11.6569C1.91863 11.6439 1.8724 11.6176 1.83543 11.5806C1.79846 11.5437 1.7721 11.4974 1.75913 11.4468C1.74615 11.3961 1.74703 11.3429 1.76167 11.2927L2.2505 9.61738C2.30546 9.42916 2.40698 9.25783 2.54567 9.11922L9.55208 2.1128Z\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/></svg>\n </button>\n <button type=\"button\" (click)=\"onLink(); $event.stopPropagation()\" title=\"Link\" class=\"cqa-p-0 cqa-text-[#99A1Af] hover:cqa-text-[#1447E6]\">\n <svg width=\"14\" height=\"14\" viewBox=\"0 0 14 14\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M5.00065 9.91671H3.66732C2.78326 9.91671 1.93542 9.60942 1.3103 9.06244C0.685174 8.51545 0.333984 7.77359 0.333984 7.00004C0.333984 6.22649 0.685174 5.48463 1.3103 4.93765C1.93542 4.39066 2.78326 4.08337 3.66732 4.08337H5.00065\" stroke=\"currentColor\" stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M9 4.08337H10.3333C11.2174 4.08337 12.0652 4.39066 12.6904 4.93765C13.3155 5.48463 13.6667 6.22649 13.6667 7.00004C13.6667 7.77359 13.3155 8.51545 12.6904 9.06244C12.0652 9.60942 11.2174 9.91671 10.3333 9.91671H9\" stroke=\"currentColor\" stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M4.33398 7H9.66732\" stroke=\"currentColor\" stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/></svg>\n </button>\n <button type=\"button\" (click)=\"onDuplicate(); $event.stopPropagation()\" title=\"Duplicate\" class=\"cqa-p-0 cqa-text-[#99A1Af] hover:cqa-text-[#1447E6]\">\n <svg width=\"14\" height=\"14\" viewBox=\"0 0 14 14\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M11.666 4.66663H5.83268C5.18835 4.66663 4.66602 5.18896 4.66602 5.83329V11.6666C4.66602 12.311 5.18835 12.8333 5.83268 12.8333H11.666C12.3103 12.8333 12.8327 12.311 12.8327 11.6666V5.83329C12.8327 5.18896 12.3103 4.66663 11.666 4.66663Z\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M2.33268 9.33329C1.69102 9.33329 1.16602 8.80829 1.16602 8.16663V2.33329C1.16602 1.69163 1.69102 1.16663 2.33268 1.16663H8.16602C8.80768 1.16663 9.33268 1.69163 9.33268 2.33329\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/></svg>\n </button>\n <button type=\"button\" (click)=\"onDelete(); $event.stopPropagation()\" title=\"Delete\" class=\"cqa-p-0 cqa-text-[#ff6467] hover:cqa-text-[#C63535]\">\n <svg width=\"14\" height=\"14\" viewBox=\"0 0 14 14\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M1.75 3.5H12.25\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M11.0827 3.5V11.6667C11.0827 12.25 10.4993 12.8333 9.91602 12.8333H4.08268C3.49935 12.8333 2.91602 12.25 2.91602 11.6667V3.5\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M4.66602 3.49996V2.33329C4.66602 1.74996 5.24935 1.16663 5.83268 1.16663H8.16602C8.74935 1.16663 9.33268 1.74996 9.33268 2.33329V3.49996\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M5.83398 6.41663V9.91663\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M8.16602 6.41663V9.91663\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/></svg>\n </button>\n </div>\n </div>\n\n <!-- Expanded Content with Branches -->\n <div *ngIf=\"expanded\" class=\"cqa-flex cqa-flex-col\">\n <!-- Branches (IF TRUE, ELSE IF, ELSE) -->\n <div *ngFor=\"let branch of branches\" class=\"cqa-flex cqa-flex-col\">\n <!-- Branch Header -->\n <div\n [class]=\"'cqa-px-4 cqa-py-2 cqa-text-[12px] cqa-leading-[15px] cqa-flex cqa-items-center cqa-gap-2 ' + getBranchTextColor(branch) + ' ' + getBranchColorClass(branch)\">\n <span>{{ getBranchLabel(branch) }}</span>\n <span *ngIf=\"branch.action\" [innerHTML]=\"branch.action\" class=\"cqa-text-[#111827]\"></span>\n </div>\n\n <!-- Branch Content (Nested Steps \u2013 renderer dispatches by step type, n-level nesting) -->\n <div *ngIf=\"!isReorder\" class=\"cqa-flex cqa-flex-col\">\n <cqa-test-case-details-renderer\n *ngFor=\"let step of branch.nestedSteps; let i = index\"\n [step]=\"step\"\n [index]=\"i\"\n [branch]=\"branch\"\n [isNested]=\"true\"\n [isReorder]=\"isReorder\"\n [dataProfileOptions]=\"dataProfileOptions\" [hasMoreDataProfiles]=\"hasMoreDataProfiles\" [isLoadingDataProfiles]=\"isLoadingDataProfiles\"\n [naturalTextActionsOptions]=\"naturalTextActionsOptions\"\n (branchStepChange)=\"onBranchStepChange($event.branch, $event.step, $event.stepIndex)\"\n (addStepForBranch)=\"onAddStep($event.branch)\"\n (deleteStepWithBranch)=\"onDeleteStep($event.branch, $event.stepIndex)\"\n (toggleExpanded)=\"onNestedToggleExpanded($event, branch, step, i)\"\n (groupNameChange)=\"$any(step).groupName = $event; onBranchStepChange(branch, step, i)\"\n (descriptionChange)=\"$any(step).description = $event; onBranchStepChange(branch, step, i)\"\n (reusableChange)=\"$any(step).reusable = $event; onBranchStepChange(branch, step, i)\"\n (openExternal)=\"onBranchStepChange(branch, step, i)\"\n (edit)=\"onBranchStepChange(branch, step, i)\"\n (link)=\"onBranchStepChange(branch, step, i)\"\n (duplicate)=\"onBranchStepChange(branch, step, i)\"\n (conditionChange)=\"$any(step).condition = $event; onBranchStepChange(branch, step, i)\"\n (addBranch)=\"onNestedConditionAddBranch($any(step)); onBranchStepChange(branch, step, i)\"\n (deleteBranch)=\"onNestedConditionDeleteBranch($any(step), $event); onBranchStepChange(branch, step, i)\"\n (testDataProfileChange)=\"$any(step).testDataProfile = $event; onBranchStepChange(branch, step, i)\"\n (startStepChange)=\"$any(step).startStep = $event; onBranchStepChange(branch, step, i)\"\n (endStepChange)=\"$any(step).endStep = $event; onBranchStepChange(branch, step, i)\"\n (maxIterationsChange)=\"$any(step).maxIterations = $event; onBranchStepChange(branch, step, i)\"\n (eventTypeChange)=\"$any(step).eventType = $event; onBranchStepChange(branch, step, i)\"\n (parameterChange)=\"onBranchStepChange(branch, step, i)\"\n (selectionChange)=\"$any(step).selected = $event; onBranchStepChange(branch, step, i)\"\n (loadMoreDataProfiles)=\"loadMoreDataProfiles.emit($event)\"\n (searchDataProfiles)=\"searchDataProfiles.emit($event)\"\n (stepUpdate)=\"stepUpdate.emit($event)\"\n (dndDropInZone)=\"dndDropInZone.emit($event)\"\n >\n </cqa-test-case-details-renderer>\n </div>\n <div *ngIf=\"isReorder\" class=\"cqa-flex cqa-flex-col nested-step-drop-list\"\n [dndDropzone]=\"['step']\"\n dndEffectAllowed=\"move\"\n dndDragoverClass=\"dndDragover\"\n (dndDrop)=\"onDndDrop($event, branch)\">\n <div dndPlaceholderRef class=\"step-drag-placeholder-nested cqa-my-1 cqa-min-h-[50px] cqa-border-2 cqa-border-dashed cqa-border-[#3F43EE] cqa-rounded cqa-bg-[rgba(63,67,238,0.08)] cqa-flex cqa-items-center cqa-justify-center cqa-text-[#3F43EE] cqa-text-xs\">Drop here</div>\n <div *ngFor=\"let step of branch.nestedSteps; let i = index\" class=\"nested-step-drag-item\"\n [dndDraggable]=\"step\"\n dndEffectAllowed=\"move\"\n dndType=\"step\">\n <cqa-test-case-details-renderer\n [step]=\"step\"\n [index]=\"i\"\n [branch]=\"branch\"\n [isNested]=\"true\"\n [isReorder]=\"isReorder\"\n [dataProfileOptions]=\"dataProfileOptions\" [hasMoreDataProfiles]=\"hasMoreDataProfiles\" [isLoadingDataProfiles]=\"isLoadingDataProfiles\"\n [naturalTextActionsOptions]=\"naturalTextActionsOptions\"\n (branchStepChange)=\"onBranchStepChange($event.branch, $event.step, $event.stepIndex)\"\n (addStepForBranch)=\"onAddStep($event.branch)\"\n (deleteStepWithBranch)=\"onDeleteStep($event.branch, $event.stepIndex)\"\n (toggleExpanded)=\"onNestedToggleExpanded($event, branch, step, i)\"\n (groupNameChange)=\"$any(step).groupName = $event; onBranchStepChange(branch, step, i)\"\n (descriptionChange)=\"$any(step).description = $event; onBranchStepChange(branch, step, i)\"\n (reusableChange)=\"$any(step).reusable = $event; onBranchStepChange(branch, step, i)\"\n (openExternal)=\"onBranchStepChange(branch, step, i)\"\n (edit)=\"onBranchStepChange(branch, step, i)\"\n (link)=\"onBranchStepChange(branch, step, i)\"\n (duplicate)=\"onBranchStepChange(branch, step, i)\"\n (conditionChange)=\"$any(step).condition = $event; onBranchStepChange(branch, step, i)\"\n (addBranch)=\"onNestedConditionAddBranch($any(step)); onBranchStepChange(branch, step, i)\"\n (deleteBranch)=\"onNestedConditionDeleteBranch($any(step), $event); onBranchStepChange(branch, step, i)\"\n (testDataProfileChange)=\"$any(step).testDataProfile = $event; onBranchStepChange(branch, step, i)\"\n (startStepChange)=\"$any(step).startStep = $event; onBranchStepChange(branch, step, i)\"\n (endStepChange)=\"$any(step).endStep = $event; onBranchStepChange(branch, step, i)\"\n (maxIterationsChange)=\"$any(step).maxIterations = $event; onBranchStepChange(branch, step, i)\"\n (eventTypeChange)=\"$any(step).eventType = $event; onBranchStepChange(branch, step, i)\"\n (parameterChange)=\"onBranchStepChange(branch, step, i)\"\n (selectionChange)=\"$any(step).selected = $event; onBranchStepChange(branch, step, i)\"\n (loadMoreDataProfiles)=\"loadMoreDataProfiles.emit($event)\"\n (searchDataProfiles)=\"searchDataProfiles.emit($event)\"\n (stepUpdate)=\"stepUpdate.emit($event)\"\n (dndDropInZone)=\"dndDropInZone.emit($event)\"\n >\n </cqa-test-case-details-renderer>\n </div>\n </div>\n </div>\n\n <!-- END IF Marker -->\n <div [class]=\"'cqa-pl-4 cqa-py-1 cqa-text-[#7B3306] cqa-text-[10px] cqa-leading-[15px] cqa-font-medium'\" style=\"border-top: 1px solid #E5E7EB;\">\n END IF\n </div>\n </div>\n</div>", styles: [".step-actions{opacity:0;transition:opacity .15s ease}.step-row:hover .step-actions{opacity:1}\n"], components: [{ type: i2.AutocompleteComponent, selector: "cqa-autocomplete", inputs: ["placeholder", "options", "value", "disabled", "showClear", "ariaLabel", "autoFocus", "size", "fullWidth"], outputs: ["valueChange", "optionSelect", "cleared"] }, { type: i3.MatSlideToggle, selector: "mat-slide-toggle", inputs: ["disabled", "disableRipple", "color", "tabIndex", "name", "id", "labelPosition", "aria-label", "aria-labelledby", "aria-describedby", "required", "checked"], outputs: ["change", "toggleChange"], exportAs: ["matSlideToggle"] }, { type: i4.DynamicSelectFieldComponent, selector: "cqa-dynamic-select", inputs: ["form", "config"], outputs: ["selectionChange", "selectClick", "searchChange", "loadMore", "addCustomValue"] }, { type: i5.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: i6.ButtonComponent, selector: "cqa-button", inputs: ["variant", "btnSize", "disabled", "icon", "iconPosition", "fullWidth", "iconColor", "type", "text", "customClass", "inlineStyles", "tooltip", "tooltipPosition"], outputs: ["clicked"] }, { type: i7.TestCaseDetailsRendererComponent, selector: "cqa-test-case-details-renderer", inputs: ["step", "index", "isNested", "isInsideLoop", "branch", "isReorder", "addStepBetween", "dataProfileOptions", "hasMoreDataProfiles", "isLoadingDataProfiles", "naturalTextActionsOptions", "setConditionTemplateVariables"], outputs: ["nestedStepChange", "addStep", "deleteStep", "toggleExpanded", "groupNameChange", "descriptionChange", "reusableChange", "openExternal", "edit", "link", "duplicate", "delete", "viewDetails", "selectionChange", "conditionChange", "branchStepChange", "addStepForBranch", "deleteStepWithBranch", "addBranch", "addElse", "deleteBranch", "testDataProfileChange", "startStepChange", "endStepChange", "maxIterationsChange", "eventTypeChange", "parameterChange", "clickAction", "dndDropInZone", "loadMoreDataProfiles", "searchDataProfiles", "stepUpdate", "addStepBetweenClick"] }], directives: [{ type: i8.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i8.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i9.DndDropzoneDirective, selector: "[dndDropzone]", inputs: ["dndDropzone", "dndEffectAllowed", "dndAllowExternal", "dndHorizontal", "dndDragoverClass", "dndDropzoneDisabledClass", "dndDisableIf", "dndDisableDropIf"], outputs: ["dndDragover", "dndDrop"] }, { type: i9.DndPlaceholderRefDirective, selector: "[dndPlaceholderRef]" }, { type: i9.DndDraggableDirective, selector: "[dndDraggable]", inputs: ["dndDraggable", "dndEffectAllowed", "dndType", "dndDraggingClass", "dndDraggingSourceClass", "dndDraggableDisabledClass", "dndDragImageOffsetFunction", "dndDisableIf", "dndDisableDragIf"], outputs: ["dndStart", "dndDrag", "dndEnd", "dndMoved", "dndCopied", "dndLinked", "dndCanceled"] }] });
258
728
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: TestCaseConditionStepComponent, decorators: [{
259
729
  type: Component,
260
- args: [{ selector: 'cqa-test-case-condition-step', host: { class: 'cqa-ui-root' }, styles: [STEP_ROW_ACTIONS_STYLES], template: "<div [class]=\"'cqa-flex cqa-flex-col cqa-border cqa-border-solid cqa-border-[#E5E7EB] ' + (isNested ? ' cqa-pl-[24px]' : '')\">\n <!-- Inline Edit Mode: CONDITION tag, three fields, IF/ELSE chips, Edit In depth, Cancel/Apply -->\n <div *ngIf=\"isEditing\" class=\"cqa-py-2.5 cqa-px-4 cqa-flex cqa-items-center cqa-gap-3 cqa-justify-between\">\n <div class=\"cqa-flex cqa-items-center cqa-gap-3 cqa-flex-grow\">\n <!-- CONDITION Tag (orange) -->\n <span class=\"cqa-px-1.5 cqa-rounded-md cqa-text-[#EA580C] cqa-text-[10px] cqa-leading-[15px] cqa-font-medium cqa-bg-[#FFEDD5]\">\n CONDITION\n </span>\n\n <!-- First field: left operand (e.g. Usertype) -->\n <cqa-custom-input\n [value]=\"editForm.get('conditionLeft')?.value ?? ''\"\n (valueChange)=\"onEditFormFieldChange('conditionLeft', $event)\"\n placeholder=\"Usertype\"\n class=\"cqa-w-full cqa-max-w-[216px]\"\n size=\"sm\">\n </cqa-custom-input>\n\n <!-- Operator: dynamic-select (IS, IS NOT, etc.) -->\n <cqa-dynamic-select [form]=\"editForm\" [config]=\"operatorSelectConfig\" class=\"cqa-w-full cqa-max-w-[216px]\"></cqa-dynamic-select>\n\n <!-- Third field: right operand (e.g. Premium) -->\n <cqa-custom-input\n [value]=\"editForm.get('conditionRight')?.value ?? ''\"\n (valueChange)=\"onEditFormFieldChange('conditionRight', $event)\"\n placeholder=\"Premium\"\n class=\"cqa-w-full cqa-max-w-[216px]\"\n size=\"sm\">\n </cqa-custom-input>\n\n <!-- IF / ELSE indicators -->\n <span class=\"cqa-px-2 cqa-py-[2px] cqa-rounded-[4px] cqa-text-[8px] cqa-leading-[12px] cqa-bg-[#DCFCE7] cqa-text-[#008236] cqa-border cqa-border-solid cqa-border-[#B9F8CF] cqa-flex cqa-items-center cqa-gap-1.5\">\n <svg width=\"8\" height=\"8\" viewBox=\"0 0 8 8\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M6.66634 2L2.99967 5.66667L1.33301 4\" stroke=\"#008236\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/></svg>\n IF\n </span>\n <span class=\"cqa-px-2 cqa-py-[2px] cqa-rounded-[4px] cqa-text-[8px] cqa-leading-[12px] cqa-bg-[#F3F4F6] cqa-text-[#99A1AF] cqa-border cqa-border-solid cqa-border-[#E5E7EB] cqa-flex cqa-items-center cqa-gap-1.5\">\n Add ELSE\n </span>\n\n <!-- Edit In depth link -->\n <a href=\"#\" (click)=\"onEditInDepth(); $event.preventDefault()\"\n class=\"cqa-text-[#3F43EE] cqa-text-[10px] cqa-leading-[15px] cqa-font-medium cqa-flex cqa-items-center cqa-gap-[2px] cqa-no-underline\">\n Edit In depth\n <svg width=\"8\" height=\"8\" viewBox=\"0 0 8 8\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M2.03809 6.74329L2.62809 7.33329L5.96142 3.99996L2.62809 0.666626L2.03809 1.25663L4.78142 3.99996L2.03809 6.74329Z\" fill=\"#3F43EE\"/></svg>\n </a> \n </div>\n <!-- Cancel / Apply -->\n <cqa-button variant=\"outlined\" btnSize=\"lg\" [customClass]=\"'cqa-text-[14px] cqa-py-[9px]'\" [text]=\"'Cancel'\" (clicked)=\"onEditCancel()\"></cqa-button>\n <cqa-button variant=\"filled\" btnSize=\"lg\" [customClass]=\"'cqa-text-[14px] cqa-py-[9px]'\" [text]=\"'Apply'\" (clicked)=\"onEditApply()\"></cqa-button>\n </div>\n\n <!-- Condition Header (normal view when not editing) -->\n <div *ngIf=\"!isEditing\" [class]=\"'step-row cqa-flex cqa-items-center cqa-gap-3 cqa-py-2 ' + (isInsideLoop ? 'cqa-pl-10 cqa-pr-4' : 'cqa-px-4')\">\n <!-- Expand/Collapse Icon -->\n <button type=\"button\" (click)=\"onToggleExpanded()\" class=\"cqa-p-0\">\n <svg [class.cqa-rotate-180]=\"!expanded\" class=\"cqa-transition-transform\" width=\"16\" height=\"16\"\n viewBox=\"0 0 16 16\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n <path d=\"M12 10L8 6L4 10\" stroke=\"#6B7280\" stroke-width=\"1.33333\" stroke-linecap=\"round\"\n stroke-linejoin=\"round\" />\n </svg>\n </button>\n\n <!-- IF/ELSE Icon -->\n <div><svg width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n <path d=\"M4 2V10\" stroke=\"#7B3306\" stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n <path\n d=\"M12 6C13.1046 6 14 5.10457 14 4C14 2.89543 13.1046 2 12 2C10.8954 2 10 2.89543 10 4C10 5.10457 10.8954 6 12 6Z\"\n stroke=\"#7B3306\" stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n <path\n d=\"M4 14C5.10457 14 6 13.1046 6 12C6 10.8954 5.10457 10 4 10C2.89543 10 2 10.8954 2 12C2 13.1046 2.89543 14 4 14Z\"\n stroke=\"#7B3306\" stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n <path d=\"M12 6C12 7.5913 11.3679 9.11742 10.2426 10.2426C9.11742 11.3679 7.5913 12 6 12\" stroke=\"#7B3306\"\n stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n </svg></div>\n\n <!-- IF/ELSE Label -->\n <span class=\"cqa-font-semibold cqa-text-[#7B3306] cqa-text-[12px] cqa-leading-none\">\n IF / ELSE\n </span>\n\n <!-- Condition Input -->\n <div class=\"cqa-flex cqa-items-center cqa-gap-3 cqa-ml-2 cqa-flex-1\">\n <span [innerHTML]=\"condition\"></span>\n <!-- <span class=\"cqa-text-[#6B7280] cqa-text-[14px] cqa-leading-[18px]\">\n If\n </span>\n <span\n class=\"cqa-py-0.5 cqa-px-2 cqa-text-[#3F43EE] cqa-text-[14px] cqa-leading-[17px] cqa-font-semibold cqa-border cqa-border-solid cqa-border-[#8A8CF4] cqa-rounded cqa-bg-[#D8D9FC]\">.success-message</span>\n <span class=\"cqa-text-[#6B7280] cqa-text-[14px] cqa-leading-[18px]\">\n is visible\n </span> -->\n <!-- <input\n type=\"text\"\n [value]=\"condition\"\n (input)=\"onConditionChange($any($event.target).value)\"\n placeholder=\"element `.success-message` is visible\"\n class=\"cqa-px-3 cqa-py-1.5 cqa-rounded-lg cqa-border cqa-border-gray-300 cqa-bg-white cqa-text-gray-900 cqa-text-sm cqa-flex-1 cqa-max-w-md cqa-outline-none focus:cqa-ring-2 focus:cqa-ring-primary focus:cqa-ring-opacity-50\"\n /> -->\n </div>\n\n <!-- Steps Summary -->\n <div\n class=\"cqa-ml-auto cqa-border cqa-border-solid cqa-border-[#E5E5E5] cqa-rounded-lg cqa-py-0.5 cqa-px-2 cqa-text-[#0A0A0A] cqa-text-[12px] cqa-leading-[15px]\">\n {{ getStepsSummary() }}\n </div>\n\n <!-- Action Icons: Edit, Link, Duplicate, Delete (show on hover) -->\n <div class=\"step-actions cqa-flex cqa-items-center cqa-gap-3 cqa-px-[7px]\">\n <button type=\"button\" (click)=\"onEdit(); $event.stopPropagation()\" title=\"Edit\" class=\"cqa-p-0 cqa-text-[#99A1Af] hover:cqa-text-[#1447E6]\">\n <svg width=\"14\" height=\"14\" viewBox=\"0 0 14 14\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M7 11.6666H12.25\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M9.55208 2.1128C9.7843 1.88058 10.0993 1.75012 10.4277 1.75012C10.7561 1.75012 11.071 1.88058 11.3033 2.1128C11.5355 2.34502 11.6659 2.65998 11.6659 2.98838C11.6659 3.31679 11.5355 3.63175 11.3033 3.86397L4.29742 10.8704C4.15864 11.0092 3.9871 11.1107 3.79867 11.1656L2.12333 11.6544C2.07314 11.669 2.01993 11.6699 1.96928 11.6569C1.91863 11.6439 1.8724 11.6176 1.83543 11.5806C1.79846 11.5437 1.7721 11.4974 1.75913 11.4468C1.74615 11.3961 1.74703 11.3429 1.76167 11.2927L2.2505 9.61738C2.30546 9.42916 2.40698 9.25783 2.54567 9.11922L9.55208 2.1128Z\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/></svg>\n </button>\n <button type=\"button\" (click)=\"onLink(); $event.stopPropagation()\" title=\"Link\" class=\"cqa-p-0 cqa-text-[#99A1Af] hover:cqa-text-[#1447E6]\">\n <svg width=\"14\" height=\"14\" viewBox=\"0 0 14 14\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M5.00065 9.91671H3.66732C2.78326 9.91671 1.93542 9.60942 1.3103 9.06244C0.685174 8.51545 0.333984 7.77359 0.333984 7.00004C0.333984 6.22649 0.685174 5.48463 1.3103 4.93765C1.93542 4.39066 2.78326 4.08337 3.66732 4.08337H5.00065\" stroke=\"currentColor\" stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M9 4.08337H10.3333C11.2174 4.08337 12.0652 4.39066 12.6904 4.93765C13.3155 5.48463 13.6667 6.22649 13.6667 7.00004C13.6667 7.77359 13.3155 8.51545 12.6904 9.06244C12.0652 9.60942 11.2174 9.91671 10.3333 9.91671H9\" stroke=\"currentColor\" stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M4.33398 7H9.66732\" stroke=\"currentColor\" stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/></svg>\n </button>\n <button type=\"button\" (click)=\"onDuplicate(); $event.stopPropagation()\" title=\"Duplicate\" class=\"cqa-p-0 cqa-text-[#99A1Af] hover:cqa-text-[#1447E6]\">\n <svg width=\"14\" height=\"14\" viewBox=\"0 0 14 14\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M11.666 4.66663H5.83268C5.18835 4.66663 4.66602 5.18896 4.66602 5.83329V11.6666C4.66602 12.311 5.18835 12.8333 5.83268 12.8333H11.666C12.3103 12.8333 12.8327 12.311 12.8327 11.6666V5.83329C12.8327 5.18896 12.3103 4.66663 11.666 4.66663Z\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M2.33268 9.33329C1.69102 9.33329 1.16602 8.80829 1.16602 8.16663V2.33329C1.16602 1.69163 1.69102 1.16663 2.33268 1.16663H8.16602C8.80768 1.16663 9.33268 1.69163 9.33268 2.33329\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/></svg>\n </button>\n <button type=\"button\" (click)=\"onDelete(); $event.stopPropagation()\" title=\"Delete\" class=\"cqa-p-0 cqa-text-[#ff6467] hover:cqa-text-[#C63535]\">\n <svg width=\"14\" height=\"14\" viewBox=\"0 0 14 14\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M1.75 3.5H12.25\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M11.0827 3.5V11.6667C11.0827 12.25 10.4993 12.8333 9.91602 12.8333H4.08268C3.49935 12.8333 2.91602 12.25 2.91602 11.6667V3.5\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M4.66602 3.49996V2.33329C4.66602 1.74996 5.24935 1.16663 5.83268 1.16663H8.16602C8.74935 1.16663 9.33268 1.74996 9.33268 2.33329V3.49996\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M5.83398 6.41663V9.91663\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M8.16602 6.41663V9.91663\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/></svg>\n </button>\n </div>\n </div>\n\n <!-- Expanded Content with Branches -->\n <div *ngIf=\"expanded\" class=\"cqa-flex cqa-flex-col\">\n <!-- Branches (IF TRUE, ELSE IF, ELSE) -->\n <div *ngFor=\"let branch of branches\" class=\"cqa-flex cqa-flex-col\">\n <!-- Branch Header -->\n <div\n [class]=\"'cqa-px-4 cqa-py-2 cqa-text-[12px] cqa-leading-[15px] cqa-flex cqa-items-center cqa-gap-2 ' + getBranchTextColor(branch) + ' ' + getBranchColorClass(branch)\">\n <span>{{ getBranchLabel(branch) }}</span>\n <span *ngIf=\"branch.action\" [innerHTML]=\"branch.action\" class=\"cqa-text-[#111827]\"></span>\n </div>\n\n <!-- Branch Content (Nested Steps \u2013 renderer dispatches by step type, n-level nesting) -->\n <div *ngIf=\"!isReorder\" class=\"cqa-flex cqa-flex-col\">\n <cqa-test-case-details-renderer\n *ngFor=\"let step of branch.nestedSteps; let i = index\"\n [step]=\"step\"\n [index]=\"i\"\n [branch]=\"branch\"\n [isNested]=\"true\"\n [isReorder]=\"isReorder\"\n (branchStepChange)=\"onBranchStepChange($event.branch, $event.step, $event.stepIndex)\"\n (addStepForBranch)=\"onAddStep($event.branch)\"\n (deleteStepWithBranch)=\"onDeleteStep($event.branch, $event.stepIndex)\"\n (toggleExpanded)=\"onNestedToggleExpanded($event, branch, step, i)\"\n (groupNameChange)=\"$any(step).groupName = $event; onBranchStepChange(branch, step, i)\"\n (descriptionChange)=\"$any(step).description = $event; onBranchStepChange(branch, step, i)\"\n (reusableChange)=\"$any(step).reusable = $event; onBranchStepChange(branch, step, i)\"\n (openExternal)=\"onBranchStepChange(branch, step, i)\"\n (edit)=\"onBranchStepChange(branch, step, i)\"\n (link)=\"onBranchStepChange(branch, step, i)\"\n (duplicate)=\"onBranchStepChange(branch, step, i)\"\n (conditionChange)=\"$any(step).condition = $event; onBranchStepChange(branch, step, i)\"\n (addBranch)=\"onNestedConditionAddBranch($any(step)); onBranchStepChange(branch, step, i)\"\n (deleteBranch)=\"onNestedConditionDeleteBranch($any(step), $event); onBranchStepChange(branch, step, i)\"\n (testDataProfileChange)=\"$any(step).testDataProfile = $event; onBranchStepChange(branch, step, i)\"\n (startStepChange)=\"$any(step).startStep = $event; onBranchStepChange(branch, step, i)\"\n (endStepChange)=\"$any(step).endStep = $event; onBranchStepChange(branch, step, i)\"\n (maxIterationsChange)=\"$any(step).maxIterations = $event; onBranchStepChange(branch, step, i)\"\n (eventTypeChange)=\"$any(step).eventType = $event; onBranchStepChange(branch, step, i)\"\n (parameterChange)=\"onBranchStepChange(branch, step, i)\"\n (selectionChange)=\"$any(step).selected = $event; onBranchStepChange(branch, step, i)\"\n (dndDropInZone)=\"dndDropInZone.emit($event)\"\n >\n </cqa-test-case-details-renderer>\n </div>\n <div *ngIf=\"isReorder\" class=\"cqa-flex cqa-flex-col nested-step-drop-list\"\n [dndDropzone]=\"['step']\"\n dndEffectAllowed=\"move\"\n dndDragoverClass=\"dndDragover\"\n (dndDrop)=\"onDndDrop($event, branch)\">\n <div dndPlaceholderRef class=\"step-drag-placeholder-nested cqa-my-1 cqa-min-h-[50px] cqa-border-2 cqa-border-dashed cqa-border-[#3F43EE] cqa-rounded cqa-bg-[rgba(63,67,238,0.08)] cqa-flex cqa-items-center cqa-justify-center cqa-text-[#3F43EE] cqa-text-xs\">Drop here</div>\n <div *ngFor=\"let step of branch.nestedSteps; let i = index\" class=\"nested-step-drag-item\"\n [dndDraggable]=\"step\"\n dndEffectAllowed=\"move\"\n dndType=\"step\">\n <cqa-test-case-details-renderer\n [step]=\"step\"\n [index]=\"i\"\n [branch]=\"branch\"\n [isNested]=\"true\"\n [isReorder]=\"isReorder\"\n (branchStepChange)=\"onBranchStepChange($event.branch, $event.step, $event.stepIndex)\"\n (addStepForBranch)=\"onAddStep($event.branch)\"\n (deleteStepWithBranch)=\"onDeleteStep($event.branch, $event.stepIndex)\"\n (toggleExpanded)=\"onNestedToggleExpanded($event, branch, step, i)\"\n (groupNameChange)=\"$any(step).groupName = $event; onBranchStepChange(branch, step, i)\"\n (descriptionChange)=\"$any(step).description = $event; onBranchStepChange(branch, step, i)\"\n (reusableChange)=\"$any(step).reusable = $event; onBranchStepChange(branch, step, i)\"\n (openExternal)=\"onBranchStepChange(branch, step, i)\"\n (edit)=\"onBranchStepChange(branch, step, i)\"\n (link)=\"onBranchStepChange(branch, step, i)\"\n (duplicate)=\"onBranchStepChange(branch, step, i)\"\n (conditionChange)=\"$any(step).condition = $event; onBranchStepChange(branch, step, i)\"\n (addBranch)=\"onNestedConditionAddBranch($any(step)); onBranchStepChange(branch, step, i)\"\n (deleteBranch)=\"onNestedConditionDeleteBranch($any(step), $event); onBranchStepChange(branch, step, i)\"\n (testDataProfileChange)=\"$any(step).testDataProfile = $event; onBranchStepChange(branch, step, i)\"\n (startStepChange)=\"$any(step).startStep = $event; onBranchStepChange(branch, step, i)\"\n (endStepChange)=\"$any(step).endStep = $event; onBranchStepChange(branch, step, i)\"\n (maxIterationsChange)=\"$any(step).maxIterations = $event; onBranchStepChange(branch, step, i)\"\n (eventTypeChange)=\"$any(step).eventType = $event; onBranchStepChange(branch, step, i)\"\n (parameterChange)=\"onBranchStepChange(branch, step, i)\"\n (selectionChange)=\"$any(step).selected = $event; onBranchStepChange(branch, step, i)\"\n (dndDropInZone)=\"dndDropInZone.emit($event)\"\n >\n </cqa-test-case-details-renderer>\n </div>\n </div>\n </div>\n\n <!-- END IF Marker -->\n <div [class]=\"'cqa-pl-4 cqa-py-1 cqa-text-[#7B3306] cqa-text-[10px] cqa-leading-[15px] cqa-font-medium'\" style=\"border-top: 1px solid #E5E7EB;\">\n END IF\n </div>\n </div>\n</div>" }]
261
- }], ctorParameters: function () { return [{ type: i1.FormBuilder }]; }, propDecorators: { config: [{
730
+ args: [{ selector: 'cqa-test-case-condition-step', host: { class: 'cqa-ui-root' }, styles: [STEP_ROW_ACTIONS_STYLES], template: "<div [class]=\"'cqa-flex cqa-flex-col cqa-border cqa-border-solid cqa-border-[#E5E7EB] ' + (isNested ? ' cqa-pl-[24px]' : '')\">\n <!-- Inline Edit Mode: CONDITION tag, three fields, IF/ELSE chips, Edit In depth, Cancel/Apply -->\n <div *ngIf=\"isEditing\" class=\"cqa-py-2.5 cqa-px-4 cqa-flex cqa-flex-col cqa-gap-3\">\n <!-- First Row: CONDITION tag, autocomplete, IF/ELSE indicators, Edit In depth, Cancel/Apply -->\n <div class=\"cqa-flex cqa-items-center cqa-gap-3 cqa-justify-between\">\n <div class=\"cqa-flex cqa-items-center cqa-gap-3 cqa-flex-grow\">\n <!-- CONDITION Tag (orange) -->\n <span class=\"cqa-px-1.5 cqa-rounded-md cqa-text-[#EA580C] cqa-text-[10px] cqa-leading-[15px] cqa-font-medium cqa-bg-[#FFEDD5]\">\n CONDITION\n </span>\n\n <!-- First field: left operand (e.g. Usertype) - autocomplete with IF_CONDITION natural text actions -->\n <cqa-autocomplete\n *ngIf=\"editForm\"\n [options]=\"conditionLeftAutocompleteOptions\"\n [value]=\"editForm.get('conditionLeft')?.value ?? ''\"\n (valueChange)=\"onEditFormFieldChange('conditionLeft', $event)\"\n (optionSelect)=\"onConditionLeftSelect($event)\"\n placeholder=\"Select condition\"\n [fullWidth]=\"true\"\n class=\"cqa-w-full cqa-max-w-[216px]\"></cqa-autocomplete>\n\n <!-- Second Row: Template Variables Section (shown when template is selected, inline before Edit In depth) -->\n <div *ngIf=\"selectedTemplate && templateVariables && templateVariables.length > 0\" class=\"cqa-flex cqa-flex-row cqa-flex-wrap cqa-gap-3\">\n <ng-container *ngFor=\"let variable of templateVariables\">\n <!-- Boolean variables with mat-slide-toggle -->\n <ng-container *ngIf=\"variable.type === 'boolean'\">\n <div class=\"cqa-flex cqa-items-center cqa-gap-2\">\n <label class=\"cqa-text-[12px] cqa-font-medium cqa-text-gray-700\">\n {{ variable.label }}\n </label>\n <mat-slide-toggle\n [checked]=\"templateVariablesForm.get(variable.name)?.value || variable.value || false\"\n (change)=\"templateVariablesForm.get(variable.name)?.setValue($event.checked)\"\n color=\"primary\">\n </mat-slide-toggle>\n </div>\n </ng-container>\n \n <!-- Non-boolean variables -->\n <ng-container *ngIf=\"variable.type !== 'boolean' && variable.name !== 'custom_code'\">\n <!-- Dropdown for select variables -->\n <ng-container *ngIf=\"variable.name === 'type' || variable.name === 'scrollTo' || variable.options\">\n <div class=\"cqa-flex cqa-flex-col\" style=\"min-width: 150px;\">\n <!-- <label class=\"cqa-text-[12px] cqa-font-medium cqa-text-gray-700 cqa-mb-1\">\n {{ variable.label }}\n </label> -->\n <cqa-dynamic-select \n [form]=\"templateVariablesForm\"\n [config]=\"getSelectConfigForVariable(variable, false)\">\n </cqa-dynamic-select>\n </div>\n </ng-container>\n <!-- Text Input for other variables -->\n <ng-container *ngIf=\"variable.name !== 'type' && variable.name !== 'scrollTo' && !variable.options\">\n <div class=\"cqa-flex cqa-flex-col\" style=\"min-width: 150px;\">\n <!-- <label class=\"cqa-text-[12px] cqa-font-medium cqa-text-gray-700 cqa-mb-1\">\n {{ variable.label }}\n </label> -->\n <cqa-custom-input\n [placeholder]=\"'Enter ' + variable.label\"\n [value]=\"templateVariablesForm.get(variable.name)?.value || variable.value || ''\"\n [fullWidth]=\"true\"\n (valueChange)=\"templateVariablesForm.get(variable.name)?.setValue($event)\">\n </cqa-custom-input>\n </div>\n </ng-container>\n </ng-container>\n </ng-container>\n </div>\n\n <!-- IF / ELSE indicators -->\n <span class=\"cqa-px-2 cqa-py-[2px] cqa-rounded-[4px] cqa-text-[8px] cqa-leading-[12px] cqa-bg-[#DCFCE7] cqa-text-[#008236] cqa-border cqa-border-solid cqa-border-[#B9F8CF] cqa-flex cqa-items-center cqa-gap-1.5\">\n <svg width=\"8\" height=\"8\" viewBox=\"0 0 8 8\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M6.66634 2L2.99967 5.66667L1.33301 4\" stroke=\"#008236\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/></svg>\n IF\n </span>\n <!-- Add ELSE IF button - always visible -->\n <button\n type=\"button\"\n (click)=\"onAddElse()\"\n class=\"cqa-px-2 cqa-py-[2px] cqa-rounded-[4px] cqa-text-[8px] cqa-leading-[12px] cqa-bg-[#F3F4F6] cqa-text-[#99A1AF] cqa-border cqa-border-solid cqa-border-[#E5E7EB] cqa-flex cqa-items-center cqa-gap-1.5 cqa-cursor-pointer hover:cqa-bg-[#E5E7EB] cqa-transition-colors\">\n Add ELSE IF\n </button>\n <!-- Add Else button - calls API to create CONDITION_ELSE step -->\n <button\n type=\"button\"\n (click)=\"onAddElseBranch()\"\n class=\"cqa-px-2 cqa-py-[2px] cqa-rounded-[4px] cqa-text-[8px] cqa-leading-[12px] cqa-bg-[#F3F4F6] cqa-text-[#99A1AF] cqa-border cqa-border-solid cqa-border-[#E5E7EB] cqa-flex cqa-items-center cqa-gap-1.5 cqa-cursor-pointer hover:cqa-bg-[#E5E7EB] cqa-transition-colors\">\n Add Else\n </button>\n\n <!-- Edit In depth link -->\n <a href=\"#\" (click)=\"onEditInDepth(); $event.preventDefault()\"\n class=\"cqa-text-[#3F43EE] cqa-text-[10px] cqa-leading-[15px] cqa-font-medium cqa-flex cqa-items-center cqa-gap-[2px] cqa-no-underline\">\n Edit In depth\n <svg width=\"8\" height=\"8\" viewBox=\"0 0 8 8\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M2.03809 6.74329L2.62809 7.33329L5.96142 3.99996L2.62809 0.666626L2.03809 1.25663L4.78142 3.99996L2.03809 6.74329Z\" fill=\"#3F43EE\"/></svg>\n </a> \n </div>\n <!-- Cancel / Apply buttons - shown on IF row when no ELSE IF branches are present -->\n <div *ngIf=\"elseIfBranches.length === 0\" class=\"cqa-flex cqa-items-center cqa-gap-2\">\n <cqa-button variant=\"outlined\" btnSize=\"lg\" [customClass]=\"'cqa-text-[14px] cqa-py-[9px]'\" [text]=\"'Cancel'\" (clicked)=\"onEditCancel()\"></cqa-button>\n <cqa-button variant=\"filled\" btnSize=\"lg\" [customClass]=\"'cqa-text-[14px] cqa-py-[9px]'\" [text]=\"'Apply'\" (clicked)=\"onEditApply()\"></cqa-button>\n </div>\n </div>\n \n \n </div>\n\n <!-- ELSE IF Sections in Edit Mode - Loop through all ELSE IF branches -->\n <ng-container *ngFor=\"let branch of elseIfBranches; let i = index\">\n <div *ngIf=\"isEditing\" class=\"cqa-py-2.5 cqa-px-4 cqa-flex cqa-flex-col cqa-gap-3 cqa-border-t cqa-border-solid cqa-border-[#E5E7EB]\">\n <!-- First Row: Remove ELSE IF button, autocomplete, Edit In depth, Cancel/Apply -->\n <div class=\"cqa-flex cqa-items-center cqa-gap-3 cqa-justify-between\">\n <div class=\"cqa-flex cqa-items-center cqa-gap-3 cqa-flex-grow\">\n <!-- Remove ELSE IF button -->\n <button\n type=\"button\"\n (click)=\"onRemoveElse(branch.id)\"\n class=\"cqa-px-2 cqa-py-[2px] cqa-rounded-[4px] cqa-text-[8px] cqa-leading-[12px] cqa-bg-[#F3F4F6] cqa-text-[#99A1AF] cqa-border cqa-border-solid cqa-border-[#E5E7EB] cqa-cursor-pointer hover:cqa-bg-[#E5E7EB] cqa-transition-colors\">\n Remove ELSE IF\n </button>\n\n <!-- ELSE IF autocomplete field: same as IF condition -->\n <cqa-autocomplete\n *ngIf=\"branch.form\"\n [options]=\"conditionLeftAutocompleteOptions\"\n [value]=\"branch.form.get('conditionLeft')?.value ?? ''\"\n (valueChange)=\"branch.form.get('conditionLeft')?.setValue($event)\"\n (optionSelect)=\"onElseConditionLeftSelect($event, branch.id)\"\n placeholder=\"Select condition\"\n [fullWidth]=\"true\"\n class=\"cqa-w-full cqa-max-w-[216px]\"></cqa-autocomplete>\n \n <!-- Second Row: ELSE IF Template Variables Section (shown when template is selected, inline before Edit In depth) -->\n <div *ngIf=\"branch.selectedTemplate && branch.templateVariables && branch.templateVariables.length > 0\" class=\"cqa-flex cqa-flex-row cqa-flex-wrap cqa-gap-3\">\n <ng-container *ngFor=\"let variable of branch.templateVariables\">\n <!-- Boolean variables with mat-slide-toggle -->\n <ng-container *ngIf=\"variable.type === 'boolean'\">\n <div class=\"cqa-flex cqa-items-center cqa-gap-2\">\n <!-- <label class=\"cqa-text-[12px] cqa-font-medium cqa-text-gray-700\">\n {{ variable.label }}\n </label> -->\n <mat-slide-toggle\n [checked]=\"branch.templateVariablesForm.get(variable.name)?.value || variable.value || false\"\n (change)=\"branch.templateVariablesForm.get(variable.name)?.setValue($event.checked)\"\n color=\"primary\">\n </mat-slide-toggle>\n </div>\n </ng-container>\n \n <!-- Non-boolean variables -->\n <ng-container *ngIf=\"variable.type !== 'boolean' && variable.name !== 'custom_code'\">\n <!-- Dropdown for select variables -->\n <ng-container *ngIf=\"variable.name === 'type' || variable.name === 'scrollTo' || variable.options\">\n <div class=\"cqa-flex cqa-flex-col\" style=\"min-width: 150px;\">\n <!-- <label class=\"cqa-text-[12px] cqa-font-medium cqa-text-gray-700 cqa-mb-1\">\n {{ variable.label }}\n </label> -->\n <cqa-dynamic-select \n [form]=\"branch.templateVariablesForm\"\n [config]=\"getSelectConfigForVariable(variable, branch.id)\">\n </cqa-dynamic-select>\n </div>\n </ng-container>\n \n <!-- Text Input for other variables -->\n <ng-container *ngIf=\"variable.name !== 'type' && variable.name !== 'scrollTo' && !variable.options\">\n <div class=\"cqa-flex cqa-flex-col\" style=\"min-width: 150px;\">\n <!-- <label class=\"cqa-text-[12px] cqa-font-medium cqa-text-gray-700 cqa-mb-1\">\n {{ variable.label }}\n </label> -->\n <cqa-custom-input\n [value]=\"branch.templateVariablesForm.get(variable.name)?.value || variable.value || ''\"\n (valueChange)=\"branch.templateVariablesForm.get(variable.name)?.setValue($event)\"\n [placeholder]=\"variable.label\">\n </cqa-custom-input>\n </div>\n </ng-container>\n </ng-container>\n </ng-container>\n </div>\n\n <!-- Edit In depth link -->\n <a href=\"#\" (click)=\"onEditInDepth(); $event.preventDefault()\"\n class=\"cqa-text-[#3F43EE] cqa-text-[10px] cqa-leading-[15px] cqa-font-medium cqa-flex cqa-items-center cqa-gap-[2px] cqa-no-underline\">\n Edit In depth\n <svg width=\"8\" height=\"8\" viewBox=\"0 0 8 8\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M2.03809 6.74329L2.62809 7.33329L5.96142 3.99996L2.62809 0.666626L2.03809 1.25663L4.78142 3.99996L2.03809 6.74329Z\" fill=\"#3F43EE\"/></svg>\n </a>\n </div>\n <!-- Cancel / Apply buttons - shown in last ELSE IF row -->\n <div *ngIf=\"i === elseIfBranches.length - 1\" class=\"cqa-flex cqa-items-center cqa-gap-2\">\n <cqa-button variant=\"outlined\" btnSize=\"lg\" [customClass]=\"'cqa-text-[14px] cqa-py-[9px]'\" [text]=\"'Cancel'\" (clicked)=\"onEditCancel()\"></cqa-button>\n <cqa-button variant=\"filled\" btnSize=\"lg\" [customClass]=\"'cqa-text-[14px] cqa-py-[9px]'\" [text]=\"'Apply'\" (clicked)=\"onEditApply()\"></cqa-button>\n </div>\n </div>\n </div>\n </ng-container>\n\n <!-- Condition Header (normal view when not editing) -->\n <div *ngIf=\"!isEditing\" [class]=\"'step-row cqa-flex cqa-items-center cqa-gap-3 cqa-py-2 ' + (isInsideLoop ? 'cqa-pl-10 cqa-pr-4' : 'cqa-px-4')\">\n <!-- Expand/Collapse Icon -->\n <button type=\"button\" (click)=\"onToggleExpanded()\" class=\"cqa-p-0\">\n <svg [class.cqa-rotate-180]=\"!expanded\" class=\"cqa-transition-transform\" width=\"16\" height=\"16\"\n viewBox=\"0 0 16 16\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n <path d=\"M12 10L8 6L4 10\" stroke=\"#6B7280\" stroke-width=\"1.33333\" stroke-linecap=\"round\"\n stroke-linejoin=\"round\" />\n </svg>\n </button>\n\n <!-- IF/ELSE Icon -->\n <div><svg width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n <path d=\"M4 2V10\" stroke=\"#7B3306\" stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n <path\n d=\"M12 6C13.1046 6 14 5.10457 14 4C14 2.89543 13.1046 2 12 2C10.8954 2 10 2.89543 10 4C10 5.10457 10.8954 6 12 6Z\"\n stroke=\"#7B3306\" stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n <path\n d=\"M4 14C5.10457 14 6 13.1046 6 12C6 10.8954 5.10457 10 4 10C2.89543 10 2 10.8954 2 12C2 13.1046 2.89543 14 4 14Z\"\n stroke=\"#7B3306\" stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n <path d=\"M12 6C12 7.5913 11.3679 9.11742 10.2426 10.2426C9.11742 11.3679 7.5913 12 6 12\" stroke=\"#7B3306\"\n stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n </svg></div>\n\n <!-- IF/ELSE Label -->\n <span class=\"cqa-font-semibold cqa-text-[#7B3306] cqa-text-[12px] cqa-leading-none\">\n IF / ELSE\n </span>\n\n <!-- Condition Input -->\n <div class=\"cqa-flex cqa-items-center cqa-gap-3 cqa-ml-2 cqa-flex-1\">\n <span [innerHTML]=\"condition\"></span>\n <!-- <span class=\"cqa-text-[#6B7280] cqa-text-[14px] cqa-leading-[18px]\">\n If\n </span>\n <span\n class=\"cqa-py-0.5 cqa-px-2 cqa-text-[#3F43EE] cqa-text-[14px] cqa-leading-[17px] cqa-font-semibold cqa-border cqa-border-solid cqa-border-[#8A8CF4] cqa-rounded cqa-bg-[#D8D9FC]\">.success-message</span>\n <span class=\"cqa-text-[#6B7280] cqa-text-[14px] cqa-leading-[18px]\">\n is visible\n </span> -->\n <!-- <input\n type=\"text\"\n [value]=\"condition\"\n (input)=\"onConditionChange($any($event.target).value)\"\n placeholder=\"element `.success-message` is visible\"\n class=\"cqa-px-3 cqa-py-1.5 cqa-rounded-lg cqa-border cqa-border-gray-300 cqa-bg-white cqa-text-gray-900 cqa-text-sm cqa-flex-1 cqa-max-w-md cqa-outline-none focus:cqa-ring-2 focus:cqa-ring-primary focus:cqa-ring-opacity-50\"\n /> -->\n </div>\n\n <!-- Steps Summary -->\n <div\n class=\"cqa-ml-auto cqa-border cqa-border-solid cqa-border-[#E5E5E5] cqa-rounded-lg cqa-py-0.5 cqa-px-2 cqa-text-[#0A0A0A] cqa-text-[12px] cqa-leading-[15px]\">\n {{ getStepsSummary() }}\n </div>\n\n <!-- Action Icons: Edit, Link, Duplicate, Delete (show on hover) -->\n <div class=\"step-actions cqa-flex cqa-items-center cqa-gap-3 cqa-px-[7px]\">\n <button type=\"button\" (click)=\"onEdit(); $event.stopPropagation()\" title=\"Edit\" class=\"cqa-p-0 cqa-text-[#99A1Af] hover:cqa-text-[#1447E6]\">\n <svg width=\"14\" height=\"14\" viewBox=\"0 0 14 14\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M7 11.6666H12.25\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M9.55208 2.1128C9.7843 1.88058 10.0993 1.75012 10.4277 1.75012C10.7561 1.75012 11.071 1.88058 11.3033 2.1128C11.5355 2.34502 11.6659 2.65998 11.6659 2.98838C11.6659 3.31679 11.5355 3.63175 11.3033 3.86397L4.29742 10.8704C4.15864 11.0092 3.9871 11.1107 3.79867 11.1656L2.12333 11.6544C2.07314 11.669 2.01993 11.6699 1.96928 11.6569C1.91863 11.6439 1.8724 11.6176 1.83543 11.5806C1.79846 11.5437 1.7721 11.4974 1.75913 11.4468C1.74615 11.3961 1.74703 11.3429 1.76167 11.2927L2.2505 9.61738C2.30546 9.42916 2.40698 9.25783 2.54567 9.11922L9.55208 2.1128Z\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/></svg>\n </button>\n <button type=\"button\" (click)=\"onLink(); $event.stopPropagation()\" title=\"Link\" class=\"cqa-p-0 cqa-text-[#99A1Af] hover:cqa-text-[#1447E6]\">\n <svg width=\"14\" height=\"14\" viewBox=\"0 0 14 14\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M5.00065 9.91671H3.66732C2.78326 9.91671 1.93542 9.60942 1.3103 9.06244C0.685174 8.51545 0.333984 7.77359 0.333984 7.00004C0.333984 6.22649 0.685174 5.48463 1.3103 4.93765C1.93542 4.39066 2.78326 4.08337 3.66732 4.08337H5.00065\" stroke=\"currentColor\" stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M9 4.08337H10.3333C11.2174 4.08337 12.0652 4.39066 12.6904 4.93765C13.3155 5.48463 13.6667 6.22649 13.6667 7.00004C13.6667 7.77359 13.3155 8.51545 12.6904 9.06244C12.0652 9.60942 11.2174 9.91671 10.3333 9.91671H9\" stroke=\"currentColor\" stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M4.33398 7H9.66732\" stroke=\"currentColor\" stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/></svg>\n </button>\n <button type=\"button\" (click)=\"onDuplicate(); $event.stopPropagation()\" title=\"Duplicate\" class=\"cqa-p-0 cqa-text-[#99A1Af] hover:cqa-text-[#1447E6]\">\n <svg width=\"14\" height=\"14\" viewBox=\"0 0 14 14\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M11.666 4.66663H5.83268C5.18835 4.66663 4.66602 5.18896 4.66602 5.83329V11.6666C4.66602 12.311 5.18835 12.8333 5.83268 12.8333H11.666C12.3103 12.8333 12.8327 12.311 12.8327 11.6666V5.83329C12.8327 5.18896 12.3103 4.66663 11.666 4.66663Z\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M2.33268 9.33329C1.69102 9.33329 1.16602 8.80829 1.16602 8.16663V2.33329C1.16602 1.69163 1.69102 1.16663 2.33268 1.16663H8.16602C8.80768 1.16663 9.33268 1.69163 9.33268 2.33329\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/></svg>\n </button>\n <button type=\"button\" (click)=\"onDelete(); $event.stopPropagation()\" title=\"Delete\" class=\"cqa-p-0 cqa-text-[#ff6467] hover:cqa-text-[#C63535]\">\n <svg width=\"14\" height=\"14\" viewBox=\"0 0 14 14\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M1.75 3.5H12.25\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M11.0827 3.5V11.6667C11.0827 12.25 10.4993 12.8333 9.91602 12.8333H4.08268C3.49935 12.8333 2.91602 12.25 2.91602 11.6667V3.5\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M4.66602 3.49996V2.33329C4.66602 1.74996 5.24935 1.16663 5.83268 1.16663H8.16602C8.74935 1.16663 9.33268 1.74996 9.33268 2.33329V3.49996\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M5.83398 6.41663V9.91663\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M8.16602 6.41663V9.91663\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/></svg>\n </button>\n </div>\n </div>\n\n <!-- Expanded Content with Branches -->\n <div *ngIf=\"expanded\" class=\"cqa-flex cqa-flex-col\">\n <!-- Branches (IF TRUE, ELSE IF, ELSE) -->\n <div *ngFor=\"let branch of branches\" class=\"cqa-flex cqa-flex-col\">\n <!-- Branch Header -->\n <div\n [class]=\"'cqa-px-4 cqa-py-2 cqa-text-[12px] cqa-leading-[15px] cqa-flex cqa-items-center cqa-gap-2 ' + getBranchTextColor(branch) + ' ' + getBranchColorClass(branch)\">\n <span>{{ getBranchLabel(branch) }}</span>\n <span *ngIf=\"branch.action\" [innerHTML]=\"branch.action\" class=\"cqa-text-[#111827]\"></span>\n </div>\n\n <!-- Branch Content (Nested Steps \u2013 renderer dispatches by step type, n-level nesting) -->\n <div *ngIf=\"!isReorder\" class=\"cqa-flex cqa-flex-col\">\n <cqa-test-case-details-renderer\n *ngFor=\"let step of branch.nestedSteps; let i = index\"\n [step]=\"step\"\n [index]=\"i\"\n [branch]=\"branch\"\n [isNested]=\"true\"\n [isReorder]=\"isReorder\"\n [dataProfileOptions]=\"dataProfileOptions\" [hasMoreDataProfiles]=\"hasMoreDataProfiles\" [isLoadingDataProfiles]=\"isLoadingDataProfiles\"\n [naturalTextActionsOptions]=\"naturalTextActionsOptions\"\n (branchStepChange)=\"onBranchStepChange($event.branch, $event.step, $event.stepIndex)\"\n (addStepForBranch)=\"onAddStep($event.branch)\"\n (deleteStepWithBranch)=\"onDeleteStep($event.branch, $event.stepIndex)\"\n (toggleExpanded)=\"onNestedToggleExpanded($event, branch, step, i)\"\n (groupNameChange)=\"$any(step).groupName = $event; onBranchStepChange(branch, step, i)\"\n (descriptionChange)=\"$any(step).description = $event; onBranchStepChange(branch, step, i)\"\n (reusableChange)=\"$any(step).reusable = $event; onBranchStepChange(branch, step, i)\"\n (openExternal)=\"onBranchStepChange(branch, step, i)\"\n (edit)=\"onBranchStepChange(branch, step, i)\"\n (link)=\"onBranchStepChange(branch, step, i)\"\n (duplicate)=\"onBranchStepChange(branch, step, i)\"\n (conditionChange)=\"$any(step).condition = $event; onBranchStepChange(branch, step, i)\"\n (addBranch)=\"onNestedConditionAddBranch($any(step)); onBranchStepChange(branch, step, i)\"\n (deleteBranch)=\"onNestedConditionDeleteBranch($any(step), $event); onBranchStepChange(branch, step, i)\"\n (testDataProfileChange)=\"$any(step).testDataProfile = $event; onBranchStepChange(branch, step, i)\"\n (startStepChange)=\"$any(step).startStep = $event; onBranchStepChange(branch, step, i)\"\n (endStepChange)=\"$any(step).endStep = $event; onBranchStepChange(branch, step, i)\"\n (maxIterationsChange)=\"$any(step).maxIterations = $event; onBranchStepChange(branch, step, i)\"\n (eventTypeChange)=\"$any(step).eventType = $event; onBranchStepChange(branch, step, i)\"\n (parameterChange)=\"onBranchStepChange(branch, step, i)\"\n (selectionChange)=\"$any(step).selected = $event; onBranchStepChange(branch, step, i)\"\n (loadMoreDataProfiles)=\"loadMoreDataProfiles.emit($event)\"\n (searchDataProfiles)=\"searchDataProfiles.emit($event)\"\n (stepUpdate)=\"stepUpdate.emit($event)\"\n (dndDropInZone)=\"dndDropInZone.emit($event)\"\n >\n </cqa-test-case-details-renderer>\n </div>\n <div *ngIf=\"isReorder\" class=\"cqa-flex cqa-flex-col nested-step-drop-list\"\n [dndDropzone]=\"['step']\"\n dndEffectAllowed=\"move\"\n dndDragoverClass=\"dndDragover\"\n (dndDrop)=\"onDndDrop($event, branch)\">\n <div dndPlaceholderRef class=\"step-drag-placeholder-nested cqa-my-1 cqa-min-h-[50px] cqa-border-2 cqa-border-dashed cqa-border-[#3F43EE] cqa-rounded cqa-bg-[rgba(63,67,238,0.08)] cqa-flex cqa-items-center cqa-justify-center cqa-text-[#3F43EE] cqa-text-xs\">Drop here</div>\n <div *ngFor=\"let step of branch.nestedSteps; let i = index\" class=\"nested-step-drag-item\"\n [dndDraggable]=\"step\"\n dndEffectAllowed=\"move\"\n dndType=\"step\">\n <cqa-test-case-details-renderer\n [step]=\"step\"\n [index]=\"i\"\n [branch]=\"branch\"\n [isNested]=\"true\"\n [isReorder]=\"isReorder\"\n [dataProfileOptions]=\"dataProfileOptions\" [hasMoreDataProfiles]=\"hasMoreDataProfiles\" [isLoadingDataProfiles]=\"isLoadingDataProfiles\"\n [naturalTextActionsOptions]=\"naturalTextActionsOptions\"\n (branchStepChange)=\"onBranchStepChange($event.branch, $event.step, $event.stepIndex)\"\n (addStepForBranch)=\"onAddStep($event.branch)\"\n (deleteStepWithBranch)=\"onDeleteStep($event.branch, $event.stepIndex)\"\n (toggleExpanded)=\"onNestedToggleExpanded($event, branch, step, i)\"\n (groupNameChange)=\"$any(step).groupName = $event; onBranchStepChange(branch, step, i)\"\n (descriptionChange)=\"$any(step).description = $event; onBranchStepChange(branch, step, i)\"\n (reusableChange)=\"$any(step).reusable = $event; onBranchStepChange(branch, step, i)\"\n (openExternal)=\"onBranchStepChange(branch, step, i)\"\n (edit)=\"onBranchStepChange(branch, step, i)\"\n (link)=\"onBranchStepChange(branch, step, i)\"\n (duplicate)=\"onBranchStepChange(branch, step, i)\"\n (conditionChange)=\"$any(step).condition = $event; onBranchStepChange(branch, step, i)\"\n (addBranch)=\"onNestedConditionAddBranch($any(step)); onBranchStepChange(branch, step, i)\"\n (deleteBranch)=\"onNestedConditionDeleteBranch($any(step), $event); onBranchStepChange(branch, step, i)\"\n (testDataProfileChange)=\"$any(step).testDataProfile = $event; onBranchStepChange(branch, step, i)\"\n (startStepChange)=\"$any(step).startStep = $event; onBranchStepChange(branch, step, i)\"\n (endStepChange)=\"$any(step).endStep = $event; onBranchStepChange(branch, step, i)\"\n (maxIterationsChange)=\"$any(step).maxIterations = $event; onBranchStepChange(branch, step, i)\"\n (eventTypeChange)=\"$any(step).eventType = $event; onBranchStepChange(branch, step, i)\"\n (parameterChange)=\"onBranchStepChange(branch, step, i)\"\n (selectionChange)=\"$any(step).selected = $event; onBranchStepChange(branch, step, i)\"\n (loadMoreDataProfiles)=\"loadMoreDataProfiles.emit($event)\"\n (searchDataProfiles)=\"searchDataProfiles.emit($event)\"\n (stepUpdate)=\"stepUpdate.emit($event)\"\n (dndDropInZone)=\"dndDropInZone.emit($event)\"\n >\n </cqa-test-case-details-renderer>\n </div>\n </div>\n </div>\n\n <!-- END IF Marker -->\n <div [class]=\"'cqa-pl-4 cqa-py-1 cqa-text-[#7B3306] cqa-text-[10px] cqa-leading-[15px] cqa-font-medium'\" style=\"border-top: 1px solid #E5E7EB;\">\n END IF\n </div>\n </div>\n</div>" }]
731
+ }], ctorParameters: function () { return [{ type: i1.FormBuilder }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { config: [{
262
732
  type: Input
263
733
  }], id: [{
264
734
  type: Input
@@ -276,6 +746,16 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImpor
276
746
  type: Input
277
747
  }], isReorder: [{
278
748
  type: Input
749
+ }], dataProfileOptions: [{
750
+ type: Input
751
+ }], hasMoreDataProfiles: [{
752
+ type: Input
753
+ }], isLoadingDataProfiles: [{
754
+ type: Input
755
+ }], naturalTextActionsOptions: [{
756
+ type: Input
757
+ }], setConditionTemplateVariables: [{
758
+ type: Input
279
759
  }], toggleExpanded: [{
280
760
  type: Output
281
761
  }], conditionChange: [{
@@ -288,6 +768,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImpor
288
768
  type: Output
289
769
  }], addBranch: [{
290
770
  type: Output
771
+ }], addElse: [{
772
+ type: Output
291
773
  }], deleteBranch: [{
292
774
  type: Output
293
775
  }], duplicate: [{
@@ -298,5 +780,11 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImpor
298
780
  type: Output
299
781
  }], dndDropInZone: [{
300
782
  type: Output
783
+ }], loadMoreDataProfiles: [{
784
+ type: Output
785
+ }], searchDataProfiles: [{
786
+ type: Output
787
+ }], stepUpdate: [{
788
+ type: Output
301
789
  }] } });
302
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"condition-step.component.js","sourceRoot":"","sources":["../../../../../../src/lib/test-case-details/condition-step/condition-step.component.ts","../../../../../../src/lib/test-case-details/condition-step/condition-step.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,KAAK,EAAE,MAAM,EAAE,YAAY,EAAU,MAAM,eAAe,CAAC;AAG/E,OAAO,EAA+G,SAAS,EAAE,MAAM,0BAA0B,CAAC;AAClK,OAAO,EAAE,uBAAuB,EAAE,MAAM,4BAA4B,CAAC;;;;;;;;;AASrE,MAAM,OAAO,8BAA8B;IAuCzC,YAAoB,EAAe;QAAf,OAAE,GAAF,EAAE,CAAa;QAlC1B,aAAQ,GAAsB,EAAE,CAAC;QACjC,aAAQ,GAAY,IAAI,CAAC;QACzB,aAAQ,GAAY,KAAK,CAAC;QAC1B,iBAAY,GAAY,KAAK,CAAC;QAC9B,cAAS,GAAY,KAAK,CAAC;QAEpC,uFAAuF;QACvF,cAAS,GAAY,KAAK,CAAC;QAQ3B,iCAAiC;QACzB,iBAAY,GAAoF,EAAE,CAAC;QAEjG,mBAAc,GAAG,IAAI,YAAY,EAAoD,CAAC;QACtF,oBAAe,GAAG,IAAI,YAAY,EAAU,CAAC;QAC7C,qBAAgB,GAAG,IAAI,YAAY,EAA4E,CAAC;QAChH,YAAO,GAAG,IAAI,YAAY,EAA+B,CAAC;QAC1D,eAAU,GAAG,IAAI,YAAY,EAAkD,CAAC;QAChF,cAAS,GAAG,IAAI,YAAY,EAAQ,CAAC;QACrC,iBAAY,GAAG,IAAI,YAAY,EAAmB,CAAC;QACnD,cAAS,GAAG,IAAI,YAAY,EAAQ,CAAC;QACrC,WAAM,GAAG,IAAI,YAAY,EAAQ,CAAC;QAClC,gBAAW,GAAG,IAAI,YAAY,EAAQ,CAAC;QACvC,kBAAa,GAAG,IAAI,YAAY,EAA6D,CAAC;IAMlE,CAAC;IAJvC,SAAS,CAAC,KAAmB,EAAE,MAAuB;QACpD,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,UAAU,EAAE,MAAM,CAAC,WAAW,EAAE,CAAC,CAAC;IACrE,CAAC;IAID,QAAQ;QACN,IAAI,IAAI,CAAC,MAAM,EAAE;YACf,IAAI,CAAC,EAAE,GAAG,IAAI,CAAC,MAAM,CAAC,EAAE,CAAC;YACzB,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC;YACzC,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC;YACvC,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,MAAM,CAAC,QAAQ,IAAI,EAAE,CAAC;YAC3C,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,MAAM,CAAC,QAAQ,KAAK,SAAS,CAAC,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC;SAClF;QACD,IAAI,CAAC,aAAa,EAAE,CAAC;QACrB,IAAI,CAAC,yBAAyB,EAAE,CAAC;IACnC,CAAC;IAEO,aAAa;QACnB,MAAM,EAAE,IAAI,EAAE,QAAQ,EAAE,KAAK,EAAE,GAAG,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QACtE,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,EAAE,CAAC,KAAK,CAAC;YAC5B,aAAa,EAAE,CAAC,IAAI,CAAC;YACrB,iBAAiB,EAAE,CAAC,QAAQ,CAAC;YAC7B,cAAc,EAAE,CAAC,KAAK,CAAC;SACxB,CAAC,CAAC;IACL,CAAC;IAEO,yBAAyB;QAC/B,MAAM,OAAO,GAAmB;YAC9B,EAAE,EAAE,EAAE,IAAI,EAAE,KAAK,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,KAAK,EAAE,IAAI,EAAE;YAClD,EAAE,EAAE,EAAE,QAAQ,EAAE,KAAK,EAAE,QAAQ,EAAE,IAAI,EAAE,QAAQ,EAAE,KAAK,EAAE,QAAQ,EAAE;YAClE,EAAE,EAAE,EAAE,UAAU,EAAE,KAAK,EAAE,UAAU,EAAE,IAAI,EAAE,UAAU,EAAE,KAAK,EAAE,UAAU,EAAE;YAC1E,EAAE,EAAE,EAAE,QAAQ,EAAE,KAAK,EAAE,QAAQ,EAAE,IAAI,EAAE,QAAQ,EAAE,KAAK,EAAE,QAAQ,EAAE;YAClE,EAAE,EAAE,EAAE,aAAa,EAAE,KAAK,EAAE,aAAa,EAAE,IAAI,EAAE,aAAa,EAAE,KAAK,EAAE,aAAa,EAAE;YACtF,EAAE,EAAE,EAAE,WAAW,EAAE,KAAK,EAAE,WAAW,EAAE,IAAI,EAAE,WAAW,EAAE,KAAK,EAAE,WAAW,EAAE;SAC/E,CAAC;QACF,IAAI,CAAC,oBAAoB,GAAG;YAC1B,GAAG,EAAE,mBAAmB;YACxB,WAAW,EAAE,UAAU;YACvB,UAAU,EAAE,KAAK;YACjB,OAAO;SACR,CAAC;IACJ,CAAC;IAED,qFAAqF;IAC7E,cAAc,CAAC,CAAS;QAC9B,IAAI,CAAC,CAAC,IAAI,OAAO,CAAC,KAAK,QAAQ,EAAE;YAC/B,OAAO,EAAE,IAAI,EAAE,UAAU,EAAE,QAAQ,EAAE,IAAI,EAAE,KAAK,EAAE,SAAS,EAAE,CAAC;SAC/D;QACD,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,CAAC;QACnB,MAAM,SAAS,GAAG,CAAC,UAAU,EAAE,MAAM,EAAE,YAAY,EAAE,UAAU,EAAE,eAAe,EAAE,aAAa,CAAC,CAAC;QACjG,KAAK,MAAM,EAAE,IAAI,SAAS,EAAE;YAC1B,MAAM,CAAC,GAAG,CAAC,CAAC,WAAW,EAAE,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;YACtC,IAAI,CAAC,KAAK,CAAC,CAAC,EAAE;gBACZ,OAAO;oBACL,IAAI,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,EAAE;oBAC1B,QAAQ,EAAE,EAAE,CAAC,IAAI,EAAE;oBACnB,KAAK,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,CAAC,IAAI,EAAE;iBACrC,CAAC;aACH;SACF;QACD,OAAO,EAAE,IAAI,EAAE,CAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,KAAK,EAAE,EAAE,EAAE,CAAC;IAChD,CAAC;IAED,8CAA8C;IACtC,sBAAsB;QAC5B,MAAM,IAAI,GAAG,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,eAAe,CAAC,EAAE,KAAK,IAAI,EAAE,CAAC;QAC7D,MAAM,EAAE,GAAG,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,mBAAmB,CAAC,EAAE,KAAK,IAAI,IAAI,CAAC;QACjE,MAAM,KAAK,GAAG,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,gBAAgB,CAAC,EAAE,KAAK,IAAI,EAAE,CAAC;QAC/D,OAAO,CAAC,IAAI,EAAE,EAAE,EAAE,KAAK,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;IACrD,CAAC;IAED,qBAAqB,CAAC,WAAmB,EAAE,KAAa;QACtD,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,WAAW,CAAC,EAAE,QAAQ,CAAC,KAAK,CAAC,CAAC;IAClD,CAAC;IAED,eAAe;QACb,MAAM,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC,MAAM,CACnC,CAAC,GAAG,EAAE,MAAM,EAAE,EAAE,CAAC,GAAG,CAAC,MAAM,CAAC,MAAM,CAAC,WAAW,CAAC,EAC/C,EAAE,CACH,CAAC;QACF,IAAI,QAAQ,CAAC,MAAM,KAAK,CAAC,EAAE;YACzB,OAAO,SAAS,CAAC;SAClB;QACD,MAAM,SAAS,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAC;QAC9B,MAAM,QAAQ,GAAG,QAAQ,CAAC,QAAQ,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;QAC/C,MAAM,KAAK,GAAI,SAAiB,CAAC,UAAU,IAAI,CAAC,CAAC;QACjD,MAAM,GAAG,GAAI,QAAgB,CAAC,UAAU,IAAI,QAAQ,CAAC,MAAM,CAAC;QAC5D,MAAM,KAAK,GAAG,QAAQ,CAAC,MAAM,CAAC;QAC9B,OAAO,SAAS,KAAK,IAAI,GAAG,KAAK,KAAK,QAAQ,KAAK,KAAK,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,GAAG,CAAC;IAC1E,CAAC;IAED,gBAAgB;QACd,IAAI,CAAC,QAAQ,GAAG,CAAC,IAAI,CAAC,QAAQ,CAAC;QAC/B,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,EAAC,MAAM,EAAC,IAAI,CAAC,MAAM,EAAE,QAAQ,EAAC,IAAI,CAAC,QAAQ,EAAC,CAAC,CAAC;IACzE,CAAC;IAED,iBAAiB,CAAC,KAAa;QAC7B,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;QACvB,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACnC,CAAC;IAED,kBAAkB,CAAC,MAAuB,EAAE,IAAwB,EAAE,SAAiB;QACrF,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,EAAE,MAAM,EAAE,IAAI,EAAE,SAAS,EAAE,CAAC,CAAC;IAC1D,CAAC;IAED,sBAAsB,CAAC,KAAgE,EAAE,MAAuB,EAAE,IAAwB,EAAE,KAAa;QACvJ,yCAAyC;QACzC,IAAI,OAAO,KAAK,KAAK,QAAQ,IAAI,KAAK,KAAK,IAAI,IAAI,UAAU,IAAI,KAAK,EAAE;YACtE,oDAAoD;YACnD,IAAY,CAAC,QAAQ,GAAG,KAAK,CAAC,QAAQ,CAAC;YACxC,+DAA+D;YAC/D,IAAI,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,EAAE;gBAC1B,0DAA0D;gBAC1D,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,KAAyD,CAAC,CAAC;aACrF;SACF;aAAM;YACL,uCAAuC;YACtC,IAAY,CAAC,QAAQ,GAAG,KAAgB,CAAC;SAC3C;QACD,IAAI,CAAC,kBAAkB,CAAC,MAAM,EAAE,IAAI,EAAE,KAAK,CAAC,CAAC;IAC/C,CAAC;IAED,SAAS,CAAC,MAAuB;QAC/B,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,MAAM,EAAE,CAAC,CAAC;IAChC,CAAC;IAED,YAAY,CAAC,MAAuB,EAAE,SAAiB;QACrD,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,EAAE,MAAM,EAAE,SAAS,EAAE,CAAC,CAAC;IAC9C,CAAC;IAED,WAAW;QACT,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,CAAC;IACxB,CAAC;IAED,cAAc,CAAC,MAAuB;QACpC,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IACjC,CAAC;IAED,0BAA0B,CAAC,UAA+B;QACxD,gDAAgD;QAChD,IAAI,CAAC,UAAU,CAAC,QAAQ,EAAE;YACxB,UAAU,CAAC,QAAQ,GAAG,EAAE,CAAC;SAC1B;QACD,MAAM,SAAS,GAAoB;YACjC,IAAI,EAAE,UAAU,CAAC,QAAQ,CAAC,MAAM,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,MAAM;YACtD,KAAK,EAAE,UAAU,CAAC,QAAQ,CAAC,MAAM,KAAK,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,MAAM;YAC5D,QAAQ,EAAE,SAAS,CAAC,YAAY;YAChC,WAAW,EAAE,EAAE;SAChB,CAAC;QACF,UAAU,CAAC,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;IACtC,CAAC;IAED,6BAA6B,CAAC,UAA+B,EAAE,MAAuB;QACpF,iDAAiD;QACjD,IAAI,UAAU,CAAC,QAAQ,EAAE;YACvB,MAAM,KAAK,GAAG,UAAU,CAAC,QAAQ,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC;YAClD,IAAI,KAAK,GAAG,CAAC,CAAC,EAAE;gBACd,UAAU,CAAC,QAAQ,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC;aACtC;SACF;IACH,CAAC;IAED,YAAY,CAAC,IAAwB;QACnC,OAAO,WAAW,IAAI,IAAI,CAAC;IAC7B,CAAC;IAED,UAAU,CAAC,IAAwB;QACjC,OAAO,UAAU,IAAI,IAAI,CAAC;IAC5B,CAAC;IAED,eAAe,CAAC,IAAwB;QACtC,OAAO,WAAW,IAAI,IAAI,IAAI,UAAU,IAAI,IAAI,CAAC;IACnD,CAAC;IAED,WAAW,CAAC,IAAwB;QAClC,OAAO,WAAW,IAAI,IAAI,CAAC;IAC7B,CAAC;IAED,cAAc,CAAC,MAAuB;QACpC,OAAO,MAAM,CAAC,KAAK,IAAI,CAAC,MAAM,CAAC,IAAI,KAAK,IAAI,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,MAAM,CAAC,IAAI,KAAK,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC;IAC7G,CAAC;IAED,mBAAmB,CAAC,MAAuB;QACzC,IAAI,MAAM,CAAC,IAAI,KAAK,IAAI,EAAE;YACxB,OAAO,oBAAoB,CAAC;SAC7B;aAAM,IAAI,MAAM,CAAC,IAAI,KAAK,SAAS,EAAE;YACpC,OAAO,wCAAwC,CAAC;SACjD;aAAM;YACL,OAAO,kCAAkC,CAAC;SAC3C;IACH,CAAC;IAED,kBAAkB,CAAC,MAAuB;QACxC,IAAI,MAAM,CAAC,IAAI,KAAK,IAAI,EAAE;YACxB,OAAO,oBAAoB,CAAC;SAC7B;aAAM,IAAI,MAAM,CAAC,IAAI,KAAK,SAAS,EAAE;YACpC,OAAO,qBAAqB,CAAC;SAC9B;aAAM;YACL,OAAO,kBAAkB,CAAC;SAC3B;IACH,CAAC;IAED,cAAc;QACZ,mEAAmE;IACrE,CAAC;IAED,MAAM;QACJ,IAAI,CAAC,YAAY,GAAG;YAClB,aAAa,EAAE,IAAI,CAAC,QAAQ,EAAE,GAAG,CAAC,eAAe,CAAC,EAAE,KAAK;YACzD,iBAAiB,EAAE,IAAI,CAAC,QAAQ,EAAE,GAAG,CAAC,mBAAmB,CAAC,EAAE,KAAK;YACjE,cAAc,EAAE,IAAI,CAAC,QAAQ,EAAE,GAAG,CAAC,gBAAgB,CAAC,EAAE,KAAK;SAC5D,CAAC;QACF,MAAM,EAAE,IAAI,EAAE,QAAQ,EAAE,KAAK,EAAE,GAAG,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QACtE,IAAI,CAAC,QAAQ,EAAE,GAAG,CAAC,eAAe,CAAC,EAAE,QAAQ,CAAC,IAAI,CAAC,CAAC;QACpD,IAAI,CAAC,QAAQ,EAAE,GAAG,CAAC,mBAAmB,CAAC,EAAE,QAAQ,CAAC,QAAQ,CAAC,CAAC;QAC5D,IAAI,CAAC,QAAQ,EAAE,GAAG,CAAC,gBAAgB,CAAC,EAAE,QAAQ,CAAC,KAAK,CAAC,CAAC;QACtD,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;IACxB,CAAC;IAED,YAAY;QACV,IAAI,CAAC,QAAQ,EAAE,GAAG,CAAC,eAAe,CAAC,EAAE,QAAQ,CAAC,IAAI,CAAC,YAAY,CAAC,aAAa,IAAI,EAAE,CAAC,CAAC;QACrF,IAAI,CAAC,QAAQ,EAAE,GAAG,CAAC,mBAAmB,CAAC,EAAE,QAAQ,CAAC,IAAI,CAAC,YAAY,CAAC,iBAAiB,IAAI,IAAI,CAAC,CAAC;QAC/F,IAAI,CAAC,QAAQ,EAAE,GAAG,CAAC,gBAAgB,CAAC,EAAE,QAAQ,CAAC,IAAI,CAAC,YAAY,CAAC,cAAc,IAAI,EAAE,CAAC,CAAC;QACvF,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;IACzB,CAAC;IAED,WAAW;QACT,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,sBAAsB,EAAE,CAAC;QAC/C,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QAC1C,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;IACzB,CAAC;IAED,aAAa;QACX,IAAI,CAAC,WAAW,CAAC,IAAI,EAAE,CAAC;IAC1B,CAAC;IAED,MAAM;QACJ,mEAAmE;IACrE,CAAC;IAED,WAAW;QACT,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,CAAC;IACxB,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,MAAM,CAAC,IAAI,EAAE,CAAC;IACrB,CAAC;IAED,aAAa;QACX,IAAI,CAAC,WAAW,CAAC,IAAI,EAAE,CAAC;IAC1B,CAAC;;2HA9RU,8BAA8B;+GAA9B,8BAA8B,koBCb3C,83hBAyNM;2FD5MO,8BAA8B;kBAN1C,SAAS;+BACE,8BAA8B,QAElC,EAAE,KAAK,EAAE,aAAa,EAAE,UACtB,CAAC,uBAAuB,CAAC;kGAGxB,MAAM;sBAAd,KAAK;gBACG,EAAE;sBAAV,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,YAAY;sBAApB,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBAcI,cAAc;sBAAvB,MAAM;gBACG,eAAe;sBAAxB,MAAM;gBACG,gBAAgB;sBAAzB,MAAM;gBACG,OAAO;sBAAhB,MAAM;gBACG,UAAU;sBAAnB,MAAM;gBACG,SAAS;sBAAlB,MAAM;gBACG,YAAY;sBAArB,MAAM;gBACG,SAAS;sBAAlB,MAAM;gBACG,MAAM;sBAAf,MAAM;gBACG,WAAW;sBAApB,MAAM;gBACG,aAAa;sBAAtB,MAAM","sourcesContent":["import { Component, Input, Output, EventEmitter, OnInit } from '@angular/core';\nimport { FormBuilder, FormGroup } from '@angular/forms';\nimport { DndDropEvent } from 'ngx-drag-drop';\nimport { ConditionStepConfig, ConditionBranch, TestCaseStepConfig, NormalStepConfig, LoopStepConfig, StepGroupConfig, StepTypes } from '../test-case-step.models';\nimport { STEP_ROW_ACTIONS_STYLES } from '../step-row-actions.styles';\nimport { DynamicSelectFieldConfig, SelectOption } from '../../dynamic-select/dynamic-select-field.component';\n\n@Component({\n  selector: 'cqa-test-case-condition-step',\n  templateUrl: './condition-step.component.html',\n  host: { class: 'cqa-ui-root' },\n  styles: [STEP_ROW_ACTIONS_STYLES],\n})\nexport class TestCaseConditionStepComponent implements OnInit {\n  @Input() config!: ConditionStepConfig;\n  @Input() id!: string;\n  @Input() stepNumber!: number | string;\n  @Input() condition!: string;\n  @Input() branches: ConditionBranch[] = [];\n  @Input() expanded: boolean = true;\n  @Input() isNested: boolean = false;\n  @Input() isInsideLoop: boolean = false;\n  @Input() isReorder: boolean = false;\n\n  /** When true, header shows inline edit form (fields, operator select, Cancel/Apply) */\n  isEditing: boolean = false;\n\n  /** Form for edit mode; bound to cqa-dynamic-select and cqa-custom-input */\n  editForm!: FormGroup;\n\n  /** Operator dropdown config (IS, IS NOT, CONTAINS, etc.) */\n  operatorSelectConfig!: DynamicSelectFieldConfig;\n\n  /** Snapshot for Cancel revert */\n  private editSnapshot: { conditionLeft?: string; conditionOperator?: string; conditionRight?: string } = {};\n\n  @Output() toggleExpanded = new EventEmitter<{config: ConditionStepConfig, expanded: boolean}>();\n  @Output() conditionChange = new EventEmitter<string>();\n  @Output() branchStepChange = new EventEmitter<{ branch: ConditionBranch; step: TestCaseStepConfig; stepIndex: number }>();\n  @Output() addStep = new EventEmitter<{ branch: ConditionBranch }>();\n  @Output() deleteStep = new EventEmitter<{ branch: ConditionBranch; stepIndex: number }>();\n  @Output() addBranch = new EventEmitter<void>();\n  @Output() deleteBranch = new EventEmitter<ConditionBranch>();\n  @Output() duplicate = new EventEmitter<void>();\n  @Output() delete = new EventEmitter<void>();\n  @Output() moreOptions = new EventEmitter<void>();\n  @Output() dndDropInZone = new EventEmitter<{ event: DndDropEvent; targetList: TestCaseStepConfig[] }>();\n\n  onDndDrop(event: DndDropEvent, branch: ConditionBranch): void {\n    this.dndDropInZone.emit({ event, targetList: branch.nestedSteps });\n  }\n\n  constructor(private fb: FormBuilder) {}\n\n  ngOnInit(): void {\n    if (this.config) {\n      this.id = this.config.id;\n      this.stepNumber = this.config.stepNumber;\n      this.condition = this.config.condition;\n      this.branches = this.config.branches || [];\n      this.expanded = this.config.expanded !== undefined ? this.config.expanded : true;\n    }\n    this.buildEditForm();\n    this.buildOperatorSelectConfig();\n  }\n\n  private buildEditForm(): void {\n    const { left, operator, right } = this.parseCondition(this.condition);\n    this.editForm = this.fb.group({\n      conditionLeft: [left],\n      conditionOperator: [operator],\n      conditionRight: [right],\n    });\n  }\n\n  private buildOperatorSelectConfig(): void {\n    const options: SelectOption[] = [\n      { id: 'is', value: 'is', name: 'IS', label: 'IS' },\n      { id: 'is not', value: 'is not', name: 'IS NOT', label: 'IS NOT' },\n      { id: 'contains', value: 'contains', name: 'CONTAINS', label: 'CONTAINS' },\n      { id: 'equals', value: 'equals', name: 'EQUALS', label: 'EQUALS' },\n      { id: 'starts with', value: 'starts with', name: 'STARTS WITH', label: 'STARTS WITH' },\n      { id: 'ends with', value: 'ends with', name: 'ENDS WITH', label: 'ENDS WITH' },\n    ];\n    this.operatorSelectConfig = {\n      key: 'conditionOperator',\n      placeholder: 'Operator',\n      searchable: false,\n      options,\n    };\n  }\n\n  /** Parse condition string into left, operator, right (e.g. \"Usertype is Premium\") */\n  private parseCondition(c: string): { left: string; operator: string; right: string } {\n    if (!c || typeof c !== 'string') {\n      return { left: 'Usertype', operator: 'is', right: 'Premium' };\n    }\n    const s = c.trim();\n    const operators = [' is not ', ' is ', ' contains ', ' equals ', ' starts with ', ' ends with '];\n    for (const op of operators) {\n      const i = s.toLowerCase().indexOf(op);\n      if (i !== -1) {\n        return {\n          left: s.slice(0, i).trim(),\n          operator: op.trim(),\n          right: s.slice(i + op.length).trim(),\n        };\n      }\n    }\n    return { left: s, operator: 'is', right: '' };\n  }\n\n  /** Build condition string from form values */\n  private buildConditionFromForm(): string {\n    const left = this.editForm.get('conditionLeft')?.value ?? '';\n    const op = this.editForm.get('conditionOperator')?.value ?? 'is';\n    const right = this.editForm.get('conditionRight')?.value ?? '';\n    return [left, op, right].filter(Boolean).join(' ');\n  }\n\n  onEditFormFieldChange(controlName: string, value: string): void {\n    this.editForm.get(controlName)?.setValue(value);\n  }\n\n  getStepsSummary(): string {\n    const allSteps = this.branches.reduce<TestCaseStepConfig[]>(\n      (acc, branch) => acc.concat(branch.nestedSteps),\n      []\n    );\n    if (allSteps.length === 0) {\n      return '0 steps';\n    }\n    const firstStep = allSteps[0];\n    const lastStep = allSteps[allSteps.length - 1];\n    const start = (firstStep as any).stepNumber || 1;\n    const end = (lastStep as any).stepNumber || allSteps.length;\n    const count = allSteps.length;\n    return `Steps ${start}-${end} (${count} step${count !== 1 ? 's' : ''})`;\n  }\n\n  onToggleExpanded(): void {\n    this.expanded = !this.expanded;\n    this.toggleExpanded.emit({config:this.config, expanded:this.expanded});\n  }\n\n  onConditionChange(value: string): void {\n    this.condition = value;\n    this.conditionChange.emit(value);\n  }\n\n  onBranchStepChange(branch: ConditionBranch, step: TestCaseStepConfig, stepIndex: number): void {\n    this.branchStepChange.emit({ branch, step, stepIndex });\n  }\n\n  onNestedToggleExpanded(event: boolean | {config: TestCaseStepConfig, expanded: boolean}, branch: ConditionBranch, step: TestCaseStepConfig, index: number): void {\n    // Handle both boolean and object formats\n    if (typeof event === 'object' && event !== null && 'expanded' in event) {\n      // Object format from step-group: {config, expanded}\n      (step as any).expanded = event.expanded;\n      // If it's a step-group, we need to emit the event up the chain\n      if (this.isStepGroup(step)) {\n        // Re-emit the toggleExpanded event with the object format\n        this.toggleExpanded.emit(event as {config: ConditionStepConfig, expanded: boolean});\n      }\n    } else {\n      // Boolean format from other step types\n      (step as any).expanded = event as boolean;\n    }\n    this.onBranchStepChange(branch, step, index);\n  }\n\n  onAddStep(branch: ConditionBranch): void {\n    this.addStep.emit({ branch });\n  }\n\n  onDeleteStep(branch: ConditionBranch, stepIndex: number): void {\n    this.deleteStep.emit({ branch, stepIndex });\n  }\n\n  onAddBranch(): void {\n    this.addBranch.emit();\n  }\n\n  onDeleteBranch(branch: ConditionBranch): void {\n    this.deleteBranch.emit(branch);\n  }\n\n  onNestedConditionAddBranch(nestedStep: ConditionStepConfig): void {\n    // Add a new branch to the nested condition step\n    if (!nestedStep.branches) {\n      nestedStep.branches = [];\n    }\n    const newBranch: ConditionBranch = {\n      type: nestedStep.branches.length === 0 ? 'if' : 'else',\n      label: nestedStep.branches.length === 0 ? 'IF TRUE' : 'ELSE',\n      stepType: StepTypes.CONDITION_IF,\n      nestedSteps: []\n    };\n    nestedStep.branches.push(newBranch);\n  }\n\n  onNestedConditionDeleteBranch(nestedStep: ConditionStepConfig, branch: ConditionBranch): void {\n    // Delete a branch from the nested condition step\n    if (nestedStep.branches) {\n      const index = nestedStep.branches.indexOf(branch);\n      if (index > -1) {\n        nestedStep.branches.splice(index, 1);\n      }\n    }\n  }\n\n  isNormalStep(step: TestCaseStepConfig): step is NormalStepConfig {\n    return 'eventType' in step;\n  }\n\n  isLoopStep(step: TestCaseStepConfig): step is LoopStepConfig {\n    return 'loopType' in step;\n  }\n\n  isConditionStep(step: TestCaseStepConfig): step is ConditionStepConfig {\n    return 'condition' in step && 'branches' in step;\n  }\n\n  isStepGroup(step: TestCaseStepConfig): step is StepGroupConfig {\n    return 'groupName' in step;\n  }\n\n  getBranchLabel(branch: ConditionBranch): string {\n    return branch.label || (branch.type === 'if' ? 'IF TRUE' : branch.type === 'else-if' ? 'ELSE IF' : 'ELSE');\n  }\n\n  getBranchColorClass(branch: ConditionBranch): string {\n    if (branch.type === 'if') {\n      return 'cqa-bg-[#0DBD7D1A]';\n    } else if (branch.type === 'else-if') {\n      return 'cqa-bg-yellow-50 cqa-border-yellow-200';\n    } else {\n      return 'cqa-bg-red-50 cqa-border-red-200';\n    }\n  }\n\n  getBranchTextColor(branch: ConditionBranch): string {\n    if (branch.type === 'if') {\n      return 'cqa-text-[#0D542B]';\n    } else if (branch.type === 'else-if') {\n      return 'cqa-text-yellow-700';\n    } else {\n      return 'cqa-text-red-700';\n    }\n  }\n\n  onOpenExternal(): void {\n    // Not used in condition step, but needed for recursive step groups\n  }\n\n  onEdit(): void {\n    this.editSnapshot = {\n      conditionLeft: this.editForm?.get('conditionLeft')?.value,\n      conditionOperator: this.editForm?.get('conditionOperator')?.value,\n      conditionRight: this.editForm?.get('conditionRight')?.value,\n    };\n    const { left, operator, right } = this.parseCondition(this.condition);\n    this.editForm?.get('conditionLeft')?.setValue(left);\n    this.editForm?.get('conditionOperator')?.setValue(operator);\n    this.editForm?.get('conditionRight')?.setValue(right);\n    this.isEditing = true;\n  }\n\n  onEditCancel(): void {\n    this.editForm?.get('conditionLeft')?.setValue(this.editSnapshot.conditionLeft ?? '');\n    this.editForm?.get('conditionOperator')?.setValue(this.editSnapshot.conditionOperator ?? 'is');\n    this.editForm?.get('conditionRight')?.setValue(this.editSnapshot.conditionRight ?? '');\n    this.isEditing = false;\n  }\n\n  onEditApply(): void {\n    this.condition = this.buildConditionFromForm();\n    this.conditionChange.emit(this.condition);\n    this.isEditing = false;\n  }\n\n  onEditInDepth(): void {\n    this.moreOptions.emit();\n  }\n\n  onLink(): void {\n    // Not used in condition step, but needed for recursive step groups\n  }\n\n  onDuplicate(): void {\n    this.duplicate.emit();\n  }\n\n  onDelete(): void {\n    this.delete.emit();\n  }\n\n  onMoreOptions(): void {\n    this.moreOptions.emit();\n  }\n}\n","<div [class]=\"'cqa-flex cqa-flex-col cqa-border cqa-border-solid cqa-border-[#E5E7EB] ' + (isNested ? ' cqa-pl-[24px]' : '')\">\n  <!-- Inline Edit Mode: CONDITION tag, three fields, IF/ELSE chips, Edit In depth, Cancel/Apply -->\n  <div *ngIf=\"isEditing\" class=\"cqa-py-2.5 cqa-px-4 cqa-flex cqa-items-center cqa-gap-3 cqa-justify-between\">\n    <div class=\"cqa-flex cqa-items-center cqa-gap-3 cqa-flex-grow\">\n      <!-- CONDITION Tag (orange) -->\n      <span class=\"cqa-px-1.5 cqa-rounded-md cqa-text-[#EA580C] cqa-text-[10px] cqa-leading-[15px] cqa-font-medium cqa-bg-[#FFEDD5]\">\n        CONDITION\n      </span>\n\n      <!-- First field: left operand (e.g. Usertype) -->\n        <cqa-custom-input\n          [value]=\"editForm.get('conditionLeft')?.value ?? ''\"\n          (valueChange)=\"onEditFormFieldChange('conditionLeft', $event)\"\n          placeholder=\"Usertype\"\n          class=\"cqa-w-full cqa-max-w-[216px]\"\n          size=\"sm\">\n        </cqa-custom-input>\n\n      <!-- Operator: dynamic-select (IS, IS NOT, etc.) -->\n        <cqa-dynamic-select [form]=\"editForm\" [config]=\"operatorSelectConfig\" class=\"cqa-w-full cqa-max-w-[216px]\"></cqa-dynamic-select>\n\n      <!-- Third field: right operand (e.g. Premium) -->\n        <cqa-custom-input\n          [value]=\"editForm.get('conditionRight')?.value ?? ''\"\n          (valueChange)=\"onEditFormFieldChange('conditionRight', $event)\"\n          placeholder=\"Premium\"\n          class=\"cqa-w-full cqa-max-w-[216px]\"\n          size=\"sm\">\n        </cqa-custom-input>\n\n      <!-- IF / ELSE indicators -->\n      <span class=\"cqa-px-2 cqa-py-[2px] cqa-rounded-[4px] cqa-text-[8px] cqa-leading-[12px] cqa-bg-[#DCFCE7] cqa-text-[#008236] cqa-border cqa-border-solid cqa-border-[#B9F8CF] cqa-flex cqa-items-center cqa-gap-1.5\">\n        <svg width=\"8\" height=\"8\" viewBox=\"0 0 8 8\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M6.66634 2L2.99967 5.66667L1.33301 4\" stroke=\"#008236\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/></svg>\n        IF\n      </span>\n      <span class=\"cqa-px-2 cqa-py-[2px] cqa-rounded-[4px] cqa-text-[8px] cqa-leading-[12px] cqa-bg-[#F3F4F6] cqa-text-[#99A1AF] cqa-border cqa-border-solid cqa-border-[#E5E7EB] cqa-flex cqa-items-center cqa-gap-1.5\">\n        Add ELSE\n      </span>\n\n      <!-- Edit In depth link -->\n      <a href=\"#\" (click)=\"onEditInDepth(); $event.preventDefault()\"\n        class=\"cqa-text-[#3F43EE] cqa-text-[10px] cqa-leading-[15px] cqa-font-medium cqa-flex cqa-items-center cqa-gap-[2px] cqa-no-underline\">\n        Edit In depth\n        <svg width=\"8\" height=\"8\" viewBox=\"0 0 8 8\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M2.03809 6.74329L2.62809 7.33329L5.96142 3.99996L2.62809 0.666626L2.03809 1.25663L4.78142 3.99996L2.03809 6.74329Z\" fill=\"#3F43EE\"/></svg>\n      </a>      \n    </div>\n    <!-- Cancel / Apply -->\n    <cqa-button variant=\"outlined\" btnSize=\"lg\" [customClass]=\"'cqa-text-[14px] cqa-py-[9px]'\" [text]=\"'Cancel'\" (clicked)=\"onEditCancel()\"></cqa-button>\n    <cqa-button variant=\"filled\" btnSize=\"lg\" [customClass]=\"'cqa-text-[14px] cqa-py-[9px]'\" [text]=\"'Apply'\" (clicked)=\"onEditApply()\"></cqa-button>\n  </div>\n\n  <!-- Condition Header (normal view when not editing) -->\n  <div *ngIf=\"!isEditing\" [class]=\"'step-row cqa-flex cqa-items-center cqa-gap-3 cqa-py-2 ' + (isInsideLoop ? 'cqa-pl-10 cqa-pr-4' : 'cqa-px-4')\">\n    <!-- Expand/Collapse Icon -->\n    <button type=\"button\" (click)=\"onToggleExpanded()\" class=\"cqa-p-0\">\n      <svg [class.cqa-rotate-180]=\"!expanded\" class=\"cqa-transition-transform\" width=\"16\" height=\"16\"\n        viewBox=\"0 0 16 16\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n        <path d=\"M12 10L8 6L4 10\" stroke=\"#6B7280\" stroke-width=\"1.33333\" stroke-linecap=\"round\"\n          stroke-linejoin=\"round\" />\n      </svg>\n    </button>\n\n    <!-- IF/ELSE Icon -->\n    <div><svg width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n        <path d=\"M4 2V10\" stroke=\"#7B3306\" stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n        <path\n          d=\"M12 6C13.1046 6 14 5.10457 14 4C14 2.89543 13.1046 2 12 2C10.8954 2 10 2.89543 10 4C10 5.10457 10.8954 6 12 6Z\"\n          stroke=\"#7B3306\" stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n        <path\n          d=\"M4 14C5.10457 14 6 13.1046 6 12C6 10.8954 5.10457 10 4 10C2.89543 10 2 10.8954 2 12C2 13.1046 2.89543 14 4 14Z\"\n          stroke=\"#7B3306\" stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n        <path d=\"M12 6C12 7.5913 11.3679 9.11742 10.2426 10.2426C9.11742 11.3679 7.5913 12 6 12\" stroke=\"#7B3306\"\n          stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n      </svg></div>\n\n    <!-- IF/ELSE Label -->\n    <span class=\"cqa-font-semibold cqa-text-[#7B3306] cqa-text-[12px] cqa-leading-none\">\n      IF / ELSE\n    </span>\n\n    <!-- Condition Input -->\n    <div class=\"cqa-flex cqa-items-center cqa-gap-3 cqa-ml-2 cqa-flex-1\">\n      <span [innerHTML]=\"condition\"></span>\n      <!-- <span class=\"cqa-text-[#6B7280] cqa-text-[14px] cqa-leading-[18px]\">\n        If\n      </span>\n      <span\n        class=\"cqa-py-0.5 cqa-px-2 cqa-text-[#3F43EE] cqa-text-[14px] cqa-leading-[17px] cqa-font-semibold cqa-border cqa-border-solid cqa-border-[#8A8CF4] cqa-rounded cqa-bg-[#D8D9FC]\">.success-message</span>\n      <span class=\"cqa-text-[#6B7280] cqa-text-[14px] cqa-leading-[18px]\">\n        is visible\n      </span> -->\n      <!-- <input\n        type=\"text\"\n        [value]=\"condition\"\n        (input)=\"onConditionChange($any($event.target).value)\"\n        placeholder=\"element `.success-message` is visible\"\n        class=\"cqa-px-3 cqa-py-1.5 cqa-rounded-lg cqa-border cqa-border-gray-300 cqa-bg-white cqa-text-gray-900 cqa-text-sm cqa-flex-1 cqa-max-w-md cqa-outline-none focus:cqa-ring-2 focus:cqa-ring-primary focus:cqa-ring-opacity-50\"\n      /> -->\n    </div>\n\n    <!-- Steps Summary -->\n    <div\n      class=\"cqa-ml-auto cqa-border cqa-border-solid cqa-border-[#E5E5E5] cqa-rounded-lg cqa-py-0.5 cqa-px-2 cqa-text-[#0A0A0A] cqa-text-[12px] cqa-leading-[15px]\">\n      {{ getStepsSummary() }}\n    </div>\n\n    <!-- Action Icons: Edit, Link, Duplicate, Delete (show on hover) -->\n    <div class=\"step-actions cqa-flex cqa-items-center cqa-gap-3 cqa-px-[7px]\">\n      <button type=\"button\" (click)=\"onEdit(); $event.stopPropagation()\" title=\"Edit\" class=\"cqa-p-0 cqa-text-[#99A1Af] hover:cqa-text-[#1447E6]\">\n        <svg width=\"14\" height=\"14\" viewBox=\"0 0 14 14\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M7 11.6666H12.25\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M9.55208 2.1128C9.7843 1.88058 10.0993 1.75012 10.4277 1.75012C10.7561 1.75012 11.071 1.88058 11.3033 2.1128C11.5355 2.34502 11.6659 2.65998 11.6659 2.98838C11.6659 3.31679 11.5355 3.63175 11.3033 3.86397L4.29742 10.8704C4.15864 11.0092 3.9871 11.1107 3.79867 11.1656L2.12333 11.6544C2.07314 11.669 2.01993 11.6699 1.96928 11.6569C1.91863 11.6439 1.8724 11.6176 1.83543 11.5806C1.79846 11.5437 1.7721 11.4974 1.75913 11.4468C1.74615 11.3961 1.74703 11.3429 1.76167 11.2927L2.2505 9.61738C2.30546 9.42916 2.40698 9.25783 2.54567 9.11922L9.55208 2.1128Z\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/></svg>\n      </button>\n      <button type=\"button\" (click)=\"onLink(); $event.stopPropagation()\" title=\"Link\" class=\"cqa-p-0 cqa-text-[#99A1Af] hover:cqa-text-[#1447E6]\">\n        <svg width=\"14\" height=\"14\" viewBox=\"0 0 14 14\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M5.00065 9.91671H3.66732C2.78326 9.91671 1.93542 9.60942 1.3103 9.06244C0.685174 8.51545 0.333984 7.77359 0.333984 7.00004C0.333984 6.22649 0.685174 5.48463 1.3103 4.93765C1.93542 4.39066 2.78326 4.08337 3.66732 4.08337H5.00065\" stroke=\"currentColor\" stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M9 4.08337H10.3333C11.2174 4.08337 12.0652 4.39066 12.6904 4.93765C13.3155 5.48463 13.6667 6.22649 13.6667 7.00004C13.6667 7.77359 13.3155 8.51545 12.6904 9.06244C12.0652 9.60942 11.2174 9.91671 10.3333 9.91671H9\" stroke=\"currentColor\" stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M4.33398 7H9.66732\" stroke=\"currentColor\" stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/></svg>\n      </button>\n      <button type=\"button\" (click)=\"onDuplicate(); $event.stopPropagation()\" title=\"Duplicate\" class=\"cqa-p-0 cqa-text-[#99A1Af] hover:cqa-text-[#1447E6]\">\n        <svg width=\"14\" height=\"14\" viewBox=\"0 0 14 14\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M11.666 4.66663H5.83268C5.18835 4.66663 4.66602 5.18896 4.66602 5.83329V11.6666C4.66602 12.311 5.18835 12.8333 5.83268 12.8333H11.666C12.3103 12.8333 12.8327 12.311 12.8327 11.6666V5.83329C12.8327 5.18896 12.3103 4.66663 11.666 4.66663Z\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M2.33268 9.33329C1.69102 9.33329 1.16602 8.80829 1.16602 8.16663V2.33329C1.16602 1.69163 1.69102 1.16663 2.33268 1.16663H8.16602C8.80768 1.16663 9.33268 1.69163 9.33268 2.33329\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/></svg>\n      </button>\n      <button type=\"button\" (click)=\"onDelete(); $event.stopPropagation()\" title=\"Delete\" class=\"cqa-p-0 cqa-text-[#ff6467] hover:cqa-text-[#C63535]\">\n        <svg width=\"14\" height=\"14\" viewBox=\"0 0 14 14\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M1.75 3.5H12.25\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M11.0827 3.5V11.6667C11.0827 12.25 10.4993 12.8333 9.91602 12.8333H4.08268C3.49935 12.8333 2.91602 12.25 2.91602 11.6667V3.5\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M4.66602 3.49996V2.33329C4.66602 1.74996 5.24935 1.16663 5.83268 1.16663H8.16602C8.74935 1.16663 9.33268 1.74996 9.33268 2.33329V3.49996\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M5.83398 6.41663V9.91663\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M8.16602 6.41663V9.91663\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/></svg>\n      </button>\n    </div>\n  </div>\n\n  <!-- Expanded Content with Branches -->\n  <div *ngIf=\"expanded\" class=\"cqa-flex cqa-flex-col\">\n    <!-- Branches (IF TRUE, ELSE IF, ELSE) -->\n    <div *ngFor=\"let branch of branches\" class=\"cqa-flex cqa-flex-col\">\n      <!-- Branch Header -->\n      <div\n        [class]=\"'cqa-px-4 cqa-py-2 cqa-text-[12px] cqa-leading-[15px] cqa-flex cqa-items-center cqa-gap-2 ' + getBranchTextColor(branch) + ' ' + getBranchColorClass(branch)\">\n        <span>{{ getBranchLabel(branch) }}</span>\n        <span *ngIf=\"branch.action\" [innerHTML]=\"branch.action\" class=\"cqa-text-[#111827]\"></span>\n      </div>\n\n      <!-- Branch Content (Nested Steps – renderer dispatches by step type, n-level nesting) -->\n      <div *ngIf=\"!isReorder\" class=\"cqa-flex cqa-flex-col\">\n        <cqa-test-case-details-renderer\n          *ngFor=\"let step of branch.nestedSteps; let i = index\"\n          [step]=\"step\"\n          [index]=\"i\"\n          [branch]=\"branch\"\n          [isNested]=\"true\"\n          [isReorder]=\"isReorder\"\n          (branchStepChange)=\"onBranchStepChange($event.branch, $event.step, $event.stepIndex)\"\n          (addStepForBranch)=\"onAddStep($event.branch)\"\n          (deleteStepWithBranch)=\"onDeleteStep($event.branch, $event.stepIndex)\"\n          (toggleExpanded)=\"onNestedToggleExpanded($event, branch, step, i)\"\n          (groupNameChange)=\"$any(step).groupName = $event; onBranchStepChange(branch, step, i)\"\n          (descriptionChange)=\"$any(step).description = $event; onBranchStepChange(branch, step, i)\"\n          (reusableChange)=\"$any(step).reusable = $event; onBranchStepChange(branch, step, i)\"\n          (openExternal)=\"onBranchStepChange(branch, step, i)\"\n          (edit)=\"onBranchStepChange(branch, step, i)\"\n          (link)=\"onBranchStepChange(branch, step, i)\"\n          (duplicate)=\"onBranchStepChange(branch, step, i)\"\n          (conditionChange)=\"$any(step).condition = $event; onBranchStepChange(branch, step, i)\"\n          (addBranch)=\"onNestedConditionAddBranch($any(step)); onBranchStepChange(branch, step, i)\"\n          (deleteBranch)=\"onNestedConditionDeleteBranch($any(step), $event); onBranchStepChange(branch, step, i)\"\n          (testDataProfileChange)=\"$any(step).testDataProfile = $event; onBranchStepChange(branch, step, i)\"\n          (startStepChange)=\"$any(step).startStep = $event; onBranchStepChange(branch, step, i)\"\n          (endStepChange)=\"$any(step).endStep = $event; onBranchStepChange(branch, step, i)\"\n          (maxIterationsChange)=\"$any(step).maxIterations = $event; onBranchStepChange(branch, step, i)\"\n          (eventTypeChange)=\"$any(step).eventType = $event; onBranchStepChange(branch, step, i)\"\n          (parameterChange)=\"onBranchStepChange(branch, step, i)\"\n          (selectionChange)=\"$any(step).selected = $event; onBranchStepChange(branch, step, i)\"\n          (dndDropInZone)=\"dndDropInZone.emit($event)\"\n        >\n        </cqa-test-case-details-renderer>\n      </div>\n      <div *ngIf=\"isReorder\" class=\"cqa-flex cqa-flex-col nested-step-drop-list\"\n           [dndDropzone]=\"['step']\"\n           dndEffectAllowed=\"move\"\n           dndDragoverClass=\"dndDragover\"\n           (dndDrop)=\"onDndDrop($event, branch)\">\n        <div dndPlaceholderRef class=\"step-drag-placeholder-nested cqa-my-1 cqa-min-h-[50px] cqa-border-2 cqa-border-dashed cqa-border-[#3F43EE] cqa-rounded cqa-bg-[rgba(63,67,238,0.08)] cqa-flex cqa-items-center cqa-justify-center cqa-text-[#3F43EE] cqa-text-xs\">Drop here</div>\n        <div *ngFor=\"let step of branch.nestedSteps; let i = index\" class=\"nested-step-drag-item\"\n             [dndDraggable]=\"step\"\n             dndEffectAllowed=\"move\"\n             dndType=\"step\">\n          <cqa-test-case-details-renderer\n            [step]=\"step\"\n            [index]=\"i\"\n            [branch]=\"branch\"\n            [isNested]=\"true\"\n            [isReorder]=\"isReorder\"\n            (branchStepChange)=\"onBranchStepChange($event.branch, $event.step, $event.stepIndex)\"\n            (addStepForBranch)=\"onAddStep($event.branch)\"\n            (deleteStepWithBranch)=\"onDeleteStep($event.branch, $event.stepIndex)\"\n            (toggleExpanded)=\"onNestedToggleExpanded($event, branch, step, i)\"\n            (groupNameChange)=\"$any(step).groupName = $event; onBranchStepChange(branch, step, i)\"\n            (descriptionChange)=\"$any(step).description = $event; onBranchStepChange(branch, step, i)\"\n            (reusableChange)=\"$any(step).reusable = $event; onBranchStepChange(branch, step, i)\"\n            (openExternal)=\"onBranchStepChange(branch, step, i)\"\n            (edit)=\"onBranchStepChange(branch, step, i)\"\n            (link)=\"onBranchStepChange(branch, step, i)\"\n            (duplicate)=\"onBranchStepChange(branch, step, i)\"\n            (conditionChange)=\"$any(step).condition = $event; onBranchStepChange(branch, step, i)\"\n            (addBranch)=\"onNestedConditionAddBranch($any(step)); onBranchStepChange(branch, step, i)\"\n            (deleteBranch)=\"onNestedConditionDeleteBranch($any(step), $event); onBranchStepChange(branch, step, i)\"\n            (testDataProfileChange)=\"$any(step).testDataProfile = $event; onBranchStepChange(branch, step, i)\"\n            (startStepChange)=\"$any(step).startStep = $event; onBranchStepChange(branch, step, i)\"\n            (endStepChange)=\"$any(step).endStep = $event; onBranchStepChange(branch, step, i)\"\n            (maxIterationsChange)=\"$any(step).maxIterations = $event; onBranchStepChange(branch, step, i)\"\n            (eventTypeChange)=\"$any(step).eventType = $event; onBranchStepChange(branch, step, i)\"\n            (parameterChange)=\"onBranchStepChange(branch, step, i)\"\n            (selectionChange)=\"$any(step).selected = $event; onBranchStepChange(branch, step, i)\"\n            (dndDropInZone)=\"dndDropInZone.emit($event)\"\n          >\n          </cqa-test-case-details-renderer>\n        </div>\n      </div>\n    </div>\n\n    <!-- END IF Marker -->\n    <div [class]=\"'cqa-pl-4 cqa-py-1 cqa-text-[#7B3306] cqa-text-[10px] cqa-leading-[15px] cqa-font-medium'\" style=\"border-top: 1px solid #E5E7EB;\">\n      END IF\n    </div>\n  </div>\n</div>"]}
790
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"condition-step.component.js","sourceRoot":"","sources":["../../../../../../src/lib/test-case-details/condition-step/condition-step.component.ts","../../../../../../src/lib/test-case-details/condition-step/condition-step.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, Output, EventEmitter, OnInit, OnChanges, ChangeDetectorRef } from '@angular/core';\nimport { FormBuilder, FormGroup, FormControl } from '@angular/forms';\nimport { DndDropEvent } from 'ngx-drag-drop';\nimport { ConditionStepConfig, ConditionBranch, TestCaseStepConfig, NormalStepConfig, LoopStepConfig, StepGroupConfig, StepTypes } from '../test-case-step.models';\nimport { STEP_ROW_ACTIONS_STYLES } from '../step-row-actions.styles';\nimport { DynamicSelectFieldConfig, SelectOption } from '../../dynamic-select/dynamic-select-field.component';\nimport { CqaAutocompleteOption } from '../../autocomplete/autocomplete.model';\n\n@Component({\n  selector: 'cqa-test-case-condition-step',\n  templateUrl: './condition-step.component.html',\n  host: { class: 'cqa-ui-root' },\n  styles: [STEP_ROW_ACTIONS_STYLES],\n})\nexport class TestCaseConditionStepComponent implements OnInit, OnChanges {\n  @Input() config!: ConditionStepConfig;\n  @Input() id!: string;\n  @Input() stepNumber!: number | string;\n  @Input() condition!: string;\n  @Input() branches: ConditionBranch[] = [];\n  @Input() expanded: boolean = true;\n  @Input() isNested: boolean = false;\n  @Input() isInsideLoop: boolean = false;\n  @Input() isReorder: boolean = false;\n  /** Options for the data profile dropdown */\n  @Input() dataProfileOptions: any[] = [];\n  /** Indicates if more data profiles are available for loading */\n  @Input() hasMoreDataProfiles: boolean = false;\n  /** Loading state for data profiles */\n  @Input() isLoadingDataProfiles: boolean = false;\n  /** Natural text actions options for while loop condition */\n  @Input() naturalTextActionsOptions: any[] = [];\n  /** Function to process template variables (similar to step-builder-condition) */\n  @Input() setConditionTemplateVariables: (template: any) => any[] = () => [];\n\n  /** When true, header shows inline edit form (fields, operator select, Cancel/Apply) */\n  isEditing: boolean = false;\n\n  /** Array of ELSE IF branches in edit mode */\n  elseIfBranches: Array<{\n    id: string;\n    form: FormGroup;\n    selectedTemplate: any;\n    templateVariables: any[];\n    templateVariablesForm: FormGroup;\n    snapshot: { conditionLeft?: string; conditionOperator?: string; conditionRight?: string };\n  }> = [];\n\n  /** Form for edit mode; bound to cqa-dynamic-select and cqa-custom-input */\n  editForm!: FormGroup;\n\n  /** Operator dropdown config (IS, IS NOT, CONTAINS, etc.) */\n  operatorSelectConfig!: DynamicSelectFieldConfig;\n  /** Condition left operand dropdown config (natural text actions with IF_CONDITION) */\n  conditionLeftSelectConfig!: DynamicSelectFieldConfig;\n\n  /** Snapshot for Cancel revert */\n  private editSnapshot: { conditionLeft?: string; conditionOperator?: string; conditionRight?: string } = {};\n  \n  /** Selected template for IF condition */\n  selectedTemplate: any = null;\n  /** Template variables for IF condition */\n  templateVariables: any[] = [];\n  /** Form group for template variables */\n  templateVariablesForm!: FormGroup;\n\n  @Output() toggleExpanded = new EventEmitter<{config: ConditionStepConfig, expanded: boolean}>();\n  @Output() conditionChange = new EventEmitter<string>();\n  @Output() branchStepChange = new EventEmitter<{ branch: ConditionBranch; step: TestCaseStepConfig; stepIndex: number }>();\n  @Output() addStep = new EventEmitter<{ branch: ConditionBranch }>();\n  @Output() deleteStep = new EventEmitter<{ branch: ConditionBranch; stepIndex: number }>();\n  @Output() addBranch = new EventEmitter<void>();\n  /** Emitted when user clicks \"Add Else\" so the parent can call POST test_steps with conditionType CONDITION_ELSE */\n  @Output() addElse = new EventEmitter<{ conditionStepConfig: ConditionStepConfig }>();\n  @Output() deleteBranch = new EventEmitter<ConditionBranch>();\n  @Output() duplicate = new EventEmitter<void>();\n  @Output() delete = new EventEmitter<void>();\n  @Output() moreOptions = new EventEmitter<void>();\n  @Output() dndDropInZone = new EventEmitter<{ event: DndDropEvent; targetList: TestCaseStepConfig[] }>();\n  /** Emit when more data profiles need to be loaded */\n  @Output() loadMoreDataProfiles = new EventEmitter<string>();\n  /** Emit when data profile search query changes */\n  @Output() searchDataProfiles = new EventEmitter<string>();\n  /** Emit when a nested step is updated (e.g., Apply button clicked in loop-step edit mode) */\n  @Output() stepUpdate = new EventEmitter<TestCaseStepConfig>();\n\n  onDndDrop(event: DndDropEvent, branch: ConditionBranch): void {\n    this.dndDropInZone.emit({ event, targetList: branch.nestedSteps });\n  }\n\n  constructor(private fb: FormBuilder, private cdr: ChangeDetectorRef) {}\n\n  ngOnInit(): void {\n    if (this.config) {\n      this.id = this.config.id;\n      this.stepNumber = this.config.stepNumber;\n      this.condition = this.config.condition;\n      this.branches = this.config.branches || [];\n      this.expanded = this.config.expanded !== undefined ? this.config.expanded : true;\n    }\n    this.buildEditForm();\n    this.buildOperatorSelectConfig();\n    this.updateConditionLeftSelectConfig();\n  }\n\n  ngOnChanges(changes: any): void {\n    if (changes['naturalTextActionsOptions']) {\n      this.updateConditionLeftSelectConfig();\n      // Rebuild form when options are loaded to populate initial value from naturalTextActionId\n      if (this.editForm && this.naturalTextActionsOptions && this.naturalTextActionsOptions.length > 0) {\n        this.rebuildEditFormWithNaturalTextAction();\n      }\n    }\n  }\n\n  /** Rebuild edit form when naturalTextActionsOptions are loaded to populate from naturalTextActionId */\n  private rebuildEditFormWithNaturalTextAction(): void {\n    if (!this.editForm) {\n      return;\n    }\n    const configWithId = this.config as any;\n    if (configWithId.naturalTextActionId && this.naturalTextActionsOptions && this.naturalTextActionsOptions.length > 0) {\n      const matchingOption = this.naturalTextActionsOptions.find(\n        (option: any) => String(option.id) === String(configWithId.naturalTextActionId)\n      );\n      if (matchingOption) {\n        const naturalText = matchingOption.naturalText ?? matchingOption.name ?? matchingOption.value ?? '';\n        if (naturalText) {\n          const currentValue = this.editForm.get('conditionLeft')?.value ?? '';\n          // Only update if current value is empty or doesn't match\n          if (!currentValue || currentValue !== naturalText) {\n            this.editForm.get('conditionLeft')?.setValue(naturalText);\n          }\n        }\n        // Get the full template object (NaturalTextActions) from the option\n        const fullTemplate = matchingOption.template || matchingOption;\n        // Store selected template and get variables\n        this.selectedTemplate = fullTemplate;\n        if (fullTemplate && fullTemplate.variables) {\n          this.templateVariables = this.setConditionTemplateVariables(fullTemplate);\n          this.buildTemplateVariablesForm();\n        }\n      }\n    }\n  }\n\n  private buildEditForm(): void {\n    // If config has naturalTextActionId, find the matching natural text action\n    let conditionLeftValue = '';\n    const configWithId = this.config as any;\n    if (configWithId.naturalTextActionId && this.naturalTextActionsOptions && this.naturalTextActionsOptions.length > 0) {\n      const matchingOption = this.naturalTextActionsOptions.find(\n        (option: any) => String(option.id) === String(configWithId.naturalTextActionId)\n      );\n      if (matchingOption) {\n        // Use naturalText exactly as received from API\n        conditionLeftValue = matchingOption.naturalText ?? matchingOption.name ?? matchingOption.value ?? '';\n        // Get the full template object (NaturalTextActions) from the option\n        const fullTemplate = matchingOption.template || matchingOption;\n        // Store selected template and get variables\n        this.selectedTemplate = fullTemplate;\n        if (fullTemplate && fullTemplate.variables) {\n          this.templateVariables = this.setConditionTemplateVariables(fullTemplate);\n          this.buildTemplateVariablesForm();\n        }\n      }\n    }\n    \n    // If no naturalTextActionId match found, parse from condition string\n    if (!conditionLeftValue) {\n      const { left } = this.parseCondition(this.condition);\n      conditionLeftValue = left;\n    }\n    \n    const { operator, right } = this.parseCondition(this.condition);\n    this.editForm = this.fb.group({\n      conditionLeft: [conditionLeftValue],\n      conditionOperator: [operator],\n      conditionRight: [right],\n    });\n    \n    // Initialize template variables form if not already initialized\n    if (!this.templateVariablesForm) {\n      this.templateVariablesForm = this.fb.group({});\n    }\n  }\n\n  private buildElseIfBranch(index?: number): {\n    id: string;\n    form: FormGroup;\n    selectedTemplate: any;\n    templateVariables: any[];\n    templateVariablesForm: FormGroup;\n    snapshot: { conditionLeft?: string; conditionOperator?: string; conditionRight?: string };\n  } {\n    // Initialize ELSE IF form with empty values or from existing ELSE IF branch if available\n    const elseIfBranches = this.branches?.filter(b => b.type === 'else-if') || [];\n    const branchIndex = index !== undefined ? index : elseIfBranches.length;\n    const elseIfBranch = elseIfBranches[branchIndex];\n    const elseCondition = elseIfBranch?.action || '';\n    const { left, operator, right } = this.parseCondition(elseCondition);\n    \n    const form = this.fb.group({\n      conditionLeft: [left],\n      conditionOperator: [operator],\n      conditionRight: [right],\n    });\n    \n    const templateVariablesForm = this.fb.group({});\n    \n    return {\n      id: `else-if-${Date.now()}-${Math.random()}`,\n      form,\n      selectedTemplate: null,\n      templateVariables: [],\n      templateVariablesForm,\n      snapshot: { conditionLeft: left, conditionOperator: operator, conditionRight: right }\n    };\n  }\n\n  private buildOperatorSelectConfig(): void {\n    const options: SelectOption[] = [\n      { id: 'is', value: 'is', name: 'IS', label: 'IS' },\n      { id: 'is not', value: 'is not', name: 'IS NOT', label: 'IS NOT' },\n      { id: 'contains', value: 'contains', name: 'CONTAINS', label: 'CONTAINS' },\n      { id: 'equals', value: 'equals', name: 'EQUALS', label: 'EQUALS' },\n      { id: 'starts with', value: 'starts with', name: 'STARTS WITH', label: 'STARTS WITH' },\n      { id: 'ends with', value: 'ends with', name: 'ENDS WITH', label: 'ENDS WITH' },\n    ];\n    this.operatorSelectConfig = {\n      key: 'conditionOperator',\n      placeholder: 'Operator',\n      searchable: false,\n      options,\n    };\n  }\n\n  /** Update condition left select config with filtered natural text actions (IF_CONDITION only) */\n  private updateConditionLeftSelectConfig(): void {\n    // Filter natural text actions to only include those with stepActionType === \"IF_CONDITION\"\n    const filteredOptions = (this.naturalTextActionsOptions || []).filter((option: any) => {\n      return option.stepActionType === 'IF_CONDITION';\n    });\n\n    this.conditionLeftSelectConfig = {\n      key: 'conditionLeft',\n      placeholder: 'Select condition',\n      searchable: true,\n      options: filteredOptions,\n    };\n  }\n\n  /** Options for the condition left autocomplete (IF_CONDITION natural text actions) */\n  get conditionLeftAutocompleteOptions(): CqaAutocompleteOption[] {\n    const opts = this.conditionLeftSelectConfig?.options ?? [];\n    return opts.map((option: any) => {\n      // Use naturalText exactly as received from API, fallback to name/value/id\n      const naturalText = option.naturalText ?? option.name ?? option.value ?? String(option.id ?? '');\n      return {\n        value: naturalText,\n        label: naturalText,\n        // Store the full template object (NaturalTextActions) for template variables processing\n        // Use option.template if available (full NaturalTextActions), otherwise use option itself\n        template: option.template || option,\n      } as CqaAutocompleteOption & { template?: any };\n    });\n  }\n\n  onConditionLeftSelect(option: CqaAutocompleteOption & { template?: any }): void {\n    this.editForm?.get('conditionLeft')?.setValue(option.value);\n    \n    // Get template from option - option.template should contain the full NaturalTextActions object\n    const matchingTemplate = option.template;\n    \n    // If template not in option, try to find from naturalTextActionsOptions by matching naturalText\n    let fullTemplate = matchingTemplate;\n    if (!fullTemplate || !fullTemplate.variables) {\n      const matchingOption = this.naturalTextActionsOptions.find(\n        (opt: any) => opt.naturalText === option.value || opt.name === option.value || opt.value === option.value\n      );\n      // Use template property from option if available, otherwise use the option itself\n      fullTemplate = matchingOption?.template || matchingOption;\n    }\n    \n    if (fullTemplate && fullTemplate.variables) {\n      // Store the full template for reference\n      this.selectedTemplate = fullTemplate;\n      \n      // Get template variables using the provided function\n      // Pass the full NaturalTextActions object which has the variables property\n      const variables = this.setConditionTemplateVariables(fullTemplate);\n      console.log('Template variables loaded:', variables, 'from template:', fullTemplate);\n      \n      this.templateVariables = variables || [];\n      // Build form for template variables\n      this.buildTemplateVariablesForm();\n      // Trigger change detection to update the template\n      this.cdr.detectChanges();\n    } else {\n      console.log('No matching template found or template has no variables', {\n        fullTemplate,\n        hasVariables: fullTemplate?.variables,\n        optionValue: option.value,\n        optionTemplate: option.template\n      });\n      this.selectedTemplate = null;\n      this.templateVariables = [];\n      if (!this.templateVariablesForm) {\n        this.templateVariablesForm = this.fb.group({});\n      }\n      // Trigger change detection to update the template\n      this.cdr.detectChanges();\n    }\n  }\n  \n  private buildTemplateVariablesForm(): void {\n    if (!this.templateVariablesForm) {\n      this.templateVariablesForm = this.fb.group({});\n    }\n    \n    // Clear existing form controls\n    Object.keys(this.templateVariablesForm.controls).forEach(key => {\n      this.templateVariablesForm.removeControl(key);\n    });\n    \n    // Get existing template variables data from config if available\n    const configWithData = this.config as any;\n    const existingData = configWithData.templateVariablesData || {};\n    \n    // Add form controls for each variable\n    this.templateVariables.forEach(variable => {\n      // Try to get value from existing data first, then from variable default\n      let defaultValue: any;\n      if (existingData.hasOwnProperty(variable.name)) {\n        defaultValue = existingData[variable.name];\n      } else {\n        defaultValue = variable.type === 'boolean' \n          ? (variable.value === true || variable.value === 'true' || variable.value === 1)\n          : (variable.value || '');\n      }\n      \n      // Convert boolean string to boolean\n      if (variable.type === 'boolean' && typeof defaultValue === 'string') {\n        defaultValue = defaultValue === 'true' || defaultValue === '1';\n      }\n      \n      this.templateVariablesForm.addControl(variable.name, new FormControl(defaultValue));\n    });\n  }\n\n  onElseConditionLeftSelect(option: CqaAutocompleteOption & { template?: any }, branchId: string): void {\n    const branch = this.elseIfBranches.find(b => b.id === branchId);\n    if (!branch) return;\n    \n    branch.form?.get('conditionLeft')?.setValue(option.value);\n    \n    // Get template from option - option.template should contain the full NaturalTextActions object\n    const matchingTemplate = option.template;\n    \n    // If template not in option, try to find from naturalTextActionsOptions by matching naturalText\n    let fullTemplate = matchingTemplate;\n    if (!fullTemplate || !fullTemplate.variables) {\n      const matchingOption = this.naturalTextActionsOptions.find(\n        (opt: any) => opt.naturalText === option.value || opt.name === option.value || opt.value === option.value\n      );\n      // Use template property from option if available, otherwise use the option itself\n      fullTemplate = matchingOption?.template || matchingOption;\n    }\n    \n    if (fullTemplate && fullTemplate.variables) {\n      // Store the full template for reference\n      branch.selectedTemplate = fullTemplate;\n      // Get template variables using the provided function\n      branch.templateVariables = this.setConditionTemplateVariables(fullTemplate);\n      // Build form for template variables\n      this.buildElseTemplateVariablesForm(branch);\n      // Trigger change detection to update the template\n      this.cdr.detectChanges();\n    } else {\n      branch.selectedTemplate = null;\n      branch.templateVariables = [];\n      if (!branch.templateVariablesForm) {\n        branch.templateVariablesForm = this.fb.group({});\n      }\n      // Trigger change detection to update the template\n      this.cdr.detectChanges();\n    }\n  }\n  \n  private buildElseTemplateVariablesForm(branch: {\n    id: string;\n    form: FormGroup;\n    selectedTemplate: any;\n    templateVariables: any[];\n    templateVariablesForm: FormGroup;\n    snapshot: { conditionLeft?: string; conditionOperator?: string; conditionRight?: string };\n  }): void {\n    if (!branch.templateVariablesForm) {\n      branch.templateVariablesForm = this.fb.group({});\n    }\n    \n    // Clear existing form controls\n    Object.keys(branch.templateVariablesForm.controls).forEach(key => {\n      branch.templateVariablesForm.removeControl(key);\n    });\n    \n    // Get existing template variables data from config if available (for ELSE IF branch)\n    const configWithData = this.config as any;\n    const existingData = configWithData.elseTemplateVariablesData || {};\n    \n    // Add form controls for each variable\n    branch.templateVariables.forEach(variable => {\n      // Try to get value from existing data first, then from variable default\n      let defaultValue: any;\n      if (existingData.hasOwnProperty(variable.name)) {\n        defaultValue = existingData[variable.name];\n      } else {\n        defaultValue = variable.type === 'boolean' \n          ? (variable.value === true || variable.value === 'true' || variable.value === 1)\n          : (variable.value || '');\n      }\n      \n      // Convert boolean string to boolean\n      if (variable.type === 'boolean' && typeof defaultValue === 'string') {\n        defaultValue = defaultValue === 'true' || defaultValue === '1';\n      }\n      \n      branch.templateVariablesForm.addControl(variable.name, new FormControl(defaultValue));\n    });\n  }\n\n  onAddElse(): void {\n    // Add a new ELSE IF branch (UI row only; APIs are called when user clicks Apply)\n    const newBranch = this.buildElseIfBranch();\n    this.elseIfBranches.push(newBranch);\n  }\n\n  onAddElseBranch(): void {\n    // Emit so parent can call POST test_steps with conditionType CONDITION_ELSE\n    if (this.config) {\n      this.addElse.emit({ conditionStepConfig: this.config });\n    }\n  }\n\n  onRemoveElse(branchId: string): void {\n    // Remove the ELSE IF branch with the given ID\n    const index = this.elseIfBranches.findIndex(b => b.id === branchId);\n    if (index !== -1) {\n      this.elseIfBranches.splice(index, 1);\n    }\n  }\n\n  /** Parse condition string into left, operator, right (e.g. \"Usertype is Premium\") */\n  private parseCondition(c: string): { left: string; operator: string; right: string } {\n    if (!c || typeof c !== 'string') {\n      return { left: 'Usertype', operator: 'is', right: 'Premium' };\n    }\n    const s = c.trim();\n    const operators = [' is not ', ' is ', ' contains ', ' equals ', ' starts with ', ' ends with '];\n    for (const op of operators) {\n      const i = s.toLowerCase().indexOf(op);\n      if (i !== -1) {\n        return {\n          left: s.slice(0, i).trim(),\n          operator: op.trim(),\n          right: s.slice(i + op.length).trim(),\n        };\n      }\n    }\n    return { left: s, operator: 'is', right: '' };\n  }\n\n  /** Build condition string from form values */\n  private buildConditionFromForm(): string {\n    let left = this.editForm.get('conditionLeft')?.value ?? '';\n    const op = this.editForm.get('conditionOperator')?.value ?? 'is';\n    const right = this.editForm.get('conditionRight')?.value ?? '';\n    \n    // If left is an ID (number), find the naturalText from options\n    if (left && this.naturalTextActionsOptions && this.naturalTextActionsOptions.length > 0) {\n      const leftValue = String(left);\n      // Check if it's a number (ID) or if we need to find the naturalText\n      const isNumericId = !isNaN(Number(leftValue)) && leftValue.trim() !== '';\n      \n      if (isNumericId) {\n        // Find the option by ID and use its naturalText\n        const selectedAction = this.naturalTextActionsOptions.find(\n          (option: any) => String(option.id) === leftValue\n        );\n        if (selectedAction && selectedAction.naturalText) {\n          left = String(selectedAction.naturalText);\n        }\n      } else {\n        // Check if it's already a naturalText or needs to be found\n        const selectedAction = this.naturalTextActionsOptions.find(\n          (option: any) => option.naturalText === left || option.name === left || option.value === left\n        );\n        if (selectedAction && selectedAction.naturalText) {\n          left = String(selectedAction.naturalText);\n        }\n      }\n    }\n    \n    return [left, op, right].filter(Boolean).join(' ');\n  }\n\n  onEditFormFieldChange(controlName: string, value: string): void {\n    this.editForm.get(controlName)?.setValue(value);\n  }\n\n  getStepsSummary(): string {\n    const allSteps = this.branches.reduce<TestCaseStepConfig[]>(\n      (acc, branch) => acc.concat(branch.nestedSteps),\n      []\n    );\n    if (allSteps.length === 0) {\n      return '0 steps';\n    }\n    const firstStep = allSteps[0];\n    const lastStep = allSteps[allSteps.length - 1];\n    const start = (firstStep as any).stepNumber || 1;\n    const end = (lastStep as any).stepNumber || allSteps.length;\n    const count = allSteps.length;\n    return `Steps ${start}-${end} (${count} step${count !== 1 ? 's' : ''})`;\n  }\n\n  onToggleExpanded(): void {\n    this.expanded = !this.expanded;\n    this.toggleExpanded.emit({config:this.config, expanded:this.expanded});\n  }\n\n  onConditionChange(value: string): void {\n    this.condition = value;\n    this.conditionChange.emit(value);\n  }\n\n  onBranchStepChange(branch: ConditionBranch, step: TestCaseStepConfig, stepIndex: number): void {\n    this.branchStepChange.emit({ branch, step, stepIndex });\n  }\n\n  onNestedToggleExpanded(event: boolean | {config: TestCaseStepConfig, expanded: boolean}, branch: ConditionBranch, step: TestCaseStepConfig, index: number): void {\n    // Handle both boolean and object formats\n    if (typeof event === 'object' && event !== null && 'expanded' in event) {\n      // Object format from step-group: {config, expanded}\n      (step as any).expanded = event.expanded;\n      // If it's a step-group, we need to emit the event up the chain\n      if (this.isStepGroup(step)) {\n        // Re-emit the toggleExpanded event with the object format\n        this.toggleExpanded.emit(event as {config: ConditionStepConfig, expanded: boolean});\n      }\n    } else {\n      // Boolean format from other step types\n      (step as any).expanded = event as boolean;\n    }\n    this.onBranchStepChange(branch, step, index);\n  }\n\n  onAddStep(branch: ConditionBranch): void {\n    this.addStep.emit({ branch });\n  }\n\n  onDeleteStep(branch: ConditionBranch, stepIndex: number): void {\n    this.deleteStep.emit({ branch, stepIndex });\n  }\n\n  onAddBranch(): void {\n    this.addBranch.emit();\n  }\n\n  onDeleteBranch(branch: ConditionBranch): void {\n    this.deleteBranch.emit(branch);\n  }\n\n  onNestedConditionAddBranch(nestedStep: ConditionStepConfig): void {\n    // Add a new branch to the nested condition step\n    if (!nestedStep.branches) {\n      nestedStep.branches = [];\n    }\n    const newBranch: ConditionBranch = {\n      type: nestedStep.branches.length === 0 ? 'if' : 'else',\n      label: nestedStep.branches.length === 0 ? 'IF TRUE' : 'ELSE',\n      stepType: StepTypes.CONDITION_IF,\n      nestedSteps: []\n    };\n    nestedStep.branches.push(newBranch);\n  }\n\n  onNestedConditionDeleteBranch(nestedStep: ConditionStepConfig, branch: ConditionBranch): void {\n    // Delete a branch from the nested condition step\n    if (nestedStep.branches) {\n      const index = nestedStep.branches.indexOf(branch);\n      if (index > -1) {\n        nestedStep.branches.splice(index, 1);\n      }\n    }\n  }\n\n  isNormalStep(step: TestCaseStepConfig): step is NormalStepConfig {\n    return 'eventType' in step;\n  }\n\n  isLoopStep(step: TestCaseStepConfig): step is LoopStepConfig {\n    return 'loopType' in step;\n  }\n\n  isConditionStep(step: TestCaseStepConfig): step is ConditionStepConfig {\n    return 'condition' in step && 'branches' in step;\n  }\n\n  isStepGroup(step: TestCaseStepConfig): step is StepGroupConfig {\n    return 'groupName' in step;\n  }\n\n  getBranchLabel(branch: ConditionBranch): string {\n    return branch.label || (branch.type === 'if' ? 'IF TRUE' : branch.type === 'else-if' ? 'ELSE IF' : 'ELSE');\n  }\n\n  getBranchColorClass(branch: ConditionBranch): string {\n    if (branch.type === 'if') {\n      return 'cqa-bg-[#0DBD7D1A]';\n    } else if (branch.type === 'else-if') {\n      return 'cqa-bg-yellow-50 cqa-border-yellow-200';\n    } else {\n      return 'cqa-bg-red-50 cqa-border-red-200';\n    }\n  }\n\n  getBranchTextColor(branch: ConditionBranch): string {\n    if (branch.type === 'if') {\n      return 'cqa-text-[#0D542B]';\n    } else if (branch.type === 'else-if') {\n      return 'cqa-text-yellow-700';\n    } else {\n      return 'cqa-text-red-700';\n    }\n  }\n\n  onOpenExternal(): void {\n    // Not used in condition step, but needed for recursive step groups\n  }\n\n  onEdit(): void {\n    this.editSnapshot = {\n      conditionLeft: this.editForm?.get('conditionLeft')?.value,\n      conditionOperator: this.editForm?.get('conditionOperator')?.value,\n      conditionRight: this.editForm?.get('conditionRight')?.value,\n    };\n    \n    // If config has naturalTextActionId, find the matching natural text action\n    let conditionLeftValue = '';\n    const configWithId = this.config as any;\n    if (configWithId.naturalTextActionId && this.naturalTextActionsOptions && this.naturalTextActionsOptions.length > 0) {\n      const matchingAction = this.naturalTextActionsOptions.find(\n        (option: any) => String(option.id) === String(configWithId.naturalTextActionId)\n      );\n      if (matchingAction) {\n        // Use naturalText exactly as received from API\n        conditionLeftValue = matchingAction.naturalText ?? matchingAction.name ?? matchingAction.value ?? '';\n      }\n    }\n    \n    // If no naturalTextActionId match found, parse from condition string\n    if (!conditionLeftValue) {\n      const { left } = this.parseCondition(this.condition);\n      conditionLeftValue = left;\n    }\n    \n    const { operator, right } = this.parseCondition(this.condition);\n    this.editForm?.get('conditionLeft')?.setValue(conditionLeftValue);\n    this.editForm?.get('conditionOperator')?.setValue(operator);\n    this.editForm?.get('conditionRight')?.setValue(right);\n    \n    this.isEditing = true;\n    // Do not pre-populate ELSE IF branches in edit mode; they are shown only when user clicks \"Add ELSE IF\"\n    this.elseIfBranches = [];\n  }\n\n  onEditCancel(): void {\n    this.editForm?.get('conditionLeft')?.setValue(this.editSnapshot.conditionLeft ?? '');\n    this.editForm?.get('conditionOperator')?.setValue(this.editSnapshot.conditionOperator ?? 'is');\n    this.editForm?.get('conditionRight')?.setValue(this.editSnapshot.conditionRight ?? '');\n    \n    // Reset all ELSE IF branches to their snapshots\n    this.elseIfBranches.forEach(branch => {\n      branch.form?.get('conditionLeft')?.setValue(branch.snapshot.conditionLeft ?? '');\n      branch.form?.get('conditionOperator')?.setValue(branch.snapshot.conditionOperator ?? 'is');\n      branch.form?.get('conditionRight')?.setValue(branch.snapshot.conditionRight ?? '');\n    });\n    \n    // Clear all ELSE IF branches\n    this.elseIfBranches = [];\n    \n    this.isEditing = false;\n  }\n\n  /**\n   * Build payload for one ELSE IF branch (action, naturalTextActionId, templateVariablesData, testDataList)\n   * so the parent can create the step via POST then PUT when Apply is clicked.\n   */\n  private buildElseIfBranchPayload(branch: {\n    form: FormGroup;\n    selectedTemplate: any;\n    templateVariables: any[];\n    templateVariablesForm: FormGroup;\n  }): { action: string; naturalTextActionId?: number; templateVariablesData?: any; testDataList?: Array<{ testData: string; testDataType: string }> } {\n    const conditionLeft = branch.form?.get('conditionLeft')?.value ?? '';\n    const conditionOperator = branch.form?.get('conditionOperator')?.value ?? 'is';\n    const conditionRight = branch.form?.get('conditionRight')?.value ?? '';\n    let naturalTextActionId: number | undefined;\n    let naturalTextValue: string = conditionLeft;\n    if (conditionLeft && this.naturalTextActionsOptions && this.naturalTextActionsOptions.length > 0) {\n      const leftValue = String(conditionLeft);\n      const isNumericId = !isNaN(Number(leftValue)) && leftValue.trim() !== '';\n      const selectedAction: any = isNumericId\n        ? this.naturalTextActionsOptions.find((opt: any) => String(opt.id) === leftValue)\n        : this.naturalTextActionsOptions.find(\n            (opt: any) => opt.naturalText === conditionLeft || opt.name === conditionLeft || opt.value === conditionLeft\n          );\n      if (selectedAction) {\n        naturalTextActionId = selectedAction.id;\n        naturalTextValue = selectedAction.naturalText || selectedAction.name || selectedAction.value || conditionLeft;\n      }\n    }\n    const templateVariablesData: any = {};\n    const testDataList: Array<{ testData: string; testDataType: string }> = [];\n    if (branch.templateVariablesForm && branch.templateVariables && branch.templateVariables.length > 0) {\n      branch.templateVariables.forEach((variable: any) => {\n        const value = branch.templateVariablesForm.get(variable.name)?.value;\n        if (value !== undefined && value !== null && value !== '') {\n          templateVariablesData[variable.name] = value;\n          testDataList.push({ testData: String(value), testDataType: 'raw' });\n        }\n      });\n    }\n    const action = [naturalTextValue, conditionOperator, conditionRight].filter(Boolean).join(' ');\n    return {\n      action: action || (branch.selectedTemplate?.naturalText ?? ''),\n      ...(naturalTextActionId !== undefined && { naturalTextActionId }),\n      ...(Object.keys(templateVariablesData).length > 0 && { templateVariablesData }),\n      ...(testDataList.length > 0 && { testDataList }),\n    };\n  }\n\n  onEditApply(): void {\n    const formValues = this.editForm.value;\n    const conditionLeft = formValues.conditionLeft ?? '';\n    const conditionOperator = formValues.conditionOperator ?? 'is';\n    const conditionRight = formValues.conditionRight ?? '';\n    \n    // Find the selected natural text action and get naturalText (not ID)\n    let naturalTextActionId: number | undefined;\n    let naturalTextValue: string = conditionLeft; // Default to conditionLeft\n    \n    if (conditionLeft && this.naturalTextActionsOptions && this.naturalTextActionsOptions.length > 0) {\n      const leftValue = String(conditionLeft);\n      const isNumericId = !isNaN(Number(leftValue)) && leftValue.trim() !== '';\n      \n      let selectedAction: any;\n      if (isNumericId) {\n        // Find by ID and get naturalText\n        selectedAction = this.naturalTextActionsOptions.find(\n          (option: any) => String(option.id) === leftValue\n        );\n      } else {\n        // Find by naturalText, name, or value\n        selectedAction = this.naturalTextActionsOptions.find(\n          (option: any) => option.naturalText === conditionLeft || option.name === conditionLeft || option.value === conditionLeft\n        );\n      }\n      \n      if (selectedAction) {\n        naturalTextActionId = selectedAction.id;\n        // Use naturalText if available, otherwise fall back to name or value\n        naturalTextValue = selectedAction.naturalText || selectedAction.name || selectedAction.value || conditionLeft;\n      }\n    }\n    \n    // Collect template variables values for event object\n    const templateVariablesData: any = {};\n    // Build testDataList array in the order of template variables\n    const testDataList: Array<{ testData: string; testDataType: string }> = [];\n    \n    if (this.templateVariablesForm && this.templateVariables.length > 0) {\n      this.templateVariables.forEach(variable => {\n        const value = this.templateVariablesForm.get(variable.name)?.value;\n        if (value !== undefined && value !== null && value !== '') {\n          // Add to event object (e.g., source_value, target_value)\n          templateVariablesData[variable.name] = value;\n          // Add to testDataList array (order matters - maintain template variable order)\n          testDataList.push({\n            testData: String(value),\n            testDataType: 'raw'\n          });\n        }\n      });\n    }\n    \n    // Build condition string using naturalText (not ID)\n    this.condition = [naturalTextValue, conditionOperator, conditionRight].filter(Boolean).join(' ');\n    \n    // Build payload for each newly added ELSE IF (so parent can call POST then PUT when Apply is clicked)\n    const newElseIfBranches = this.elseIfBranches.map(b => this.buildElseIfBranchPayload(b));\n    \n    // Update config with new values\n    const updatedConfig: ConditionStepConfig & { \n      naturalTextActionId?: number; \n      templateVariablesData?: any;\n      testDataList?: Array<{ testData: string; testDataType: string }>;\n      newElseIfBranches?: Array<{ action: string; naturalTextActionId?: number; templateVariablesData?: any; testDataList?: Array<{ testData: string; testDataType: string }> }>;\n    } = {\n      ...this.config,\n      condition: this.condition, // Condition now uses naturalText\n      stepType: this.config.stepType || StepTypes.CONDITION_IF, // Ensure stepType is set\n      ...(naturalTextActionId !== undefined && { naturalTextActionId } as any),\n      ...(Object.keys(templateVariablesData).length > 0 && { templateVariablesData } as any),\n      ...(testDataList.length > 0 && { testDataList } as any),\n      ...(newElseIfBranches.length > 0 && { newElseIfBranches } as any),\n    };\n    \n    // Emit individual change event\n    this.conditionChange.emit(this.condition);\n    \n    // Emit step update event with full config (includes newElseIfBranches so parent can create steps on Apply)\n    console.log('Condition-step: Emitting stepUpdate event', updatedConfig);\n    this.stepUpdate.emit(updatedConfig);\n    \n    this.isEditing = false;\n  }\n\n  onEditInDepth(): void {\n    this.moreOptions.emit();\n  }\n\n  onLink(): void {\n    // Not used in condition step, but needed for recursive step groups\n  }\n\n  onDuplicate(): void {\n    this.duplicate.emit();\n  }\n\n  onDelete(): void {\n    this.delete.emit();\n  }\n\n  onMoreOptions(): void {\n    this.moreOptions.emit();\n  }\n  \n  /** Get select config for a template variable */\n  getSelectConfigForVariable(variable: any, branchIdOrIsElse: string | boolean = false): DynamicSelectFieldConfig {\n    const options: SelectOption[] = (variable.options || []).map((opt: string) => ({\n      id: opt,\n      value: opt,\n      name: opt,\n      label: opt\n    }));\n\n    // If branchIdOrIsElse is a string, it's a branch ID; otherwise it's a boolean for backward compatibility\n    let form: FormGroup;\n    if (typeof branchIdOrIsElse === 'string') {\n      const branch = this.elseIfBranches.find(b => b.id === branchIdOrIsElse);\n      form = branch?.templateVariablesForm || this.fb.group({});\n    } else {\n      form = branchIdOrIsElse ? (this.elseIfBranches[0]?.templateVariablesForm || this.fb.group({})) : this.templateVariablesForm;\n    }\n\n    return {\n      key: variable.name,\n      placeholder: `Select ${variable.label}`,\n      multiple: false,\n      searchable: false,\n      options: options,\n      onChange: (value: any) => {\n        if (form && form.get(variable.name)) {\n          form.get(variable.name)?.setValue(value);\n        }\n      }\n    };\n  }\n}\n","<div [class]=\"'cqa-flex cqa-flex-col cqa-border cqa-border-solid cqa-border-[#E5E7EB] ' + (isNested ? ' cqa-pl-[24px]' : '')\">\n  <!-- Inline Edit Mode: CONDITION tag, three fields, IF/ELSE chips, Edit In depth, Cancel/Apply -->\n  <div *ngIf=\"isEditing\" class=\"cqa-py-2.5 cqa-px-4 cqa-flex cqa-flex-col cqa-gap-3\">\n    <!-- First Row: CONDITION tag, autocomplete, IF/ELSE indicators, Edit In depth, Cancel/Apply -->\n    <div class=\"cqa-flex cqa-items-center cqa-gap-3 cqa-justify-between\">\n      <div class=\"cqa-flex cqa-items-center cqa-gap-3 cqa-flex-grow\">\n        <!-- CONDITION Tag (orange) -->\n        <span class=\"cqa-px-1.5 cqa-rounded-md cqa-text-[#EA580C] cqa-text-[10px] cqa-leading-[15px] cqa-font-medium cqa-bg-[#FFEDD5]\">\n          CONDITION\n        </span>\n\n        <!-- First field: left operand (e.g. Usertype) - autocomplete with IF_CONDITION natural text actions -->\n        <cqa-autocomplete\n          *ngIf=\"editForm\"\n          [options]=\"conditionLeftAutocompleteOptions\"\n          [value]=\"editForm.get('conditionLeft')?.value ?? ''\"\n          (valueChange)=\"onEditFormFieldChange('conditionLeft', $event)\"\n          (optionSelect)=\"onConditionLeftSelect($event)\"\n          placeholder=\"Select condition\"\n          [fullWidth]=\"true\"\n          class=\"cqa-w-full cqa-max-w-[216px]\"></cqa-autocomplete>\n\n        <!-- Second Row: Template Variables Section (shown when template is selected, inline before Edit In depth) -->\n        <div *ngIf=\"selectedTemplate && templateVariables && templateVariables.length > 0\" class=\"cqa-flex cqa-flex-row cqa-flex-wrap cqa-gap-3\">\n          <ng-container *ngFor=\"let variable of templateVariables\">\n            <!-- Boolean variables with mat-slide-toggle -->\n            <ng-container *ngIf=\"variable.type === 'boolean'\">\n              <div class=\"cqa-flex cqa-items-center cqa-gap-2\">\n                <label class=\"cqa-text-[12px] cqa-font-medium cqa-text-gray-700\">\n                  {{ variable.label }}\n                </label>\n                <mat-slide-toggle\n                  [checked]=\"templateVariablesForm.get(variable.name)?.value || variable.value || false\"\n                  (change)=\"templateVariablesForm.get(variable.name)?.setValue($event.checked)\"\n                  color=\"primary\">\n                </mat-slide-toggle>\n              </div>\n            </ng-container>\n            \n            <!-- Non-boolean variables -->\n            <ng-container *ngIf=\"variable.type !== 'boolean' && variable.name !== 'custom_code'\">\n              <!-- Dropdown for select variables -->\n              <ng-container *ngIf=\"variable.name === 'type' || variable.name === 'scrollTo' || variable.options\">\n                <div class=\"cqa-flex cqa-flex-col\" style=\"min-width: 150px;\">\n                  <!-- <label class=\"cqa-text-[12px] cqa-font-medium cqa-text-gray-700 cqa-mb-1\">\n                    {{ variable.label }}\n                  </label> -->\n                  <cqa-dynamic-select \n                    [form]=\"templateVariablesForm\"\n                    [config]=\"getSelectConfigForVariable(variable, false)\">\n                  </cqa-dynamic-select>\n                </div>\n              </ng-container>\n              <!-- Text Input for other variables -->\n              <ng-container *ngIf=\"variable.name !== 'type' && variable.name !== 'scrollTo' && !variable.options\">\n                <div class=\"cqa-flex cqa-flex-col\" style=\"min-width: 150px;\">\n                  <!-- <label class=\"cqa-text-[12px] cqa-font-medium cqa-text-gray-700 cqa-mb-1\">\n                    {{ variable.label }}\n                  </label> -->\n                  <cqa-custom-input\n                    [placeholder]=\"'Enter ' + variable.label\"\n                    [value]=\"templateVariablesForm.get(variable.name)?.value || variable.value || ''\"\n                    [fullWidth]=\"true\"\n                    (valueChange)=\"templateVariablesForm.get(variable.name)?.setValue($event)\">\n                  </cqa-custom-input>\n                </div>\n              </ng-container>\n            </ng-container>\n          </ng-container>\n        </div>\n\n        <!-- IF / ELSE indicators -->\n        <span class=\"cqa-px-2 cqa-py-[2px] cqa-rounded-[4px] cqa-text-[8px] cqa-leading-[12px] cqa-bg-[#DCFCE7] cqa-text-[#008236] cqa-border cqa-border-solid cqa-border-[#B9F8CF] cqa-flex cqa-items-center cqa-gap-1.5\">\n          <svg width=\"8\" height=\"8\" viewBox=\"0 0 8 8\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M6.66634 2L2.99967 5.66667L1.33301 4\" stroke=\"#008236\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/></svg>\n          IF\n        </span>\n        <!-- Add ELSE IF button - always visible -->\n        <button\n          type=\"button\"\n          (click)=\"onAddElse()\"\n          class=\"cqa-px-2 cqa-py-[2px] cqa-rounded-[4px] cqa-text-[8px] cqa-leading-[12px] cqa-bg-[#F3F4F6] cqa-text-[#99A1AF] cqa-border cqa-border-solid cqa-border-[#E5E7EB] cqa-flex cqa-items-center cqa-gap-1.5 cqa-cursor-pointer hover:cqa-bg-[#E5E7EB] cqa-transition-colors\">\n          Add ELSE IF\n        </button>\n        <!-- Add Else button - calls API to create CONDITION_ELSE step -->\n        <button\n          type=\"button\"\n          (click)=\"onAddElseBranch()\"\n          class=\"cqa-px-2 cqa-py-[2px] cqa-rounded-[4px] cqa-text-[8px] cqa-leading-[12px] cqa-bg-[#F3F4F6] cqa-text-[#99A1AF] cqa-border cqa-border-solid cqa-border-[#E5E7EB] cqa-flex cqa-items-center cqa-gap-1.5 cqa-cursor-pointer hover:cqa-bg-[#E5E7EB] cqa-transition-colors\">\n          Add Else\n        </button>\n\n        <!-- Edit In depth link -->\n        <a href=\"#\" (click)=\"onEditInDepth(); $event.preventDefault()\"\n          class=\"cqa-text-[#3F43EE] cqa-text-[10px] cqa-leading-[15px] cqa-font-medium cqa-flex cqa-items-center cqa-gap-[2px] cqa-no-underline\">\n          Edit In depth\n          <svg width=\"8\" height=\"8\" viewBox=\"0 0 8 8\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M2.03809 6.74329L2.62809 7.33329L5.96142 3.99996L2.62809 0.666626L2.03809 1.25663L4.78142 3.99996L2.03809 6.74329Z\" fill=\"#3F43EE\"/></svg>\n        </a>      \n      </div>\n      <!-- Cancel / Apply buttons - shown on IF row when no ELSE IF branches are present -->\n      <div *ngIf=\"elseIfBranches.length === 0\" class=\"cqa-flex cqa-items-center cqa-gap-2\">\n        <cqa-button variant=\"outlined\" btnSize=\"lg\" [customClass]=\"'cqa-text-[14px] cqa-py-[9px]'\" [text]=\"'Cancel'\" (clicked)=\"onEditCancel()\"></cqa-button>\n        <cqa-button variant=\"filled\" btnSize=\"lg\" [customClass]=\"'cqa-text-[14px] cqa-py-[9px]'\" [text]=\"'Apply'\" (clicked)=\"onEditApply()\"></cqa-button>\n      </div>\n    </div>\n    \n    \n  </div>\n\n  <!-- ELSE IF Sections in Edit Mode - Loop through all ELSE IF branches -->\n  <ng-container *ngFor=\"let branch of elseIfBranches; let i = index\">\n    <div *ngIf=\"isEditing\" class=\"cqa-py-2.5 cqa-px-4 cqa-flex cqa-flex-col cqa-gap-3 cqa-border-t cqa-border-solid cqa-border-[#E5E7EB]\">\n      <!-- First Row: Remove ELSE IF button, autocomplete, Edit In depth, Cancel/Apply -->\n      <div class=\"cqa-flex cqa-items-center cqa-gap-3 cqa-justify-between\">\n        <div class=\"cqa-flex cqa-items-center cqa-gap-3 cqa-flex-grow\">\n          <!-- Remove ELSE IF button -->\n          <button\n            type=\"button\"\n            (click)=\"onRemoveElse(branch.id)\"\n            class=\"cqa-px-2 cqa-py-[2px] cqa-rounded-[4px] cqa-text-[8px] cqa-leading-[12px] cqa-bg-[#F3F4F6] cqa-text-[#99A1AF] cqa-border cqa-border-solid cqa-border-[#E5E7EB] cqa-cursor-pointer hover:cqa-bg-[#E5E7EB] cqa-transition-colors\">\n            Remove ELSE IF\n          </button>\n\n          <!-- ELSE IF autocomplete field: same as IF condition -->\n          <cqa-autocomplete\n            *ngIf=\"branch.form\"\n            [options]=\"conditionLeftAutocompleteOptions\"\n            [value]=\"branch.form.get('conditionLeft')?.value ?? ''\"\n            (valueChange)=\"branch.form.get('conditionLeft')?.setValue($event)\"\n            (optionSelect)=\"onElseConditionLeftSelect($event, branch.id)\"\n            placeholder=\"Select condition\"\n            [fullWidth]=\"true\"\n            class=\"cqa-w-full cqa-max-w-[216px]\"></cqa-autocomplete>\n          \n          <!-- Second Row: ELSE IF Template Variables Section (shown when template is selected, inline before Edit In depth) -->\n          <div *ngIf=\"branch.selectedTemplate && branch.templateVariables && branch.templateVariables.length > 0\" class=\"cqa-flex cqa-flex-row cqa-flex-wrap cqa-gap-3\">\n            <ng-container *ngFor=\"let variable of branch.templateVariables\">\n              <!-- Boolean variables with mat-slide-toggle -->\n              <ng-container *ngIf=\"variable.type === 'boolean'\">\n                <div class=\"cqa-flex cqa-items-center cqa-gap-2\">\n                  <!-- <label class=\"cqa-text-[12px] cqa-font-medium cqa-text-gray-700\">\n                    {{ variable.label }}\n                  </label> -->\n                  <mat-slide-toggle\n                    [checked]=\"branch.templateVariablesForm.get(variable.name)?.value || variable.value || false\"\n                    (change)=\"branch.templateVariablesForm.get(variable.name)?.setValue($event.checked)\"\n                    color=\"primary\">\n                  </mat-slide-toggle>\n                </div>\n              </ng-container>\n              \n              <!-- Non-boolean variables -->\n              <ng-container *ngIf=\"variable.type !== 'boolean' && variable.name !== 'custom_code'\">\n                <!-- Dropdown for select variables -->\n                <ng-container *ngIf=\"variable.name === 'type' || variable.name === 'scrollTo' || variable.options\">\n                  <div class=\"cqa-flex cqa-flex-col\" style=\"min-width: 150px;\">\n                    <!-- <label class=\"cqa-text-[12px] cqa-font-medium cqa-text-gray-700 cqa-mb-1\">\n                      {{ variable.label }}\n                    </label> -->\n                    <cqa-dynamic-select \n                      [form]=\"branch.templateVariablesForm\"\n                      [config]=\"getSelectConfigForVariable(variable, branch.id)\">\n                    </cqa-dynamic-select>\n                  </div>\n                </ng-container>\n                \n                <!-- Text Input for other variables -->\n                <ng-container *ngIf=\"variable.name !== 'type' && variable.name !== 'scrollTo' && !variable.options\">\n                  <div class=\"cqa-flex cqa-flex-col\" style=\"min-width: 150px;\">\n                    <!-- <label class=\"cqa-text-[12px] cqa-font-medium cqa-text-gray-700 cqa-mb-1\">\n                      {{ variable.label }}\n                    </label> -->\n                    <cqa-custom-input\n                      [value]=\"branch.templateVariablesForm.get(variable.name)?.value || variable.value || ''\"\n                      (valueChange)=\"branch.templateVariablesForm.get(variable.name)?.setValue($event)\"\n                      [placeholder]=\"variable.label\">\n                    </cqa-custom-input>\n                  </div>\n                </ng-container>\n              </ng-container>\n            </ng-container>\n          </div>\n\n          <!-- Edit In depth link -->\n          <a href=\"#\" (click)=\"onEditInDepth(); $event.preventDefault()\"\n            class=\"cqa-text-[#3F43EE] cqa-text-[10px] cqa-leading-[15px] cqa-font-medium cqa-flex cqa-items-center cqa-gap-[2px] cqa-no-underline\">\n            Edit In depth\n            <svg width=\"8\" height=\"8\" viewBox=\"0 0 8 8\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M2.03809 6.74329L2.62809 7.33329L5.96142 3.99996L2.62809 0.666626L2.03809 1.25663L4.78142 3.99996L2.03809 6.74329Z\" fill=\"#3F43EE\"/></svg>\n          </a>\n        </div>\n        <!-- Cancel / Apply buttons - shown in last ELSE IF row -->\n        <div *ngIf=\"i === elseIfBranches.length - 1\" class=\"cqa-flex cqa-items-center cqa-gap-2\">\n          <cqa-button variant=\"outlined\" btnSize=\"lg\" [customClass]=\"'cqa-text-[14px] cqa-py-[9px]'\" [text]=\"'Cancel'\" (clicked)=\"onEditCancel()\"></cqa-button>\n          <cqa-button variant=\"filled\" btnSize=\"lg\" [customClass]=\"'cqa-text-[14px] cqa-py-[9px]'\" [text]=\"'Apply'\" (clicked)=\"onEditApply()\"></cqa-button>\n        </div>\n      </div>\n    </div>\n  </ng-container>\n\n  <!-- Condition Header (normal view when not editing) -->\n  <div *ngIf=\"!isEditing\" [class]=\"'step-row cqa-flex cqa-items-center cqa-gap-3 cqa-py-2 ' + (isInsideLoop ? 'cqa-pl-10 cqa-pr-4' : 'cqa-px-4')\">\n    <!-- Expand/Collapse Icon -->\n    <button type=\"button\" (click)=\"onToggleExpanded()\" class=\"cqa-p-0\">\n      <svg [class.cqa-rotate-180]=\"!expanded\" class=\"cqa-transition-transform\" width=\"16\" height=\"16\"\n        viewBox=\"0 0 16 16\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n        <path d=\"M12 10L8 6L4 10\" stroke=\"#6B7280\" stroke-width=\"1.33333\" stroke-linecap=\"round\"\n          stroke-linejoin=\"round\" />\n      </svg>\n    </button>\n\n    <!-- IF/ELSE Icon -->\n    <div><svg width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n        <path d=\"M4 2V10\" stroke=\"#7B3306\" stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n        <path\n          d=\"M12 6C13.1046 6 14 5.10457 14 4C14 2.89543 13.1046 2 12 2C10.8954 2 10 2.89543 10 4C10 5.10457 10.8954 6 12 6Z\"\n          stroke=\"#7B3306\" stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n        <path\n          d=\"M4 14C5.10457 14 6 13.1046 6 12C6 10.8954 5.10457 10 4 10C2.89543 10 2 10.8954 2 12C2 13.1046 2.89543 14 4 14Z\"\n          stroke=\"#7B3306\" stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n        <path d=\"M12 6C12 7.5913 11.3679 9.11742 10.2426 10.2426C9.11742 11.3679 7.5913 12 6 12\" stroke=\"#7B3306\"\n          stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n      </svg></div>\n\n    <!-- IF/ELSE Label -->\n    <span class=\"cqa-font-semibold cqa-text-[#7B3306] cqa-text-[12px] cqa-leading-none\">\n      IF / ELSE\n    </span>\n\n    <!-- Condition Input -->\n    <div class=\"cqa-flex cqa-items-center cqa-gap-3 cqa-ml-2 cqa-flex-1\">\n      <span [innerHTML]=\"condition\"></span>\n      <!-- <span class=\"cqa-text-[#6B7280] cqa-text-[14px] cqa-leading-[18px]\">\n        If\n      </span>\n      <span\n        class=\"cqa-py-0.5 cqa-px-2 cqa-text-[#3F43EE] cqa-text-[14px] cqa-leading-[17px] cqa-font-semibold cqa-border cqa-border-solid cqa-border-[#8A8CF4] cqa-rounded cqa-bg-[#D8D9FC]\">.success-message</span>\n      <span class=\"cqa-text-[#6B7280] cqa-text-[14px] cqa-leading-[18px]\">\n        is visible\n      </span> -->\n      <!-- <input\n        type=\"text\"\n        [value]=\"condition\"\n        (input)=\"onConditionChange($any($event.target).value)\"\n        placeholder=\"element `.success-message` is visible\"\n        class=\"cqa-px-3 cqa-py-1.5 cqa-rounded-lg cqa-border cqa-border-gray-300 cqa-bg-white cqa-text-gray-900 cqa-text-sm cqa-flex-1 cqa-max-w-md cqa-outline-none focus:cqa-ring-2 focus:cqa-ring-primary focus:cqa-ring-opacity-50\"\n      /> -->\n    </div>\n\n    <!-- Steps Summary -->\n    <div\n      class=\"cqa-ml-auto cqa-border cqa-border-solid cqa-border-[#E5E5E5] cqa-rounded-lg cqa-py-0.5 cqa-px-2 cqa-text-[#0A0A0A] cqa-text-[12px] cqa-leading-[15px]\">\n      {{ getStepsSummary() }}\n    </div>\n\n    <!-- Action Icons: Edit, Link, Duplicate, Delete (show on hover) -->\n    <div class=\"step-actions cqa-flex cqa-items-center cqa-gap-3 cqa-px-[7px]\">\n      <button type=\"button\" (click)=\"onEdit(); $event.stopPropagation()\" title=\"Edit\" class=\"cqa-p-0 cqa-text-[#99A1Af] hover:cqa-text-[#1447E6]\">\n        <svg width=\"14\" height=\"14\" viewBox=\"0 0 14 14\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M7 11.6666H12.25\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M9.55208 2.1128C9.7843 1.88058 10.0993 1.75012 10.4277 1.75012C10.7561 1.75012 11.071 1.88058 11.3033 2.1128C11.5355 2.34502 11.6659 2.65998 11.6659 2.98838C11.6659 3.31679 11.5355 3.63175 11.3033 3.86397L4.29742 10.8704C4.15864 11.0092 3.9871 11.1107 3.79867 11.1656L2.12333 11.6544C2.07314 11.669 2.01993 11.6699 1.96928 11.6569C1.91863 11.6439 1.8724 11.6176 1.83543 11.5806C1.79846 11.5437 1.7721 11.4974 1.75913 11.4468C1.74615 11.3961 1.74703 11.3429 1.76167 11.2927L2.2505 9.61738C2.30546 9.42916 2.40698 9.25783 2.54567 9.11922L9.55208 2.1128Z\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/></svg>\n      </button>\n      <button type=\"button\" (click)=\"onLink(); $event.stopPropagation()\" title=\"Link\" class=\"cqa-p-0 cqa-text-[#99A1Af] hover:cqa-text-[#1447E6]\">\n        <svg width=\"14\" height=\"14\" viewBox=\"0 0 14 14\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M5.00065 9.91671H3.66732C2.78326 9.91671 1.93542 9.60942 1.3103 9.06244C0.685174 8.51545 0.333984 7.77359 0.333984 7.00004C0.333984 6.22649 0.685174 5.48463 1.3103 4.93765C1.93542 4.39066 2.78326 4.08337 3.66732 4.08337H5.00065\" stroke=\"currentColor\" stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M9 4.08337H10.3333C11.2174 4.08337 12.0652 4.39066 12.6904 4.93765C13.3155 5.48463 13.6667 6.22649 13.6667 7.00004C13.6667 7.77359 13.3155 8.51545 12.6904 9.06244C12.0652 9.60942 11.2174 9.91671 10.3333 9.91671H9\" stroke=\"currentColor\" stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M4.33398 7H9.66732\" stroke=\"currentColor\" stroke-width=\"1.33333\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/></svg>\n      </button>\n      <button type=\"button\" (click)=\"onDuplicate(); $event.stopPropagation()\" title=\"Duplicate\" class=\"cqa-p-0 cqa-text-[#99A1Af] hover:cqa-text-[#1447E6]\">\n        <svg width=\"14\" height=\"14\" viewBox=\"0 0 14 14\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M11.666 4.66663H5.83268C5.18835 4.66663 4.66602 5.18896 4.66602 5.83329V11.6666C4.66602 12.311 5.18835 12.8333 5.83268 12.8333H11.666C12.3103 12.8333 12.8327 12.311 12.8327 11.6666V5.83329C12.8327 5.18896 12.3103 4.66663 11.666 4.66663Z\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M2.33268 9.33329C1.69102 9.33329 1.16602 8.80829 1.16602 8.16663V2.33329C1.16602 1.69163 1.69102 1.16663 2.33268 1.16663H8.16602C8.80768 1.16663 9.33268 1.69163 9.33268 2.33329\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/></svg>\n      </button>\n      <button type=\"button\" (click)=\"onDelete(); $event.stopPropagation()\" title=\"Delete\" class=\"cqa-p-0 cqa-text-[#ff6467] hover:cqa-text-[#C63535]\">\n        <svg width=\"14\" height=\"14\" viewBox=\"0 0 14 14\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M1.75 3.5H12.25\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M11.0827 3.5V11.6667C11.0827 12.25 10.4993 12.8333 9.91602 12.8333H4.08268C3.49935 12.8333 2.91602 12.25 2.91602 11.6667V3.5\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M4.66602 3.49996V2.33329C4.66602 1.74996 5.24935 1.16663 5.83268 1.16663H8.16602C8.74935 1.16663 9.33268 1.74996 9.33268 2.33329V3.49996\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M5.83398 6.41663V9.91663\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/><path d=\"M8.16602 6.41663V9.91663\" stroke=\"currentColor\" stroke-width=\"1.16667\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/></svg>\n      </button>\n    </div>\n  </div>\n\n  <!-- Expanded Content with Branches -->\n  <div *ngIf=\"expanded\" class=\"cqa-flex cqa-flex-col\">\n    <!-- Branches (IF TRUE, ELSE IF, ELSE) -->\n    <div *ngFor=\"let branch of branches\" class=\"cqa-flex cqa-flex-col\">\n      <!-- Branch Header -->\n      <div\n        [class]=\"'cqa-px-4 cqa-py-2 cqa-text-[12px] cqa-leading-[15px] cqa-flex cqa-items-center cqa-gap-2 ' + getBranchTextColor(branch) + ' ' + getBranchColorClass(branch)\">\n        <span>{{ getBranchLabel(branch) }}</span>\n        <span *ngIf=\"branch.action\" [innerHTML]=\"branch.action\" class=\"cqa-text-[#111827]\"></span>\n      </div>\n\n      <!-- Branch Content (Nested Steps – renderer dispatches by step type, n-level nesting) -->\n      <div *ngIf=\"!isReorder\" class=\"cqa-flex cqa-flex-col\">\n        <cqa-test-case-details-renderer\n          *ngFor=\"let step of branch.nestedSteps; let i = index\"\n          [step]=\"step\"\n          [index]=\"i\"\n          [branch]=\"branch\"\n          [isNested]=\"true\"\n          [isReorder]=\"isReorder\"\n          [dataProfileOptions]=\"dataProfileOptions\" [hasMoreDataProfiles]=\"hasMoreDataProfiles\" [isLoadingDataProfiles]=\"isLoadingDataProfiles\"\n          [naturalTextActionsOptions]=\"naturalTextActionsOptions\"\n          (branchStepChange)=\"onBranchStepChange($event.branch, $event.step, $event.stepIndex)\"\n          (addStepForBranch)=\"onAddStep($event.branch)\"\n          (deleteStepWithBranch)=\"onDeleteStep($event.branch, $event.stepIndex)\"\n          (toggleExpanded)=\"onNestedToggleExpanded($event, branch, step, i)\"\n          (groupNameChange)=\"$any(step).groupName = $event; onBranchStepChange(branch, step, i)\"\n          (descriptionChange)=\"$any(step).description = $event; onBranchStepChange(branch, step, i)\"\n          (reusableChange)=\"$any(step).reusable = $event; onBranchStepChange(branch, step, i)\"\n          (openExternal)=\"onBranchStepChange(branch, step, i)\"\n          (edit)=\"onBranchStepChange(branch, step, i)\"\n          (link)=\"onBranchStepChange(branch, step, i)\"\n          (duplicate)=\"onBranchStepChange(branch, step, i)\"\n          (conditionChange)=\"$any(step).condition = $event; onBranchStepChange(branch, step, i)\"\n          (addBranch)=\"onNestedConditionAddBranch($any(step)); onBranchStepChange(branch, step, i)\"\n          (deleteBranch)=\"onNestedConditionDeleteBranch($any(step), $event); onBranchStepChange(branch, step, i)\"\n          (testDataProfileChange)=\"$any(step).testDataProfile = $event; onBranchStepChange(branch, step, i)\"\n          (startStepChange)=\"$any(step).startStep = $event; onBranchStepChange(branch, step, i)\"\n          (endStepChange)=\"$any(step).endStep = $event; onBranchStepChange(branch, step, i)\"\n          (maxIterationsChange)=\"$any(step).maxIterations = $event; onBranchStepChange(branch, step, i)\"\n          (eventTypeChange)=\"$any(step).eventType = $event; onBranchStepChange(branch, step, i)\"\n          (parameterChange)=\"onBranchStepChange(branch, step, i)\"\n          (selectionChange)=\"$any(step).selected = $event; onBranchStepChange(branch, step, i)\"\n          (loadMoreDataProfiles)=\"loadMoreDataProfiles.emit($event)\"\n          (searchDataProfiles)=\"searchDataProfiles.emit($event)\"\n          (stepUpdate)=\"stepUpdate.emit($event)\"\n          (dndDropInZone)=\"dndDropInZone.emit($event)\"\n        >\n        </cqa-test-case-details-renderer>\n      </div>\n      <div *ngIf=\"isReorder\" class=\"cqa-flex cqa-flex-col nested-step-drop-list\"\n           [dndDropzone]=\"['step']\"\n           dndEffectAllowed=\"move\"\n           dndDragoverClass=\"dndDragover\"\n           (dndDrop)=\"onDndDrop($event, branch)\">\n        <div dndPlaceholderRef class=\"step-drag-placeholder-nested cqa-my-1 cqa-min-h-[50px] cqa-border-2 cqa-border-dashed cqa-border-[#3F43EE] cqa-rounded cqa-bg-[rgba(63,67,238,0.08)] cqa-flex cqa-items-center cqa-justify-center cqa-text-[#3F43EE] cqa-text-xs\">Drop here</div>\n        <div *ngFor=\"let step of branch.nestedSteps; let i = index\" class=\"nested-step-drag-item\"\n             [dndDraggable]=\"step\"\n             dndEffectAllowed=\"move\"\n             dndType=\"step\">\n          <cqa-test-case-details-renderer\n            [step]=\"step\"\n            [index]=\"i\"\n            [branch]=\"branch\"\n            [isNested]=\"true\"\n            [isReorder]=\"isReorder\"\n            [dataProfileOptions]=\"dataProfileOptions\" [hasMoreDataProfiles]=\"hasMoreDataProfiles\" [isLoadingDataProfiles]=\"isLoadingDataProfiles\"\n            [naturalTextActionsOptions]=\"naturalTextActionsOptions\"\n            (branchStepChange)=\"onBranchStepChange($event.branch, $event.step, $event.stepIndex)\"\n            (addStepForBranch)=\"onAddStep($event.branch)\"\n            (deleteStepWithBranch)=\"onDeleteStep($event.branch, $event.stepIndex)\"\n            (toggleExpanded)=\"onNestedToggleExpanded($event, branch, step, i)\"\n            (groupNameChange)=\"$any(step).groupName = $event; onBranchStepChange(branch, step, i)\"\n            (descriptionChange)=\"$any(step).description = $event; onBranchStepChange(branch, step, i)\"\n            (reusableChange)=\"$any(step).reusable = $event; onBranchStepChange(branch, step, i)\"\n            (openExternal)=\"onBranchStepChange(branch, step, i)\"\n            (edit)=\"onBranchStepChange(branch, step, i)\"\n            (link)=\"onBranchStepChange(branch, step, i)\"\n            (duplicate)=\"onBranchStepChange(branch, step, i)\"\n            (conditionChange)=\"$any(step).condition = $event; onBranchStepChange(branch, step, i)\"\n            (addBranch)=\"onNestedConditionAddBranch($any(step)); onBranchStepChange(branch, step, i)\"\n            (deleteBranch)=\"onNestedConditionDeleteBranch($any(step), $event); onBranchStepChange(branch, step, i)\"\n            (testDataProfileChange)=\"$any(step).testDataProfile = $event; onBranchStepChange(branch, step, i)\"\n            (startStepChange)=\"$any(step).startStep = $event; onBranchStepChange(branch, step, i)\"\n            (endStepChange)=\"$any(step).endStep = $event; onBranchStepChange(branch, step, i)\"\n            (maxIterationsChange)=\"$any(step).maxIterations = $event; onBranchStepChange(branch, step, i)\"\n            (eventTypeChange)=\"$any(step).eventType = $event; onBranchStepChange(branch, step, i)\"\n            (parameterChange)=\"onBranchStepChange(branch, step, i)\"\n            (selectionChange)=\"$any(step).selected = $event; onBranchStepChange(branch, step, i)\"\n            (loadMoreDataProfiles)=\"loadMoreDataProfiles.emit($event)\"\n            (searchDataProfiles)=\"searchDataProfiles.emit($event)\"\n            (stepUpdate)=\"stepUpdate.emit($event)\"\n            (dndDropInZone)=\"dndDropInZone.emit($event)\"\n          >\n          </cqa-test-case-details-renderer>\n        </div>\n      </div>\n    </div>\n\n    <!-- END IF Marker -->\n    <div [class]=\"'cqa-pl-4 cqa-py-1 cqa-text-[#7B3306] cqa-text-[10px] cqa-leading-[15px] cqa-font-medium'\" style=\"border-top: 1px solid #E5E7EB;\">\n      END IF\n    </div>\n  </div>\n</div>"]}