@cqa-lib/cqa-ui 1.1.203 → 1.1.204
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2020/lib/step-builder/step-builder-action/step-builder-action.component.mjs +7 -9
- package/esm2020/lib/step-builder/step-builder-ai-agent/step-builder-ai-agent.component.mjs +4 -4
- package/esm2020/lib/step-builder/step-builder-condition/step-builder-condition.component.mjs +121 -23
- package/esm2020/lib/step-builder/step-builder-document/step-builder-document.component.mjs +65 -9
- package/esm2020/lib/step-builder/step-builder-loop/step-builder-loop.component.mjs +8 -9
- package/esm2020/lib/step-builder/template-variables-form/template-variables-form.component.mjs +319 -0
- package/esm2020/lib/ui-kit.module.mjs +12 -3
- package/esm2020/public-api.mjs +2 -1
- package/fesm2015/cqa-lib-cqa-ui.mjs +520 -43
- package/fesm2015/cqa-lib-cqa-ui.mjs.map +1 -1
- package/fesm2020/cqa-lib-cqa-ui.mjs +512 -38
- package/fesm2020/cqa-lib-cqa-ui.mjs.map +1 -1
- package/lib/step-builder/step-builder-condition/step-builder-condition.component.d.ts +12 -2
- package/lib/step-builder/step-builder-document/step-builder-document.component.d.ts +18 -1
- package/lib/step-builder/template-variables-form/template-variables-form.component.d.ts +55 -0
- package/lib/ui-kit.module.d.ts +24 -22
- package/package.json +1 -1
- package/public-api.d.ts +1 -0
- package/styles.css +1 -1
package/esm2020/lib/step-builder/step-builder-condition/step-builder-condition.component.mjs
CHANGED
|
@@ -1,15 +1,16 @@
|
|
|
1
|
-
import { Component, Input, Output, EventEmitter } from '@angular/core';
|
|
1
|
+
import { Component, Input, Output, EventEmitter, ChangeDetectionStrategy } from '@angular/core';
|
|
2
2
|
import { FormControl, Validators } from '@angular/forms';
|
|
3
3
|
import * as i0 from "@angular/core";
|
|
4
4
|
import * as i1 from "@angular/forms";
|
|
5
5
|
import * as i2 from "../../dynamic-select/dynamic-select-field.component";
|
|
6
6
|
import * as i3 from "../../button/button.component";
|
|
7
|
-
import * as i4 from "
|
|
7
|
+
import * as i4 from "../template-variables-form/template-variables-form.component";
|
|
8
8
|
import * as i5 from "@angular/material/slide-toggle";
|
|
9
9
|
import * as i6 from "@angular/common";
|
|
10
10
|
export class StepBuilderConditionComponent {
|
|
11
|
-
constructor(fb) {
|
|
11
|
+
constructor(fb, cdr) {
|
|
12
12
|
this.fb = fb;
|
|
13
|
+
this.cdr = cdr;
|
|
13
14
|
/** Options for operator dropdown */
|
|
14
15
|
this.operatorOptions = [
|
|
15
16
|
{ id: 'equals', value: 'equals', name: 'equals', label: 'equals' },
|
|
@@ -30,10 +31,16 @@ export class StepBuilderConditionComponent {
|
|
|
30
31
|
this.includeElse = false;
|
|
31
32
|
// Cache for value configs to avoid recreating on every change detection
|
|
32
33
|
this.valueConfigCache = null;
|
|
34
|
+
// Cache for operator configs (static, no need to recreate)
|
|
35
|
+
this.operatorConfigCache = null;
|
|
36
|
+
// Cache for value configs with onChange handlers per index
|
|
37
|
+
this.valueConfigsWithHandlers = new Map();
|
|
33
38
|
// Track selected templates and their variables for each condition row
|
|
34
39
|
this.selectedTemplates = new Map();
|
|
35
40
|
this.conditionTemplateVariables = new Map();
|
|
36
41
|
this.conditionVariablesForms = new Map();
|
|
42
|
+
// Cache for condition form groups to avoid repeated lookups
|
|
43
|
+
this.conditionFormGroupCache = new Map();
|
|
37
44
|
this.conditionForm = this.fb.group({
|
|
38
45
|
conditions: this.fb.array([]),
|
|
39
46
|
includeElse: [false]
|
|
@@ -42,14 +49,30 @@ export class StepBuilderConditionComponent {
|
|
|
42
49
|
ngOnInit() {
|
|
43
50
|
// Add initial condition row
|
|
44
51
|
this.addCondition("CONDITION_IF");
|
|
45
|
-
// Initialize
|
|
52
|
+
// Initialize config caches
|
|
46
53
|
this.updateValueConfigCache();
|
|
54
|
+
this.updateOperatorConfigCache();
|
|
55
|
+
// Mark for check since we're using OnPush
|
|
56
|
+
this.cdr.markForCheck();
|
|
47
57
|
}
|
|
48
58
|
ngOnChanges(changes) {
|
|
49
59
|
// Regenerate value config cache when conditionTemplates changes
|
|
50
60
|
if (changes['conditionTemplates'] && !changes['conditionTemplates'].firstChange) {
|
|
51
61
|
this.updateValueConfigCache();
|
|
62
|
+
// Clear value configs with handlers since base config changed
|
|
63
|
+
this.valueConfigsWithHandlers.clear();
|
|
52
64
|
}
|
|
65
|
+
// Mark for check since we're using OnPush
|
|
66
|
+
this.cdr.markForCheck();
|
|
67
|
+
}
|
|
68
|
+
updateOperatorConfigCache() {
|
|
69
|
+
this.operatorConfigCache = {
|
|
70
|
+
key: 'operator',
|
|
71
|
+
placeholder: 'Select operator',
|
|
72
|
+
multiple: false,
|
|
73
|
+
searchable: false,
|
|
74
|
+
options: this.operatorOptions
|
|
75
|
+
};
|
|
53
76
|
}
|
|
54
77
|
get conditionsFormArray() {
|
|
55
78
|
return this.conditionForm.get('conditions');
|
|
@@ -66,6 +89,10 @@ export class StepBuilderConditionComponent {
|
|
|
66
89
|
this.conditionsFormArray.push(conditionGroup);
|
|
67
90
|
// Initialize variables form for this condition
|
|
68
91
|
this.conditionVariablesForms.set(index, this.fb.group({}));
|
|
92
|
+
// Cache the form group
|
|
93
|
+
this.conditionFormGroupCache.set(index, conditionGroup);
|
|
94
|
+
// Mark for check since we're using OnPush
|
|
95
|
+
this.cdr.markForCheck();
|
|
69
96
|
}
|
|
70
97
|
removeCondition(index) {
|
|
71
98
|
if (this.conditionsFormArray.length > 1) {
|
|
@@ -74,8 +101,12 @@ export class StepBuilderConditionComponent {
|
|
|
74
101
|
this.selectedTemplates.delete(index);
|
|
75
102
|
this.conditionTemplateVariables.delete(index);
|
|
76
103
|
this.conditionVariablesForms.delete(index);
|
|
104
|
+
this.conditionFormGroupCache.delete(index);
|
|
105
|
+
this.valueConfigsWithHandlers.delete(index);
|
|
77
106
|
// Reindex remaining conditions
|
|
78
107
|
this.reindexConditionData(index);
|
|
108
|
+
// Mark for check since we're using OnPush
|
|
109
|
+
this.cdr.markForCheck();
|
|
79
110
|
}
|
|
80
111
|
}
|
|
81
112
|
reindexConditionData(removedIndex) {
|
|
@@ -83,6 +114,8 @@ export class StepBuilderConditionComponent {
|
|
|
83
114
|
const newSelectedTemplates = new Map();
|
|
84
115
|
const newTemplateVariables = new Map();
|
|
85
116
|
const newVariablesForms = new Map();
|
|
117
|
+
const newFormGroupCache = new Map();
|
|
118
|
+
const newValueConfigs = new Map();
|
|
86
119
|
this.selectedTemplates.forEach((template, oldIndex) => {
|
|
87
120
|
if (oldIndex < removedIndex) {
|
|
88
121
|
newSelectedTemplates.set(oldIndex, template);
|
|
@@ -107,18 +140,41 @@ export class StepBuilderConditionComponent {
|
|
|
107
140
|
newVariablesForms.set(oldIndex - 1, form);
|
|
108
141
|
}
|
|
109
142
|
});
|
|
143
|
+
this.conditionFormGroupCache.forEach((formGroup, oldIndex) => {
|
|
144
|
+
if (oldIndex < removedIndex) {
|
|
145
|
+
newFormGroupCache.set(oldIndex, formGroup);
|
|
146
|
+
}
|
|
147
|
+
else if (oldIndex > removedIndex) {
|
|
148
|
+
newFormGroupCache.set(oldIndex - 1, formGroup);
|
|
149
|
+
}
|
|
150
|
+
});
|
|
151
|
+
this.valueConfigsWithHandlers.forEach((config, oldIndex) => {
|
|
152
|
+
if (oldIndex < removedIndex) {
|
|
153
|
+
newValueConfigs.set(oldIndex, config);
|
|
154
|
+
}
|
|
155
|
+
else if (oldIndex > removedIndex) {
|
|
156
|
+
// Recreate config with new index for onChange handler
|
|
157
|
+
const newConfig = {
|
|
158
|
+
...config,
|
|
159
|
+
onChange: (value) => {
|
|
160
|
+
this.onTemplateValueChange(oldIndex - 1, value);
|
|
161
|
+
}
|
|
162
|
+
};
|
|
163
|
+
newValueConfigs.set(oldIndex - 1, newConfig);
|
|
164
|
+
}
|
|
165
|
+
});
|
|
110
166
|
this.selectedTemplates = newSelectedTemplates;
|
|
111
167
|
this.conditionTemplateVariables = newTemplateVariables;
|
|
112
168
|
this.conditionVariablesForms = newVariablesForms;
|
|
169
|
+
this.conditionFormGroupCache = newFormGroupCache;
|
|
170
|
+
this.valueConfigsWithHandlers = newValueConfigs;
|
|
113
171
|
}
|
|
114
172
|
getOperatorConfig(index) {
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
options: this.operatorOptions
|
|
121
|
-
};
|
|
173
|
+
// Return cached config (static, same for all conditions)
|
|
174
|
+
if (!this.operatorConfigCache) {
|
|
175
|
+
this.updateOperatorConfigCache();
|
|
176
|
+
}
|
|
177
|
+
return this.operatorConfigCache;
|
|
122
178
|
}
|
|
123
179
|
updateValueConfigCache() {
|
|
124
180
|
// Convert ActionTemplate[] to SelectOption[]
|
|
@@ -138,18 +194,23 @@ export class StepBuilderConditionComponent {
|
|
|
138
194
|
};
|
|
139
195
|
}
|
|
140
196
|
getValueConfig(index) {
|
|
141
|
-
// Return cached config to avoid recreating
|
|
197
|
+
// Return cached config with handler to avoid recreating on every change detection
|
|
198
|
+
if (this.valueConfigsWithHandlers.has(index)) {
|
|
199
|
+
return this.valueConfigsWithHandlers.get(index);
|
|
200
|
+
}
|
|
201
|
+
// Ensure base config cache exists
|
|
142
202
|
if (!this.valueConfigCache) {
|
|
143
203
|
this.updateValueConfigCache();
|
|
144
204
|
}
|
|
145
|
-
// Create
|
|
146
|
-
|
|
147
|
-
return {
|
|
205
|
+
// Create and cache config with onChange handler for this specific index
|
|
206
|
+
const config = {
|
|
148
207
|
...this.valueConfigCache,
|
|
149
208
|
onChange: (value) => {
|
|
150
209
|
this.onTemplateValueChange(index, value);
|
|
151
210
|
}
|
|
152
211
|
};
|
|
212
|
+
this.valueConfigsWithHandlers.set(index, config);
|
|
213
|
+
return config;
|
|
153
214
|
}
|
|
154
215
|
onTemplateValueChange(index, templateId) {
|
|
155
216
|
// Find the selected template
|
|
@@ -174,6 +235,8 @@ export class StepBuilderConditionComponent {
|
|
|
174
235
|
});
|
|
175
236
|
}
|
|
176
237
|
}
|
|
238
|
+
// Mark for check since we're using OnPush
|
|
239
|
+
this.cdr.markForCheck();
|
|
177
240
|
}
|
|
178
241
|
buildConditionVariablesForm(index, variables) {
|
|
179
242
|
let form = this.conditionVariablesForms.get(index);
|
|
@@ -240,8 +303,10 @@ export class StepBuilderConditionComponent {
|
|
|
240
303
|
// Also update form control
|
|
241
304
|
const form = this.conditionVariablesForms.get(conditionIndex);
|
|
242
305
|
if (form && form.get(variableName)) {
|
|
243
|
-
form.get(variableName)?.setValue(value);
|
|
306
|
+
form.get(variableName)?.setValue(value, { emitEvent: false });
|
|
244
307
|
}
|
|
308
|
+
// Mark for check since we're using OnPush
|
|
309
|
+
this.cdr.markForCheck();
|
|
245
310
|
}
|
|
246
311
|
onConditionVariableInputChange(conditionIndex, variableName, value) {
|
|
247
312
|
// Update the variable in templateVariables array
|
|
@@ -267,20 +332,53 @@ export class StepBuilderConditionComponent {
|
|
|
267
332
|
const form = this.conditionVariablesForms.get(conditionIndex);
|
|
268
333
|
if (form) {
|
|
269
334
|
if (form.get(variableName)) {
|
|
270
|
-
form.get(variableName)?.setValue(value);
|
|
335
|
+
form.get(variableName)?.setValue(value, { emitEvent: false });
|
|
271
336
|
}
|
|
272
337
|
else {
|
|
273
338
|
// Create form control if it doesn't exist
|
|
274
339
|
form.addControl(variableName, new FormControl(value));
|
|
275
340
|
}
|
|
276
341
|
}
|
|
342
|
+
// Mark for check since we're using OnPush
|
|
343
|
+
this.cdr.markForCheck();
|
|
277
344
|
}
|
|
278
345
|
getConditionFormGroup(index) {
|
|
279
|
-
|
|
346
|
+
// Use cache to avoid repeated lookups
|
|
347
|
+
if (this.conditionFormGroupCache.has(index)) {
|
|
348
|
+
return this.conditionFormGroupCache.get(index);
|
|
349
|
+
}
|
|
350
|
+
const formGroup = this.conditionsFormArray.at(index);
|
|
351
|
+
if (formGroup) {
|
|
352
|
+
this.conditionFormGroupCache.set(index, formGroup);
|
|
353
|
+
}
|
|
354
|
+
return formGroup;
|
|
355
|
+
}
|
|
356
|
+
getConditionFieldValue(index) {
|
|
357
|
+
const formGroup = this.getConditionFormGroup(index);
|
|
358
|
+
return formGroup?.get('field')?.value || '';
|
|
359
|
+
}
|
|
360
|
+
isConditionIf(index) {
|
|
361
|
+
return this.getConditionFieldValue(index) === 'CONDITION_IF';
|
|
362
|
+
}
|
|
363
|
+
isConditionElseIf(index) {
|
|
364
|
+
return this.getConditionFieldValue(index) === 'CONDITION_ELSE_IF';
|
|
365
|
+
}
|
|
366
|
+
getConditionLabel(index) {
|
|
367
|
+
const fieldValue = this.getConditionFieldValue(index);
|
|
368
|
+
if (fieldValue === 'CONDITION_IF')
|
|
369
|
+
return 'IF';
|
|
370
|
+
if (fieldValue === 'CONDITION_ELSE_IF')
|
|
371
|
+
return 'ELSE IF';
|
|
372
|
+
return 'ELSE';
|
|
373
|
+
}
|
|
374
|
+
trackByConditionIndex(index) {
|
|
375
|
+
return index;
|
|
280
376
|
}
|
|
281
377
|
onIncludeElseChange(checked) {
|
|
282
378
|
this.includeElse = checked;
|
|
283
379
|
this.conditionForm.patchValue({ includeElse: checked });
|
|
380
|
+
// Mark for check since we're using OnPush
|
|
381
|
+
this.cdr.markForCheck();
|
|
284
382
|
}
|
|
285
383
|
onCancel() {
|
|
286
384
|
this.cancelled.emit();
|
|
@@ -311,12 +409,12 @@ export class StepBuilderConditionComponent {
|
|
|
311
409
|
}
|
|
312
410
|
}
|
|
313
411
|
}
|
|
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 [disabled]=\"!conditionForm.valid\"\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", "addCustomValue"] }, { 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"] }] });
|
|
412
|
+
StepBuilderConditionComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: StepBuilderConditionComponent, deps: [{ token: i1.FormBuilder }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
413
|
+
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; trackBy: trackByConditionIndex\">\n <div\n *ngIf=\"isConditionIf(i) || isConditionElseIf(i)\"\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 {{ getConditionLabel(i) }}\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 <!-- Template Variables Form Component (includes Description and Metadata) -->\n <cqa-template-variables-form\n [templateVariables]=\"getConditionTemplateVariables(i)\"\n [variablesForm]=\"getConditionVariablesForm(i)\"\n [metadata]=\"getConditionFormGroup(i).get('metadata')?.value || ''\"\n [description]=\"getConditionFormGroup(i).get('description')?.value || ''\"\n (variableValueChange)=\"onConditionVariableValueChange(i, $event.name, $event.value)\"\n (variableBooleanChange)=\"onConditionVariableBooleanChange(i, $event.name, $event.value)\"\n (metadataChange)=\"getConditionFormGroup(i).get('metadata')?.setValue($event)\"\n (descriptionChange)=\"getConditionFormGroup(i).get('description')?.setValue($event)\">\n </cqa-template-variables-form>\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 [disabled]=\"!conditionForm.valid\"\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", "addCustomValue"] }, { type: i3.ButtonComponent, selector: "cqa-button", inputs: ["variant", "btnSize", "disabled", "icon", "iconPosition", "fullWidth", "iconColor", "type", "text", "customClass", "inlineStyles", "tooltip", "tooltipPosition"], outputs: ["clicked"] }, { type: i4.TemplateVariablesFormComponent, selector: "cqa-template-variables-form", inputs: ["templateVariables", "variablesForm", "metadata", "description"], outputs: ["variableValueChange", "variableBooleanChange", "metadataChange", "descriptionChange"] }, { 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"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
316
414
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: StepBuilderConditionComponent, decorators: [{
|
|
317
415
|
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=\"
|
|
319
|
-
}], ctorParameters: function () { return [{ type: i1.FormBuilder }]; }, propDecorators: { operatorOptions: [{
|
|
416
|
+
args: [{ selector: 'cqa-step-builder-condition', host: { class: 'cqa-ui-root' }, changeDetection: ChangeDetectionStrategy.OnPush, 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; trackBy: trackByConditionIndex\">\n <div\n *ngIf=\"isConditionIf(i) || isConditionElseIf(i)\"\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 {{ getConditionLabel(i) }}\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 <!-- Template Variables Form Component (includes Description and Metadata) -->\n <cqa-template-variables-form\n [templateVariables]=\"getConditionTemplateVariables(i)\"\n [variablesForm]=\"getConditionVariablesForm(i)\"\n [metadata]=\"getConditionFormGroup(i).get('metadata')?.value || ''\"\n [description]=\"getConditionFormGroup(i).get('description')?.value || ''\"\n (variableValueChange)=\"onConditionVariableValueChange(i, $event.name, $event.value)\"\n (variableBooleanChange)=\"onConditionVariableBooleanChange(i, $event.name, $event.value)\"\n (metadataChange)=\"getConditionFormGroup(i).get('metadata')?.setValue($event)\"\n (descriptionChange)=\"getConditionFormGroup(i).get('description')?.setValue($event)\">\n </cqa-template-variables-form>\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 [disabled]=\"!conditionForm.valid\"\n (clicked)=\"onCreateStep()\">\n </cqa-button>\n </div>\n</div>", styles: [] }]
|
|
417
|
+
}], ctorParameters: function () { return [{ type: i1.FormBuilder }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { operatorOptions: [{
|
|
320
418
|
type: Input
|
|
321
419
|
}], conditionTemplates: [{
|
|
322
420
|
type: Input
|
|
@@ -327,4 +425,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImpor
|
|
|
327
425
|
}], cancelled: [{
|
|
328
426
|
type: Output
|
|
329
427
|
}] } });
|
|
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      [disabled]=\"!conditionForm.valid\"\n      (clicked)=\"onCreateStep()\">\n    </cqa-button>\n  </div>\n</div>"]}
|
|
428
|
+
//# 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, ChangeDetectionStrategy, ChangeDetectorRef } 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  changeDetection: ChangeDetectionStrategy.OnPush\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  // Cache for operator configs (static, no need to recreate)\n  private operatorConfigCache: DynamicSelectFieldConfig | null = null;\n  \n  // Cache for value configs with onChange handlers per index\n  private valueConfigsWithHandlers: Map<number, DynamicSelectFieldConfig> = new Map();\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  // Cache for condition form groups to avoid repeated lookups\n  private conditionFormGroupCache: Map<number, FormGroup> = new Map();\n\n  constructor(private fb: FormBuilder, private cdr: ChangeDetectorRef) {\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 config caches\n    this.updateValueConfigCache();\n    this.updateOperatorConfigCache();\n    // Mark for check since we're using OnPush\n    this.cdr.markForCheck();\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      // Clear value configs with handlers since base config changed\n      this.valueConfigsWithHandlers.clear();\n    }\n    // Mark for check since we're using OnPush\n    this.cdr.markForCheck();\n  }\n  \n  private updateOperatorConfigCache(): void {\n    this.operatorConfigCache = {\n      key: 'operator',\n      placeholder: 'Select operator',\n      multiple: false,\n      searchable: false,\n      options: this.operatorOptions\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    // Cache the form group\n    this.conditionFormGroupCache.set(index, conditionGroup);\n    \n    // Mark for check since we're using OnPush\n    this.cdr.markForCheck();\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      this.conditionFormGroupCache.delete(index);\n      this.valueConfigsWithHandlers.delete(index);\n      \n      // Reindex remaining conditions\n      this.reindexConditionData(index);\n      \n      // Mark for check since we're using OnPush\n      this.cdr.markForCheck();\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    const newFormGroupCache = new Map<number, FormGroup>();\n    const newValueConfigs = new Map<number, DynamicSelectFieldConfig>();\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.conditionFormGroupCache.forEach((formGroup, oldIndex) => {\n      if (oldIndex < removedIndex) {\n        newFormGroupCache.set(oldIndex, formGroup);\n      } else if (oldIndex > removedIndex) {\n        newFormGroupCache.set(oldIndex - 1, formGroup);\n      }\n    });\n    \n    this.valueConfigsWithHandlers.forEach((config, oldIndex) => {\n      if (oldIndex < removedIndex) {\n        newValueConfigs.set(oldIndex, config);\n      } else if (oldIndex > removedIndex) {\n        // Recreate config with new index for onChange handler\n        const newConfig = {\n          ...config,\n          onChange: (value: any) => {\n            this.onTemplateValueChange(oldIndex - 1, value);\n          }\n        };\n        newValueConfigs.set(oldIndex - 1, newConfig);\n      }\n    });\n    \n    this.selectedTemplates = newSelectedTemplates;\n    this.conditionTemplateVariables = newTemplateVariables;\n    this.conditionVariablesForms = newVariablesForms;\n    this.conditionFormGroupCache = newFormGroupCache;\n    this.valueConfigsWithHandlers = newValueConfigs;\n  }\n\n  getOperatorConfig(index: number): DynamicSelectFieldConfig {\n    // Return cached config (static, same for all conditions)\n    if (!this.operatorConfigCache) {\n      this.updateOperatorConfigCache();\n    }\n    return this.operatorConfigCache!;\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 with handler to avoid recreating on every change detection\n    if (this.valueConfigsWithHandlers.has(index)) {\n      return this.valueConfigsWithHandlers.get(index)!;\n    }\n    \n    // Ensure base config cache exists\n    if (!this.valueConfigCache) {\n      this.updateValueConfigCache();\n    }\n    \n    // Create and cache config with onChange handler for this specific index\n    const config: DynamicSelectFieldConfig = {\n      ...this.valueConfigCache!,\n      onChange: (value: any) => {\n        this.onTemplateValueChange(index, value);\n      }\n    };\n    \n    this.valueConfigsWithHandlers.set(index, config);\n    return config;\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    // Mark for check since we're using OnPush\n    this.cdr.markForCheck();\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, { emitEvent: false });\n    }\n    \n    // Mark for check since we're using OnPush\n    this.cdr.markForCheck();\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, { emitEvent: false });\n      } else {\n        // Create form control if it doesn't exist\n        form.addControl(variableName, new FormControl(value));\n      }\n    }\n    \n    // Mark for check since we're using OnPush\n    this.cdr.markForCheck();\n  }\n\n  getConditionFormGroup(index: number): FormGroup {\n    // Use cache to avoid repeated lookups\n    if (this.conditionFormGroupCache.has(index)) {\n      return this.conditionFormGroupCache.get(index)!;\n    }\n    \n    const formGroup = this.conditionsFormArray.at(index) as FormGroup;\n    if (formGroup) {\n      this.conditionFormGroupCache.set(index, formGroup);\n    }\n    return formGroup;\n  }\n  \n  getConditionFieldValue(index: number): string {\n    const formGroup = this.getConditionFormGroup(index);\n    return formGroup?.get('field')?.value || '';\n  }\n  \n  isConditionIf(index: number): boolean {\n    return this.getConditionFieldValue(index) === 'CONDITION_IF';\n  }\n  \n  isConditionElseIf(index: number): boolean {\n    return this.getConditionFieldValue(index) === 'CONDITION_ELSE_IF';\n  }\n  \n  getConditionLabel(index: number): string {\n    const fieldValue = this.getConditionFieldValue(index);\n    if (fieldValue === 'CONDITION_IF') return 'IF';\n    if (fieldValue === 'CONDITION_ELSE_IF') return 'ELSE IF';\n    return 'ELSE';\n  }\n  \n  trackByConditionIndex(index: number): number {\n    return index;\n  }\n\n  onIncludeElseChange(checked: boolean): void {\n    this.includeElse = checked;\n    this.conditionForm.patchValue({ includeElse: checked });\n    \n    // Mark for check since we're using OnPush\n    this.cdr.markForCheck();\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; trackBy: trackByConditionIndex\">\n          <div\n            *ngIf=\"isConditionIf(i) || isConditionElseIf(i)\"\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                {{ getConditionLabel(i) }}\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              <!-- Template Variables Form Component (includes Description and Metadata) -->\n              <cqa-template-variables-form\n                [templateVariables]=\"getConditionTemplateVariables(i)\"\n                [variablesForm]=\"getConditionVariablesForm(i)\"\n                [metadata]=\"getConditionFormGroup(i).get('metadata')?.value || ''\"\n                [description]=\"getConditionFormGroup(i).get('description')?.value || ''\"\n                (variableValueChange)=\"onConditionVariableValueChange(i, $event.name, $event.value)\"\n                (variableBooleanChange)=\"onConditionVariableBooleanChange(i, $event.name, $event.value)\"\n                (metadataChange)=\"getConditionFormGroup(i).get('metadata')?.setValue($event)\"\n                (descriptionChange)=\"getConditionFormGroup(i).get('description')?.setValue($event)\">\n              </cqa-template-variables-form>\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      [disabled]=\"!conditionForm.valid\"\n      (clicked)=\"onCreateStep()\">\n    </cqa-button>\n  </div>\n</div>"]}
|