@cqa-lib/cqa-ui 1.1.202 → 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.
Files changed (22) hide show
  1. package/esm2020/lib/item-list/item-list.component.mjs +3 -3
  2. package/esm2020/lib/step-builder/step-builder-action/step-builder-action.component.mjs +7 -9
  3. package/esm2020/lib/step-builder/step-builder-ai-agent/step-builder-ai-agent.component.mjs +4 -4
  4. package/esm2020/lib/step-builder/step-builder-condition/step-builder-condition.component.mjs +121 -23
  5. package/esm2020/lib/step-builder/step-builder-document/step-builder-document.component.mjs +65 -9
  6. package/esm2020/lib/step-builder/step-builder-loop/step-builder-loop.component.mjs +8 -9
  7. package/esm2020/lib/step-builder/template-variables-form/template-variables-form.component.mjs +319 -0
  8. package/esm2020/lib/test-case-details/normal-step/normal-step.component.mjs +3 -3
  9. package/esm2020/lib/test-case-details/test-data-modal/test-data-modal.component.mjs +9 -8
  10. package/esm2020/lib/ui-kit.module.mjs +12 -3
  11. package/esm2020/public-api.mjs +2 -1
  12. package/fesm2015/cqa-lib-cqa-ui.mjs +526 -49
  13. package/fesm2015/cqa-lib-cqa-ui.mjs.map +1 -1
  14. package/fesm2020/cqa-lib-cqa-ui.mjs +518 -44
  15. package/fesm2020/cqa-lib-cqa-ui.mjs.map +1 -1
  16. package/lib/step-builder/step-builder-condition/step-builder-condition.component.d.ts +12 -2
  17. package/lib/step-builder/step-builder-document/step-builder-document.component.d.ts +18 -1
  18. package/lib/step-builder/template-variables-form/template-variables-form.component.d.ts +55 -0
  19. package/lib/ui-kit.module.d.ts +24 -22
  20. package/package.json +1 -1
  21. package/public-api.d.ts +1 -0
  22. package/styles.css +1 -1
@@ -0,0 +1,319 @@
1
+ import { Component, Input, Output, EventEmitter, ChangeDetectionStrategy } from '@angular/core';
2
+ import { FormGroup, FormControl } from '@angular/forms';
3
+ import * as i0 from "@angular/core";
4
+ import * as i1 from "@angular/material/slide-toggle";
5
+ import * as i2 from "../../dynamic-select/dynamic-select-field.component";
6
+ import * as i3 from "../../custom-input/custom-input.component";
7
+ import * as i4 from "@angular/common";
8
+ export class TemplateVariablesFormComponent {
9
+ constructor(cdr) {
10
+ this.cdr = cdr;
11
+ this.templateVariables = [];
12
+ this.variablesForm = new FormGroup({});
13
+ this.metadata = '';
14
+ this.description = '';
15
+ this.variableValueChange = new EventEmitter();
16
+ this.variableBooleanChange = new EventEmitter();
17
+ this.metadataChange = new EventEmitter();
18
+ this.descriptionChange = new EventEmitter();
19
+ // Cache for select configs to avoid recalculating on every change detection
20
+ this.selectConfigCache = new Map();
21
+ // Cache for data type select configs
22
+ this.dataTypeSelectConfigCache = new Map();
23
+ // Store data types for test-data variables
24
+ this.variableDataTypes = new Map();
25
+ // Store raw values (without formatting) for test-data variables
26
+ this.variableRawValues = new Map();
27
+ // Cache for computed properties
28
+ this.needsDataTypeDropdownCache = new Map();
29
+ this.shouldShowDropdownCache = new Map();
30
+ // Pre-computed data type options (static, no need to recreate)
31
+ this.dataTypeOptions = [
32
+ { id: 'plain-text', value: 'plain-text', name: 'Plain Text', label: 'Plain Text' },
33
+ { id: 'parameter', value: 'parameter', name: '@|Parameter|', label: '@|Parameter|' },
34
+ { id: 'runtime', value: 'runtime', name: '$|Runtime|', label: '$|Runtime|' },
35
+ { id: 'environment', value: 'environment', name: '*|Environment|', label: '*|Environment|' }
36
+ ];
37
+ }
38
+ ngOnChanges(changes) {
39
+ if (changes['templateVariables'] || changes['variablesForm']) {
40
+ // Clear all caches when inputs change
41
+ this.selectConfigCache.clear();
42
+ this.dataTypeSelectConfigCache.clear();
43
+ this.needsDataTypeDropdownCache.clear();
44
+ this.shouldShowDropdownCache.clear();
45
+ // Initialize data types and raw values for test-data variables
46
+ if (changes['templateVariables'] && this.templateVariables) {
47
+ this.initializeTestDataVariables();
48
+ }
49
+ // Pre-compute all configs to avoid calling methods in template
50
+ this.precomputeConfigs();
51
+ // Mark for check since we're using OnPush
52
+ this.cdr.markForCheck();
53
+ }
54
+ }
55
+ initializeTestDataVariables() {
56
+ this.templateVariables.forEach(variable => {
57
+ if (this.needsDataTypeDropdown(variable)) {
58
+ const { dataType, rawValue } = this.parseTestDataValue(variable.value || '');
59
+ this.variableDataTypes.set(variable.name, dataType);
60
+ this.variableRawValues.set(variable.name, rawValue);
61
+ // Ensure form control exists for data type
62
+ const dataTypeControlName = `${variable.name}_dataType`;
63
+ if (!this.variablesForm.get(dataTypeControlName)) {
64
+ this.variablesForm.addControl(dataTypeControlName, new FormControl(dataType));
65
+ }
66
+ else {
67
+ this.variablesForm.get(dataTypeControlName)?.setValue(dataType, { emitEvent: false });
68
+ }
69
+ }
70
+ });
71
+ }
72
+ precomputeConfigs() {
73
+ if (!this.templateVariables)
74
+ return;
75
+ // Pre-compute all select configs
76
+ this.templateVariables.forEach(variable => {
77
+ // Pre-compute regular select configs
78
+ if (this.shouldShowDropdown(variable)) {
79
+ this.getSelectConfig(variable);
80
+ }
81
+ // Pre-compute data type select configs
82
+ if (this.needsDataTypeDropdown(variable)) {
83
+ this.getDataTypeSelectConfig(variable);
84
+ }
85
+ });
86
+ }
87
+ parseTestDataValue(value) {
88
+ if (!value || typeof value !== 'string') {
89
+ return { dataType: 'plain-text', rawValue: '' };
90
+ }
91
+ // Check for parameter format: @|value|
92
+ if (value.startsWith('@|') && value.endsWith('|')) {
93
+ return { dataType: 'parameter', rawValue: value.slice(2, -1) };
94
+ }
95
+ // Check for runtime format: $|value|
96
+ else if (value.startsWith('$|') && value.endsWith('|')) {
97
+ return { dataType: 'runtime', rawValue: value.slice(2, -1) };
98
+ }
99
+ // Check for environment format: *|value|
100
+ else if (value.startsWith('*|') && value.endsWith('|')) {
101
+ return { dataType: 'environment', rawValue: value.slice(2, -1) };
102
+ }
103
+ // Plain text (no formatting)
104
+ else {
105
+ return { dataType: 'plain-text', rawValue: value };
106
+ }
107
+ }
108
+ formatTestDataValue(rawValue, dataType) {
109
+ if (!rawValue) {
110
+ return '';
111
+ }
112
+ switch (dataType) {
113
+ case 'parameter':
114
+ return `@|${rawValue}|`;
115
+ case 'runtime':
116
+ return `$|${rawValue}|`;
117
+ case 'environment':
118
+ return `*|${rawValue}|`;
119
+ case 'plain-text':
120
+ default:
121
+ return rawValue;
122
+ }
123
+ }
124
+ trackByVariable(index, variable) {
125
+ return variable.name || index;
126
+ }
127
+ getSelectConfig(variable) {
128
+ // Use cache to avoid recalculating on every change detection
129
+ const cacheKey = `${variable.name}_${variable.options?.join(',') || ''}`;
130
+ if (this.selectConfigCache.has(cacheKey)) {
131
+ return this.selectConfigCache.get(cacheKey);
132
+ }
133
+ const options = (variable.options || []).map((opt) => ({
134
+ id: opt,
135
+ value: opt,
136
+ name: opt,
137
+ label: opt
138
+ }));
139
+ const config = {
140
+ key: variable.name,
141
+ placeholder: `Select ${variable.label}`,
142
+ multiple: false,
143
+ searchable: false,
144
+ options: options,
145
+ onChange: (value) => {
146
+ this.onVariableValueChange(variable.name, value);
147
+ }
148
+ };
149
+ this.selectConfigCache.set(cacheKey, config);
150
+ return config;
151
+ }
152
+ onVariableValueChange(variableName, value) {
153
+ const variable = this.templateVariables.find(v => v.name === variableName);
154
+ if (!variable)
155
+ return;
156
+ // If this is a test-data variable, parse and update raw value and data type
157
+ if (this.needsDataTypeDropdown(variable)) {
158
+ const { dataType, rawValue } = this.parseTestDataValue(value || '');
159
+ this.variableDataTypes.set(variableName, dataType);
160
+ this.variableRawValues.set(variableName, rawValue);
161
+ // Update data type form control
162
+ const dataTypeControlName = `${variableName}_dataType`;
163
+ if (this.variablesForm.get(dataTypeControlName)) {
164
+ this.variablesForm.get(dataTypeControlName)?.setValue(dataType, { emitEvent: false });
165
+ }
166
+ }
167
+ // Update the variable in templateVariables array
168
+ variable.value = value;
169
+ // Also update form control (use emitEvent: false to prevent triggering valueChanges)
170
+ if (this.variablesForm.get(variableName)) {
171
+ this.variablesForm.get(variableName)?.setValue(value, { emitEvent: false });
172
+ }
173
+ // Mark for check since we're using OnPush
174
+ this.cdr.markForCheck();
175
+ // Emit the change event
176
+ this.variableValueChange.emit({ name: variableName, value: value });
177
+ }
178
+ onVariableBooleanChange(variableName, value) {
179
+ // Update the variable in templateVariables array
180
+ const variable = this.templateVariables.find(v => v.name === variableName);
181
+ if (variable) {
182
+ variable.value = value;
183
+ }
184
+ // Also update form control (use emitEvent: false to prevent triggering valueChanges)
185
+ if (this.variablesForm.get(variableName)) {
186
+ this.variablesForm.get(variableName)?.setValue(value, { emitEvent: false });
187
+ }
188
+ else {
189
+ // Create form control if it doesn't exist
190
+ this.variablesForm.addControl(variableName, new FormControl(value));
191
+ }
192
+ // Mark for check since we're using OnPush
193
+ this.cdr.markForCheck();
194
+ // Emit the change event
195
+ this.variableBooleanChange.emit({ name: variableName, value: value });
196
+ }
197
+ shouldShowDropdown(variable) {
198
+ // Use cache to avoid repeated calculations
199
+ if (this.shouldShowDropdownCache.has(variable.name)) {
200
+ return this.shouldShowDropdownCache.get(variable.name);
201
+ }
202
+ const result = variable.name === 'type' || variable.name === 'scrollTo';
203
+ this.shouldShowDropdownCache.set(variable.name, result);
204
+ return result;
205
+ }
206
+ needsDataTypeDropdown(variable) {
207
+ // Use cache to avoid repeated calculations
208
+ if (this.needsDataTypeDropdownCache.has(variable.name)) {
209
+ return this.needsDataTypeDropdownCache.get(variable.name);
210
+ }
211
+ const label = variable.label?.toLowerCase() || '';
212
+ const result = label === 'test-data' || label === 'source-value' || label === 'target-value';
213
+ this.needsDataTypeDropdownCache.set(variable.name, result);
214
+ return result;
215
+ }
216
+ getDataTypeOptions() {
217
+ // Return cached static array
218
+ return this.dataTypeOptions;
219
+ }
220
+ getDataTypeSelectConfig(variable) {
221
+ // Use cache to avoid recalculating on every change detection
222
+ const cacheKey = `${variable.name}_dataType`;
223
+ if (this.dataTypeSelectConfigCache.has(cacheKey)) {
224
+ return this.dataTypeSelectConfigCache.get(cacheKey);
225
+ }
226
+ const dataTypeControlName = `${variable.name}_dataType`;
227
+ // Ensure form control exists
228
+ if (!this.variablesForm.get(dataTypeControlName)) {
229
+ const currentDataType = this.variableDataTypes.get(variable.name) || 'plain-text';
230
+ this.variablesForm.addControl(dataTypeControlName, new FormControl(currentDataType));
231
+ }
232
+ const config = {
233
+ key: dataTypeControlName,
234
+ placeholder: 'Select Type',
235
+ multiple: false,
236
+ searchable: false,
237
+ options: this.dataTypeOptions,
238
+ onChange: (value) => {
239
+ this.onDataTypeChange(variable.name, value);
240
+ }
241
+ };
242
+ this.dataTypeSelectConfigCache.set(cacheKey, config);
243
+ return config;
244
+ }
245
+ getCurrentDataType(variable) {
246
+ // Simple getter - already cached in Map, no computation needed
247
+ return this.variableDataTypes.get(variable.name) || 'plain-text';
248
+ }
249
+ getRawValue(variable) {
250
+ // Simple getter - already cached in Map, no computation needed
251
+ return this.variableRawValues.get(variable.name) || '';
252
+ }
253
+ onDataTypeChange(variableName, dataType) {
254
+ // Update stored data type
255
+ this.variableDataTypes.set(variableName, dataType);
256
+ // Get current raw value
257
+ const rawValue = this.variableRawValues.get(variableName) || '';
258
+ // Format the value based on new data type
259
+ const formattedValue = this.formatTestDataValue(rawValue, dataType);
260
+ // Update variable value
261
+ const variable = this.templateVariables.find(v => v.name === variableName);
262
+ if (variable) {
263
+ variable.value = formattedValue;
264
+ }
265
+ // Update form control
266
+ if (this.variablesForm.get(variableName)) {
267
+ this.variablesForm.get(variableName)?.setValue(formattedValue, { emitEvent: false });
268
+ }
269
+ // Mark for check since we're using OnPush
270
+ this.cdr.markForCheck();
271
+ console.log('onDataTypeChange', variableName, dataType, formattedValue);
272
+ // Emit the change event
273
+ this.variableValueChange.emit({ name: variableName, value: formattedValue });
274
+ }
275
+ onTestDataValueChange(variableName, rawValue) {
276
+ // Update stored raw value
277
+ this.variableRawValues.set(variableName, rawValue);
278
+ // Get current data type
279
+ const dataType = this.variableDataTypes.get(variableName) || 'plain-text';
280
+ // Format the value based on data type
281
+ const formattedValue = this.formatTestDataValue(rawValue, dataType);
282
+ // Update variable value
283
+ const variable = this.templateVariables.find(v => v.name === variableName);
284
+ if (variable) {
285
+ variable.value = formattedValue;
286
+ }
287
+ // Update form control
288
+ if (this.variablesForm.get(variableName)) {
289
+ this.variablesForm.get(variableName)?.setValue(formattedValue, { emitEvent: false });
290
+ }
291
+ // Mark for check since we're using OnPush
292
+ this.cdr.markForCheck();
293
+ // Emit the change event
294
+ this.variableValueChange.emit({ name: variableName, value: formattedValue });
295
+ }
296
+ }
297
+ TemplateVariablesFormComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: TemplateVariablesFormComponent, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
298
+ TemplateVariablesFormComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.4.0", type: TemplateVariablesFormComponent, selector: "cqa-template-variables-form", inputs: { templateVariables: "templateVariables", variablesForm: "variablesForm", metadata: "metadata", description: "description" }, outputs: { variableValueChange: "variableValueChange", variableBooleanChange: "variableBooleanChange", metadataChange: "metadataChange", descriptionChange: "descriptionChange" }, host: { classAttribute: "cqa-ui-root" }, usesOnChanges: true, ngImport: i0, template: "<div class=\"cqa-flex cqa-gap-x-6 cqa-flex-wrap\">\n <ng-container *ngFor=\"let variable of templateVariables; trackBy: trackByVariable\">\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-sm cqa-font-medium cqa-text-gray-700\">\n {{ variable.label }}\n </label>\n <mat-slide-toggle\n [checked]=\"variablesForm.get(variable.name)?.value || variable.value || false\"\n (change)=\"onVariableBooleanChange(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 <ng-container *ngIf=\"shouldShowDropdown(variable); else defaultInput\">\n <div class=\"cqa-flex cqa-flex-col\" style=\"width: calc(50% - 12px);\">\n <label class=\"cqa-text-sm cqa-font-medium cqa-text-gray-700 cqa-mb-1\">\n {{ variable.label }}\n </label>\n <cqa-dynamic-select [form]=\"variablesForm\" [config]=\"getSelectConfig(variable)\">\n </cqa-dynamic-select>\n </div>\n </ng-container>\n <ng-template #defaultInput>\n <!-- Test-data, source-value, or target-value with data type dropdown -->\n <ng-container *ngIf=\"needsDataTypeDropdown(variable); else regularInput\">\n <div class=\"cqa-flex cqa-flex-col\" style=\"width: calc(50% - 12px);\">\n <label class=\"cqa-text-sm cqa-font-medium cqa-text-gray-700 cqa-mb-1\">\n {{ variable.label }} Type\n </label>\n <cqa-dynamic-select [form]=\"variablesForm\" [config]=\"getDataTypeSelectConfig(variable)\">\n </cqa-dynamic-select>\n </div>\n <div class=\"cqa-flex cqa-flex-col\" style=\"width: calc(50% - 12px);\">\n <label class=\"cqa-text-sm cqa-font-medium cqa-text-gray-700 cqa-mb-1\">\n {{ variable.label }}\n </label>\n <cqa-custom-input [placeholder]=\"'Text Input'\" [value]=\"variable.value\" [fullWidth]=\"true\"\n (valueChange)=\"onTestDataValueChange(variable.name, $event)\">\n </cqa-custom-input>\n </div>\n </ng-container>\n <ng-template #regularInput>\n <div class=\"cqa-flex cqa-flex-col\" style=\"width: calc(50% - 12px);\">\n <label class=\"cqa-text-sm cqa-font-medium cqa-text-gray-700 cqa-mb-1\">\n {{ variable.label }}\n </label>\n <cqa-custom-input [placeholder]=\"'Text Input'\" [value]=\"variable.value\" [fullWidth]=\"true\"\n (valueChange)=\"onVariableValueChange(variable.name, $event)\">\n </cqa-custom-input>\n </div>\n </ng-template>\n </ng-template>\n </ng-container>\n </ng-container>\n\n <!-- Metadata -->\n <div class=\"cqa-flex cqa-flex-col\" style=\"width: calc(50% - 12px);\">\n <label class=\"cqa-text-sm cqa-font-medium cqa-text-gray-700 cqa-mb-1\">\n Metadata\n </label>\n <cqa-custom-input [placeholder]=\"'Text Input'\" [value]=\"metadata\" [fullWidth]=\"true\"\n (valueChange)=\"metadataChange.emit($event)\">\n </cqa-custom-input>\n </div>\n\n <!-- Description -->\n <div class=\"cqa-flex cqa-flex-col\" style=\"width: calc(50% - 12px);\">\n <label class=\"cqa-text-sm cqa-font-medium cqa-text-gray-700 cqa-mb-1\">\n Description\n </label>\n <cqa-custom-input [placeholder]=\"'Text Input'\" [value]=\"description\" [fullWidth]=\"true\"\n (valueChange)=\"descriptionChange.emit($event)\">\n </cqa-custom-input>\n </div>\n</div>\n\n", components: [{ type: i1.MatSlideToggle, selector: "mat-slide-toggle", inputs: ["disabled", "disableRipple", "color", "tabIndex", "name", "id", "labelPosition", "aria-label", "aria-labelledby", "aria-describedby", "required", "checked"], outputs: ["change", "toggleChange"], exportAs: ["matSlideToggle"] }, { type: i2.DynamicSelectFieldComponent, selector: "cqa-dynamic-select", inputs: ["form", "config"], outputs: ["selectionChange", "selectClick", "searchChange", "loadMore", "addCustomValue"] }, { type: i3.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"] }], directives: [{ type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
299
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: TemplateVariablesFormComponent, decorators: [{
300
+ type: Component,
301
+ args: [{ selector: 'cqa-template-variables-form', host: { class: 'cqa-ui-root' }, changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"cqa-flex cqa-gap-x-6 cqa-flex-wrap\">\n <ng-container *ngFor=\"let variable of templateVariables; trackBy: trackByVariable\">\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-sm cqa-font-medium cqa-text-gray-700\">\n {{ variable.label }}\n </label>\n <mat-slide-toggle\n [checked]=\"variablesForm.get(variable.name)?.value || variable.value || false\"\n (change)=\"onVariableBooleanChange(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 <ng-container *ngIf=\"shouldShowDropdown(variable); else defaultInput\">\n <div class=\"cqa-flex cqa-flex-col\" style=\"width: calc(50% - 12px);\">\n <label class=\"cqa-text-sm cqa-font-medium cqa-text-gray-700 cqa-mb-1\">\n {{ variable.label }}\n </label>\n <cqa-dynamic-select [form]=\"variablesForm\" [config]=\"getSelectConfig(variable)\">\n </cqa-dynamic-select>\n </div>\n </ng-container>\n <ng-template #defaultInput>\n <!-- Test-data, source-value, or target-value with data type dropdown -->\n <ng-container *ngIf=\"needsDataTypeDropdown(variable); else regularInput\">\n <div class=\"cqa-flex cqa-flex-col\" style=\"width: calc(50% - 12px);\">\n <label class=\"cqa-text-sm cqa-font-medium cqa-text-gray-700 cqa-mb-1\">\n {{ variable.label }} Type\n </label>\n <cqa-dynamic-select [form]=\"variablesForm\" [config]=\"getDataTypeSelectConfig(variable)\">\n </cqa-dynamic-select>\n </div>\n <div class=\"cqa-flex cqa-flex-col\" style=\"width: calc(50% - 12px);\">\n <label class=\"cqa-text-sm cqa-font-medium cqa-text-gray-700 cqa-mb-1\">\n {{ variable.label }}\n </label>\n <cqa-custom-input [placeholder]=\"'Text Input'\" [value]=\"variable.value\" [fullWidth]=\"true\"\n (valueChange)=\"onTestDataValueChange(variable.name, $event)\">\n </cqa-custom-input>\n </div>\n </ng-container>\n <ng-template #regularInput>\n <div class=\"cqa-flex cqa-flex-col\" style=\"width: calc(50% - 12px);\">\n <label class=\"cqa-text-sm cqa-font-medium cqa-text-gray-700 cqa-mb-1\">\n {{ variable.label }}\n </label>\n <cqa-custom-input [placeholder]=\"'Text Input'\" [value]=\"variable.value\" [fullWidth]=\"true\"\n (valueChange)=\"onVariableValueChange(variable.name, $event)\">\n </cqa-custom-input>\n </div>\n </ng-template>\n </ng-template>\n </ng-container>\n </ng-container>\n\n <!-- Metadata -->\n <div class=\"cqa-flex cqa-flex-col\" style=\"width: calc(50% - 12px);\">\n <label class=\"cqa-text-sm cqa-font-medium cqa-text-gray-700 cqa-mb-1\">\n Metadata\n </label>\n <cqa-custom-input [placeholder]=\"'Text Input'\" [value]=\"metadata\" [fullWidth]=\"true\"\n (valueChange)=\"metadataChange.emit($event)\">\n </cqa-custom-input>\n </div>\n\n <!-- Description -->\n <div class=\"cqa-flex cqa-flex-col\" style=\"width: calc(50% - 12px);\">\n <label class=\"cqa-text-sm cqa-font-medium cqa-text-gray-700 cqa-mb-1\">\n Description\n </label>\n <cqa-custom-input [placeholder]=\"'Text Input'\" [value]=\"description\" [fullWidth]=\"true\"\n (valueChange)=\"descriptionChange.emit($event)\">\n </cqa-custom-input>\n </div>\n</div>\n\n", styles: [] }]
302
+ }], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }]; }, propDecorators: { templateVariables: [{
303
+ type: Input
304
+ }], variablesForm: [{
305
+ type: Input
306
+ }], metadata: [{
307
+ type: Input
308
+ }], description: [{
309
+ type: Input
310
+ }], variableValueChange: [{
311
+ type: Output
312
+ }], variableBooleanChange: [{
313
+ type: Output
314
+ }], metadataChange: [{
315
+ type: Output
316
+ }], descriptionChange: [{
317
+ type: Output
318
+ }] } });
319
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"template-variables-form.component.js","sourceRoot":"","sources":["../../../../../../src/lib/step-builder/template-variables-form/template-variables-form.component.ts","../../../../../../src/lib/step-builder/template-variables-form/template-variables-form.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,KAAK,EAAE,MAAM,EAAE,YAAY,EAA4B,uBAAuB,EAAqB,MAAM,eAAe,CAAC;AAC7I,OAAO,EAAE,SAAS,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC;;;;;;AAkBxD,MAAM,OAAO,8BAA8B;IAmCzC,YAAoB,GAAsB;QAAtB,QAAG,GAAH,GAAG,CAAmB;QAlCjC,sBAAiB,GAAuB,EAAE,CAAC;QAC3C,kBAAa,GAAc,IAAI,SAAS,CAAC,EAAE,CAAC,CAAC;QAC7C,aAAQ,GAAW,EAAE,CAAC;QACtB,gBAAW,GAAW,EAAE,CAAC;QAExB,wBAAmB,GAAG,IAAI,YAAY,EAAgC,CAAC;QACvE,0BAAqB,GAAG,IAAI,YAAY,EAAoC,CAAC;QAC7E,mBAAc,GAAG,IAAI,YAAY,EAAU,CAAC;QAC5C,sBAAiB,GAAG,IAAI,YAAY,EAAU,CAAC;QAEzD,4EAA4E;QACpE,sBAAiB,GAA0C,IAAI,GAAG,EAAE,CAAC;QAE7E,qCAAqC;QAC7B,8BAAyB,GAA0C,IAAI,GAAG,EAAE,CAAC;QAErF,2CAA2C;QACnC,sBAAiB,GAAwE,IAAI,GAAG,EAAE,CAAC;QAE3G,gEAAgE;QACxD,sBAAiB,GAAwB,IAAI,GAAG,EAAE,CAAC;QAE3D,gCAAgC;QACxB,+BAA0B,GAAyB,IAAI,GAAG,EAAE,CAAC;QAC7D,4BAAuB,GAAyB,IAAI,GAAG,EAAE,CAAC;QAElE,+DAA+D;QAC9C,oBAAe,GAAmB;YACjD,EAAE,EAAE,EAAE,YAAY,EAAE,KAAK,EAAE,YAAY,EAAE,IAAI,EAAE,YAAY,EAAE,KAAK,EAAE,YAAY,EAAE;YAClF,EAAE,EAAE,EAAE,WAAW,EAAE,KAAK,EAAE,WAAW,EAAE,IAAI,EAAE,cAAc,EAAE,KAAK,EAAE,cAAc,EAAE;YACpF,EAAE,EAAE,EAAE,SAAS,EAAE,KAAK,EAAE,SAAS,EAAE,IAAI,EAAE,YAAY,EAAE,KAAK,EAAE,YAAY,EAAE;YAC5E,EAAE,EAAE,EAAE,aAAa,EAAE,KAAK,EAAE,aAAa,EAAE,IAAI,EAAE,gBAAgB,EAAE,KAAK,EAAE,gBAAgB,EAAE;SAC7F,CAAC;IAE2C,CAAC;IAE9C,WAAW,CAAC,OAAsB;QAChC,IAAI,OAAO,CAAC,mBAAmB,CAAC,IAAI,OAAO,CAAC,eAAe,CAAC,EAAE;YAC5D,sCAAsC;YACtC,IAAI,CAAC,iBAAiB,CAAC,KAAK,EAAE,CAAC;YAC/B,IAAI,CAAC,yBAAyB,CAAC,KAAK,EAAE,CAAC;YACvC,IAAI,CAAC,0BAA0B,CAAC,KAAK,EAAE,CAAC;YACxC,IAAI,CAAC,uBAAuB,CAAC,KAAK,EAAE,CAAC;YAErC,+DAA+D;YAC/D,IAAI,OAAO,CAAC,mBAAmB,CAAC,IAAI,IAAI,CAAC,iBAAiB,EAAE;gBAC1D,IAAI,CAAC,2BAA2B,EAAE,CAAC;aACpC;YAED,+DAA+D;YAC/D,IAAI,CAAC,iBAAiB,EAAE,CAAC;YAEzB,0CAA0C;YAC1C,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;SACzB;IACH,CAAC;IAEO,2BAA2B;QACjC,IAAI,CAAC,iBAAiB,CAAC,OAAO,CAAC,QAAQ,CAAC,EAAE;YACxC,IAAI,IAAI,CAAC,qBAAqB,CAAC,QAAQ,CAAC,EAAE;gBACxC,MAAM,EAAE,QAAQ,EAAE,QAAQ,EAAE,GAAG,IAAI,CAAC,kBAAkB,CAAC,QAAQ,CAAC,KAAK,IAAI,EAAE,CAAC,CAAC;gBAC7E,IAAI,CAAC,iBAAiB,CAAC,GAAG,CAAC,QAAQ,CAAC,IAAI,EAAE,QAAQ,CAAC,CAAC;gBACpD,IAAI,CAAC,iBAAiB,CAAC,GAAG,CAAC,QAAQ,CAAC,IAAI,EAAE,QAAQ,CAAC,CAAC;gBAEpD,2CAA2C;gBAC3C,MAAM,mBAAmB,GAAG,GAAG,QAAQ,CAAC,IAAI,WAAW,CAAC;gBACxD,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,mBAAmB,CAAC,EAAE;oBAChD,IAAI,CAAC,aAAa,CAAC,UAAU,CAAC,mBAAmB,EAAE,IAAI,WAAW,CAAC,QAAQ,CAAC,CAAC,CAAC;iBAC/E;qBAAM;oBACL,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,mBAAmB,CAAC,EAAE,QAAQ,CAAC,QAAQ,EAAE,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC,CAAC;iBACvF;aACF;QACH,CAAC,CAAC,CAAC;IACL,CAAC;IAEO,iBAAiB;QACvB,IAAI,CAAC,IAAI,CAAC,iBAAiB;YAAE,OAAO;QAEpC,iCAAiC;QACjC,IAAI,CAAC,iBAAiB,CAAC,OAAO,CAAC,QAAQ,CAAC,EAAE;YACxC,qCAAqC;YACrC,IAAI,IAAI,CAAC,kBAAkB,CAAC,QAAQ,CAAC,EAAE;gBACrC,IAAI,CAAC,eAAe,CAAC,QAAQ,CAAC,CAAC;aAChC;YAED,uCAAuC;YACvC,IAAI,IAAI,CAAC,qBAAqB,CAAC,QAAQ,CAAC,EAAE;gBACxC,IAAI,CAAC,uBAAuB,CAAC,QAAQ,CAAC,CAAC;aACxC;QACH,CAAC,CAAC,CAAC;IACL,CAAC;IAEO,kBAAkB,CAAC,KAAa;QACtC,IAAI,CAAC,KAAK,IAAI,OAAO,KAAK,KAAK,QAAQ,EAAE;YACvC,OAAO,EAAE,QAAQ,EAAE,YAAY,EAAE,QAAQ,EAAE,EAAE,EAAE,CAAC;SACjD;QAED,uCAAuC;QACvC,IAAI,KAAK,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,KAAK,CAAC,QAAQ,CAAC,GAAG,CAAC,EAAE;YACjD,OAAO,EAAE,QAAQ,EAAE,WAAW,EAAE,QAAQ,EAAE,KAAK,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;SAChE;QACD,qCAAqC;aAChC,IAAI,KAAK,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,KAAK,CAAC,QAAQ,CAAC,GAAG,CAAC,EAAE;YACtD,OAAO,EAAE,QAAQ,EAAE,SAAS,EAAE,QAAQ,EAAE,KAAK,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;SAC9D;QACD,yCAAyC;aACpC,IAAI,KAAK,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,KAAK,CAAC,QAAQ,CAAC,GAAG,CAAC,EAAE;YACtD,OAAO,EAAE,QAAQ,EAAE,aAAa,EAAE,QAAQ,EAAE,KAAK,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;SAClE;QACD,6BAA6B;aACxB;YACH,OAAO,EAAE,QAAQ,EAAE,YAAY,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC;SACpD;IACH,CAAC;IAEO,mBAAmB,CAAC,QAAgB,EAAE,QAAgE;QAC5G,IAAI,CAAC,QAAQ,EAAE;YACb,OAAO,EAAE,CAAC;SACX;QAED,QAAQ,QAAQ,EAAE;YAChB,KAAK,WAAW;gBACd,OAAO,KAAK,QAAQ,GAAG,CAAC;YAC1B,KAAK,SAAS;gBACZ,OAAO,KAAK,QAAQ,GAAG,CAAC;YAC1B,KAAK,aAAa;gBAChB,OAAO,KAAK,QAAQ,GAAG,CAAC;YAC1B,KAAK,YAAY,CAAC;YAClB;gBACE,OAAO,QAAQ,CAAC;SACnB;IACH,CAAC;IAED,eAAe,CAAC,KAAa,EAAE,QAA0B;QACvD,OAAO,QAAQ,CAAC,IAAI,IAAI,KAAK,CAAC;IAChC,CAAC;IAED,eAAe,CAAC,QAA0B;QACxC,6DAA6D;QAC7D,MAAM,QAAQ,GAAG,GAAG,QAAQ,CAAC,IAAI,IAAI,QAAQ,CAAC,OAAO,EAAE,IAAI,CAAC,GAAG,CAAC,IAAI,EAAE,EAAE,CAAC;QACzE,IAAI,IAAI,CAAC,iBAAiB,CAAC,GAAG,CAAC,QAAQ,CAAC,EAAE;YACxC,OAAO,IAAI,CAAC,iBAAiB,CAAC,GAAG,CAAC,QAAQ,CAAE,CAAC;SAC9C;QAED,MAAM,OAAO,GAAmB,CAAC,QAAQ,CAAC,OAAO,IAAI,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,GAAW,EAAE,EAAE,CAAC,CAAC;YAC7E,EAAE,EAAE,GAAG;YACP,KAAK,EAAE,GAAG;YACV,IAAI,EAAE,GAAG;YACT,KAAK,EAAE,GAAG;SACX,CAAC,CAAC,CAAC;QAEJ,MAAM,MAAM,GAA6B;YACvC,GAAG,EAAE,QAAQ,CAAC,IAAI;YAClB,WAAW,EAAE,UAAU,QAAQ,CAAC,KAAK,EAAE;YACvC,QAAQ,EAAE,KAAK;YACf,UAAU,EAAE,KAAK;YACjB,OAAO,EAAE,OAAO;YAChB,QAAQ,EAAE,CAAC,KAAU,EAAE,EAAE;gBACvB,IAAI,CAAC,qBAAqB,CAAC,QAAQ,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC;YACnD,CAAC;SACF,CAAC;QAEF,IAAI,CAAC,iBAAiB,CAAC,GAAG,CAAC,QAAQ,EAAE,MAAM,CAAC,CAAC;QAC7C,OAAO,MAAM,CAAC;IAChB,CAAC;IAED,qBAAqB,CAAC,YAAoB,EAAE,KAAU;QACpD,MAAM,QAAQ,GAAG,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,YAAY,CAAC,CAAC;QAC3E,IAAI,CAAC,QAAQ;YAAE,OAAO;QAEtB,4EAA4E;QAC5E,IAAI,IAAI,CAAC,qBAAqB,CAAC,QAAQ,CAAC,EAAE;YACxC,MAAM,EAAE,QAAQ,EAAE,QAAQ,EAAE,GAAG,IAAI,CAAC,kBAAkB,CAAC,KAAK,IAAI,EAAE,CAAC,CAAC;YACpE,IAAI,CAAC,iBAAiB,CAAC,GAAG,CAAC,YAAY,EAAE,QAAQ,CAAC,CAAC;YACnD,IAAI,CAAC,iBAAiB,CAAC,GAAG,CAAC,YAAY,EAAE,QAAQ,CAAC,CAAC;YAEnD,gCAAgC;YAChC,MAAM,mBAAmB,GAAG,GAAG,YAAY,WAAW,CAAC;YACvD,IAAI,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,mBAAmB,CAAC,EAAE;gBAC/C,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,mBAAmB,CAAC,EAAE,QAAQ,CAAC,QAAQ,EAAE,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC,CAAC;aACvF;SACF;QAED,iDAAiD;QACjD,QAAQ,CAAC,KAAK,GAAG,KAAK,CAAC;QAEvB,qFAAqF;QACrF,IAAI,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,YAAY,CAAC,EAAE;YACxC,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,YAAY,CAAC,EAAE,QAAQ,CAAC,KAAK,EAAE,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC,CAAC;SAC7E;QAED,0CAA0C;QAC1C,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;QAExB,wBAAwB;QACxB,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,YAAY,EAAE,KAAK,EAAE,KAAK,EAAE,CAAC,CAAC;IACtE,CAAC;IAED,uBAAuB,CAAC,YAAoB,EAAE,KAAc;QAC1D,iDAAiD;QACjD,MAAM,QAAQ,GAAG,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,YAAY,CAAC,CAAC;QAC3E,IAAI,QAAQ,EAAE;YACZ,QAAQ,CAAC,KAAK,GAAG,KAAK,CAAC;SACxB;QACD,qFAAqF;QACrF,IAAI,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,YAAY,CAAC,EAAE;YACxC,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,YAAY,CAAC,EAAE,QAAQ,CAAC,KAAK,EAAE,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC,CAAC;SAC7E;aAAM;YACL,0CAA0C;YAC1C,IAAI,CAAC,aAAa,CAAC,UAAU,CAAC,YAAY,EAAE,IAAI,WAAW,CAAC,KAAK,CAAC,CAAC,CAAC;SACrE;QAED,0CAA0C;QAC1C,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;QAExB,wBAAwB;QACxB,IAAI,CAAC,qBAAqB,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,YAAY,EAAE,KAAK,EAAE,KAAK,EAAE,CAAC,CAAC;IACxE,CAAC;IAED,kBAAkB,CAAC,QAA0B;QAC3C,2CAA2C;QAC3C,IAAI,IAAI,CAAC,uBAAuB,CAAC,GAAG,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE;YACnD,OAAO,IAAI,CAAC,uBAAuB,CAAC,GAAG,CAAC,QAAQ,CAAC,IAAI,CAAE,CAAC;SACzD;QACD,MAAM,MAAM,GAAG,QAAQ,CAAC,IAAI,KAAK,MAAM,IAAI,QAAQ,CAAC,IAAI,KAAK,UAAU,CAAC;QACxE,IAAI,CAAC,uBAAuB,CAAC,GAAG,CAAC,QAAQ,CAAC,IAAI,EAAE,MAAM,CAAC,CAAC;QACxD,OAAO,MAAM,CAAC;IAChB,CAAC;IAED,qBAAqB,CAAC,QAA0B;QAC9C,2CAA2C;QAC3C,IAAI,IAAI,CAAC,0BAA0B,CAAC,GAAG,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE;YACtD,OAAO,IAAI,CAAC,0BAA0B,CAAC,GAAG,CAAC,QAAQ,CAAC,IAAI,CAAE,CAAC;SAC5D;QACD,MAAM,KAAK,GAAG,QAAQ,CAAC,KAAK,EAAE,WAAW,EAAE,IAAI,EAAE,CAAC;QAClD,MAAM,MAAM,GAAG,KAAK,KAAK,WAAW,IAAI,KAAK,KAAK,cAAc,IAAI,KAAK,KAAK,cAAc,CAAC;QAC7F,IAAI,CAAC,0BAA0B,CAAC,GAAG,CAAC,QAAQ,CAAC,IAAI,EAAE,MAAM,CAAC,CAAC;QAC3D,OAAO,MAAM,CAAC;IAChB,CAAC;IAED,kBAAkB;QAChB,6BAA6B;QAC7B,OAAO,IAAI,CAAC,eAAe,CAAC;IAC9B,CAAC;IAED,uBAAuB,CAAC,QAA0B;QAChD,6DAA6D;QAC7D,MAAM,QAAQ,GAAG,GAAG,QAAQ,CAAC,IAAI,WAAW,CAAC;QAC7C,IAAI,IAAI,CAAC,yBAAyB,CAAC,GAAG,CAAC,QAAQ,CAAC,EAAE;YAChD,OAAO,IAAI,CAAC,yBAAyB,CAAC,GAAG,CAAC,QAAQ,CAAE,CAAC;SACtD;QAED,MAAM,mBAAmB,GAAG,GAAG,QAAQ,CAAC,IAAI,WAAW,CAAC;QAExD,6BAA6B;QAC7B,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,mBAAmB,CAAC,EAAE;YAChD,MAAM,eAAe,GAAG,IAAI,CAAC,iBAAiB,CAAC,GAAG,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,YAAY,CAAC;YAClF,IAAI,CAAC,aAAa,CAAC,UAAU,CAAC,mBAAmB,EAAE,IAAI,WAAW,CAAC,eAAe,CAAC,CAAC,CAAC;SACtF;QAED,MAAM,MAAM,GAA6B;YACvC,GAAG,EAAE,mBAAmB;YACxB,WAAW,EAAE,aAAa;YAC1B,QAAQ,EAAE,KAAK;YACf,UAAU,EAAE,KAAK;YACjB,OAAO,EAAE,IAAI,CAAC,eAAe;YAC7B,QAAQ,EAAE,CAAC,KAAU,EAAE,EAAE;gBACvB,IAAI,CAAC,gBAAgB,CAAC,QAAQ,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC;YAC9C,CAAC;SACF,CAAC;QAEF,IAAI,CAAC,yBAAyB,CAAC,GAAG,CAAC,QAAQ,EAAE,MAAM,CAAC,CAAC;QACrD,OAAO,MAAM,CAAC;IAChB,CAAC;IAED,kBAAkB,CAAC,QAA0B;QAC3C,+DAA+D;QAC/D,OAAO,IAAI,CAAC,iBAAiB,CAAC,GAAG,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,YAAY,CAAC;IACnE,CAAC;IAED,WAAW,CAAC,QAA0B;QACpC,+DAA+D;QAC/D,OAAO,IAAI,CAAC,iBAAiB,CAAC,GAAG,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,EAAE,CAAC;IACzD,CAAC;IAED,gBAAgB,CAAC,YAAoB,EAAE,QAAgE;QACrG,0BAA0B;QAC1B,IAAI,CAAC,iBAAiB,CAAC,GAAG,CAAC,YAAY,EAAE,QAAQ,CAAC,CAAC;QAEnD,wBAAwB;QACxB,MAAM,QAAQ,GAAG,IAAI,CAAC,iBAAiB,CAAC,GAAG,CAAC,YAAY,CAAC,IAAI,EAAE,CAAC;QAEhE,0CAA0C;QAC1C,MAAM,cAAc,GAAG,IAAI,CAAC,mBAAmB,CAAC,QAAQ,EAAE,QAAQ,CAAC,CAAC;QAEpE,wBAAwB;QACxB,MAAM,QAAQ,GAAG,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,YAAY,CAAC,CAAC;QAC3E,IAAI,QAAQ,EAAE;YACZ,QAAQ,CAAC,KAAK,GAAG,cAAc,CAAC;SACjC;QAED,sBAAsB;QACtB,IAAI,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,YAAY,CAAC,EAAE;YACxC,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,YAAY,CAAC,EAAE,QAAQ,CAAC,cAAc,EAAE,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC,CAAC;SACtF;QAED,0CAA0C;QAC1C,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;QACxB,OAAO,CAAC,GAAG,CAAC,kBAAkB,EAAE,YAAY,EAAE,QAAQ,EAAE,cAAc,CAAC,CAAC;QACxE,wBAAwB;QACxB,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,YAAY,EAAE,KAAK,EAAE,cAAc,EAAE,CAAC,CAAC;IAC/E,CAAC;IAED,qBAAqB,CAAC,YAAoB,EAAE,QAAgB;QAC1D,0BAA0B;QAC1B,IAAI,CAAC,iBAAiB,CAAC,GAAG,CAAC,YAAY,EAAE,QAAQ,CAAC,CAAC;QAEnD,wBAAwB;QACxB,MAAM,QAAQ,GAAG,IAAI,CAAC,iBAAiB,CAAC,GAAG,CAAC,YAAY,CAAC,IAAI,YAAY,CAAC;QAE1E,sCAAsC;QACtC,MAAM,cAAc,GAAG,IAAI,CAAC,mBAAmB,CAAC,QAAQ,EAAE,QAAQ,CAAC,CAAC;QAEpE,wBAAwB;QACxB,MAAM,QAAQ,GAAG,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,YAAY,CAAC,CAAC;QAC3E,IAAI,QAAQ,EAAE;YACZ,QAAQ,CAAC,KAAK,GAAG,cAAc,CAAC;SACjC;QAED,sBAAsB;QACtB,IAAI,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,YAAY,CAAC,EAAE;YACxC,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,YAAY,CAAC,EAAE,QAAQ,CAAC,cAAc,EAAE,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC,CAAC;SACtF;QAED,0CAA0C;QAC1C,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;QAExB,wBAAwB;QACxB,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,YAAY,EAAE,KAAK,EAAE,cAAc,EAAE,CAAC,CAAC;IAC/E,CAAC;;2HApVU,8BAA8B;+GAA9B,8BAA8B,0bCnB3C,6xHAiFA;2FD9Da,8BAA8B;kBAP1C,SAAS;+BACE,6BAA6B,QAGjC,EAAE,KAAK,EAAE,aAAa,EAAE,mBACb,uBAAuB,CAAC,MAAM;wGAGtC,iBAAiB;sBAAzB,KAAK;gBACG,aAAa;sBAArB,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBAEI,mBAAmB;sBAA5B,MAAM;gBACG,qBAAqB;sBAA9B,MAAM;gBACG,cAAc;sBAAvB,MAAM;gBACG,iBAAiB;sBAA1B,MAAM","sourcesContent":["import { Component, Input, Output, EventEmitter, OnChanges, SimpleChanges, ChangeDetectionStrategy, ChangeDetectorRef } from '@angular/core';\nimport { FormGroup, FormControl } from '@angular/forms';\nimport { DynamicSelectFieldConfig, SelectOption } from '../../dynamic-select/dynamic-select-field.component';\n\nexport interface TemplateVariable {\n  name: string;\n  label: string;\n  value: any;\n  type?: string;\n  options?: string[];\n}\n\n@Component({\n  selector: 'cqa-template-variables-form',\n  templateUrl: './template-variables-form.component.html',\n  styleUrls: [],\n  host: { class: 'cqa-ui-root' },\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class TemplateVariablesFormComponent implements OnChanges {\n  @Input() templateVariables: TemplateVariable[] = [];\n  @Input() variablesForm: FormGroup = new FormGroup({});\n  @Input() metadata: string = '';\n  @Input() description: string = '';\n  \n  @Output() variableValueChange = new EventEmitter<{ name: string; value: any }>();\n  @Output() variableBooleanChange = new EventEmitter<{ name: string; value: boolean }>();\n  @Output() metadataChange = new EventEmitter<string>();\n  @Output() descriptionChange = new EventEmitter<string>();\n  \n  // Cache for select configs to avoid recalculating on every change detection\n  private selectConfigCache: Map<string, DynamicSelectFieldConfig> = new Map();\n  \n  // Cache for data type select configs\n  private dataTypeSelectConfigCache: Map<string, DynamicSelectFieldConfig> = new Map();\n  \n  // Store data types for test-data variables\n  private variableDataTypes: Map<string, 'plain-text' | 'parameter' | 'runtime' | 'environment'> = new Map();\n  \n  // Store raw values (without formatting) for test-data variables\n  private variableRawValues: Map<string, string> = new Map();\n  \n  // Cache for computed properties\n  private needsDataTypeDropdownCache: Map<string, boolean> = new Map();\n  private shouldShowDropdownCache: Map<string, boolean> = new Map();\n  \n  // Pre-computed data type options (static, no need to recreate)\n  private readonly dataTypeOptions: SelectOption[] = [\n    { id: 'plain-text', value: 'plain-text', name: 'Plain Text', label: 'Plain Text' },\n    { id: 'parameter', value: 'parameter', name: '@|Parameter|', label: '@|Parameter|' },\n    { id: 'runtime', value: 'runtime', name: '$|Runtime|', label: '$|Runtime|' },\n    { id: 'environment', value: 'environment', name: '*|Environment|', label: '*|Environment|' }\n  ];\n  \n  constructor(private cdr: ChangeDetectorRef) {}\n  \n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes['templateVariables'] || changes['variablesForm']) {\n      // Clear all caches when inputs change\n      this.selectConfigCache.clear();\n      this.dataTypeSelectConfigCache.clear();\n      this.needsDataTypeDropdownCache.clear();\n      this.shouldShowDropdownCache.clear();\n      \n      // Initialize data types and raw values for test-data variables\n      if (changes['templateVariables'] && this.templateVariables) {\n        this.initializeTestDataVariables();\n      }\n      \n      // Pre-compute all configs to avoid calling methods in template\n      this.precomputeConfigs();\n      \n      // Mark for check since we're using OnPush\n      this.cdr.markForCheck();\n    }\n  }\n  \n  private initializeTestDataVariables(): void {\n    this.templateVariables.forEach(variable => {\n      if (this.needsDataTypeDropdown(variable)) {\n        const { dataType, rawValue } = this.parseTestDataValue(variable.value || '');\n        this.variableDataTypes.set(variable.name, dataType);\n        this.variableRawValues.set(variable.name, rawValue);\n        \n        // Ensure form control exists for data type\n        const dataTypeControlName = `${variable.name}_dataType`;\n        if (!this.variablesForm.get(dataTypeControlName)) {\n          this.variablesForm.addControl(dataTypeControlName, new FormControl(dataType));\n        } else {\n          this.variablesForm.get(dataTypeControlName)?.setValue(dataType, { emitEvent: false });\n        }\n      }\n    });\n  }\n  \n  private precomputeConfigs(): void {\n    if (!this.templateVariables) return;\n    \n    // Pre-compute all select configs\n    this.templateVariables.forEach(variable => {\n      // Pre-compute regular select configs\n      if (this.shouldShowDropdown(variable)) {\n        this.getSelectConfig(variable);\n      }\n      \n      // Pre-compute data type select configs\n      if (this.needsDataTypeDropdown(variable)) {\n        this.getDataTypeSelectConfig(variable);\n      }\n    });\n  }\n  \n  private parseTestDataValue(value: string): { dataType: 'plain-text' | 'parameter' | 'runtime' | 'environment', rawValue: string } {\n    if (!value || typeof value !== 'string') {\n      return { dataType: 'plain-text', rawValue: '' };\n    }\n    \n    // Check for parameter format: @|value|\n    if (value.startsWith('@|') && value.endsWith('|')) {\n      return { dataType: 'parameter', rawValue: value.slice(2, -1) };\n    }\n    // Check for runtime format: $|value|\n    else if (value.startsWith('$|') && value.endsWith('|')) {\n      return { dataType: 'runtime', rawValue: value.slice(2, -1) };\n    }\n    // Check for environment format: *|value|\n    else if (value.startsWith('*|') && value.endsWith('|')) {\n      return { dataType: 'environment', rawValue: value.slice(2, -1) };\n    }\n    // Plain text (no formatting)\n    else {\n      return { dataType: 'plain-text', rawValue: value };\n    }\n  }\n  \n  private formatTestDataValue(rawValue: string, dataType: 'plain-text' | 'parameter' | 'runtime' | 'environment'): string {\n    if (!rawValue) {\n      return '';\n    }\n    \n    switch (dataType) {\n      case 'parameter':\n        return `@|${rawValue}|`;\n      case 'runtime':\n        return `$|${rawValue}|`;\n      case 'environment':\n        return `*|${rawValue}|`;\n      case 'plain-text':\n      default:\n        return rawValue;\n    }\n  }\n  \n  trackByVariable(index: number, variable: TemplateVariable): any {\n    return variable.name || index;\n  }\n  \n  getSelectConfig(variable: TemplateVariable): DynamicSelectFieldConfig {\n    // Use cache to avoid recalculating on every change detection\n    const cacheKey = `${variable.name}_${variable.options?.join(',') || ''}`;\n    if (this.selectConfigCache.has(cacheKey)) {\n      return this.selectConfigCache.get(cacheKey)!;\n    }\n\n    const options: SelectOption[] = (variable.options || []).map((opt: string) => ({\n      id: opt,\n      value: opt,\n      name: opt,\n      label: opt\n    }));\n\n    const config: DynamicSelectFieldConfig = {\n      key: variable.name,\n      placeholder: `Select ${variable.label}`,\n      multiple: false,\n      searchable: false,\n      options: options,\n      onChange: (value: any) => {\n        this.onVariableValueChange(variable.name, value);\n      }\n    };\n    \n    this.selectConfigCache.set(cacheKey, config);\n    return config;\n  }\n  \n  onVariableValueChange(variableName: string, value: any): void {\n    const variable = this.templateVariables.find(v => v.name === variableName);\n    if (!variable) return;\n    \n    // If this is a test-data variable, parse and update raw value and data type\n    if (this.needsDataTypeDropdown(variable)) {\n      const { dataType, rawValue } = this.parseTestDataValue(value || '');\n      this.variableDataTypes.set(variableName, dataType);\n      this.variableRawValues.set(variableName, rawValue);\n      \n      // Update data type form control\n      const dataTypeControlName = `${variableName}_dataType`;\n      if (this.variablesForm.get(dataTypeControlName)) {\n        this.variablesForm.get(dataTypeControlName)?.setValue(dataType, { emitEvent: false });\n      }\n    }\n    \n    // Update the variable in templateVariables array\n    variable.value = value;\n    \n    // Also update form control (use emitEvent: false to prevent triggering valueChanges)\n    if (this.variablesForm.get(variableName)) {\n      this.variablesForm.get(variableName)?.setValue(value, { emitEvent: false });\n    }\n    \n    // Mark for check since we're using OnPush\n    this.cdr.markForCheck();\n    \n    // Emit the change event\n    this.variableValueChange.emit({ name: variableName, value: value });\n  }\n  \n  onVariableBooleanChange(variableName: string, value: boolean): void {\n    // Update the variable in templateVariables array\n    const variable = this.templateVariables.find(v => v.name === variableName);\n    if (variable) {\n      variable.value = value;\n    }\n    // Also update form control (use emitEvent: false to prevent triggering valueChanges)\n    if (this.variablesForm.get(variableName)) {\n      this.variablesForm.get(variableName)?.setValue(value, { emitEvent: false });\n    } else {\n      // Create form control if it doesn't exist\n      this.variablesForm.addControl(variableName, new FormControl(value));\n    }\n    \n    // Mark for check since we're using OnPush\n    this.cdr.markForCheck();\n    \n    // Emit the change event\n    this.variableBooleanChange.emit({ name: variableName, value: value });\n  }\n  \n  shouldShowDropdown(variable: TemplateVariable): boolean {\n    // Use cache to avoid repeated calculations\n    if (this.shouldShowDropdownCache.has(variable.name)) {\n      return this.shouldShowDropdownCache.get(variable.name)!;\n    }\n    const result = variable.name === 'type' || variable.name === 'scrollTo';\n    this.shouldShowDropdownCache.set(variable.name, result);\n    return result;\n  }\n  \n  needsDataTypeDropdown(variable: TemplateVariable): boolean {\n    // Use cache to avoid repeated calculations\n    if (this.needsDataTypeDropdownCache.has(variable.name)) {\n      return this.needsDataTypeDropdownCache.get(variable.name)!;\n    }\n    const label = variable.label?.toLowerCase() || '';\n    const result = label === 'test-data' || label === 'source-value' || label === 'target-value';\n    this.needsDataTypeDropdownCache.set(variable.name, result);\n    return result;\n  }\n  \n  getDataTypeOptions(): SelectOption[] {\n    // Return cached static array\n    return this.dataTypeOptions;\n  }\n  \n  getDataTypeSelectConfig(variable: TemplateVariable): DynamicSelectFieldConfig {\n    // Use cache to avoid recalculating on every change detection\n    const cacheKey = `${variable.name}_dataType`;\n    if (this.dataTypeSelectConfigCache.has(cacheKey)) {\n      return this.dataTypeSelectConfigCache.get(cacheKey)!;\n    }\n    \n    const dataTypeControlName = `${variable.name}_dataType`;\n    \n    // Ensure form control exists\n    if (!this.variablesForm.get(dataTypeControlName)) {\n      const currentDataType = this.variableDataTypes.get(variable.name) || 'plain-text';\n      this.variablesForm.addControl(dataTypeControlName, new FormControl(currentDataType));\n    }\n    \n    const config: DynamicSelectFieldConfig = {\n      key: dataTypeControlName,\n      placeholder: 'Select Type',\n      multiple: false,\n      searchable: false,\n      options: this.dataTypeOptions,\n      onChange: (value: any) => {\n        this.onDataTypeChange(variable.name, value);\n      }\n    };\n    \n    this.dataTypeSelectConfigCache.set(cacheKey, config);\n    return config;\n  }\n  \n  getCurrentDataType(variable: TemplateVariable): 'plain-text' | 'parameter' | 'runtime' | 'environment' {\n    // Simple getter - already cached in Map, no computation needed\n    return this.variableDataTypes.get(variable.name) || 'plain-text';\n  }\n  \n  getRawValue(variable: TemplateVariable): string {\n    // Simple getter - already cached in Map, no computation needed\n    return this.variableRawValues.get(variable.name) || '';\n  }\n  \n  onDataTypeChange(variableName: string, dataType: 'plain-text' | 'parameter' | 'runtime' | 'environment'): void {\n    // Update stored data type\n    this.variableDataTypes.set(variableName, dataType);\n    \n    // Get current raw value\n    const rawValue = this.variableRawValues.get(variableName) || '';\n    \n    // Format the value based on new data type\n    const formattedValue = this.formatTestDataValue(rawValue, dataType);\n    \n    // Update variable value\n    const variable = this.templateVariables.find(v => v.name === variableName);\n    if (variable) {\n      variable.value = formattedValue;\n    }\n    \n    // Update form control\n    if (this.variablesForm.get(variableName)) {\n      this.variablesForm.get(variableName)?.setValue(formattedValue, { emitEvent: false });\n    }\n    \n    // Mark for check since we're using OnPush\n    this.cdr.markForCheck();\n    console.log('onDataTypeChange', variableName, dataType, formattedValue);\n    // Emit the change event\n    this.variableValueChange.emit({ name: variableName, value: formattedValue });\n  }\n  \n  onTestDataValueChange(variableName: string, rawValue: string): void {\n    // Update stored raw value\n    this.variableRawValues.set(variableName, rawValue);\n    \n    // Get current data type\n    const dataType = this.variableDataTypes.get(variableName) || 'plain-text';\n    \n    // Format the value based on data type\n    const formattedValue = this.formatTestDataValue(rawValue, dataType);\n    \n    // Update variable value\n    const variable = this.templateVariables.find(v => v.name === variableName);\n    if (variable) {\n      variable.value = formattedValue;\n    }\n    \n    // Update form control\n    if (this.variablesForm.get(variableName)) {\n      this.variablesForm.get(variableName)?.setValue(formattedValue, { emitEvent: false });\n    }\n    \n    // Mark for check since we're using OnPush\n    this.cdr.markForCheck();\n    \n    // Emit the change event\n    this.variableValueChange.emit({ name: variableName, value: formattedValue });\n  }\n}\n\n","<div class=\"cqa-flex cqa-gap-x-6 cqa-flex-wrap\">\n  <ng-container *ngFor=\"let variable of templateVariables; trackBy: trackByVariable\">\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-sm cqa-font-medium cqa-text-gray-700\">\n          {{ variable.label }}\n        </label>\n        <mat-slide-toggle\n          [checked]=\"variablesForm.get(variable.name)?.value || variable.value || false\"\n          (change)=\"onVariableBooleanChange(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      <ng-container *ngIf=\"shouldShowDropdown(variable); else defaultInput\">\n        <div class=\"cqa-flex cqa-flex-col\" style=\"width: calc(50% - 12px);\">\n          <label class=\"cqa-text-sm cqa-font-medium cqa-text-gray-700 cqa-mb-1\">\n            {{ variable.label }}\n          </label>\n          <cqa-dynamic-select [form]=\"variablesForm\" [config]=\"getSelectConfig(variable)\">\n          </cqa-dynamic-select>\n        </div>\n      </ng-container>\n      <ng-template #defaultInput>\n        <!-- Test-data, source-value, or target-value with data type dropdown -->\n        <ng-container *ngIf=\"needsDataTypeDropdown(variable); else regularInput\">\n          <div class=\"cqa-flex cqa-flex-col\" style=\"width: calc(50% - 12px);\">\n            <label class=\"cqa-text-sm cqa-font-medium cqa-text-gray-700 cqa-mb-1\">\n              {{ variable.label }} Type\n            </label>\n            <cqa-dynamic-select [form]=\"variablesForm\" [config]=\"getDataTypeSelectConfig(variable)\">\n            </cqa-dynamic-select>\n          </div>\n          <div class=\"cqa-flex cqa-flex-col\" style=\"width: calc(50% - 12px);\">\n            <label class=\"cqa-text-sm cqa-font-medium cqa-text-gray-700 cqa-mb-1\">\n              {{ variable.label }}\n            </label>\n            <cqa-custom-input [placeholder]=\"'Text Input'\" [value]=\"variable.value\" [fullWidth]=\"true\"\n              (valueChange)=\"onTestDataValueChange(variable.name, $event)\">\n            </cqa-custom-input>\n          </div>\n        </ng-container>\n        <ng-template #regularInput>\n          <div class=\"cqa-flex cqa-flex-col\" style=\"width: calc(50% - 12px);\">\n            <label class=\"cqa-text-sm cqa-font-medium cqa-text-gray-700 cqa-mb-1\">\n              {{ variable.label }}\n            </label>\n            <cqa-custom-input [placeholder]=\"'Text Input'\" [value]=\"variable.value\" [fullWidth]=\"true\"\n              (valueChange)=\"onVariableValueChange(variable.name, $event)\">\n            </cqa-custom-input>\n          </div>\n        </ng-template>\n      </ng-template>\n    </ng-container>\n  </ng-container>\n\n  <!-- Metadata -->\n  <div class=\"cqa-flex cqa-flex-col\" style=\"width: calc(50% - 12px);\">\n    <label class=\"cqa-text-sm cqa-font-medium cqa-text-gray-700 cqa-mb-1\">\n      Metadata\n    </label>\n    <cqa-custom-input [placeholder]=\"'Text Input'\" [value]=\"metadata\" [fullWidth]=\"true\"\n      (valueChange)=\"metadataChange.emit($event)\">\n    </cqa-custom-input>\n  </div>\n\n  <!-- Description -->\n  <div class=\"cqa-flex cqa-flex-col\" style=\"width: calc(50% - 12px);\">\n    <label class=\"cqa-text-sm cqa-font-medium cqa-text-gray-700 cqa-mb-1\">\n      Description\n    </label>\n    <cqa-custom-input [placeholder]=\"'Text Input'\" [value]=\"description\" [fullWidth]=\"true\"\n      (valueChange)=\"descriptionChange.emit($event)\">\n    </cqa-custom-input>\n  </div>\n</div>\n\n"]}