@cqa-lib/cqa-ui 1.1.225 → 1.1.227
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/simulator/simulator.component.mjs +28 -45
- package/esm2020/lib/step-builder/step-builder-action/step-builder-action.component.mjs +267 -44
- package/esm2020/lib/step-builder/step-builder-condition/step-builder-condition.component.mjs +183 -41
- package/esm2020/lib/step-builder/step-builder-loop/step-builder-loop.component.mjs +44 -3
- package/esm2020/lib/step-builder/template-variables-form/template-variables-form.component.mjs +218 -57
- package/esm2020/lib/test-case-details/element-popup/element-form/element-form.component.mjs +277 -0
- package/esm2020/lib/test-case-details/element-popup/element-popup.component.mjs +32 -192
- package/esm2020/lib/ui-kit.module.mjs +6 -1
- package/esm2020/public-api.mjs +2 -1
- package/fesm2015/cqa-lib-cqa-ui.mjs +1118 -444
- package/fesm2015/cqa-lib-cqa-ui.mjs.map +1 -1
- package/fesm2020/cqa-lib-cqa-ui.mjs +1103 -440
- package/fesm2020/cqa-lib-cqa-ui.mjs.map +1 -1
- package/lib/step-builder/step-builder-action/step-builder-action.component.d.ts +50 -4
- package/lib/step-builder/step-builder-condition/step-builder-condition.component.d.ts +39 -2
- package/lib/step-builder/step-builder-loop/step-builder-loop.component.d.ts +17 -1
- package/lib/step-builder/template-variables-form/template-variables-form.component.d.ts +56 -5
- package/lib/test-case-details/element-popup/element-form/element-form.component.d.ts +77 -0
- package/lib/test-case-details/element-popup/element-popup.component.d.ts +13 -32
- package/lib/ui-kit.module.d.ts +42 -41
- package/package.json +1 -1
- package/public-api.d.ts +1 -0
- package/styles.css +1 -1
package/esm2020/lib/step-builder/template-variables-form/template-variables-form.component.mjs
CHANGED
|
@@ -1,21 +1,40 @@
|
|
|
1
1
|
import { Component, Input, Output, EventEmitter, ChangeDetectionStrategy } from '@angular/core';
|
|
2
|
-
import {
|
|
2
|
+
import { FormControl, FormArray } from '@angular/forms';
|
|
3
3
|
import * as i0 from "@angular/core";
|
|
4
4
|
import * as i1 from "@angular/material/slide-toggle";
|
|
5
5
|
import * as i2 from "../../dynamic-select/dynamic-select-field.component";
|
|
6
6
|
import * as i3 from "../../custom-input/custom-input.component";
|
|
7
|
-
import * as i4 from "
|
|
7
|
+
import * as i4 from "../../test-case-details/element-popup/element-form/element-form.component";
|
|
8
|
+
import * as i5 from "../../button/button.component";
|
|
9
|
+
import * as i6 from "@angular/common";
|
|
8
10
|
export class TemplateVariablesFormComponent {
|
|
9
11
|
constructor(cdr) {
|
|
10
12
|
this.cdr = cdr;
|
|
11
13
|
this.templateVariables = [];
|
|
12
|
-
this.variablesForm = new
|
|
14
|
+
this.variablesForm = new FormArray([]);
|
|
13
15
|
this.metadata = '';
|
|
14
16
|
this.description = '';
|
|
17
|
+
this.elementOptions = []; // Element objects for element dropdown
|
|
18
|
+
this.hasMoreElements = false; // Whether more elements are available
|
|
19
|
+
this.isLoadingElements = false; // Loading state for elements
|
|
20
|
+
/** Screen name options for element form autocomplete (from API) */
|
|
21
|
+
this.screenNameOptions = [];
|
|
22
|
+
/** Whether more screen names are available for infinite scroll */
|
|
23
|
+
this.hasMoreScreenNames = false;
|
|
24
|
+
/** True while parent is loading screen names (search or load more) */
|
|
25
|
+
this.isLoadingScreenNames = false;
|
|
15
26
|
this.variableValueChange = new EventEmitter();
|
|
16
27
|
this.variableBooleanChange = new EventEmitter();
|
|
17
28
|
this.metadataChange = new EventEmitter();
|
|
18
29
|
this.descriptionChange = new EventEmitter();
|
|
30
|
+
this.loadMoreElements = new EventEmitter(); // Emit when load more is requested
|
|
31
|
+
this.searchElements = new EventEmitter(); // Emit when user searches for elements
|
|
32
|
+
this.createElement = new EventEmitter(); // Emit when element is created with payload
|
|
33
|
+
this.searchScreenName = new EventEmitter(); // Emit when user searches screen names
|
|
34
|
+
this.loadMoreScreenNames = new EventEmitter(); // Emit when user scrolls to load more screen names
|
|
35
|
+
this.createScreenNameRequest = new EventEmitter(); // Emit when user requests to create a new screen name
|
|
36
|
+
this.cancelElementForm = new EventEmitter(); // Emit when element form is cancelled
|
|
37
|
+
this.elementFormVisibilityChange = new EventEmitter(); // Emit when element form visibility changes
|
|
19
38
|
// Cache for select configs to avoid recalculating on every change detection
|
|
20
39
|
this.selectConfigCache = new Map();
|
|
21
40
|
// Cache for data type select configs
|
|
@@ -34,9 +53,29 @@ export class TemplateVariablesFormComponent {
|
|
|
34
53
|
{ id: 'runtime', value: 'runtime', name: '$|Runtime|', label: '$|Runtime|' },
|
|
35
54
|
{ id: 'environment', value: 'environment', name: '*|Environment|', label: '*|Environment|' }
|
|
36
55
|
];
|
|
56
|
+
this.createElementVisible = false;
|
|
57
|
+
}
|
|
58
|
+
onCreateElement(payload) {
|
|
59
|
+
console.log('onCreateElement', payload);
|
|
60
|
+
this.createElement.emit(payload);
|
|
61
|
+
this.createElementVisible = false;
|
|
62
|
+
this.elementFormVisibilityChange.emit(false);
|
|
63
|
+
this.cdr.markForCheck();
|
|
64
|
+
}
|
|
65
|
+
onCancelElementForm() {
|
|
66
|
+
this.createElementVisible = false;
|
|
67
|
+
this.elementFormVisibilityChange.emit(false);
|
|
68
|
+
this.cancelElementForm.emit();
|
|
69
|
+
this.cdr.markForCheck();
|
|
70
|
+
}
|
|
71
|
+
onShowElementForm() {
|
|
72
|
+
this.createElementVisible = true;
|
|
73
|
+
this.elementFormVisibilityChange.emit(true);
|
|
74
|
+
this.cdr.markForCheck();
|
|
37
75
|
}
|
|
38
76
|
ngOnChanges(changes) {
|
|
39
|
-
if (changes['templateVariables'] || changes['variablesForm']
|
|
77
|
+
if (changes['templateVariables'] || changes['variablesForm'] || changes['elementOptions'] ||
|
|
78
|
+
changes['hasMoreElements'] || changes['isLoadingElements']) {
|
|
40
79
|
// Clear all caches when inputs change
|
|
41
80
|
this.selectConfigCache.clear();
|
|
42
81
|
this.dataTypeSelectConfigCache.clear();
|
|
@@ -53,34 +92,51 @@ export class TemplateVariablesFormComponent {
|
|
|
53
92
|
}
|
|
54
93
|
}
|
|
55
94
|
initializeTestDataVariables() {
|
|
56
|
-
this.templateVariables.forEach(variable => {
|
|
95
|
+
this.templateVariables.forEach((variable, index) => {
|
|
57
96
|
if (this.needsDataTypeDropdown(variable)) {
|
|
58
97
|
const { dataType, rawValue } = this.parseTestDataValue(variable.value || '');
|
|
59
98
|
this.variableDataTypes.set(variable.name, dataType);
|
|
60
99
|
this.variableRawValues.set(variable.name, rawValue);
|
|
61
|
-
// Ensure form control exists for data type
|
|
62
|
-
const
|
|
63
|
-
if (
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
100
|
+
// Ensure form control exists for data type in the FormArray
|
|
101
|
+
const variableGroup = this.getVariableFormGroup(variable.name);
|
|
102
|
+
if (variableGroup) {
|
|
103
|
+
if (!variableGroup.get('dataType')) {
|
|
104
|
+
variableGroup.addControl('dataType', new FormControl(dataType));
|
|
105
|
+
}
|
|
106
|
+
else {
|
|
107
|
+
variableGroup.get('dataType')?.setValue(dataType, { emitEvent: false });
|
|
108
|
+
}
|
|
68
109
|
}
|
|
69
110
|
}
|
|
70
111
|
});
|
|
71
112
|
}
|
|
113
|
+
/** Get form group for a variable by name from FormArray */
|
|
114
|
+
getVariableFormGroup(variableName) {
|
|
115
|
+
const variableIndex = this.variablesForm.controls.findIndex(control => control.get('name')?.value === variableName);
|
|
116
|
+
if (variableIndex !== -1) {
|
|
117
|
+
return this.variablesForm.at(variableIndex);
|
|
118
|
+
}
|
|
119
|
+
return null;
|
|
120
|
+
}
|
|
121
|
+
/** Get form group at a specific index from FormArray (for template use) */
|
|
122
|
+
getFormGroupAt(index) {
|
|
123
|
+
if (index >= 0 && index < this.variablesForm.length) {
|
|
124
|
+
return this.variablesForm.at(index);
|
|
125
|
+
}
|
|
126
|
+
return null;
|
|
127
|
+
}
|
|
72
128
|
precomputeConfigs() {
|
|
73
129
|
if (!this.templateVariables)
|
|
74
130
|
return;
|
|
75
131
|
// Pre-compute all select configs
|
|
76
|
-
this.templateVariables.forEach(variable => {
|
|
132
|
+
this.templateVariables.forEach((variable, index) => {
|
|
77
133
|
// Pre-compute regular select configs
|
|
78
134
|
if (this.shouldShowDropdown(variable)) {
|
|
79
|
-
this.getSelectConfig(variable);
|
|
135
|
+
this.getSelectConfig(variable, index);
|
|
80
136
|
}
|
|
81
137
|
// Pre-compute data type select configs
|
|
82
138
|
if (this.needsDataTypeDropdown(variable)) {
|
|
83
|
-
this.getDataTypeSelectConfig(variable);
|
|
139
|
+
this.getDataTypeSelectConfig(variable, index);
|
|
84
140
|
}
|
|
85
141
|
});
|
|
86
142
|
}
|
|
@@ -124,32 +180,70 @@ export class TemplateVariablesFormComponent {
|
|
|
124
180
|
trackByVariable(index, variable) {
|
|
125
181
|
return variable.name || index;
|
|
126
182
|
}
|
|
127
|
-
getSelectConfig(variable) {
|
|
183
|
+
getSelectConfig(variable, index) {
|
|
128
184
|
// Use cache to avoid recalculating on every change detection
|
|
129
|
-
|
|
185
|
+
// For element variables, include elementOptions, hasMoreElements, and isLoadingElements in cache key
|
|
186
|
+
const optionsKey = variable.dataKey === 'element' || variable.dataKey === 'label'
|
|
187
|
+
? this.elementOptions.map(el => String(el.name || '')).join(',')
|
|
188
|
+
: (variable.options?.join(',') || '');
|
|
189
|
+
// Include hasMoreElements and isLoadingElements in cache key for selector variables
|
|
190
|
+
const cacheKey = variable.dataKey === 'element' || variable.dataKey === 'label'
|
|
191
|
+
? `${variable.name}_${optionsKey}_${this.hasMoreElements}_${this.isLoadingElements}`
|
|
192
|
+
: `${variable.name}_${optionsKey}`;
|
|
130
193
|
if (this.selectConfigCache.has(cacheKey)) {
|
|
131
194
|
return this.selectConfigCache.get(cacheKey);
|
|
132
195
|
}
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
196
|
+
// Use elementOptions if variable name is 'selector', otherwise use variable.options
|
|
197
|
+
// Extract element names from Element objects
|
|
198
|
+
let optionsArray = [];
|
|
199
|
+
if (variable.dataKey === 'element' || variable.dataKey === 'label') {
|
|
200
|
+
// For element options, use locatorValue as both id and value so the component returns locatorValue
|
|
201
|
+
// This ensures the selected value is the locatorValue (not the element id)
|
|
202
|
+
optionsArray = this.elementOptions
|
|
203
|
+
.map(el => {
|
|
204
|
+
const locatorValue = el.locatorValue || '';
|
|
205
|
+
return {
|
|
206
|
+
id: locatorValue,
|
|
207
|
+
elementId: el.id?.toString() || '',
|
|
208
|
+
value: locatorValue,
|
|
209
|
+
name: el.name,
|
|
210
|
+
label: el.name
|
|
211
|
+
};
|
|
212
|
+
});
|
|
213
|
+
}
|
|
214
|
+
else {
|
|
215
|
+
optionsArray = variable.options?.map(opt => { return { id: opt, value: opt, name: opt, label: opt }; }) || [];
|
|
216
|
+
}
|
|
217
|
+
console.log('optionsArray', optionsArray);
|
|
139
218
|
const config = {
|
|
140
|
-
key:
|
|
219
|
+
key: 'value',
|
|
141
220
|
placeholder: `Select ${variable.label}`,
|
|
142
221
|
multiple: false,
|
|
143
222
|
searchable: false,
|
|
144
|
-
options:
|
|
223
|
+
options: optionsArray,
|
|
145
224
|
onChange: (value) => {
|
|
146
225
|
this.onVariableValueChange(variable.name, value);
|
|
147
226
|
}
|
|
148
227
|
};
|
|
228
|
+
// Add load more and search support for selector variables
|
|
229
|
+
if (variable.dataKey === 'element' || variable.dataKey === 'label') {
|
|
230
|
+
config.searchable = true; // Enable search for selector dropdown
|
|
231
|
+
config.serverSearch = true; // Enable server-side search
|
|
232
|
+
config.hasMore = this.hasMoreElements;
|
|
233
|
+
config.isLoading = this.isLoadingElements;
|
|
234
|
+
config.onLoadMore = () => {
|
|
235
|
+
this.loadMoreElements.emit();
|
|
236
|
+
};
|
|
237
|
+
config.onSearch = (query) => {
|
|
238
|
+
// Emit search event when user types in the search box
|
|
239
|
+
this.searchElements.emit(query);
|
|
240
|
+
};
|
|
241
|
+
}
|
|
149
242
|
this.selectConfigCache.set(cacheKey, config);
|
|
150
243
|
return config;
|
|
151
244
|
}
|
|
152
245
|
onVariableValueChange(variableName, value) {
|
|
246
|
+
console.log("onVariableValueChange", variableName, value);
|
|
153
247
|
const variable = this.templateVariables.find(v => v.name === variableName);
|
|
154
248
|
if (!variable)
|
|
155
249
|
return;
|
|
@@ -158,17 +252,18 @@ export class TemplateVariablesFormComponent {
|
|
|
158
252
|
const { dataType, rawValue } = this.parseTestDataValue(value || '');
|
|
159
253
|
this.variableDataTypes.set(variableName, dataType);
|
|
160
254
|
this.variableRawValues.set(variableName, rawValue);
|
|
161
|
-
// Update data type form control
|
|
162
|
-
const
|
|
163
|
-
if (
|
|
164
|
-
|
|
255
|
+
// Update data type form control in FormArray
|
|
256
|
+
const variableGroup = this.getVariableFormGroup(variableName);
|
|
257
|
+
if (variableGroup && variableGroup.get('dataType')) {
|
|
258
|
+
variableGroup.get('dataType')?.setValue(dataType, { emitEvent: false });
|
|
165
259
|
}
|
|
166
260
|
}
|
|
167
261
|
// Update the variable in templateVariables array
|
|
168
262
|
variable.value = value;
|
|
169
|
-
// Also update form control (use emitEvent: false to prevent triggering valueChanges)
|
|
170
|
-
|
|
171
|
-
|
|
263
|
+
// Also update form control in FormArray (use emitEvent: false to prevent triggering valueChanges)
|
|
264
|
+
const variableGroup = this.getVariableFormGroup(variableName);
|
|
265
|
+
if (variableGroup && variableGroup.get('value')) {
|
|
266
|
+
variableGroup.get('value')?.setValue(value, { emitEvent: false });
|
|
172
267
|
}
|
|
173
268
|
// Mark for check since we're using OnPush
|
|
174
269
|
this.cdr.markForCheck();
|
|
@@ -181,14 +276,12 @@ export class TemplateVariablesFormComponent {
|
|
|
181
276
|
if (variable) {
|
|
182
277
|
variable.value = value;
|
|
183
278
|
}
|
|
184
|
-
// Also update form control (use emitEvent: false to prevent triggering valueChanges)
|
|
185
|
-
|
|
186
|
-
|
|
187
|
-
|
|
188
|
-
else {
|
|
189
|
-
// Create form control if it doesn't exist
|
|
190
|
-
this.variablesForm.addControl(variableName, new FormControl(value));
|
|
279
|
+
// Also update form control in FormArray (use emitEvent: false to prevent triggering valueChanges)
|
|
280
|
+
const variableGroup = this.getVariableFormGroup(variableName);
|
|
281
|
+
if (variableGroup && variableGroup.get('value')) {
|
|
282
|
+
variableGroup.get('value')?.setValue(value, { emitEvent: false });
|
|
191
283
|
}
|
|
284
|
+
// Note: If variable doesn't exist in FormArray, it should be added by parent component
|
|
192
285
|
// Mark for check since we're using OnPush
|
|
193
286
|
this.cdr.markForCheck();
|
|
194
287
|
// Emit the change event
|
|
@@ -199,7 +292,7 @@ export class TemplateVariablesFormComponent {
|
|
|
199
292
|
if (this.shouldShowDropdownCache.has(variable.name)) {
|
|
200
293
|
return this.shouldShowDropdownCache.get(variable.name);
|
|
201
294
|
}
|
|
202
|
-
const result = variable.name === 'type' || variable.name === 'scrollTo';
|
|
295
|
+
const result = variable.name === 'type' || variable.name === 'scrollTo' || variable.dataKey === 'element' || variable.dataKey === 'label';
|
|
203
296
|
this.shouldShowDropdownCache.set(variable.name, result);
|
|
204
297
|
return result;
|
|
205
298
|
}
|
|
@@ -208,8 +301,8 @@ export class TemplateVariablesFormComponent {
|
|
|
208
301
|
if (this.needsDataTypeDropdownCache.has(variable.name)) {
|
|
209
302
|
return this.needsDataTypeDropdownCache.get(variable.name);
|
|
210
303
|
}
|
|
211
|
-
const
|
|
212
|
-
const result =
|
|
304
|
+
const dataKey = variable.dataKey?.toLowerCase() || '';
|
|
305
|
+
const result = dataKey === 'test-data' || dataKey === 'source_value' || dataKey === 'target_value';
|
|
213
306
|
this.needsDataTypeDropdownCache.set(variable.name, result);
|
|
214
307
|
return result;
|
|
215
308
|
}
|
|
@@ -217,20 +310,20 @@ export class TemplateVariablesFormComponent {
|
|
|
217
310
|
// Return cached static array
|
|
218
311
|
return this.dataTypeOptions;
|
|
219
312
|
}
|
|
220
|
-
getDataTypeSelectConfig(variable) {
|
|
313
|
+
getDataTypeSelectConfig(variable, index) {
|
|
221
314
|
// Use cache to avoid recalculating on every change detection
|
|
222
315
|
const cacheKey = `${variable.name}_dataType`;
|
|
223
316
|
if (this.dataTypeSelectConfigCache.has(cacheKey)) {
|
|
224
317
|
return this.dataTypeSelectConfigCache.get(cacheKey);
|
|
225
318
|
}
|
|
226
|
-
|
|
227
|
-
|
|
228
|
-
if (!
|
|
319
|
+
// Ensure form control exists in FormArray
|
|
320
|
+
const variableGroup = this.getVariableFormGroup(variable.name);
|
|
321
|
+
if (variableGroup && !variableGroup.get('dataType')) {
|
|
229
322
|
const currentDataType = this.variableDataTypes.get(variable.name) || 'plain-text';
|
|
230
|
-
|
|
323
|
+
variableGroup.addControl('dataType', new FormControl(currentDataType));
|
|
231
324
|
}
|
|
232
325
|
const config = {
|
|
233
|
-
key:
|
|
326
|
+
key: 'dataType',
|
|
234
327
|
placeholder: 'Select Type',
|
|
235
328
|
multiple: false,
|
|
236
329
|
searchable: false,
|
|
@@ -250,6 +343,38 @@ export class TemplateVariablesFormComponent {
|
|
|
250
343
|
// Simple getter - already cached in Map, no computation needed
|
|
251
344
|
return this.variableRawValues.get(variable.name) || '';
|
|
252
345
|
}
|
|
346
|
+
/**
|
|
347
|
+
* Check if selector variable is available in templateVariables
|
|
348
|
+
*/
|
|
349
|
+
get selectorVariableAvailable() {
|
|
350
|
+
return this.templateVariables.some(v => v.dataKey === 'element' || v.dataKey === 'label');
|
|
351
|
+
}
|
|
352
|
+
/**
|
|
353
|
+
* Check if parameter variable is available (testData with parameter type)
|
|
354
|
+
*/
|
|
355
|
+
get parameterVariableAvailable() {
|
|
356
|
+
return this.templateVariables.some(v => {
|
|
357
|
+
const dataKey = v.dataKey?.toLowerCase() || '';
|
|
358
|
+
if (dataKey === 'test-data' || dataKey === 'source_value' || dataKey === 'target_value') {
|
|
359
|
+
const dataType = this.variableDataTypes.get(v.name) || 'plain-text';
|
|
360
|
+
return dataType === 'parameter';
|
|
361
|
+
}
|
|
362
|
+
return false;
|
|
363
|
+
});
|
|
364
|
+
}
|
|
365
|
+
/**
|
|
366
|
+
* Check if environment variable is available (testData with environment type)
|
|
367
|
+
*/
|
|
368
|
+
get environmentVariableAvailable() {
|
|
369
|
+
return this.templateVariables.some(v => {
|
|
370
|
+
const dataKey = v.name?.toLowerCase() || '';
|
|
371
|
+
if (dataKey === 'test-data' || dataKey === 'source_value' || dataKey === 'target_value') {
|
|
372
|
+
const dataType = this.variableDataTypes.get(v.name) || 'plain-text';
|
|
373
|
+
return dataType === 'environment';
|
|
374
|
+
}
|
|
375
|
+
return false;
|
|
376
|
+
});
|
|
377
|
+
}
|
|
253
378
|
onDataTypeChange(variableName, dataType) {
|
|
254
379
|
// Update stored data type
|
|
255
380
|
this.variableDataTypes.set(variableName, dataType);
|
|
@@ -262,9 +387,10 @@ export class TemplateVariablesFormComponent {
|
|
|
262
387
|
if (variable) {
|
|
263
388
|
variable.value = formattedValue;
|
|
264
389
|
}
|
|
265
|
-
// Update form control
|
|
266
|
-
|
|
267
|
-
|
|
390
|
+
// Update form control in FormArray
|
|
391
|
+
const variableGroup = this.getVariableFormGroup(variableName);
|
|
392
|
+
if (variableGroup && variableGroup.get('value')) {
|
|
393
|
+
variableGroup.get('value')?.setValue(formattedValue, { emitEvent: false });
|
|
268
394
|
}
|
|
269
395
|
// Mark for check since we're using OnPush
|
|
270
396
|
this.cdr.markForCheck();
|
|
@@ -272,6 +398,12 @@ export class TemplateVariablesFormComponent {
|
|
|
272
398
|
// Emit the change event
|
|
273
399
|
this.variableValueChange.emit({ name: variableName, value: formattedValue });
|
|
274
400
|
}
|
|
401
|
+
onElementSearch(event) {
|
|
402
|
+
// Only handle search for selector variables
|
|
403
|
+
// The key will be 'value' since that's what we set in the config
|
|
404
|
+
// Emit the search query to parent component
|
|
405
|
+
this.searchElements.emit(event.query);
|
|
406
|
+
}
|
|
275
407
|
onTestDataValueChange(variableName, rawValue) {
|
|
276
408
|
// Update stored raw value
|
|
277
409
|
this.variableRawValues.set(variableName, rawValue);
|
|
@@ -284,9 +416,10 @@ export class TemplateVariablesFormComponent {
|
|
|
284
416
|
if (variable) {
|
|
285
417
|
variable.value = formattedValue;
|
|
286
418
|
}
|
|
287
|
-
// Update form control
|
|
288
|
-
|
|
289
|
-
|
|
419
|
+
// Update form control in FormArray
|
|
420
|
+
const variableGroup = this.getVariableFormGroup(variableName);
|
|
421
|
+
if (variableGroup && variableGroup.get('value')) {
|
|
422
|
+
variableGroup.get('value')?.setValue(formattedValue, { emitEvent: false });
|
|
290
423
|
}
|
|
291
424
|
// Mark for check since we're using OnPush
|
|
292
425
|
this.cdr.markForCheck();
|
|
@@ -295,10 +428,10 @@ export class TemplateVariablesFormComponent {
|
|
|
295
428
|
}
|
|
296
429
|
}
|
|
297
430
|
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
|
|
431
|
+
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", elementOptions: "elementOptions", hasMoreElements: "hasMoreElements", isLoadingElements: "isLoadingElements", screenNameOptions: "screenNameOptions", hasMoreScreenNames: "hasMoreScreenNames", isLoadingScreenNames: "isLoadingScreenNames" }, outputs: { variableValueChange: "variableValueChange", variableBooleanChange: "variableBooleanChange", metadataChange: "metadataChange", descriptionChange: "descriptionChange", loadMoreElements: "loadMoreElements", searchElements: "searchElements", createElement: "createElement", searchScreenName: "searchScreenName", loadMoreScreenNames: "loadMoreScreenNames", createScreenNameRequest: "createScreenNameRequest", cancelElementForm: "cancelElementForm", elementFormVisibilityChange: "elementFormVisibilityChange" }, host: { classAttribute: "cqa-ui-root" }, usesOnChanges: true, ngImport: i0, template: "<div class=\"cqa-flex cqa-gap-x-6 cqa-gap-y-4 cqa-flex-wrap\" *ngIf=\"!createElementVisible\">\n <ng-container *ngFor=\"let variable of templateVariables; let i = index; 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 [checked]=\"variablesForm.at(i)?.get('value')?.value || variable.value || false\"\n (change)=\"onVariableBooleanChange(variable.name, $event.checked)\" 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]=\"getFormGroupAt(i)!\" [config]=\"getSelectConfig(variable, i)\">\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]=\"getFormGroupAt(i)!\" [config]=\"getDataTypeSelectConfig(variable, i)\">\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]=\"getRawValue(variable)\" [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<div *ngIf=\"createElementVisible\">\n <cqa-element-form\n [isCreateMode]=\"true\"\n [screenNameOptions]=\"screenNameOptions\"\n [hasMoreScreenNames]=\"hasMoreScreenNames\"\n [isLoadingScreenNames]=\"isLoadingScreenNames\"\n [isEditInDepthAvailable]=\"false\"\n (createElement)=\"onCreateElement($event)\"\n (cancel)=\"onCancelElementForm()\"\n (searchScreenName)=\"searchScreenName.emit($event)\"\n (loadMoreScreenNames)=\"loadMoreScreenNames.emit($event)\"\n (createScreenNameRequest)=\"createScreenNameRequest.emit($event)\">\n </cqa-element-form>\n</div>\n<div class=\"cqa-flex cqa-justify-end cqa-pt-2\" *ngIf=\"!createElementVisible\">\n <cqa-button \n *ngIf=\"selectorVariableAvailable\"\n variant=\"text\" \n size=\"sm\"\n text=\"Create Element\"\n (clicked)=\"onShowElementForm()\">\n </cqa-button>\n <!-- <cqa-button \n *ngIf=\"parameterVariableAvailable\"\n variant=\"filled\" \n text=\"Create Parameter\"\n (clicked)=\"onCreateParameter()\">\n </cqa-button>\n <cqa-button \n *ngIf=\"environmentVariableAvailable\"\n variant=\"filled\" \n text=\"Create Environment\"\n (clicked)=\"onCreateEnvironment()\">\n </cqa-button> -->\n</div>", 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"] }, { type: i4.ElementFormComponent, selector: "cqa-element-form", inputs: ["elementId", "element", "screenNameOptions", "hasMoreScreenNames", "isLoadingScreenNames", "isElementLoading", "isEditMode", "isCreateMode", "isEditInDepthAvailable"], outputs: ["createElement", "updateElement", "createScreenNameRequest", "searchScreenName", "loadMoreScreenNames", "cancel", "editInDepth"] }, { type: i5.ButtonComponent, selector: "cqa-button", inputs: ["variant", "btnSize", "disabled", "icon", "iconPosition", "fullWidth", "iconColor", "type", "text", "customClass", "inlineStyles", "tooltip", "tooltipPosition"], outputs: ["clicked"] }], directives: [{ type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i6.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
299
432
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: TemplateVariablesFormComponent, decorators: [{
|
|
300
433
|
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
|
|
434
|
+
args: [{ selector: 'cqa-template-variables-form', host: { class: 'cqa-ui-root' }, changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"cqa-flex cqa-gap-x-6 cqa-gap-y-4 cqa-flex-wrap\" *ngIf=\"!createElementVisible\">\n <ng-container *ngFor=\"let variable of templateVariables; let i = index; 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 [checked]=\"variablesForm.at(i)?.get('value')?.value || variable.value || false\"\n (change)=\"onVariableBooleanChange(variable.name, $event.checked)\" 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]=\"getFormGroupAt(i)!\" [config]=\"getSelectConfig(variable, i)\">\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]=\"getFormGroupAt(i)!\" [config]=\"getDataTypeSelectConfig(variable, i)\">\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]=\"getRawValue(variable)\" [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<div *ngIf=\"createElementVisible\">\n <cqa-element-form\n [isCreateMode]=\"true\"\n [screenNameOptions]=\"screenNameOptions\"\n [hasMoreScreenNames]=\"hasMoreScreenNames\"\n [isLoadingScreenNames]=\"isLoadingScreenNames\"\n [isEditInDepthAvailable]=\"false\"\n (createElement)=\"onCreateElement($event)\"\n (cancel)=\"onCancelElementForm()\"\n (searchScreenName)=\"searchScreenName.emit($event)\"\n (loadMoreScreenNames)=\"loadMoreScreenNames.emit($event)\"\n (createScreenNameRequest)=\"createScreenNameRequest.emit($event)\">\n </cqa-element-form>\n</div>\n<div class=\"cqa-flex cqa-justify-end cqa-pt-2\" *ngIf=\"!createElementVisible\">\n <cqa-button \n *ngIf=\"selectorVariableAvailable\"\n variant=\"text\" \n size=\"sm\"\n text=\"Create Element\"\n (clicked)=\"onShowElementForm()\">\n </cqa-button>\n <!-- <cqa-button \n *ngIf=\"parameterVariableAvailable\"\n variant=\"filled\" \n text=\"Create Parameter\"\n (clicked)=\"onCreateParameter()\">\n </cqa-button>\n <cqa-button \n *ngIf=\"environmentVariableAvailable\"\n variant=\"filled\" \n text=\"Create Environment\"\n (clicked)=\"onCreateEnvironment()\">\n </cqa-button> -->\n</div>", styles: [] }]
|
|
302
435
|
}], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }]; }, propDecorators: { templateVariables: [{
|
|
303
436
|
type: Input
|
|
304
437
|
}], variablesForm: [{
|
|
@@ -307,6 +440,18 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImpor
|
|
|
307
440
|
type: Input
|
|
308
441
|
}], description: [{
|
|
309
442
|
type: Input
|
|
443
|
+
}], elementOptions: [{
|
|
444
|
+
type: Input
|
|
445
|
+
}], hasMoreElements: [{
|
|
446
|
+
type: Input
|
|
447
|
+
}], isLoadingElements: [{
|
|
448
|
+
type: Input
|
|
449
|
+
}], screenNameOptions: [{
|
|
450
|
+
type: Input
|
|
451
|
+
}], hasMoreScreenNames: [{
|
|
452
|
+
type: Input
|
|
453
|
+
}], isLoadingScreenNames: [{
|
|
454
|
+
type: Input
|
|
310
455
|
}], variableValueChange: [{
|
|
311
456
|
type: Output
|
|
312
457
|
}], variableBooleanChange: [{
|
|
@@ -315,5 +460,21 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImpor
|
|
|
315
460
|
type: Output
|
|
316
461
|
}], descriptionChange: [{
|
|
317
462
|
type: Output
|
|
463
|
+
}], loadMoreElements: [{
|
|
464
|
+
type: Output
|
|
465
|
+
}], searchElements: [{
|
|
466
|
+
type: Output
|
|
467
|
+
}], createElement: [{
|
|
468
|
+
type: Output
|
|
469
|
+
}], searchScreenName: [{
|
|
470
|
+
type: Output
|
|
471
|
+
}], loadMoreScreenNames: [{
|
|
472
|
+
type: Output
|
|
473
|
+
}], createScreenNameRequest: [{
|
|
474
|
+
type: Output
|
|
475
|
+
}], cancelElementForm: [{
|
|
476
|
+
type: Output
|
|
477
|
+
}], elementFormVisibilityChange: [{
|
|
478
|
+
type: Output
|
|
318
479
|
}] } });
|
|
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":"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","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' || 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]=\"getRawValue(variable)\" [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"]}
|
|
480
|
+
//# 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":"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","sourcesContent":["import { Component, Input, Output, EventEmitter, OnChanges, SimpleChanges, ChangeDetectionStrategy, ChangeDetectorRef } from '@angular/core';\nimport { FormGroup, FormControl, FormArray } from '@angular/forms';\nimport { DynamicSelectFieldConfig, SelectOption } from '../../dynamic-select/dynamic-select-field.component';\nimport { ElementCreatePayload, ScreenNameOption } from '../../test-case-details/element-popup/element-popup-form-data';\n\n// Import Element type - using any for now since Element is from ts-portal-ui\n// In a real scenario, you might want to create a shared interface or import from a shared package\ninterface Element {\n  id?: number;\n  name: string;\n  locatorValue?: string;\n  otherLocator?: string[];\n  [key: string]: any;\n}\n\nexport interface TemplateVariable {\n  name: string;\n  dataKey: 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: FormArray = new FormArray([]);\n  @Input() metadata: string = '';\n  @Input() description: string = '';\n  @Input() elementOptions: Element[] = []; // Element objects for element dropdown\n  @Input() hasMoreElements: boolean = false; // Whether more elements are available\n  @Input() isLoadingElements: boolean = false; // Loading state for elements\n  /** Screen name options for element form autocomplete (from API) */\n  @Input() screenNameOptions: ScreenNameOption[] = [];\n  /** Whether more screen names are available for infinite scroll */\n  @Input() hasMoreScreenNames: boolean = false;\n  /** True while parent is loading screen names (search or load more) */\n  @Input() isLoadingScreenNames: boolean = false;\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  @Output() loadMoreElements = new EventEmitter<void>(); // Emit when load more is requested\n  @Output() searchElements = new EventEmitter<string>(); // Emit when user searches for elements\n  @Output() createElement = new EventEmitter<ElementCreatePayload>(); // Emit when element is created with payload\n  @Output() searchScreenName = new EventEmitter<string>(); // Emit when user searches screen names\n  @Output() loadMoreScreenNames = new EventEmitter<string>(); // Emit when user scrolls to load more screen names\n  @Output() createScreenNameRequest = new EventEmitter<string>(); // Emit when user requests to create a new screen name\n  @Output() cancelElementForm = new EventEmitter<void>(); // Emit when element form is cancelled\n  @Output() elementFormVisibilityChange = new EventEmitter<boolean>(); // Emit when element form visibility changes\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  createElementVisible: boolean = false;\n  \n  constructor(private cdr: ChangeDetectorRef) {}\n\n  onCreateElement(payload: ElementCreatePayload): void {\n    console.log('onCreateElement', payload);\n    this.createElement.emit(payload);\n    this.createElementVisible = false;\n    this.elementFormVisibilityChange.emit(false);\n    this.cdr.markForCheck();\n  }\n\n  onCancelElementForm(): void {\n    this.createElementVisible = false;\n    this.elementFormVisibilityChange.emit(false);\n    this.cancelElementForm.emit();\n    this.cdr.markForCheck();\n  }\n\n  onShowElementForm(): void {\n    this.createElementVisible = true;\n    this.elementFormVisibilityChange.emit(true);\n    this.cdr.markForCheck();\n  }\n  \n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes['templateVariables'] || changes['variablesForm'] || changes['elementOptions'] || \n        changes['hasMoreElements'] || changes['isLoadingElements']) {\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, index) => {\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 in the FormArray\n        const variableGroup = this.getVariableFormGroup(variable.name);\n        if (variableGroup) {\n          if (!variableGroup.get('dataType')) {\n            variableGroup.addControl('dataType', new FormControl(dataType));\n          } else {\n            variableGroup.get('dataType')?.setValue(dataType, { emitEvent: false });\n          }\n        }\n      }\n    });\n  }\n  \n  /** Get form group for a variable by name from FormArray */\n  getVariableFormGroup(variableName: string): FormGroup | null {\n    const variableIndex = this.variablesForm.controls.findIndex(\n      control => (control as FormGroup).get('name')?.value === variableName\n    );\n    if (variableIndex !== -1) {\n      return this.variablesForm.at(variableIndex) as FormGroup;\n    }\n    return null;\n  }\n  \n  /** Get form group at a specific index from FormArray (for template use) */\n  getFormGroupAt(index: number): FormGroup | null {\n    if (index >= 0 && index < this.variablesForm.length) {\n      return this.variablesForm.at(index) as FormGroup;\n    }\n    return null;\n  }\n  \n  private precomputeConfigs(): void {\n    if (!this.templateVariables) return;\n    \n    // Pre-compute all select configs\n    this.templateVariables.forEach((variable, index) => {\n      // Pre-compute regular select configs\n      if (this.shouldShowDropdown(variable)) {\n        this.getSelectConfig(variable, index);\n      }\n      \n      // Pre-compute data type select configs\n      if (this.needsDataTypeDropdown(variable)) {\n        this.getDataTypeSelectConfig(variable, index);\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, index: number): DynamicSelectFieldConfig {\n    // Use cache to avoid recalculating on every change detection\n    // For element variables, include elementOptions, hasMoreElements, and isLoadingElements in cache key\n    const optionsKey = variable.dataKey === 'element' || variable.dataKey === 'label'\n      ? this.elementOptions.map(el => String(el.name || '')).join(',') \n      : (variable.options?.join(',') || '');\n    // Include hasMoreElements and isLoadingElements in cache key for selector variables\n    const cacheKey = variable.dataKey === 'element' || variable.dataKey === 'label'\n      ? `${variable.name}_${optionsKey}_${this.hasMoreElements}_${this.isLoadingElements}`\n      : `${variable.name}_${optionsKey}`;\n    if (this.selectConfigCache.has(cacheKey)) {\n      return this.selectConfigCache.get(cacheKey)!;\n    }\n\n    // Use elementOptions if variable name is 'selector', otherwise use variable.options\n    // Extract element names from Element objects\n    let optionsArray: SelectOption[] = [];\n    if (variable.dataKey === 'element' || variable.dataKey === 'label') {\n      // For element options, use locatorValue as both id and value so the component returns locatorValue\n      // This ensures the selected value is the locatorValue (not the element id)\n      optionsArray = this.elementOptions\n        .map(el => {\n          const locatorValue = el.locatorValue || '';\n          return {\n            id: locatorValue, // Use locatorValue as id so it gets returned as the value\n            elementId: el.id?.toString() || '',\n            value: locatorValue, // Also set value for consistency\n            name: el.name,\n            label: el.name\n          };\n        });\n    } else {\n      optionsArray = variable.options?.map(opt => {return {id: opt, value: opt, name: opt, label: opt}}) as SelectOption[] || [];\n    }\n\n    console.log('optionsArray', optionsArray);\n    const config: DynamicSelectFieldConfig = {\n      key: 'value', // Use 'value' as key since we're accessing from FormArray\n      placeholder: `Select ${variable.label}`,\n      multiple: false,\n      searchable: false,\n      options: optionsArray,\n      onChange: (value: any) => {\n        this.onVariableValueChange(variable.name, value);\n      }\n    };\n    \n    // Add load more and search support for selector variables\n    if (variable.dataKey === 'element' || variable.dataKey === 'label') {\n      config.searchable = true; // Enable search for selector dropdown\n      config.serverSearch = true; // Enable server-side search\n      config.hasMore = this.hasMoreElements;\n      config.isLoading = this.isLoadingElements;\n      config.onLoadMore = () => {\n        this.loadMoreElements.emit();\n      };\n      config.onSearch = (query: string) => {\n        // Emit search event when user types in the search box\n        this.searchElements.emit(query);\n      };\n    }\n    \n    this.selectConfigCache.set(cacheKey, config);\n    return config;\n  }\n  \n  onVariableValueChange(variableName: string, value: any): void {\n    console.log(\"onVariableValueChange\", variableName, value);\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 in FormArray\n      const variableGroup = this.getVariableFormGroup(variableName);\n      if (variableGroup && variableGroup.get('dataType')) {\n        variableGroup.get('dataType')?.setValue(dataType, { emitEvent: false });\n      }\n    }\n    \n    // Update the variable in templateVariables array\n    variable.value = value;\n    \n    // Also update form control in FormArray (use emitEvent: false to prevent triggering valueChanges)\n    const variableGroup = this.getVariableFormGroup(variableName);\n    if (variableGroup && variableGroup.get('value')) {\n      variableGroup.get('value')?.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 in FormArray (use emitEvent: false to prevent triggering valueChanges)\n    const variableGroup = this.getVariableFormGroup(variableName);\n    if (variableGroup && variableGroup.get('value')) {\n      variableGroup.get('value')?.setValue(value, { emitEvent: false });\n    }\n    // Note: If variable doesn't exist in FormArray, it should be added by parent component\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' || variable.dataKey === 'element' || variable.dataKey === 'label';\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 dataKey = variable.dataKey?.toLowerCase() || '';\n    const result = dataKey === 'test-data' || dataKey === 'source_value' || dataKey === '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, index: number): 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    // Ensure form control exists in FormArray\n    const variableGroup = this.getVariableFormGroup(variable.name);\n    if (variableGroup && !variableGroup.get('dataType')) {\n      const currentDataType = this.variableDataTypes.get(variable.name) || 'plain-text';\n      variableGroup.addControl('dataType', new FormControl(currentDataType));\n    }\n    \n    const config: DynamicSelectFieldConfig = {\n      key: 'dataType', // Use 'dataType' as key since we're accessing from FormArray\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  /**\n   * Check if selector variable is available in templateVariables\n   */\n  get selectorVariableAvailable(): boolean {\n    return this.templateVariables.some(v => v.dataKey === 'element' || v.dataKey === 'label');\n  }\n\n  /**\n   * Check if parameter variable is available (testData with parameter type)\n   */\n  get parameterVariableAvailable(): boolean {\n    return this.templateVariables.some(v => {\n      const dataKey = v.dataKey?.toLowerCase() || '';\n      if (dataKey === 'test-data' || dataKey === 'source_value' || dataKey === 'target_value') {\n        const dataType = this.variableDataTypes.get(v.name) || 'plain-text';\n        return dataType === 'parameter';\n      }\n      return false;\n    });\n  }\n\n  /**\n   * Check if environment variable is available (testData with environment type)\n   */\n  get environmentVariableAvailable(): boolean {\n    return this.templateVariables.some(v => {\n      const dataKey = v.name?.toLowerCase() || '';\n      if (dataKey === 'test-data' || dataKey === 'source_value' || dataKey === 'target_value') {\n        const dataType = this.variableDataTypes.get(v.name) || 'plain-text';\n        return dataType === 'environment';\n      }\n      return false;\n    });\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 in FormArray\n    const variableGroup = this.getVariableFormGroup(variableName);\n    if (variableGroup && variableGroup.get('value')) {\n      variableGroup.get('value')?.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  onElementSearch(event: { key: string; query: string }): void {\n    // Only handle search for selector variables\n    // The key will be 'value' since that's what we set in the config\n    // Emit the search query to parent component\n    this.searchElements.emit(event.query);\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 in FormArray\n    const variableGroup = this.getVariableFormGroup(variableName);\n    if (variableGroup && variableGroup.get('value')) {\n      variableGroup.get('value')?.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-gap-y-4 cqa-flex-wrap\" *ngIf=\"!createElementVisible\">\n  <ng-container *ngFor=\"let variable of templateVariables; let i = index; 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 [checked]=\"variablesForm.at(i)?.get('value')?.value || variable.value || false\"\n          (change)=\"onVariableBooleanChange(variable.name, $event.checked)\" 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]=\"getFormGroupAt(i)!\" [config]=\"getSelectConfig(variable, i)\">\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]=\"getFormGroupAt(i)!\" [config]=\"getDataTypeSelectConfig(variable, i)\">\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]=\"getRawValue(variable)\" [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<div *ngIf=\"createElementVisible\">\n  <cqa-element-form\n    [isCreateMode]=\"true\"\n    [screenNameOptions]=\"screenNameOptions\"\n    [hasMoreScreenNames]=\"hasMoreScreenNames\"\n    [isLoadingScreenNames]=\"isLoadingScreenNames\"\n    [isEditInDepthAvailable]=\"false\"\n    (createElement)=\"onCreateElement($event)\"\n    (cancel)=\"onCancelElementForm()\"\n    (searchScreenName)=\"searchScreenName.emit($event)\"\n    (loadMoreScreenNames)=\"loadMoreScreenNames.emit($event)\"\n    (createScreenNameRequest)=\"createScreenNameRequest.emit($event)\">\n  </cqa-element-form>\n</div>\n<div class=\"cqa-flex cqa-justify-end cqa-pt-2\" *ngIf=\"!createElementVisible\">\n  <cqa-button \n    *ngIf=\"selectorVariableAvailable\"\n    variant=\"text\" \n    size=\"sm\"\n    text=\"Create Element\"\n    (clicked)=\"onShowElementForm()\">\n  </cqa-button>\n  <!-- <cqa-button \n    *ngIf=\"parameterVariableAvailable\"\n    variant=\"filled\" \n    text=\"Create Parameter\"\n    (clicked)=\"onCreateParameter()\">\n  </cqa-button>\n  <cqa-button \n    *ngIf=\"environmentVariableAvailable\"\n    variant=\"filled\" \n    text=\"Create Environment\"\n    (clicked)=\"onCreateEnvironment()\">\n  </cqa-button> -->\n</div>"]}
|