@cqa-lib/cqa-ui 1.1.175 → 1.1.177

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 (39) hide show
  1. package/esm2020/lib/compare-runs/compare-runs.component.mjs +1 -1
  2. package/esm2020/lib/dynamic-select/dynamic-select-field.component.mjs +3 -3
  3. package/esm2020/lib/execution-screen/db-query-execution-item/db-query-execution-item.component.mjs +70 -5
  4. package/esm2020/lib/execution-screen/db-verification-step/db-verification-step.component.mjs +15 -3
  5. package/esm2020/lib/iterations-loop/iterations-loop.component.mjs +1 -1
  6. package/esm2020/lib/step-builder/step-builder-action/step-builder-action.component.mjs +29 -9
  7. package/esm2020/lib/step-builder/step-builder-condition/step-builder-condition.component.mjs +330 -0
  8. package/esm2020/lib/step-builder/step-builder-database/step-builder-database.component.mjs +205 -0
  9. package/esm2020/lib/table/dynamic-table/dynamic-table.component.mjs +35 -3
  10. package/esm2020/lib/templates/table-template.component.mjs +7 -4
  11. package/esm2020/lib/test-case-details/custom-edit-step/custom-edit-step-data.mjs +5 -0
  12. package/esm2020/lib/test-case-details/custom-edit-step/custom-edit-step-ref.mjs +32 -0
  13. package/esm2020/lib/test-case-details/custom-edit-step/custom-edit-step.component.mjs +71 -0
  14. package/esm2020/lib/test-case-details/custom-edit-step/custom-edit-step.service.mjs +97 -0
  15. package/esm2020/lib/test-case-details/normal-step/normal-step.component.mjs +59 -9
  16. package/esm2020/lib/ui-kit.module.mjs +18 -3
  17. package/esm2020/lib/utils/tw-overlay-container.mjs +6 -3
  18. package/esm2020/public-api.mjs +7 -1
  19. package/fesm2015/cqa-lib-cqa-ui.mjs +939 -34
  20. package/fesm2015/cqa-lib-cqa-ui.mjs.map +1 -1
  21. package/fesm2020/cqa-lib-cqa-ui.mjs +926 -34
  22. package/fesm2020/cqa-lib-cqa-ui.mjs.map +1 -1
  23. package/lib/dynamic-select/dynamic-select-field.component.d.ts +1 -0
  24. package/lib/execution-screen/db-query-execution-item/db-query-execution-item.component.d.ts +18 -3
  25. package/lib/execution-screen/db-verification-step/db-verification-step.component.d.ts +7 -1
  26. package/lib/step-builder/step-builder-action/step-builder-action.component.d.ts +2 -1
  27. package/lib/step-builder/step-builder-condition/step-builder-condition.component.d.ts +61 -0
  28. package/lib/step-builder/step-builder-database/step-builder-database.component.d.ts +61 -0
  29. package/lib/table/dynamic-table/dynamic-table.component.d.ts +7 -1
  30. package/lib/templates/table-template.component.d.ts +6 -1
  31. package/lib/test-case-details/custom-edit-step/custom-edit-step-data.d.ts +8 -0
  32. package/lib/test-case-details/custom-edit-step/custom-edit-step-ref.d.ts +13 -0
  33. package/lib/test-case-details/custom-edit-step/custom-edit-step.component.d.ts +25 -0
  34. package/lib/test-case-details/custom-edit-step/custom-edit-step.service.d.ts +23 -0
  35. package/lib/test-case-details/normal-step/normal-step.component.d.ts +9 -0
  36. package/lib/ui-kit.module.d.ts +26 -23
  37. package/package.json +1 -1
  38. package/public-api.d.ts +6 -0
  39. package/styles.css +1 -1
@@ -0,0 +1,330 @@
1
+ import { Component, Input, Output, EventEmitter } from '@angular/core';
2
+ import { FormControl, Validators } from '@angular/forms';
3
+ import * as i0 from "@angular/core";
4
+ import * as i1 from "@angular/forms";
5
+ import * as i2 from "../../dynamic-select/dynamic-select-field.component";
6
+ import * as i3 from "../../button/button.component";
7
+ import * as i4 from "../../custom-input/custom-input.component";
8
+ import * as i5 from "@angular/material/slide-toggle";
9
+ import * as i6 from "@angular/common";
10
+ export class StepBuilderConditionComponent {
11
+ constructor(fb) {
12
+ this.fb = fb;
13
+ /** Options for operator dropdown */
14
+ this.operatorOptions = [
15
+ { id: 'equals', value: 'equals', name: 'equals', label: 'equals' },
16
+ { id: 'not_equals', value: 'not_equals', name: 'not equals', label: 'not equals' },
17
+ { id: 'contains', value: 'contains', name: 'contains', label: 'contains' },
18
+ { id: 'not_contains', value: 'not_contains', name: 'not contains', label: 'not contains' },
19
+ { id: 'greater_than', value: 'greater_than', name: 'greater than', label: 'greater than' },
20
+ { id: 'less_than', value: 'less_than', name: 'less than', label: 'less than' }
21
+ ];
22
+ /** List of action templates to display in value dropdown */
23
+ this.conditionTemplates = [];
24
+ /** Function to handle variable processing or custom logic. Can be passed from parent component. */
25
+ this.setConditionTemplateVariables = () => { return []; };
26
+ /** Emit when step is created */
27
+ this.createStep = new EventEmitter();
28
+ /** Emit when cancelled */
29
+ this.cancelled = new EventEmitter();
30
+ this.includeElse = false;
31
+ // Cache for value configs to avoid recreating on every change detection
32
+ this.valueConfigCache = null;
33
+ // Track selected templates and their variables for each condition row
34
+ this.selectedTemplates = new Map();
35
+ this.conditionTemplateVariables = new Map();
36
+ this.conditionVariablesForms = new Map();
37
+ this.conditionForm = this.fb.group({
38
+ conditions: this.fb.array([]),
39
+ includeElse: [false]
40
+ });
41
+ }
42
+ ngOnInit() {
43
+ // Add initial condition row
44
+ this.addCondition("CONDITION_IF");
45
+ // Initialize value config cache
46
+ this.updateValueConfigCache();
47
+ }
48
+ ngOnChanges(changes) {
49
+ // Regenerate value config cache when conditionTemplates changes
50
+ if (changes['conditionTemplates'] && !changes['conditionTemplates'].firstChange) {
51
+ this.updateValueConfigCache();
52
+ }
53
+ }
54
+ get conditionsFormArray() {
55
+ return this.conditionForm.get('conditions');
56
+ }
57
+ addCondition(conditionType) {
58
+ const conditionGroup = this.fb.group({
59
+ field: [conditionType, Validators.required],
60
+ operator: ['equals', Validators.required],
61
+ value: [null, Validators.required],
62
+ description: [''],
63
+ metadata: [''],
64
+ });
65
+ const index = this.conditionsFormArray.length;
66
+ this.conditionsFormArray.push(conditionGroup);
67
+ // Initialize variables form for this condition
68
+ this.conditionVariablesForms.set(index, this.fb.group({}));
69
+ }
70
+ removeCondition(index) {
71
+ if (this.conditionsFormArray.length > 1) {
72
+ this.conditionsFormArray.removeAt(index);
73
+ // Clean up associated data
74
+ this.selectedTemplates.delete(index);
75
+ this.conditionTemplateVariables.delete(index);
76
+ this.conditionVariablesForms.delete(index);
77
+ // Reindex remaining conditions
78
+ this.reindexConditionData(index);
79
+ }
80
+ }
81
+ reindexConditionData(removedIndex) {
82
+ // Create new maps with reindexed data
83
+ const newSelectedTemplates = new Map();
84
+ const newTemplateVariables = new Map();
85
+ const newVariablesForms = new Map();
86
+ this.selectedTemplates.forEach((template, oldIndex) => {
87
+ if (oldIndex < removedIndex) {
88
+ newSelectedTemplates.set(oldIndex, template);
89
+ }
90
+ else if (oldIndex > removedIndex) {
91
+ newSelectedTemplates.set(oldIndex - 1, template);
92
+ }
93
+ });
94
+ this.conditionTemplateVariables.forEach((variables, oldIndex) => {
95
+ if (oldIndex < removedIndex) {
96
+ newTemplateVariables.set(oldIndex, variables);
97
+ }
98
+ else if (oldIndex > removedIndex) {
99
+ newTemplateVariables.set(oldIndex - 1, variables);
100
+ }
101
+ });
102
+ this.conditionVariablesForms.forEach((form, oldIndex) => {
103
+ if (oldIndex < removedIndex) {
104
+ newVariablesForms.set(oldIndex, form);
105
+ }
106
+ else if (oldIndex > removedIndex) {
107
+ newVariablesForms.set(oldIndex - 1, form);
108
+ }
109
+ });
110
+ this.selectedTemplates = newSelectedTemplates;
111
+ this.conditionTemplateVariables = newTemplateVariables;
112
+ this.conditionVariablesForms = newVariablesForms;
113
+ }
114
+ getOperatorConfig(index) {
115
+ return {
116
+ key: 'operator',
117
+ placeholder: 'Select operator',
118
+ multiple: false,
119
+ searchable: false,
120
+ options: this.operatorOptions
121
+ };
122
+ }
123
+ updateValueConfigCache() {
124
+ // Convert ActionTemplate[] to SelectOption[]
125
+ const templateOptions = (this.conditionTemplates || []).map(template => ({
126
+ id: template.id?.toString() || template.displayName || '',
127
+ value: template.id?.toString() || template.displayName || '',
128
+ name: template.htmlGrammar || template.naturalText || '',
129
+ label: template.htmlGrammar || template.naturalText || ''
130
+ }));
131
+ this.valueConfigCache = {
132
+ key: 'value',
133
+ placeholder: 'Select Template',
134
+ multiple: false,
135
+ searchable: true,
136
+ displayLabelAsInnerHtml: true,
137
+ options: templateOptions
138
+ };
139
+ }
140
+ getValueConfig(index) {
141
+ // Return cached config to avoid recreating options on every change detection
142
+ if (!this.valueConfigCache) {
143
+ this.updateValueConfigCache();
144
+ }
145
+ // Create a new config object with the onChange handler for this specific index
146
+ // This ensures each condition row has its own handler while sharing the base config
147
+ return {
148
+ ...this.valueConfigCache,
149
+ onChange: (value) => {
150
+ this.onTemplateValueChange(index, value);
151
+ }
152
+ };
153
+ }
154
+ onTemplateValueChange(index, templateId) {
155
+ // Find the selected template
156
+ const selectedTemplate = this.conditionTemplates.find(t => (t.id?.toString() === templateId) || (t.displayName === templateId));
157
+ if (selectedTemplate && this.setConditionTemplateVariables) {
158
+ // Store selected template
159
+ this.selectedTemplates.set(index, selectedTemplate);
160
+ // Get template variables using the provided function
161
+ const variables = this.setConditionTemplateVariables(selectedTemplate);
162
+ this.conditionTemplateVariables.set(index, variables);
163
+ // Build form for template variables
164
+ this.buildConditionVariablesForm(index, variables);
165
+ }
166
+ else {
167
+ // Clear template and variables if no template selected
168
+ this.selectedTemplates.delete(index);
169
+ this.conditionTemplateVariables.delete(index);
170
+ const form = this.conditionVariablesForms.get(index);
171
+ if (form) {
172
+ Object.keys(form.controls).forEach(key => {
173
+ form.removeControl(key);
174
+ });
175
+ }
176
+ }
177
+ }
178
+ buildConditionVariablesForm(index, variables) {
179
+ let form = this.conditionVariablesForms.get(index);
180
+ if (!form) {
181
+ form = this.fb.group({});
182
+ this.conditionVariablesForms.set(index, form);
183
+ }
184
+ // Ensure form is not undefined
185
+ if (!form) {
186
+ return;
187
+ }
188
+ // Clear existing form controls
189
+ Object.keys(form.controls).forEach(key => {
190
+ form.removeControl(key);
191
+ });
192
+ // Add form controls for each variable
193
+ variables.forEach(variable => {
194
+ // Handle boolean variables - use boolean value, others use string
195
+ const defaultValue = variable.type === 'boolean'
196
+ ? (variable.value === true || variable.value === 'true' || variable.value === 1)
197
+ : (variable.value || '');
198
+ form.addControl(variable.name, new FormControl(defaultValue));
199
+ });
200
+ }
201
+ getConditionTemplateVariables(index) {
202
+ return this.conditionTemplateVariables.get(index) || [];
203
+ }
204
+ getConditionVariablesForm(index) {
205
+ let form = this.conditionVariablesForms.get(index);
206
+ if (!form) {
207
+ form = this.fb.group({});
208
+ this.conditionVariablesForms.set(index, form);
209
+ }
210
+ return form;
211
+ }
212
+ getSelectedTemplate(index) {
213
+ return this.selectedTemplates.get(index) || null;
214
+ }
215
+ getSelectConfigForVariable(index, variable) {
216
+ const options = (variable.options || []).map((opt) => ({
217
+ id: opt,
218
+ value: opt,
219
+ name: opt,
220
+ label: opt
221
+ }));
222
+ return {
223
+ key: variable.name,
224
+ placeholder: `Select ${variable.label}`,
225
+ multiple: false,
226
+ searchable: false,
227
+ options: options,
228
+ onChange: (value) => {
229
+ this.onConditionVariableValueChange(index, variable.name, value);
230
+ }
231
+ };
232
+ }
233
+ onConditionVariableValueChange(conditionIndex, variableName, value) {
234
+ // Update the variable in templateVariables array
235
+ const variables = this.conditionTemplateVariables.get(conditionIndex) || [];
236
+ const variable = variables.find(v => v.name === variableName);
237
+ if (variable) {
238
+ variable.value = value;
239
+ }
240
+ // Also update form control
241
+ const form = this.conditionVariablesForms.get(conditionIndex);
242
+ if (form && form.get(variableName)) {
243
+ form.get(variableName)?.setValue(value);
244
+ }
245
+ }
246
+ onConditionVariableInputChange(conditionIndex, variableName, value) {
247
+ // Update the variable in templateVariables array
248
+ const variables = this.conditionTemplateVariables.get(conditionIndex) || [];
249
+ const variable = variables.find(v => v.name === variableName);
250
+ if (variable) {
251
+ variable.value = value;
252
+ }
253
+ // Also update form control
254
+ const form = this.conditionVariablesForms.get(conditionIndex);
255
+ if (form && form.get(variableName)) {
256
+ form.get(variableName)?.setValue(value);
257
+ }
258
+ }
259
+ onConditionVariableBooleanChange(conditionIndex, variableName, value) {
260
+ // Update the variable in templateVariables array
261
+ const variables = this.conditionTemplateVariables.get(conditionIndex) || [];
262
+ const variable = variables.find(v => v.name === variableName);
263
+ if (variable) {
264
+ variable.value = value;
265
+ }
266
+ // Also update form control
267
+ const form = this.conditionVariablesForms.get(conditionIndex);
268
+ if (form) {
269
+ if (form.get(variableName)) {
270
+ form.get(variableName)?.setValue(value);
271
+ }
272
+ else {
273
+ // Create form control if it doesn't exist
274
+ form.addControl(variableName, new FormControl(value));
275
+ }
276
+ }
277
+ }
278
+ getConditionFormGroup(index) {
279
+ return this.conditionsFormArray.at(index);
280
+ }
281
+ onIncludeElseChange(checked) {
282
+ this.includeElse = checked;
283
+ this.conditionForm.patchValue({ includeElse: checked });
284
+ }
285
+ onCancel() {
286
+ this.cancelled.emit();
287
+ }
288
+ onCreateStep() {
289
+ if (this.conditionForm.valid) {
290
+ const formValue = this.conditionForm.value;
291
+ const stepData = {
292
+ conditions: formValue.conditions.map((cond, index) => {
293
+ // Find the ActionTemplate object from the stored ID/value
294
+ const templateId = cond.value;
295
+ const selectedTemplate = this.conditionTemplates.find(t => (t.id?.toString() === templateId) || (t.displayName === templateId)) || this.selectedTemplates.get(index);
296
+ // Get template variables for this condition
297
+ const templateVariables = this.conditionTemplateVariables.get(index) || [];
298
+ return {
299
+ field: cond.field,
300
+ operator: cond.operator,
301
+ value: selectedTemplate || null,
302
+ templateVariables: templateVariables,
303
+ description: cond.description || '',
304
+ metadata: cond.metadata || ''
305
+ };
306
+ }),
307
+ includeElse: formValue.includeElse || false
308
+ };
309
+ console.log('stepData', stepData);
310
+ this.createStep.emit(stepData);
311
+ }
312
+ }
313
+ }
314
+ StepBuilderConditionComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: StepBuilderConditionComponent, deps: [{ token: i1.FormBuilder }], target: i0.ɵɵFactoryTarget.Component });
315
+ StepBuilderConditionComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.4.0", type: StepBuilderConditionComponent, selector: "cqa-step-builder-condition", inputs: { operatorOptions: "operatorOptions", conditionTemplates: "conditionTemplates", setConditionTemplateVariables: "setConditionTemplateVariables" }, outputs: { createStep: "createStep", cancelled: "cancelled" }, host: { classAttribute: "cqa-ui-root" }, usesOnChanges: true, ngImport: i0, template: "<div class=\"cqa-flex cqa-flex-col cqa-h-full cqa-bg-white cqa-px-4 cqa-py-2\">\n <!-- Header -->\n <h2 class=\"cqa-text-[12px] cqa-font-semibold cqa-text-black-100 cqa-mb-4\">\n Create Condition Step\n </h2>\n\n <div class=\"cqa-flex cqa-flex-col cqa-flex-1 cqa-overflow-y-auto\">\n <!-- Condition Builder Section -->\n <div class=\"cqa-mb-6\">\n <h3 class=\"cqa-text-sm cqa-text-[12px] cqa-font-semibold cqa-text-gray-900 cqa-mb-3\">\n Condition Builder\n </h3>\n\n <!-- Condition Rows -->\n <div class=\"cqa-flex cqa-flex-col cqa-gap-3 cqa-mb-3\">\n <ng-container *ngFor=\"let condition of conditionsFormArray.controls; let i = index\">\n <div\n *ngIf=\"getConditionFormGroup(i).get('field')?.value === 'CONDITION_IF' || getConditionFormGroup(i).get('field')?.value === 'CONDITION_ELSE_IF'\"\n class=\"cqa-flex cqa-flex-col cqa-gap-2\">\n <!-- Condition Row -->\n <div class=\"cqa-flex cqa-items-center cqa-gap-2\">\n <!-- Condition Label -->\n <div class=\"cqa-text-[12px] cqa-font-semibold\">\n {{getConditionFormGroup(i).get('field')?.value === 'CONDITION_IF' ? 'IF' :\n getConditionFormGroup(i).get('field')?.value === 'CONDITION_ELSE_IF' ? 'ELSE IF' : 'ELSE'}}\n </div>\n\n <!-- Operator Dropdown -->\n <!-- <div class=\"cqa-flex-1 cqa-max-w-[100px] cqa-text-[10px]\">\n <cqa-dynamic-select [form]=\"getConditionFormGroup(i)\" [config]=\"getOperatorConfig(i)\">\n </cqa-dynamic-select>\n </div> -->\n\n <!-- Value Template Dropdown -->\n <div class=\"cqa-flex-1 cqa-min-w-[150px] cqa-text-[10px]\">\n <cqa-dynamic-select [form]=\"getConditionFormGroup(i)\" [config]=\"getValueConfig(i)\">\n </cqa-dynamic-select>\n </div>\n\n <!-- Remove Button -->\n <cqa-button\n *ngIf=\"i >= 1\"\n variant=\"text\"\n icon=\"close\"\n iconPosition=\"start\"\n [customClass]=\"'cqa-w-full cqa-flex cqa-items-center cqa-justify-center'\"\n (click)=\"removeCondition(i)\"\n [attr.aria-label]=\"'Remove condition'\">\n </cqa-button>\n <!-- <button type=\"button\"\n class=\"cqa-flex cqa-items-center cqa-justify-center cqa-w-8 cqa-h-8 cqa-rounded cqa-text-gray-500 hover:cqa-text-gray-700 hover:cqa-bg-gray-100 cqa-transition-colors\"\n (click)=\"removeCondition(i)\" *ngIf=\"i >= 1\"\n [attr.aria-label]=\"'Remove condition'\">\n <mat-icon class=\"cqa-text-lg cqa-text-[24px]\">close</mat-icon>\n </button> -->\n </div>\n\n <!-- Template Variables Section (shown when template is selected) -->\n <div *ngIf=\"getSelectedTemplate(i)\">\n <!-- Template Grammar Display -->\n <!-- <div class=\"cqa-text-[12px] cqa-leading-[23px] cqa-text-black-100\"\n [innerHTML]=\"getSelectedTemplate(i)?.htmlGrammar || getSelectedTemplate(i)?.naturalText || ''\">\n </div> -->\n\n \n <!-- Description and Metadata Inputs -->\n <div class=\"cqa-flex cqa-flex cqa-gap-x-4 cqa-mb-4\" style=\"flex-wrap: wrap;\">\n <!-- Description -->\n <div class=\"cqa-flex cqa-flex-col\" style=\"width: calc(50% - 12px);\">\n <label class=\"cqa-text-[12px] cqa-font-medium cqa-text-gray-700 cqa-mb-1\">\n Description\n </label>\n <cqa-custom-input\n [placeholder]=\"'Enter description'\"\n [value]=\"getConditionFormGroup(i).get('description')?.value\"\n [fullWidth]=\"true\"\n (valueChange)=\"getConditionFormGroup(i).get('description')?.setValue($event)\">\n </cqa-custom-input>\n </div>\n\n <!-- Metadata -->\n <div class=\"cqa-flex cqa-flex-col\" style=\"width: calc(50% - 12px);\">\n <label class=\"cqa-text-[12px] cqa-font-medium cqa-text-gray-700 cqa-mb-1\">\n Metadata\n </label>\n <cqa-custom-input\n [placeholder]=\"'Enter metadata'\"\n [value]=\"getConditionFormGroup(i).get('metadata')?.value\"\n [fullWidth]=\"true\"\n (valueChange)=\"getConditionFormGroup(i).get('metadata')?.setValue($event)\">\n </cqa-custom-input>\n </div>\n </div>\n\n <!-- Template Variables Form Fields -->\n <div class=\"cqa-flex cqa-flex-col cqa-gap-4\" style=\"flex-wrap: wrap;\">\n <ng-container *ngFor=\"let variable of getConditionTemplateVariables(i)\">\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\" style=\"width: calc(50% - 12px);\">\n <label class=\"cqa-text-[12px] cqa-font-medium cqa-text-gray-700\">\n {{ variable.label }}\n </label>\n <mat-slide-toggle\n [checked]=\"getConditionVariablesForm(i).get(variable.name)?.value || variable.value || false\"\n (change)=\"onConditionVariableBooleanChange(i, variable.name, $event.checked)\"\n color=\"primary\">\n </mat-slide-toggle>\n </div>\n </ng-container>\n \n <!-- Non-boolean, non-custom_code variables -->\n <ng-container *ngIf=\"variable.name !== 'custom_code' && variable.type !== 'boolean'\">\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=\"width: calc(50% - 12px);\">\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 [form]=\"getConditionVariablesForm(i)\"\n [config]=\"getSelectConfigForVariable(i, variable)\">\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=\"width: calc(50% - 12px);\">\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]=\"'Text Input'\"\n [value]=\"variable.value\"\n [fullWidth]=\"true\"\n (valueChange)=\"onConditionVariableInputChange(i, variable.name, $event)\">\n </cqa-custom-input>\n </div>\n </ng-container>\n </ng-container>\n </ng-container>\n </div>\n\n </div>\n </div>\n </ng-container>\n </div>\n\n <!-- Add Condition Button -->\n <div class=\"cqa-border-2 cqa-border-dashed cqa-border-gray-300 cqa-rounded-lg cqa-p-1 cqa-mt-3\">\n <cqa-button\n variant=\"text\"\n icon=\"add\"\n iconPosition=\"start\"\n [customClass]=\"'cqa-w-full cqa-flex cqa-items-center cqa-justify-center'\"\n [text]=\"'Add Condition'\"\n (clicked)=\"addCondition('CONDITION_ELSE_IF')\">\n </cqa-button>\n </div>\n </div>\n\n <!-- Include ELSE Branch Section -->\n <div class=\"cqa-flex cqa-items-center cqa-justify-between cqa-mb-6 cqa-p-3 cqa-bg-gray-50 cqa-rounded-lg\">\n <div class=\"cqa-flex cqa-flex-col\">\n <h3 class=\"cqa-text-[14px] cqa-font-semibold cqa-text-gray-900 cqa-mb-1\">\n Include ELSE branch\n </h3>\n <p class=\"cqa-text-[12px] cqa-text-gray-600\">\n Execute alternative steps when condition is not met.\n </p>\n </div>\n <mat-slide-toggle [checked]=\"includeElse\" (change)=\"onIncludeElseChange($event.checked)\" color=\"primary\">\n </mat-slide-toggle>\n </div>\n </div>\n <!-- Action Buttons -->\n <div class=\"cqa-flex cqa-w-full cqa-gap-2 cqa-mt-auto cqa-pt-4 cqa-border-t cqa-border-gray-200\">\n <cqa-button class=\"cqa-w-1/2\" variant=\"outlined\" text=\"Cancel\" [customClass]=\"'cqa-flex-1 cqa-w-full'\"\n (clicked)=\"onCancel()\">\n </cqa-button>\n <cqa-button class=\"cqa-w-1/2\" variant=\"filled\" text=\"Create Step\" [customClass]=\"'cqa-flex-1 cqa-w-full'\"\n (clicked)=\"onCreateStep()\">\n </cqa-button>\n </div>\n</div>", components: [{ type: i2.DynamicSelectFieldComponent, selector: "cqa-dynamic-select", inputs: ["form", "config"], outputs: ["selectionChange", "selectClick", "searchChange", "loadMore"] }, { type: i3.ButtonComponent, selector: "cqa-button", inputs: ["variant", "btnSize", "disabled", "icon", "iconPosition", "fullWidth", "iconColor", "type", "text", "customClass", "inlineStyles", "tooltip", "tooltipPosition"], outputs: ["clicked"] }, { type: i4.CustomInputComponent, selector: "cqa-custom-input", inputs: ["label", "type", "placeholder", "value", "disabled", "errors", "required", "ariaLabel", "size", "fullWidth", "maxLength", "showCharCount", "inputInlineStyle", "labelInlineStyle"], outputs: ["valueChange", "blurred", "focused", "enterPressed"] }, { type: i5.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"] }], directives: [{ type: i6.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] });
316
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: StepBuilderConditionComponent, decorators: [{
317
+ type: Component,
318
+ args: [{ selector: 'cqa-step-builder-condition', host: { class: 'cqa-ui-root' }, template: "<div class=\"cqa-flex cqa-flex-col cqa-h-full cqa-bg-white cqa-px-4 cqa-py-2\">\n <!-- Header -->\n <h2 class=\"cqa-text-[12px] cqa-font-semibold cqa-text-black-100 cqa-mb-4\">\n Create Condition Step\n </h2>\n\n <div class=\"cqa-flex cqa-flex-col cqa-flex-1 cqa-overflow-y-auto\">\n <!-- Condition Builder Section -->\n <div class=\"cqa-mb-6\">\n <h3 class=\"cqa-text-sm cqa-text-[12px] cqa-font-semibold cqa-text-gray-900 cqa-mb-3\">\n Condition Builder\n </h3>\n\n <!-- Condition Rows -->\n <div class=\"cqa-flex cqa-flex-col cqa-gap-3 cqa-mb-3\">\n <ng-container *ngFor=\"let condition of conditionsFormArray.controls; let i = index\">\n <div\n *ngIf=\"getConditionFormGroup(i).get('field')?.value === 'CONDITION_IF' || getConditionFormGroup(i).get('field')?.value === 'CONDITION_ELSE_IF'\"\n class=\"cqa-flex cqa-flex-col cqa-gap-2\">\n <!-- Condition Row -->\n <div class=\"cqa-flex cqa-items-center cqa-gap-2\">\n <!-- Condition Label -->\n <div class=\"cqa-text-[12px] cqa-font-semibold\">\n {{getConditionFormGroup(i).get('field')?.value === 'CONDITION_IF' ? 'IF' :\n getConditionFormGroup(i).get('field')?.value === 'CONDITION_ELSE_IF' ? 'ELSE IF' : 'ELSE'}}\n </div>\n\n <!-- Operator Dropdown -->\n <!-- <div class=\"cqa-flex-1 cqa-max-w-[100px] cqa-text-[10px]\">\n <cqa-dynamic-select [form]=\"getConditionFormGroup(i)\" [config]=\"getOperatorConfig(i)\">\n </cqa-dynamic-select>\n </div> -->\n\n <!-- Value Template Dropdown -->\n <div class=\"cqa-flex-1 cqa-min-w-[150px] cqa-text-[10px]\">\n <cqa-dynamic-select [form]=\"getConditionFormGroup(i)\" [config]=\"getValueConfig(i)\">\n </cqa-dynamic-select>\n </div>\n\n <!-- Remove Button -->\n <cqa-button\n *ngIf=\"i >= 1\"\n variant=\"text\"\n icon=\"close\"\n iconPosition=\"start\"\n [customClass]=\"'cqa-w-full cqa-flex cqa-items-center cqa-justify-center'\"\n (click)=\"removeCondition(i)\"\n [attr.aria-label]=\"'Remove condition'\">\n </cqa-button>\n <!-- <button type=\"button\"\n class=\"cqa-flex cqa-items-center cqa-justify-center cqa-w-8 cqa-h-8 cqa-rounded cqa-text-gray-500 hover:cqa-text-gray-700 hover:cqa-bg-gray-100 cqa-transition-colors\"\n (click)=\"removeCondition(i)\" *ngIf=\"i >= 1\"\n [attr.aria-label]=\"'Remove condition'\">\n <mat-icon class=\"cqa-text-lg cqa-text-[24px]\">close</mat-icon>\n </button> -->\n </div>\n\n <!-- Template Variables Section (shown when template is selected) -->\n <div *ngIf=\"getSelectedTemplate(i)\">\n <!-- Template Grammar Display -->\n <!-- <div class=\"cqa-text-[12px] cqa-leading-[23px] cqa-text-black-100\"\n [innerHTML]=\"getSelectedTemplate(i)?.htmlGrammar || getSelectedTemplate(i)?.naturalText || ''\">\n </div> -->\n\n \n <!-- Description and Metadata Inputs -->\n <div class=\"cqa-flex cqa-flex cqa-gap-x-4 cqa-mb-4\" style=\"flex-wrap: wrap;\">\n <!-- Description -->\n <div class=\"cqa-flex cqa-flex-col\" style=\"width: calc(50% - 12px);\">\n <label class=\"cqa-text-[12px] cqa-font-medium cqa-text-gray-700 cqa-mb-1\">\n Description\n </label>\n <cqa-custom-input\n [placeholder]=\"'Enter description'\"\n [value]=\"getConditionFormGroup(i).get('description')?.value\"\n [fullWidth]=\"true\"\n (valueChange)=\"getConditionFormGroup(i).get('description')?.setValue($event)\">\n </cqa-custom-input>\n </div>\n\n <!-- Metadata -->\n <div class=\"cqa-flex cqa-flex-col\" style=\"width: calc(50% - 12px);\">\n <label class=\"cqa-text-[12px] cqa-font-medium cqa-text-gray-700 cqa-mb-1\">\n Metadata\n </label>\n <cqa-custom-input\n [placeholder]=\"'Enter metadata'\"\n [value]=\"getConditionFormGroup(i).get('metadata')?.value\"\n [fullWidth]=\"true\"\n (valueChange)=\"getConditionFormGroup(i).get('metadata')?.setValue($event)\">\n </cqa-custom-input>\n </div>\n </div>\n\n <!-- Template Variables Form Fields -->\n <div class=\"cqa-flex cqa-flex-col cqa-gap-4\" style=\"flex-wrap: wrap;\">\n <ng-container *ngFor=\"let variable of getConditionTemplateVariables(i)\">\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\" style=\"width: calc(50% - 12px);\">\n <label class=\"cqa-text-[12px] cqa-font-medium cqa-text-gray-700\">\n {{ variable.label }}\n </label>\n <mat-slide-toggle\n [checked]=\"getConditionVariablesForm(i).get(variable.name)?.value || variable.value || false\"\n (change)=\"onConditionVariableBooleanChange(i, variable.name, $event.checked)\"\n color=\"primary\">\n </mat-slide-toggle>\n </div>\n </ng-container>\n \n <!-- Non-boolean, non-custom_code variables -->\n <ng-container *ngIf=\"variable.name !== 'custom_code' && variable.type !== 'boolean'\">\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=\"width: calc(50% - 12px);\">\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 [form]=\"getConditionVariablesForm(i)\"\n [config]=\"getSelectConfigForVariable(i, variable)\">\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=\"width: calc(50% - 12px);\">\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]=\"'Text Input'\"\n [value]=\"variable.value\"\n [fullWidth]=\"true\"\n (valueChange)=\"onConditionVariableInputChange(i, variable.name, $event)\">\n </cqa-custom-input>\n </div>\n </ng-container>\n </ng-container>\n </ng-container>\n </div>\n\n </div>\n </div>\n </ng-container>\n </div>\n\n <!-- Add Condition Button -->\n <div class=\"cqa-border-2 cqa-border-dashed cqa-border-gray-300 cqa-rounded-lg cqa-p-1 cqa-mt-3\">\n <cqa-button\n variant=\"text\"\n icon=\"add\"\n iconPosition=\"start\"\n [customClass]=\"'cqa-w-full cqa-flex cqa-items-center cqa-justify-center'\"\n [text]=\"'Add Condition'\"\n (clicked)=\"addCondition('CONDITION_ELSE_IF')\">\n </cqa-button>\n </div>\n </div>\n\n <!-- Include ELSE Branch Section -->\n <div class=\"cqa-flex cqa-items-center cqa-justify-between cqa-mb-6 cqa-p-3 cqa-bg-gray-50 cqa-rounded-lg\">\n <div class=\"cqa-flex cqa-flex-col\">\n <h3 class=\"cqa-text-[14px] cqa-font-semibold cqa-text-gray-900 cqa-mb-1\">\n Include ELSE branch\n </h3>\n <p class=\"cqa-text-[12px] cqa-text-gray-600\">\n Execute alternative steps when condition is not met.\n </p>\n </div>\n <mat-slide-toggle [checked]=\"includeElse\" (change)=\"onIncludeElseChange($event.checked)\" color=\"primary\">\n </mat-slide-toggle>\n </div>\n </div>\n <!-- Action Buttons -->\n <div class=\"cqa-flex cqa-w-full cqa-gap-2 cqa-mt-auto cqa-pt-4 cqa-border-t cqa-border-gray-200\">\n <cqa-button class=\"cqa-w-1/2\" variant=\"outlined\" text=\"Cancel\" [customClass]=\"'cqa-flex-1 cqa-w-full'\"\n (clicked)=\"onCancel()\">\n </cqa-button>\n <cqa-button class=\"cqa-w-1/2\" variant=\"filled\" text=\"Create Step\" [customClass]=\"'cqa-flex-1 cqa-w-full'\"\n (clicked)=\"onCreateStep()\">\n </cqa-button>\n </div>\n</div>", styles: [] }]
319
+ }], ctorParameters: function () { return [{ type: i1.FormBuilder }]; }, propDecorators: { operatorOptions: [{
320
+ type: Input
321
+ }], conditionTemplates: [{
322
+ type: Input
323
+ }], setConditionTemplateVariables: [{
324
+ type: Input
325
+ }], createStep: [{
326
+ type: Output
327
+ }], cancelled: [{
328
+ type: Output
329
+ }] } });
330
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"step-builder-condition.component.js","sourceRoot":"","sources":["../../../../../../src/lib/step-builder/step-builder-condition/step-builder-condition.component.ts","../../../../../../src/lib/step-builder/step-builder-condition/step-builder-condition.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, Output, EventEmitter, OnInit, OnChanges, SimpleChanges } from '@angular/core';\nimport { FormArray, FormBuilder, FormGroup, FormControl, Validators } from '@angular/forms';\nimport { DynamicSelectFieldConfig, SelectOption } from '../../dynamic-select/dynamic-select-field.component';\nimport { ActionTemplate } from '../step-builder-action/step-builder-action.component';\n\nexport interface ConditionRow {\n  field: string;\n  operator: string;\n  value: ActionTemplate;\n  templateVariables?: any[];\n  description?: string;\n  metadata?: string;\n}\n\nexport interface ConditionFormData {\n  conditions: ConditionRow[];\n  includeElse: boolean;\n}\n\n@Component({\n  selector: 'cqa-step-builder-condition',\n  templateUrl: './step-builder-condition.component.html',\n  styleUrls: [],\n  host: { class: 'cqa-ui-root' }\n})\nexport class StepBuilderConditionComponent implements OnInit, OnChanges {\n  /** Options for operator dropdown */\n  @Input() operatorOptions: SelectOption[] = [\n    { id: 'equals', value: 'equals', name: 'equals', label: 'equals' },\n    { id: 'not_equals', value: 'not_equals', name: 'not equals', label: 'not equals' },\n    { id: 'contains', value: 'contains', name: 'contains', label: 'contains' },\n    { id: 'not_contains', value: 'not_contains', name: 'not contains', label: 'not contains' },\n    { id: 'greater_than', value: 'greater_than', name: 'greater than', label: 'greater than' },\n    { id: 'less_than', value: 'less_than', name: 'less than', label: 'less than' }\n  ];\n\n  /** List of action templates to display in value dropdown */\n  @Input() conditionTemplates: ActionTemplate[] = [];\n  /** Function to handle variable processing or custom logic. Can be passed from parent component. */\n  @Input() setConditionTemplateVariables: (variables: ActionTemplate) => any = () => { return []};\n\n  /** Emit when step is created */\n  @Output() createStep = new EventEmitter<ConditionFormData>();\n\n  /** Emit when cancelled */\n  @Output() cancelled = new EventEmitter<void>();\n\n  conditionForm: FormGroup;\n  includeElse: boolean = false;\n  \n  // Cache for value configs to avoid recreating on every change detection\n  private valueConfigCache: DynamicSelectFieldConfig | null = null;\n  \n  // Track selected templates and their variables for each condition row\n  private selectedTemplates: Map<number, ActionTemplate> = new Map();\n  private conditionTemplateVariables: Map<number, any[]> = new Map();\n  private conditionVariablesForms: Map<number, FormGroup> = new Map();\n\n  constructor(private fb: FormBuilder) {\n    this.conditionForm = this.fb.group({\n      conditions: this.fb.array([]),\n      includeElse: [false]\n    });\n  }\n\n  ngOnInit(): void {\n    // Add initial condition row\n    this.addCondition(\"CONDITION_IF\");\n    // Initialize value config cache\n    this.updateValueConfigCache();\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    // Regenerate value config cache when conditionTemplates changes\n    if (changes['conditionTemplates'] && !changes['conditionTemplates'].firstChange) {\n      this.updateValueConfigCache();\n    }\n  }\n\n  get conditionsFormArray(): FormArray {\n    return this.conditionForm.get('conditions') as FormArray;\n  }\n\n  addCondition(conditionType: string): void {\n    const conditionGroup = this.fb.group({\n      field: [conditionType, Validators.required],\n      operator: ['equals', Validators.required],\n      value: [null, Validators.required], // Will store template ID, then map to ActionTemplate\n      description: [''],\n      metadata: [''],\n    });\n    const index = this.conditionsFormArray.length;\n    this.conditionsFormArray.push(conditionGroup);\n    \n    // Initialize variables form for this condition\n    this.conditionVariablesForms.set(index, this.fb.group({}));\n  }\n\n  removeCondition(index: number): void {\n    if (this.conditionsFormArray.length > 1) {\n      this.conditionsFormArray.removeAt(index);\n      // Clean up associated data\n      this.selectedTemplates.delete(index);\n      this.conditionTemplateVariables.delete(index);\n      this.conditionVariablesForms.delete(index);\n      \n      // Reindex remaining conditions\n      this.reindexConditionData(index);\n    }\n  }\n  \n  private reindexConditionData(removedIndex: number): void {\n    // Create new maps with reindexed data\n    const newSelectedTemplates = new Map<number, ActionTemplate>();\n    const newTemplateVariables = new Map<number, any[]>();\n    const newVariablesForms = new Map<number, FormGroup>();\n    \n    this.selectedTemplates.forEach((template, oldIndex) => {\n      if (oldIndex < removedIndex) {\n        newSelectedTemplates.set(oldIndex, template);\n      } else if (oldIndex > removedIndex) {\n        newSelectedTemplates.set(oldIndex - 1, template);\n      }\n    });\n    \n    this.conditionTemplateVariables.forEach((variables, oldIndex) => {\n      if (oldIndex < removedIndex) {\n        newTemplateVariables.set(oldIndex, variables);\n      } else if (oldIndex > removedIndex) {\n        newTemplateVariables.set(oldIndex - 1, variables);\n      }\n    });\n    \n    this.conditionVariablesForms.forEach((form, oldIndex) => {\n      if (oldIndex < removedIndex) {\n        newVariablesForms.set(oldIndex, form);\n      } else if (oldIndex > removedIndex) {\n        newVariablesForms.set(oldIndex - 1, form);\n      }\n    });\n    \n    this.selectedTemplates = newSelectedTemplates;\n    this.conditionTemplateVariables = newTemplateVariables;\n    this.conditionVariablesForms = newVariablesForms;\n  }\n\n  getOperatorConfig(index: number): DynamicSelectFieldConfig {\n    return {\n      key: 'operator',\n      placeholder: 'Select operator',\n      multiple: false,\n      searchable: false,\n      options: this.operatorOptions\n    };\n  }\n\n  private updateValueConfigCache(): void {\n    // Convert ActionTemplate[] to SelectOption[]\n    const templateOptions: SelectOption[] = (this.conditionTemplates || []).map(template => ({\n      id: template.id?.toString() || template.displayName || '',\n      value: template.id?.toString() || template.displayName || '',\n      name: template.htmlGrammar || template.naturalText || '',\n      label: template.htmlGrammar || template.naturalText || ''\n    }));\n\n    this.valueConfigCache = {\n      key: 'value',\n      placeholder: 'Select Template',\n      multiple: false,\n      searchable: true,\n      displayLabelAsInnerHtml: true,\n      options: templateOptions\n    };\n  }\n\n  getValueConfig(index: number): DynamicSelectFieldConfig {\n    // Return cached config to avoid recreating options on every change detection\n    if (!this.valueConfigCache) {\n      this.updateValueConfigCache();\n    }\n    \n    // Create a new config object with the onChange handler for this specific index\n    // This ensures each condition row has its own handler while sharing the base config\n    return {\n      ...this.valueConfigCache!,\n      onChange: (value: any) => {\n        this.onTemplateValueChange(index, value);\n      }\n    };\n  }\n  \n  onTemplateValueChange(index: number, templateId: any): void {\n    // Find the selected template\n    const selectedTemplate = this.conditionTemplates.find(\n      t => (t.id?.toString() === templateId) || (t.displayName === templateId)\n    );\n    \n    if (selectedTemplate && this.setConditionTemplateVariables) {\n      // Store selected template\n      this.selectedTemplates.set(index, selectedTemplate);\n      \n      // Get template variables using the provided function\n      const variables = this.setConditionTemplateVariables(selectedTemplate);\n      this.conditionTemplateVariables.set(index, variables);\n      // Build form for template variables\n      this.buildConditionVariablesForm(index, variables);\n    } else {\n      // Clear template and variables if no template selected\n      this.selectedTemplates.delete(index);\n      this.conditionTemplateVariables.delete(index);\n      const form = this.conditionVariablesForms.get(index);\n      if (form) {\n        Object.keys(form.controls).forEach(key => {\n          form.removeControl(key);\n        });\n      }\n    }\n  }\n  \n  private buildConditionVariablesForm(index: number, variables: any[]): void {\n    let form = this.conditionVariablesForms.get(index);\n    if (!form) {\n      form = this.fb.group({});\n      this.conditionVariablesForms.set(index, form);\n    }\n    \n    // Ensure form is not undefined\n    if (!form) {\n      return;\n    }\n    \n    // Clear existing form controls\n    Object.keys(form.controls).forEach(key => {\n      form!.removeControl(key);\n    });\n    \n    // Add form controls for each variable\n    variables.forEach(variable => {\n      // Handle boolean variables - use boolean value, others use string\n      const defaultValue = variable.type === 'boolean' \n        ? (variable.value === true || variable.value === 'true' || variable.value === 1)\n        : (variable.value || '');\n      form!.addControl(variable.name, new FormControl(defaultValue));\n    });\n  }\n  \n  getConditionTemplateVariables(index: number): any[] {\n    return this.conditionTemplateVariables.get(index) || [];\n  }\n  \n  getConditionVariablesForm(index: number): FormGroup {\n    let form = this.conditionVariablesForms.get(index);\n    if (!form) {\n      form = this.fb.group({});\n      this.conditionVariablesForms.set(index, form);\n    }\n    return form;\n  }\n  \n  getSelectedTemplate(index: number): ActionTemplate | null {\n    return this.selectedTemplates.get(index) || null;\n  }\n  \n  getSelectConfigForVariable(index: number, variable: any): 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    return {\n      key: variable.name,\n      placeholder: `Select ${variable.label}`,\n      multiple: false,\n      searchable: false,\n      options: options,\n      onChange: (value: any) => {\n        this.onConditionVariableValueChange(index, variable.name, value);\n      }\n    };\n  }\n  \n  onConditionVariableValueChange(conditionIndex: number, variableName: string, value: any): void {\n    // Update the variable in templateVariables array\n    const variables = this.conditionTemplateVariables.get(conditionIndex) || [];\n    const variable = variables.find(v => v.name === variableName);\n    if (variable) {\n      variable.value = value;\n    }\n    // Also update form control\n    const form = this.conditionVariablesForms.get(conditionIndex);\n    if (form && form.get(variableName)) {\n      form.get(variableName)?.setValue(value);\n    }\n  }\n  \n  onConditionVariableInputChange(conditionIndex: number, variableName: string, value: any): void {\n    // Update the variable in templateVariables array\n    const variables = this.conditionTemplateVariables.get(conditionIndex) || [];\n    const variable = variables.find(v => v.name === variableName);\n    if (variable) {\n      variable.value = value;\n    }\n    // Also update form control\n    const form = this.conditionVariablesForms.get(conditionIndex);\n    if (form && form.get(variableName)) {\n      form.get(variableName)?.setValue(value);\n    }\n  }\n\n  onConditionVariableBooleanChange(conditionIndex: number, variableName: string, value: boolean): void {\n    // Update the variable in templateVariables array\n    const variables = this.conditionTemplateVariables.get(conditionIndex) || [];\n    const variable = variables.find(v => v.name === variableName);\n    if (variable) {\n      variable.value = value;\n    }\n    // Also update form control\n    const form = this.conditionVariablesForms.get(conditionIndex);\n    if (form) {\n      if (form.get(variableName)) {\n        form.get(variableName)?.setValue(value);\n      } else {\n        // Create form control if it doesn't exist\n        form.addControl(variableName, new FormControl(value));\n      }\n    }\n  }\n\n  getConditionFormGroup(index: number): FormGroup {\n    return this.conditionsFormArray.at(index) as FormGroup;\n  }\n\n  onIncludeElseChange(checked: boolean): void {\n    this.includeElse = checked;\n    this.conditionForm.patchValue({ includeElse: checked });\n  }\n\n  onCancel(): void {\n    this.cancelled.emit();\n  }\n\n  onCreateStep(): void {\n    if (this.conditionForm.valid) {\n      const formValue = this.conditionForm.value;\n      const stepData: ConditionFormData = {\n        conditions: formValue.conditions.map((cond: any, index: number) => {\n          // Find the ActionTemplate object from the stored ID/value\n          const templateId = cond.value;\n          const selectedTemplate = this.conditionTemplates.find(\n            t => (t.id?.toString() === templateId) || (t.displayName === templateId)\n          ) || this.selectedTemplates.get(index);\n          \n          // Get template variables for this condition\n          const templateVariables = this.conditionTemplateVariables.get(index) || [];\n          \n          return {\n            field: cond.field,\n            operator: cond.operator,\n            value: selectedTemplate || null,\n            templateVariables: templateVariables,\n            description: cond.description || '',\n            metadata: cond.metadata || ''\n          };\n        }),\n        includeElse: formValue.includeElse || false\n      };\n      console.log('stepData', stepData);\n      this.createStep.emit(stepData);\n    }\n  }\n}\n\n","<div class=\"cqa-flex cqa-flex-col cqa-h-full cqa-bg-white cqa-px-4 cqa-py-2\">\n  <!-- Header -->\n  <h2 class=\"cqa-text-[12px] cqa-font-semibold cqa-text-black-100 cqa-mb-4\">\n    Create Condition Step\n  </h2>\n\n  <div class=\"cqa-flex cqa-flex-col cqa-flex-1 cqa-overflow-y-auto\">\n    <!-- Condition Builder Section -->\n    <div class=\"cqa-mb-6\">\n      <h3 class=\"cqa-text-sm cqa-text-[12px] cqa-font-semibold cqa-text-gray-900 cqa-mb-3\">\n        Condition Builder\n      </h3>\n\n      <!-- Condition Rows -->\n      <div class=\"cqa-flex cqa-flex-col cqa-gap-3 cqa-mb-3\">\n        <ng-container *ngFor=\"let condition of conditionsFormArray.controls; let i = index\">\n          <div\n            *ngIf=\"getConditionFormGroup(i).get('field')?.value === 'CONDITION_IF' || getConditionFormGroup(i).get('field')?.value === 'CONDITION_ELSE_IF'\"\n            class=\"cqa-flex cqa-flex-col cqa-gap-2\">\n            <!-- Condition Row -->\n            <div class=\"cqa-flex cqa-items-center cqa-gap-2\">\n              <!-- Condition Label -->\n              <div class=\"cqa-text-[12px] cqa-font-semibold\">\n                {{getConditionFormGroup(i).get('field')?.value === 'CONDITION_IF' ? 'IF' :\n                getConditionFormGroup(i).get('field')?.value === 'CONDITION_ELSE_IF' ? 'ELSE IF' : 'ELSE'}}\n              </div>\n\n              <!-- Operator Dropdown -->\n              <!-- <div class=\"cqa-flex-1 cqa-max-w-[100px] cqa-text-[10px]\">\n                <cqa-dynamic-select [form]=\"getConditionFormGroup(i)\" [config]=\"getOperatorConfig(i)\">\n                </cqa-dynamic-select>\n              </div> -->\n\n              <!-- Value Template Dropdown -->\n              <div class=\"cqa-flex-1 cqa-min-w-[150px] cqa-text-[10px]\">\n                <cqa-dynamic-select [form]=\"getConditionFormGroup(i)\" [config]=\"getValueConfig(i)\">\n                </cqa-dynamic-select>\n              </div>\n\n              <!-- Remove Button -->\n              <cqa-button\n                *ngIf=\"i >= 1\"\n                variant=\"text\"\n                icon=\"close\"\n                iconPosition=\"start\"\n                [customClass]=\"'cqa-w-full cqa-flex cqa-items-center cqa-justify-center'\"\n                (click)=\"removeCondition(i)\"\n                [attr.aria-label]=\"'Remove condition'\">\n              </cqa-button>\n              <!-- <button type=\"button\"\n                class=\"cqa-flex cqa-items-center cqa-justify-center cqa-w-8 cqa-h-8 cqa-rounded cqa-text-gray-500 hover:cqa-text-gray-700 hover:cqa-bg-gray-100 cqa-transition-colors\"\n                (click)=\"removeCondition(i)\" *ngIf=\"i >= 1\"\n                [attr.aria-label]=\"'Remove condition'\">\n                <mat-icon class=\"cqa-text-lg cqa-text-[24px]\">close</mat-icon>\n              </button> -->\n            </div>\n\n            <!-- Template Variables Section (shown when template is selected) -->\n            <div *ngIf=\"getSelectedTemplate(i)\">\n              <!-- Template Grammar Display -->\n              <!-- <div class=\"cqa-text-[12px] cqa-leading-[23px] cqa-text-black-100\"\n                [innerHTML]=\"getSelectedTemplate(i)?.htmlGrammar || getSelectedTemplate(i)?.naturalText || ''\">\n              </div> -->\n\n              \n              <!-- Description and Metadata Inputs -->\n              <div class=\"cqa-flex cqa-flex cqa-gap-x-4 cqa-mb-4\" style=\"flex-wrap: wrap;\">\n                <!-- Description -->\n                <div class=\"cqa-flex cqa-flex-col\" style=\"width: calc(50% - 12px);\">\n                  <label class=\"cqa-text-[12px] cqa-font-medium cqa-text-gray-700 cqa-mb-1\">\n                    Description\n                  </label>\n                  <cqa-custom-input\n                    [placeholder]=\"'Enter description'\"\n                    [value]=\"getConditionFormGroup(i).get('description')?.value\"\n                    [fullWidth]=\"true\"\n                    (valueChange)=\"getConditionFormGroup(i).get('description')?.setValue($event)\">\n                  </cqa-custom-input>\n                </div>\n\n                <!-- Metadata -->\n                <div class=\"cqa-flex cqa-flex-col\" style=\"width: calc(50% - 12px);\">\n                  <label class=\"cqa-text-[12px] cqa-font-medium cqa-text-gray-700 cqa-mb-1\">\n                    Metadata\n                  </label>\n                  <cqa-custom-input\n                    [placeholder]=\"'Enter metadata'\"\n                    [value]=\"getConditionFormGroup(i).get('metadata')?.value\"\n                    [fullWidth]=\"true\"\n                    (valueChange)=\"getConditionFormGroup(i).get('metadata')?.setValue($event)\">\n                  </cqa-custom-input>\n                </div>\n              </div>\n\n              <!-- Template Variables Form Fields -->\n              <div class=\"cqa-flex cqa-flex-col cqa-gap-4\"  style=\"flex-wrap: wrap;\">\n                <ng-container *ngFor=\"let variable of getConditionTemplateVariables(i)\">\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\" style=\"width: calc(50% - 12px);\">\n                      <label class=\"cqa-text-[12px] cqa-font-medium cqa-text-gray-700\">\n                        {{ variable.label }}\n                      </label>\n                      <mat-slide-toggle\n                        [checked]=\"getConditionVariablesForm(i).get(variable.name)?.value || variable.value || false\"\n                        (change)=\"onConditionVariableBooleanChange(i, variable.name, $event.checked)\"\n                        color=\"primary\">\n                      </mat-slide-toggle>\n                    </div>\n                  </ng-container>\n                  \n                  <!-- Non-boolean, non-custom_code variables -->\n                  <ng-container *ngIf=\"variable.name !== 'custom_code' && variable.type !== 'boolean'\">\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=\"width: calc(50% - 12px);\">\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 [form]=\"getConditionVariablesForm(i)\"\n                          [config]=\"getSelectConfigForVariable(i, variable)\">\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=\"width: calc(50% - 12px);\">\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]=\"'Text Input'\"\n                          [value]=\"variable.value\"\n                          [fullWidth]=\"true\"\n                          (valueChange)=\"onConditionVariableInputChange(i, variable.name, $event)\">\n                        </cqa-custom-input>\n                      </div>\n                    </ng-container>\n                  </ng-container>\n                </ng-container>\n              </div>\n\n            </div>\n          </div>\n        </ng-container>\n      </div>\n\n      <!-- Add Condition Button -->\n      <div class=\"cqa-border-2 cqa-border-dashed cqa-border-gray-300 cqa-rounded-lg cqa-p-1 cqa-mt-3\">\n        <cqa-button\n          variant=\"text\"\n          icon=\"add\"\n          iconPosition=\"start\"\n          [customClass]=\"'cqa-w-full cqa-flex cqa-items-center cqa-justify-center'\"\n          [text]=\"'Add Condition'\"\n          (clicked)=\"addCondition('CONDITION_ELSE_IF')\">\n        </cqa-button>\n      </div>\n    </div>\n\n    <!-- Include ELSE Branch Section -->\n    <div class=\"cqa-flex cqa-items-center cqa-justify-between cqa-mb-6 cqa-p-3 cqa-bg-gray-50 cqa-rounded-lg\">\n      <div class=\"cqa-flex cqa-flex-col\">\n        <h3 class=\"cqa-text-[14px] cqa-font-semibold cqa-text-gray-900 cqa-mb-1\">\n          Include ELSE branch\n        </h3>\n        <p class=\"cqa-text-[12px] cqa-text-gray-600\">\n          Execute alternative steps when condition is not met.\n        </p>\n      </div>\n      <mat-slide-toggle [checked]=\"includeElse\" (change)=\"onIncludeElseChange($event.checked)\" color=\"primary\">\n      </mat-slide-toggle>\n    </div>\n  </div>\n  <!-- Action Buttons -->\n  <div class=\"cqa-flex cqa-w-full cqa-gap-2 cqa-mt-auto cqa-pt-4 cqa-border-t cqa-border-gray-200\">\n    <cqa-button class=\"cqa-w-1/2\" variant=\"outlined\" text=\"Cancel\" [customClass]=\"'cqa-flex-1 cqa-w-full'\"\n      (clicked)=\"onCancel()\">\n    </cqa-button>\n    <cqa-button class=\"cqa-w-1/2\" variant=\"filled\" text=\"Create Step\" [customClass]=\"'cqa-flex-1 cqa-w-full'\"\n      (clicked)=\"onCreateStep()\">\n    </cqa-button>\n  </div>\n</div>"]}