@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.
Files changed (23) hide show
  1. package/esm2020/lib/simulator/simulator.component.mjs +28 -45
  2. package/esm2020/lib/step-builder/step-builder-action/step-builder-action.component.mjs +267 -44
  3. package/esm2020/lib/step-builder/step-builder-condition/step-builder-condition.component.mjs +183 -41
  4. package/esm2020/lib/step-builder/step-builder-loop/step-builder-loop.component.mjs +44 -3
  5. package/esm2020/lib/step-builder/template-variables-form/template-variables-form.component.mjs +218 -57
  6. package/esm2020/lib/test-case-details/element-popup/element-form/element-form.component.mjs +277 -0
  7. package/esm2020/lib/test-case-details/element-popup/element-popup.component.mjs +32 -192
  8. package/esm2020/lib/ui-kit.module.mjs +6 -1
  9. package/esm2020/public-api.mjs +2 -1
  10. package/fesm2015/cqa-lib-cqa-ui.mjs +1118 -444
  11. package/fesm2015/cqa-lib-cqa-ui.mjs.map +1 -1
  12. package/fesm2020/cqa-lib-cqa-ui.mjs +1103 -440
  13. package/fesm2020/cqa-lib-cqa-ui.mjs.map +1 -1
  14. package/lib/step-builder/step-builder-action/step-builder-action.component.d.ts +50 -4
  15. package/lib/step-builder/step-builder-condition/step-builder-condition.component.d.ts +39 -2
  16. package/lib/step-builder/step-builder-loop/step-builder-loop.component.d.ts +17 -1
  17. package/lib/step-builder/template-variables-form/template-variables-form.component.d.ts +56 -5
  18. package/lib/test-case-details/element-popup/element-form/element-form.component.d.ts +77 -0
  19. package/lib/test-case-details/element-popup/element-popup.component.d.ts +13 -32
  20. package/lib/ui-kit.module.d.ts +42 -41
  21. package/package.json +1 -1
  22. package/public-api.d.ts +1 -0
  23. package/styles.css +1 -1
@@ -4,9 +4,8 @@ import * as i0 from "@angular/core";
4
4
  import * as i1 from "@angular/forms";
5
5
  import * as i2 from "../../search-bar/search-bar.component";
6
6
  import * as i3 from "../template-variables-form/template-variables-form.component";
7
- import * as i4 from "@angular/material/icon";
8
- import * as i5 from "../../button/button.component";
9
- import * as i6 from "@angular/common";
7
+ import * as i4 from "../../button/button.component";
8
+ import * as i5 from "@angular/common";
10
9
  export class StepBuilderActionComponent {
11
10
  constructor(fb) {
12
11
  this.fb = fb;
@@ -18,7 +17,22 @@ export class StepBuilderActionComponent {
18
17
  /** Function to handle variable processing or custom logic. Can be passed from parent component. */
19
18
  this.setTemplateVariables = () => { return []; };
20
19
  this.preventSelectTemplate = ['databaseverification'];
20
+ this.elementOptions = []; // Element objects for element dropdown
21
+ this.hasMoreElements = false; // Whether more elements are available
22
+ this.isLoadingElements = false; // Loading state for elements
23
+ /** Screen name options for element form autocomplete (from API) */
24
+ this.screenNameOptions = [];
25
+ /** Whether more screen names are available for infinite scroll */
26
+ this.hasMoreScreenNames = false;
27
+ /** True while parent is loading screen names (search or load more) */
28
+ this.isLoadingScreenNames = false;
21
29
  this.templateChanged = 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
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
22
36
  /** Emit when step is created */
23
37
  this.createStep = new EventEmitter();
24
38
  /** Emit when cancelled */
@@ -30,12 +44,21 @@ export class StepBuilderActionComponent {
30
44
  this.description = '';
31
45
  this.advancedExpanded = false;
32
46
  this.templateVariables = [];
47
+ this.updatedHtmlGrammar = ''; // Updated HTML grammar with variable values
48
+ // Track element form visibility
49
+ this.isElementFormVisible = false;
33
50
  // Cache for select configs to avoid recalculating on every change detection
34
51
  this.selectConfigCache = new Map();
35
52
  this.formValidCache = false;
36
53
  this.lastFormValidationTime = 0;
37
54
  this.FORM_VALIDATION_CACHE_MS = 100; // Cache for 100ms
38
- this.variablesForm = this.fb.group({});
55
+ this.variablesForm = this.fb.array([]);
56
+ }
57
+ /**
58
+ * Handle element form visibility change
59
+ */
60
+ onElementFormVisibilityChange(visible) {
61
+ this.isElementFormVisible = visible;
39
62
  }
40
63
  ngOnInit() {
41
64
  this.filteredTemplates = [...this.templates];
@@ -65,14 +88,38 @@ export class StepBuilderActionComponent {
65
88
  const searchTerm = this.searchValue.toLowerCase().trim();
66
89
  this.filteredTemplates = this.templates.filter(template => {
67
90
  const naturalText = template.naturalText?.toLowerCase() || '';
68
- const displayName = template.displayName?.toLowerCase() || '';
91
+ // Strip HTML tags from htmlGrammar for searching (only search text content, not HTML markup)
92
+ const htmlGrammarText = this.stripHtmlTags(template.htmlGrammar || '').toLowerCase();
69
93
  const searchableGrammar = template.searchableGrammar?.toLowerCase() || '';
70
94
  return naturalText.includes(searchTerm) ||
71
- displayName.includes(searchTerm) ||
95
+ htmlGrammarText.includes(searchTerm) ||
72
96
  searchableGrammar.includes(searchTerm);
73
97
  });
74
98
  console.log("filteredTemplates", this.filteredTemplates);
75
99
  }
100
+ /**
101
+ * Strip HTML tags from a string, returning only the text content
102
+ * @param htmlString - HTML string to strip tags from
103
+ * @returns Plain text without HTML tags
104
+ */
105
+ stripHtmlTags(htmlString) {
106
+ if (!htmlString)
107
+ return '';
108
+ // Use browser's DOMParser if available
109
+ if (typeof document !== 'undefined' && document.createElement) {
110
+ try {
111
+ const tempDiv = document.createElement('div');
112
+ tempDiv.innerHTML = htmlString;
113
+ return tempDiv.textContent || tempDiv.innerText || '';
114
+ }
115
+ catch (error) {
116
+ // Fallback to regex if DOM parsing fails
117
+ return htmlString.replace(/<[^>]*>/g, '');
118
+ }
119
+ }
120
+ // Fallback: regex-based tag removal for server-side rendering
121
+ return htmlString.replace(/<[^>]*>/g, '');
122
+ }
76
123
  selectTemplate(template) {
77
124
  if (this.preventSelectTemplate.includes(template.displayName || '')) {
78
125
  this.templateChanged.emit(template);
@@ -89,20 +136,26 @@ export class StepBuilderActionComponent {
89
136
  setTimeout(() => {
90
137
  try {
91
138
  this.templateVariables = this.setTemplateVariables(template);
139
+ console.log("templateVariables", this.templateVariables);
92
140
  this.buildVariablesForm();
141
+ // Initialize updated HTML grammar
142
+ this.updateHtmlGrammar();
93
143
  }
94
144
  catch (error) {
95
145
  console.error('Error processing template variables:', error);
96
146
  }
97
147
  }, 0);
98
148
  }
149
+ else {
150
+ // Initialize with template's HTML grammar if no variables
151
+ this.updatedHtmlGrammar = template.htmlGrammar || template.naturalText || '';
152
+ }
99
153
  }
100
154
  buildVariablesForm() {
101
- // Clear existing form controls
102
- const controlKeys = Object.keys(this.variablesForm.controls);
103
- controlKeys.forEach(key => {
104
- this.variablesForm.removeControl(key);
105
- });
155
+ // Clear existing form array
156
+ while (this.variablesForm.length !== 0) {
157
+ this.variablesForm.removeAt(0);
158
+ }
106
159
  // Clear cache when form is rebuilt
107
160
  this.selectConfigCache.clear();
108
161
  this.formValidCache = false;
@@ -110,13 +163,39 @@ export class StepBuilderActionComponent {
110
163
  if (this.formValueChangesSubscription) {
111
164
  this.formValueChangesSubscription.unsubscribe();
112
165
  }
113
- // Add form controls for each variable
166
+ // Add form groups for each variable
114
167
  this.templateVariables.forEach(variable => {
115
168
  // Handle boolean variables - use boolean value, others use string
116
169
  const defaultValue = variable.type === 'boolean'
117
170
  ? (variable.value === true || variable.value === 'true' || variable.value === 1)
118
171
  : (variable.value || '');
119
- this.variablesForm.addControl(variable.name, new FormControl(defaultValue));
172
+ // Create a FormGroup for each variable with name and value
173
+ const variableGroup = this.fb.group({
174
+ name: [variable.name],
175
+ value: [defaultValue],
176
+ type: [variable.type || 'string'],
177
+ label: [variable.label || ''],
178
+ options: [variable.options || []]
179
+ });
180
+ // Add dataType control for test-data variables if needed
181
+ const label = variable.label?.toLowerCase() || '';
182
+ if (label === 'test-data' || label === 'source-value' || label === 'target-value' ||
183
+ label === 'source_value' || label === 'target_value') {
184
+ // Parse the value to determine data type
185
+ const valueStr = String(defaultValue || '');
186
+ let dataType = 'plain-text';
187
+ if (valueStr.startsWith('@|') && valueStr.endsWith('|')) {
188
+ dataType = 'parameter';
189
+ }
190
+ else if (valueStr.startsWith('$|') && valueStr.endsWith('|')) {
191
+ dataType = 'runtime';
192
+ }
193
+ else if (valueStr.startsWith('*|') && valueStr.endsWith('|')) {
194
+ dataType = 'environment';
195
+ }
196
+ variableGroup.addControl('dataType', new FormControl(dataType));
197
+ }
198
+ this.variablesForm.push(variableGroup);
120
199
  });
121
200
  // Subscribe to form value changes to invalidate cache (only when user actually changes values)
122
201
  // Note: We use emitEvent: false when programmatically setting values, so this won't fire unnecessarily
@@ -130,7 +209,7 @@ export class StepBuilderActionComponent {
130
209
  this.formValueChangesSubscription.unsubscribe();
131
210
  }
132
211
  }
133
- getSelectConfig(variable) {
212
+ getSelectConfig(variable, index) {
134
213
  // Use cache to avoid recalculating on every change detection
135
214
  const cacheKey = `${variable.name}_${variable.options?.join(',') || ''}`;
136
215
  if (this.selectConfigCache.has(cacheKey)) {
@@ -143,7 +222,7 @@ export class StepBuilderActionComponent {
143
222
  label: opt
144
223
  }));
145
224
  const config = {
146
- key: variable.name,
225
+ key: `value`,
147
226
  placeholder: `Select ${variable.label}`,
148
227
  multiple: false,
149
228
  searchable: false,
@@ -155,18 +234,62 @@ export class StepBuilderActionComponent {
155
234
  this.selectConfigCache.set(cacheKey, config);
156
235
  return config;
157
236
  }
237
+ /** Get form group for a variable by name */
238
+ getVariableFormGroup(variableName) {
239
+ const variableIndex = this.variablesForm.controls.findIndex(control => control.get('name')?.value === variableName);
240
+ if (variableIndex !== -1) {
241
+ return this.variablesForm.at(variableIndex);
242
+ }
243
+ return null;
244
+ }
245
+ /** Add a new variable to the form array dynamically */
246
+ addVariable(variable) {
247
+ const defaultValue = variable.type === 'boolean'
248
+ ? (variable.value === true || variable.value === 'true' || variable.value === 1)
249
+ : (variable.value || '');
250
+ const variableGroup = this.fb.group({
251
+ name: [variable.name],
252
+ value: [defaultValue],
253
+ type: [variable.type || 'string'],
254
+ label: [variable.label || ''],
255
+ options: [variable.options || []]
256
+ });
257
+ // Add dataType control for test-data variables if needed
258
+ const label = variable.label?.toLowerCase() || '';
259
+ if (label === 'test-data' || label === 'source-value' || label === 'target-value' ||
260
+ label === 'source_value' || label === 'target_value') {
261
+ const valueStr = String(defaultValue || '');
262
+ let dataType = 'plain-text';
263
+ if (valueStr.startsWith('@|') && valueStr.endsWith('|')) {
264
+ dataType = 'parameter';
265
+ }
266
+ else if (valueStr.startsWith('$|') && valueStr.endsWith('|')) {
267
+ dataType = 'runtime';
268
+ }
269
+ else if (valueStr.startsWith('*|') && valueStr.endsWith('|')) {
270
+ dataType = 'environment';
271
+ }
272
+ variableGroup.addControl('dataType', new FormControl(dataType));
273
+ }
274
+ this.variablesForm.push(variableGroup);
275
+ this.formValidCache = false;
276
+ }
158
277
  onVariableValueChange(variableName, value) {
278
+ console.log("onVariableValueChange", variableName, value);
159
279
  // Update the variable in templateVariables array
160
280
  const variable = this.templateVariables.find(v => v.name === variableName);
161
281
  if (variable) {
162
282
  variable.value = value;
163
283
  }
164
- // Also update form control (use emitEvent: false to prevent triggering valueChanges)
165
- if (this.variablesForm.get(variableName)) {
166
- this.variablesForm.get(variableName)?.setValue(value, { emitEvent: false });
284
+ // Also update form array (use emitEvent: false to prevent triggering valueChanges)
285
+ const variableIndex = this.variablesForm.controls.findIndex(control => control.get('name')?.value === variableName);
286
+ if (variableIndex !== -1) {
287
+ this.variablesForm.at(variableIndex).get('value')?.setValue(value, { emitEvent: false });
167
288
  }
168
289
  // Invalidate form validation cache
169
290
  this.formValidCache = false;
291
+ // Update HTML grammar with new value
292
+ this.updateHtmlGrammar();
170
293
  }
171
294
  onVariableBooleanChange(variableName, value) {
172
295
  // Update the variable in templateVariables array
@@ -174,16 +297,26 @@ export class StepBuilderActionComponent {
174
297
  if (variable) {
175
298
  variable.value = value;
176
299
  }
177
- // Also update form control (use emitEvent: false to prevent triggering valueChanges)
178
- if (this.variablesForm.get(variableName)) {
179
- this.variablesForm.get(variableName)?.setValue(value, { emitEvent: false });
300
+ // Also update form array (use emitEvent: false to prevent triggering valueChanges)
301
+ const variableIndex = this.variablesForm.controls.findIndex(control => control.get('name')?.value === variableName);
302
+ if (variableIndex !== -1) {
303
+ this.variablesForm.at(variableIndex).get('value')?.setValue(value, { emitEvent: false });
180
304
  }
181
305
  else {
182
- // Create form control if it doesn't exist
183
- this.variablesForm.addControl(variableName, new FormControl(value));
306
+ // Create new form group if it doesn't exist
307
+ const variableGroup = this.fb.group({
308
+ name: [variableName],
309
+ value: [value],
310
+ type: ['boolean'],
311
+ label: [variable?.label || ''],
312
+ options: [variable?.options || []]
313
+ });
314
+ this.variablesForm.push(variableGroup);
184
315
  }
185
316
  // Invalidate form validation cache
186
317
  this.formValidCache = false;
318
+ // Update HTML grammar with new value
319
+ this.updateHtmlGrammar();
187
320
  }
188
321
  onBack() {
189
322
  this.selectedTemplate = null;
@@ -191,10 +324,11 @@ export class StepBuilderActionComponent {
191
324
  this.description = '';
192
325
  this.advancedExpanded = false;
193
326
  this.templateVariables = [];
194
- // Clear form controls
195
- Object.keys(this.variablesForm.controls).forEach(key => {
196
- this.variablesForm.removeControl(key);
197
- });
327
+ this.updatedHtmlGrammar = '';
328
+ // Clear form array
329
+ while (this.variablesForm.length !== 0) {
330
+ this.variablesForm.removeAt(0);
331
+ }
198
332
  // Reapply filter to maintain search state
199
333
  this.applyFilter();
200
334
  }
@@ -212,22 +346,22 @@ export class StepBuilderActionComponent {
212
346
  return this.formValidCache;
213
347
  }
214
348
  // Check if all required variables are filled
215
- let isValid = true;
216
- if (this.templateVariables && this.templateVariables.length > 0) {
217
- isValid = this.templateVariables.every(variable => {
218
- // Boolean variables are always valid (they have a default value)
219
- if (variable.type === 'boolean') {
220
- return true;
221
- }
222
- // Check if variable has a value
223
- const value = variable.value;
224
- return value !== null && value !== undefined && value !== '';
225
- });
226
- }
349
+ // let isValid = true;
350
+ // if (this.templateVariables && this.templateVariables.length > 0) {
351
+ // isValid = this.templateVariables.every(variable => {
352
+ // // Boolean variables are always valid (they have a default value)
353
+ // if (variable.type === 'boolean') {
354
+ // return true;
355
+ // }
356
+ // // Check if variable has a value
357
+ // const value = variable.value;
358
+ // return value !== null && value !== undefined && value !== '';
359
+ // });
360
+ // }
227
361
  // Cache the result
228
- this.formValidCache = isValid;
362
+ this.formValidCache = this.variablesForm.valid;
229
363
  this.lastFormValidationTime = now;
230
- return isValid;
364
+ return this.variablesForm.valid;
231
365
  }
232
366
  trackByTemplate(index, template) {
233
367
  return template.id || template.displayName || index;
@@ -245,6 +379,8 @@ export class StepBuilderActionComponent {
245
379
  description: this.description,
246
380
  templateVariables: this.templateVariables
247
381
  };
382
+ console.log("stepData", stepData);
383
+ console.log("variablesForm", this.variablesForm.value);
248
384
  this.createStep.emit(stepData);
249
385
  }
250
386
  toggleAdvanced() {
@@ -260,12 +396,75 @@ export class StepBuilderActionComponent {
260
396
  onTestDataValueChange(key, value) {
261
397
  console.log(key, value);
262
398
  }
399
+ /**
400
+ * Update HTML grammar by replacing placeholder spans with actual variable values
401
+ */
402
+ updateHtmlGrammar() {
403
+ if (!this.selectedTemplate) {
404
+ this.updatedHtmlGrammar = '';
405
+ return;
406
+ }
407
+ const htmlGrammar = this.selectedTemplate.htmlGrammar || this.selectedTemplate.naturalText || '';
408
+ if (!htmlGrammar) {
409
+ this.updatedHtmlGrammar = '';
410
+ return;
411
+ }
412
+ // Create a map of variable values by name for quick lookup
413
+ const valueMap = new Map();
414
+ if (this.templateVariables && Array.isArray(this.templateVariables)) {
415
+ this.templateVariables.forEach((variable) => {
416
+ if (variable.name && variable.value !== undefined && variable.value !== null) {
417
+ // Convert value to string, handling boolean values
418
+ const valueStr = typeof variable.value === 'boolean'
419
+ ? (variable.value ? 'true' : 'false')
420
+ : String(variable.value || '');
421
+ valueMap.set(variable.name, valueStr);
422
+ }
423
+ });
424
+ }
425
+ // Use browser's DOMParser if available, otherwise fallback to string replacement
426
+ if (typeof document !== 'undefined' && document.createElement) {
427
+ try {
428
+ const tempDiv = document.createElement('div');
429
+ tempDiv.innerHTML = String(htmlGrammar);
430
+ // Find all spans with data-event-key attribute
431
+ const spans = tempDiv.querySelectorAll('span[data-event-key]');
432
+ spans.forEach((span) => {
433
+ const eventKey = span.getAttribute('data-event-key');
434
+ if (eventKey && valueMap.has(eventKey)) {
435
+ const value = valueMap.get(eventKey);
436
+ // Preserve the span structure but update the content
437
+ span.innerHTML = value || '';
438
+ }
439
+ });
440
+ this.updatedHtmlGrammar = tempDiv.innerHTML;
441
+ }
442
+ catch (error) {
443
+ console.error('Error updating HTML grammar:', error);
444
+ // Fallback to original HTML grammar
445
+ this.updatedHtmlGrammar = String(htmlGrammar);
446
+ }
447
+ }
448
+ else {
449
+ // Fallback: simple string replacement for server-side rendering
450
+ let updatedHtml = String(htmlGrammar);
451
+ valueMap.forEach((value, key) => {
452
+ // Replace spans with data-event-key matching the variable name
453
+ const regex = new RegExp(`<span[^>]*data-event-key="${key}"[^>]*>.*?</span>`, 'gi');
454
+ updatedHtml = updatedHtml.replace(regex, (match) => {
455
+ // Replace the content inside the span
456
+ return match.replace(/>.*?</, `>${value}<`);
457
+ });
458
+ });
459
+ this.updatedHtmlGrammar = updatedHtml;
460
+ }
461
+ }
263
462
  }
264
463
  StepBuilderActionComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: StepBuilderActionComponent, deps: [{ token: i1.FormBuilder }], target: i0.ɵɵFactoryTarget.Component });
265
- StepBuilderActionComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.4.0", type: StepBuilderActionComponent, selector: "cqa-step-builder-action", inputs: { showHeader: "showHeader", templates: "templates", searchPlaceholder: "searchPlaceholder", setTemplateVariables: "setTemplateVariables", preventSelectTemplate: "preventSelectTemplate" }, outputs: { templateChanged: "templateChanged", createStep: "createStep", cancelled: "cancelled" }, host: { classAttribute: "cqa-ui-root" }, usesOnChanges: true, ngImport: i0, template: "<div class=\"cqa-flex cqa-flex-col cqa-h-full cqa-bg-white\" [ngClass]=\"{'cqa-px-4 cqa-py-2': showHeader}\">\n <!-- Header -->\n <h2 *ngIf=\"showHeader\" class=\"cqa-text-[12px] cqa-font-semibold cqa-text-black-100 cqa-mb-1\">\n Create an action step\n </h2>\n <div *ngIf=\"!selectedTemplate\" class=\"cqa-flex cqa-flex-col cqa-h-full cqa-flex-1\"\n [ngClass]=\"{'cqa-px-3': showHeader}\">\n\n <!-- Search Bar -->\n <div class=\"cqa-pb-1\">\n <div class=\"cqa-pb-1\" *ngIf=\"showHeader\">\n <p class=\"cqa-text-[12px] cqa-text-gray-500\">\n Template library\n </p>\n </div>\n <cqa-search-bar [placeholder]=\"searchPlaceholder\" [fullWidth]=\"true\" [value]=\"searchValue\"\n (valueChange)=\"onSearchChange($event)\" (search)=\"onSearchSubmit($event)\" (cleared)=\"onSearchCleared()\">\n </cqa-search-bar>\n </div>\n\n <!-- Template List -->\n <div class=\"cqa-flex-1 cqa-overflow-y-auto cqa-px-2\">\n <div class=\"cqa-py-2\">\n <div *ngFor=\"let template of filteredTemplates; trackBy: trackByTemplate\"\n class=\"cqa-action-format cqa-bg-white cqa-cursor-pointer cqa-transition-all hover:cqa-border-blue-500 hover:cqa-shadow-sm mb-6\"\n (click)=\"selectTemplate(template)\">\n <div class=\"cqa-text-[12px] cqa-leading-[23px] cqa-text-black-100\"\n [innerHTML]=\"template.htmlGrammar || template.naturalText || ''\">\n </div>\n </div>\n\n <div *ngIf=\"filteredTemplates.length === 0\" class=\"cqa-text-center cqa-py-8 cqa-text-gray-400 cqa-text-[12px]\">\n No templates found\n </div>\n </div>\n </div>\n </div>\n\n <div *ngIf=\"selectedTemplate\" class=\"cqa-flex cqa-flex-col cqa-h-full\">\n <!-- Instruction Text with Element Buttons -->\n <div class=\"cqa-mb-4 cqa-flex cqa-items-center cqa-flex-wrap cqa-gap-1 cqa-text-sm cqa-text-gray-700\">\n <div class=\"cqa-action-format cqa-text-[12px] cqa-leading-[23px] cqa-text-black-100\"\n [innerHTML]=\"selectedTemplate.htmlGrammar || selectedTemplate.naturalText || ''\">\n </div>\n </div>\n\n <!-- Form Fields in Two Columns -->\n <div class=\"cqa-flex cqa-overflow-y-auto\">\n <div class=\"cqa-flex-1 cqa-flex cqa-flex-col cqa-gap-1\">\n <div class=\"cqa-flex cqa-gap-x-6 cqa-flex-wrap\">\n <!-- Template Variables Form Component -->\n <cqa-template-variables-form\n [templateVariables]=\"templateVariables\"\n [variablesForm]=\"variablesForm\"\n [metadata]=\"metadata\"\n [description]=\"description\"\n (variableValueChange)=\"onVariableValueChange($event.name, $event.value)\"\n (variableBooleanChange)=\"onVariableBooleanChange($event.name, $event.value)\"\n (metadataChange)=\"metadata = $event\"\n (descriptionChange)=\"description = $event\">\n </cqa-template-variables-form>\n </div>\n\n <!-- Advanced (Expandable) -->\n <div class=\"cqa-flex cqa-flex-col cqa-w-full\">\n <button type=\"button\"\n class=\"cqa-flex cqa-w-full cqa-items-center cqa-justify-between cqa-gap-2 cqa-text-sm cqa-font-medium cqa-text-gray-700 cqa-bg-transparent cqa-border-none cqa-cursor-pointer cqa-p-0 cqa-mb-1.5\"\n (click)=\"toggleAdvanced()\">\n <span class=\"cqa-text-[10px]\">Advanced</span>\n <mat-icon class=\"cqa-text-base\" [class.cqa-rotate-180]=\"advancedExpanded\">\n expand_more\n </mat-icon>\n </button>\n <div *ngIf=\"advancedExpanded\" class=\"cqa-mt-2\">\n <!-- Advanced fields can be added here -->\n </div>\n </div>\n </div>\n\n\n </div>\n\n <!-- Action Buttons -->\n <div class=\"cqa-flex cqa-w-full cqa-gap-2 cqa-border-t cqa-border-gray-200\">\n <cqa-button class=\"cqa-w-1/2\" variant=\"outlined\" text=\"Cancel\" [customClass]=\"'cqa-flex-1 cqa-w-full'\"\n (clicked)=\"onCancel()\">\n </cqa-button>\n <cqa-button class=\"cqa-w-1/2\" variant=\"filled\" text=\"Create Step\" [customClass]=\"'cqa-flex-1 cqa-w-full'\"\n [disabled]=\"!isFormValid()\"\n (clicked)=\"onCreateStep()\">\n </cqa-button>\n </div>\n </div>\n</div>", components: [{ type: i2.SearchBarComponent, selector: "cqa-search-bar", inputs: ["placeholder", "value", "disabled", "showClear", "ariaLabel", "autoFocus", "size", "fullWidth"], outputs: ["valueChange", "search", "cleared"] }, { type: i3.TemplateVariablesFormComponent, selector: "cqa-template-variables-form", inputs: ["templateVariables", "variablesForm", "metadata", "description"], outputs: ["variableValueChange", "variableBooleanChange", "metadataChange", "descriptionChange"] }, { type: i4.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { 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.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i6.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }] });
464
+ StepBuilderActionComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.4.0", type: StepBuilderActionComponent, selector: "cqa-step-builder-action", inputs: { showHeader: "showHeader", templates: "templates", searchPlaceholder: "searchPlaceholder", setTemplateVariables: "setTemplateVariables", preventSelectTemplate: "preventSelectTemplate", elementOptions: "elementOptions", hasMoreElements: "hasMoreElements", isLoadingElements: "isLoadingElements", screenNameOptions: "screenNameOptions", hasMoreScreenNames: "hasMoreScreenNames", isLoadingScreenNames: "isLoadingScreenNames" }, outputs: { templateChanged: "templateChanged", loadMoreElements: "loadMoreElements", searchElements: "searchElements", createElement: "createElement", searchScreenName: "searchScreenName", loadMoreScreenNames: "loadMoreScreenNames", createScreenNameRequest: "createScreenNameRequest", createStep: "createStep", cancelled: "cancelled" }, host: { styleAttribute: "display: block;height: 100%;width: 100%;", classAttribute: "cqa-ui-root" }, usesOnChanges: true, ngImport: i0, template: "<div class=\"cqa-flex cqa-flex-col cqa-h-full cqa-bg-white\" [ngClass]=\"{'cqa-px-4': showHeader, 'cqa-py-2': showHeader && !selectedTemplate}\">\n <!-- Header -->\n <h2 *ngIf=\"showHeader\" class=\"cqa-text-[12px] cqa-font-semibold cqa-text-black-100 cqa-mb-1\">\n Create an action step\n </h2>\n <div *ngIf=\"!selectedTemplate\" class=\"cqa-flex cqa-flex-col cqa-h-full cqa-flex-1\"\n [ngClass]=\"{'cqa-px-3': showHeader}\">\n\n <!-- Search Bar -->\n <div class=\"cqa-pb-1\">\n <div class=\"cqa-pb-1\" *ngIf=\"showHeader\">\n <p class=\"cqa-text-[12px] cqa-text-gray-500\">\n Template library\n </p>\n </div>\n <cqa-search-bar [placeholder]=\"searchPlaceholder\" [fullWidth]=\"true\" [value]=\"searchValue\"\n (valueChange)=\"onSearchChange($event)\" (search)=\"onSearchSubmit($event)\" (cleared)=\"onSearchCleared()\">\n </cqa-search-bar>\n </div>\n\n <!-- Template List -->\n <div class=\"cqa-flex-1 cqa-overflow-y-auto cqa-px-2\">\n <div class=\"cqa-py-2\">\n <div *ngFor=\"let template of filteredTemplates; trackBy: trackByTemplate\"\n class=\"cqa-action-format cqa-bg-white cqa-cursor-pointer cqa-transition-all hover:cqa-border-blue-500 hover:cqa-shadow-sm mb-6\"\n (click)=\"selectTemplate(template)\">\n <div class=\"cqa-text-[12px] cqa-leading-[23px] cqa-text-black-100\"\n [innerHTML]=\"template.htmlGrammar || template.naturalText || ''\">\n </div>\n </div>\n\n <div *ngIf=\"filteredTemplates.length === 0\" class=\"cqa-text-center cqa-py-8 cqa-text-gray-400 cqa-text-[12px]\">\n No templates found\n </div>\n </div>\n </div>\n </div>\n\n <div *ngIf=\"selectedTemplate\" class=\"cqa-flex cqa-flex-col cqa-overflow-y-auto\" style=\"flex: 1 1 0 !important;\">\n <!-- Instruction Text with Element Buttons -->\n <div class=\"cqa-mb-4 cqa-flex cqa-items-center cqa-flex-wrap cqa-gap-1 cqa-text-sm cqa-text-gray-700\">\n <div class=\"cqa-action-format cqa-text-[12px] cqa-leading-[23px] cqa-text-black-100\"\n [innerHTML]=\"updatedHtmlGrammar || selectedTemplate.htmlGrammar || selectedTemplate.naturalText || ''\">\n </div>\n </div>\n\n <!-- Form Fields in Two Columns -->\n <div class=\"cqa-flex cqa-overflow-y-auto cqa-flex-1 cqa-pb-2\">\n <div class=\"cqa-flex-1 cqa-flex cqa-flex-col cqa-gap-1\">\n <div class=\"cqa-flex cqa-gap-x-6 cqa-flex-wrap cqa-pb-4\">\n <!-- Template Variables Form Component -->\n <cqa-template-variables-form\n style=\"width: 100%;\"\n [templateVariables]=\"templateVariables\"\n [variablesForm]=\"variablesForm\"\n [metadata]=\"metadata\"\n [description]=\"description\"\n [elementOptions]=\"elementOptions\"\n [hasMoreElements]=\"hasMoreElements\"\n [isLoadingElements]=\"isLoadingElements\"\n [screenNameOptions]=\"screenNameOptions\"\n [hasMoreScreenNames]=\"hasMoreScreenNames\"\n [isLoadingScreenNames]=\"isLoadingScreenNames\"\n (variableValueChange)=\"onVariableValueChange($event.name, $event.value)\"\n (variableBooleanChange)=\"onVariableBooleanChange($event.name, $event.value)\"\n (metadataChange)=\"metadata = $event\"\n (descriptionChange)=\"description = $event\"\n (loadMoreElements)=\"loadMoreElements.emit()\"\n (searchElements)=\"searchElements.emit($event)\"\n (createElement)=\"createElement.emit($event)\"\n (searchScreenName)=\"searchScreenName.emit($event)\"\n (loadMoreScreenNames)=\"loadMoreScreenNames.emit($event)\"\n (createScreenNameRequest)=\"createScreenNameRequest.emit($event)\"\n (elementFormVisibilityChange)=\"onElementFormVisibilityChange($event)\">\n </cqa-template-variables-form>\n </div>\n\n <!-- Advanced (Expandable) -->\n <!-- <div class=\"cqa-flex cqa-flex-col cqa-w-full\">\n <button type=\"button\"\n class=\"cqa-flex cqa-w-full cqa-items-center cqa-justify-between cqa-gap-2 cqa-text-sm cqa-font-medium cqa-text-gray-700 cqa-bg-transparent cqa-border-none cqa-cursor-pointer cqa-p-0 cqa-mb-1.5\"\n (click)=\"toggleAdvanced()\">\n <span class=\"cqa-text-[10px]\">Advanced</span>\n <mat-icon class=\"cqa-text-base\" [class.cqa-rotate-180]=\"advancedExpanded\">\n expand_more\n </mat-icon>\n </button>\n <div *ngIf=\"advancedExpanded\" class=\"cqa-mt-2\">\n </div>\n </div> -->\n <div>\n \n </div>\n </div>\n\n\n </div>\n\n <!-- Action Buttons -->\n <div *ngIf=\"!isElementFormVisible\" class=\"cqa-flex cqa-w-full cqa-gap-2 cqa-border-t cqa-border-gray-200 cqa-pb-2\">\n <cqa-button class=\"cqa-w-1/2\" variant=\"outlined\" text=\"Cancel\" [customClass]=\"'cqa-flex-1 cqa-w-full'\"\n (clicked)=\"onCancel()\">\n </cqa-button>\n <cqa-button class=\"cqa-w-1/2\" variant=\"filled\" text=\"Create Step\" [customClass]=\"'cqa-flex-1 cqa-w-full'\"\n [disabled]=\"!isFormValid()\"\n (clicked)=\"onCreateStep()\">\n </cqa-button>\n </div>\n </div>\n</div>", components: [{ type: i2.SearchBarComponent, selector: "cqa-search-bar", inputs: ["placeholder", "value", "disabled", "showClear", "ariaLabel", "autoFocus", "size", "fullWidth"], outputs: ["valueChange", "search", "cleared"] }, { type: i3.TemplateVariablesFormComponent, selector: "cqa-template-variables-form", inputs: ["templateVariables", "variablesForm", "metadata", "description", "elementOptions", "hasMoreElements", "isLoadingElements", "screenNameOptions", "hasMoreScreenNames", "isLoadingScreenNames"], outputs: ["variableValueChange", "variableBooleanChange", "metadataChange", "descriptionChange", "loadMoreElements", "searchElements", "createElement", "searchScreenName", "loadMoreScreenNames", "createScreenNameRequest", "cancelElementForm", "elementFormVisibilityChange"] }, { type: i4.ButtonComponent, selector: "cqa-button", inputs: ["variant", "btnSize", "disabled", "icon", "iconPosition", "fullWidth", "iconColor", "type", "text", "customClass", "inlineStyles", "tooltip", "tooltipPosition"], outputs: ["clicked"] }], directives: [{ type: i5.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i5.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }] });
266
465
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: StepBuilderActionComponent, decorators: [{
267
466
  type: Component,
268
- args: [{ selector: 'cqa-step-builder-action', host: { class: 'cqa-ui-root' }, template: "<div class=\"cqa-flex cqa-flex-col cqa-h-full cqa-bg-white\" [ngClass]=\"{'cqa-px-4 cqa-py-2': showHeader}\">\n <!-- Header -->\n <h2 *ngIf=\"showHeader\" class=\"cqa-text-[12px] cqa-font-semibold cqa-text-black-100 cqa-mb-1\">\n Create an action step\n </h2>\n <div *ngIf=\"!selectedTemplate\" class=\"cqa-flex cqa-flex-col cqa-h-full cqa-flex-1\"\n [ngClass]=\"{'cqa-px-3': showHeader}\">\n\n <!-- Search Bar -->\n <div class=\"cqa-pb-1\">\n <div class=\"cqa-pb-1\" *ngIf=\"showHeader\">\n <p class=\"cqa-text-[12px] cqa-text-gray-500\">\n Template library\n </p>\n </div>\n <cqa-search-bar [placeholder]=\"searchPlaceholder\" [fullWidth]=\"true\" [value]=\"searchValue\"\n (valueChange)=\"onSearchChange($event)\" (search)=\"onSearchSubmit($event)\" (cleared)=\"onSearchCleared()\">\n </cqa-search-bar>\n </div>\n\n <!-- Template List -->\n <div class=\"cqa-flex-1 cqa-overflow-y-auto cqa-px-2\">\n <div class=\"cqa-py-2\">\n <div *ngFor=\"let template of filteredTemplates; trackBy: trackByTemplate\"\n class=\"cqa-action-format cqa-bg-white cqa-cursor-pointer cqa-transition-all hover:cqa-border-blue-500 hover:cqa-shadow-sm mb-6\"\n (click)=\"selectTemplate(template)\">\n <div class=\"cqa-text-[12px] cqa-leading-[23px] cqa-text-black-100\"\n [innerHTML]=\"template.htmlGrammar || template.naturalText || ''\">\n </div>\n </div>\n\n <div *ngIf=\"filteredTemplates.length === 0\" class=\"cqa-text-center cqa-py-8 cqa-text-gray-400 cqa-text-[12px]\">\n No templates found\n </div>\n </div>\n </div>\n </div>\n\n <div *ngIf=\"selectedTemplate\" class=\"cqa-flex cqa-flex-col cqa-h-full\">\n <!-- Instruction Text with Element Buttons -->\n <div class=\"cqa-mb-4 cqa-flex cqa-items-center cqa-flex-wrap cqa-gap-1 cqa-text-sm cqa-text-gray-700\">\n <div class=\"cqa-action-format cqa-text-[12px] cqa-leading-[23px] cqa-text-black-100\"\n [innerHTML]=\"selectedTemplate.htmlGrammar || selectedTemplate.naturalText || ''\">\n </div>\n </div>\n\n <!-- Form Fields in Two Columns -->\n <div class=\"cqa-flex cqa-overflow-y-auto\">\n <div class=\"cqa-flex-1 cqa-flex cqa-flex-col cqa-gap-1\">\n <div class=\"cqa-flex cqa-gap-x-6 cqa-flex-wrap\">\n <!-- Template Variables Form Component -->\n <cqa-template-variables-form\n [templateVariables]=\"templateVariables\"\n [variablesForm]=\"variablesForm\"\n [metadata]=\"metadata\"\n [description]=\"description\"\n (variableValueChange)=\"onVariableValueChange($event.name, $event.value)\"\n (variableBooleanChange)=\"onVariableBooleanChange($event.name, $event.value)\"\n (metadataChange)=\"metadata = $event\"\n (descriptionChange)=\"description = $event\">\n </cqa-template-variables-form>\n </div>\n\n <!-- Advanced (Expandable) -->\n <div class=\"cqa-flex cqa-flex-col cqa-w-full\">\n <button type=\"button\"\n class=\"cqa-flex cqa-w-full cqa-items-center cqa-justify-between cqa-gap-2 cqa-text-sm cqa-font-medium cqa-text-gray-700 cqa-bg-transparent cqa-border-none cqa-cursor-pointer cqa-p-0 cqa-mb-1.5\"\n (click)=\"toggleAdvanced()\">\n <span class=\"cqa-text-[10px]\">Advanced</span>\n <mat-icon class=\"cqa-text-base\" [class.cqa-rotate-180]=\"advancedExpanded\">\n expand_more\n </mat-icon>\n </button>\n <div *ngIf=\"advancedExpanded\" class=\"cqa-mt-2\">\n <!-- Advanced fields can be added here -->\n </div>\n </div>\n </div>\n\n\n </div>\n\n <!-- Action Buttons -->\n <div class=\"cqa-flex cqa-w-full cqa-gap-2 cqa-border-t cqa-border-gray-200\">\n <cqa-button class=\"cqa-w-1/2\" variant=\"outlined\" text=\"Cancel\" [customClass]=\"'cqa-flex-1 cqa-w-full'\"\n (clicked)=\"onCancel()\">\n </cqa-button>\n <cqa-button class=\"cqa-w-1/2\" variant=\"filled\" text=\"Create Step\" [customClass]=\"'cqa-flex-1 cqa-w-full'\"\n [disabled]=\"!isFormValid()\"\n (clicked)=\"onCreateStep()\">\n </cqa-button>\n </div>\n </div>\n</div>", styles: [] }]
467
+ args: [{ selector: 'cqa-step-builder-action', host: { class: 'cqa-ui-root', style: 'display: block;height: 100%;width: 100%;' }, template: "<div class=\"cqa-flex cqa-flex-col cqa-h-full cqa-bg-white\" [ngClass]=\"{'cqa-px-4': showHeader, 'cqa-py-2': showHeader && !selectedTemplate}\">\n <!-- Header -->\n <h2 *ngIf=\"showHeader\" class=\"cqa-text-[12px] cqa-font-semibold cqa-text-black-100 cqa-mb-1\">\n Create an action step\n </h2>\n <div *ngIf=\"!selectedTemplate\" class=\"cqa-flex cqa-flex-col cqa-h-full cqa-flex-1\"\n [ngClass]=\"{'cqa-px-3': showHeader}\">\n\n <!-- Search Bar -->\n <div class=\"cqa-pb-1\">\n <div class=\"cqa-pb-1\" *ngIf=\"showHeader\">\n <p class=\"cqa-text-[12px] cqa-text-gray-500\">\n Template library\n </p>\n </div>\n <cqa-search-bar [placeholder]=\"searchPlaceholder\" [fullWidth]=\"true\" [value]=\"searchValue\"\n (valueChange)=\"onSearchChange($event)\" (search)=\"onSearchSubmit($event)\" (cleared)=\"onSearchCleared()\">\n </cqa-search-bar>\n </div>\n\n <!-- Template List -->\n <div class=\"cqa-flex-1 cqa-overflow-y-auto cqa-px-2\">\n <div class=\"cqa-py-2\">\n <div *ngFor=\"let template of filteredTemplates; trackBy: trackByTemplate\"\n class=\"cqa-action-format cqa-bg-white cqa-cursor-pointer cqa-transition-all hover:cqa-border-blue-500 hover:cqa-shadow-sm mb-6\"\n (click)=\"selectTemplate(template)\">\n <div class=\"cqa-text-[12px] cqa-leading-[23px] cqa-text-black-100\"\n [innerHTML]=\"template.htmlGrammar || template.naturalText || ''\">\n </div>\n </div>\n\n <div *ngIf=\"filteredTemplates.length === 0\" class=\"cqa-text-center cqa-py-8 cqa-text-gray-400 cqa-text-[12px]\">\n No templates found\n </div>\n </div>\n </div>\n </div>\n\n <div *ngIf=\"selectedTemplate\" class=\"cqa-flex cqa-flex-col cqa-overflow-y-auto\" style=\"flex: 1 1 0 !important;\">\n <!-- Instruction Text with Element Buttons -->\n <div class=\"cqa-mb-4 cqa-flex cqa-items-center cqa-flex-wrap cqa-gap-1 cqa-text-sm cqa-text-gray-700\">\n <div class=\"cqa-action-format cqa-text-[12px] cqa-leading-[23px] cqa-text-black-100\"\n [innerHTML]=\"updatedHtmlGrammar || selectedTemplate.htmlGrammar || selectedTemplate.naturalText || ''\">\n </div>\n </div>\n\n <!-- Form Fields in Two Columns -->\n <div class=\"cqa-flex cqa-overflow-y-auto cqa-flex-1 cqa-pb-2\">\n <div class=\"cqa-flex-1 cqa-flex cqa-flex-col cqa-gap-1\">\n <div class=\"cqa-flex cqa-gap-x-6 cqa-flex-wrap cqa-pb-4\">\n <!-- Template Variables Form Component -->\n <cqa-template-variables-form\n style=\"width: 100%;\"\n [templateVariables]=\"templateVariables\"\n [variablesForm]=\"variablesForm\"\n [metadata]=\"metadata\"\n [description]=\"description\"\n [elementOptions]=\"elementOptions\"\n [hasMoreElements]=\"hasMoreElements\"\n [isLoadingElements]=\"isLoadingElements\"\n [screenNameOptions]=\"screenNameOptions\"\n [hasMoreScreenNames]=\"hasMoreScreenNames\"\n [isLoadingScreenNames]=\"isLoadingScreenNames\"\n (variableValueChange)=\"onVariableValueChange($event.name, $event.value)\"\n (variableBooleanChange)=\"onVariableBooleanChange($event.name, $event.value)\"\n (metadataChange)=\"metadata = $event\"\n (descriptionChange)=\"description = $event\"\n (loadMoreElements)=\"loadMoreElements.emit()\"\n (searchElements)=\"searchElements.emit($event)\"\n (createElement)=\"createElement.emit($event)\"\n (searchScreenName)=\"searchScreenName.emit($event)\"\n (loadMoreScreenNames)=\"loadMoreScreenNames.emit($event)\"\n (createScreenNameRequest)=\"createScreenNameRequest.emit($event)\"\n (elementFormVisibilityChange)=\"onElementFormVisibilityChange($event)\">\n </cqa-template-variables-form>\n </div>\n\n <!-- Advanced (Expandable) -->\n <!-- <div class=\"cqa-flex cqa-flex-col cqa-w-full\">\n <button type=\"button\"\n class=\"cqa-flex cqa-w-full cqa-items-center cqa-justify-between cqa-gap-2 cqa-text-sm cqa-font-medium cqa-text-gray-700 cqa-bg-transparent cqa-border-none cqa-cursor-pointer cqa-p-0 cqa-mb-1.5\"\n (click)=\"toggleAdvanced()\">\n <span class=\"cqa-text-[10px]\">Advanced</span>\n <mat-icon class=\"cqa-text-base\" [class.cqa-rotate-180]=\"advancedExpanded\">\n expand_more\n </mat-icon>\n </button>\n <div *ngIf=\"advancedExpanded\" class=\"cqa-mt-2\">\n </div>\n </div> -->\n <div>\n \n </div>\n </div>\n\n\n </div>\n\n <!-- Action Buttons -->\n <div *ngIf=\"!isElementFormVisible\" class=\"cqa-flex cqa-w-full cqa-gap-2 cqa-border-t cqa-border-gray-200 cqa-pb-2\">\n <cqa-button class=\"cqa-w-1/2\" variant=\"outlined\" text=\"Cancel\" [customClass]=\"'cqa-flex-1 cqa-w-full'\"\n (clicked)=\"onCancel()\">\n </cqa-button>\n <cqa-button class=\"cqa-w-1/2\" variant=\"filled\" text=\"Create Step\" [customClass]=\"'cqa-flex-1 cqa-w-full'\"\n [disabled]=\"!isFormValid()\"\n (clicked)=\"onCreateStep()\">\n </cqa-button>\n </div>\n </div>\n</div>", styles: [] }]
269
468
  }], ctorParameters: function () { return [{ type: i1.FormBuilder }]; }, propDecorators: { showHeader: [{
270
469
  type: Input
271
470
  }], templates: [{
@@ -276,11 +475,35 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImpor
276
475
  type: Input
277
476
  }], preventSelectTemplate: [{
278
477
  type: Input
478
+ }], elementOptions: [{
479
+ type: Input
480
+ }], hasMoreElements: [{
481
+ type: Input
482
+ }], isLoadingElements: [{
483
+ type: Input
484
+ }], screenNameOptions: [{
485
+ type: Input
486
+ }], hasMoreScreenNames: [{
487
+ type: Input
488
+ }], isLoadingScreenNames: [{
489
+ type: Input
279
490
  }], templateChanged: [{
280
491
  type: Output
492
+ }], loadMoreElements: [{
493
+ type: Output
494
+ }], searchElements: [{
495
+ type: Output
496
+ }], createElement: [{
497
+ type: Output
498
+ }], searchScreenName: [{
499
+ type: Output
500
+ }], loadMoreScreenNames: [{
501
+ type: Output
502
+ }], createScreenNameRequest: [{
503
+ type: Output
281
504
  }], createStep: [{
282
505
  type: Output
283
506
  }], cancelled: [{
284
507
  type: Output
285
508
  }] } });
286
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"step-builder-action.component.js","sourceRoot":"","sources":["../../../../../../src/lib/step-builder/step-builder-action/step-builder-action.component.ts","../../../../../../src/lib/step-builder/step-builder-action/step-builder-action.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, Output, EventEmitter, OnInit, OnChanges, SimpleChanges, OnDestroy } from '@angular/core';\nimport { FormBuilder, FormGroup, FormControl } from '@angular/forms';\nimport { DynamicSelectFieldConfig, SelectOption } from '../../dynamic-select/dynamic-select-field.component';\nimport { Subscription } from 'rxjs';\n\nexport interface VariableDefinition {\n  path: string;\n  default: string | boolean;\n  mutable: boolean;\n  type?: string;\n  options?: string[];\n}\n\nexport interface ActionTemplate {\n  id?: number;\n  naturalText?: string;\n  displayName?: string;\n  htmlGrammar?: string;\n  searchableGrammar?: string;\n  workspaceType?: string;\n  action?: string;\n  isAddon?: boolean;\n  variables?: Record<string, VariableDefinition>;\n}\n\nexport interface ElementField {\n  key: string;\n  label: string;\n  value: string;\n  type: 'element' | 'test-data' | 'attribute';\n}\n\n@Component({\n  selector: 'cqa-step-builder-action',\n  templateUrl: './step-builder-action.component.html',\n  styleUrls: [],\n  host: { class: 'cqa-ui-root' }\n})\nexport class StepBuilderActionComponent implements OnInit, OnChanges, OnDestroy {\n  @Input() showHeader: boolean = true;\n  /** List of action templates to display */\n  @Input() templates: ActionTemplate[] = [];\n\n  /** Placeholder text for search input */\n  @Input() searchPlaceholder: string = 'Search library';\n\n  /** Function to handle variable processing or custom logic. Can be passed from parent component. */\n  @Input() setTemplateVariables: (variables: ActionTemplate) => any = () => { return []};\n\n  @Input() preventSelectTemplate: string[] = ['databaseverification'];\n  @Output() templateChanged = new EventEmitter<ActionTemplate>();\n  /** Emit when step is created */\n  @Output() createStep = new EventEmitter<any>();\n\n  /** Emit when cancelled */\n  @Output() cancelled = new EventEmitter<void>();\n\n  filteredTemplates: ActionTemplate[] = [];\n  searchValue: string = '';\n  selectedTemplate: ActionTemplate | null = null;\n  metadata: string = '';\n  description: string = '';\n  advancedExpanded: boolean = false;\n  templateVariables: any[] = [];\n  variablesForm: FormGroup;\n  \n  // Cache for select configs to avoid recalculating on every change detection\n  private selectConfigCache: Map<string, DynamicSelectFieldConfig> = new Map();\n  private formValidCache: boolean = false;\n  private lastFormValidationTime: number = 0;\n  private readonly FORM_VALIDATION_CACHE_MS = 100; // Cache for 100ms\n  private formValueChangesSubscription?: Subscription;\n\n  constructor(private fb: FormBuilder) {\n    this.variablesForm = this.fb.group({});\n  }\n\n  ngOnInit(): void {\n    this.filteredTemplates = [...this.templates];\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes['templates']) {\n      this.applyFilter();\n    }\n  }\n\n  onSearchChange(value: string): void {\n    this.searchValue = value;\n    this.applyFilter();\n  }\n\n  onSearchSubmit(value: string): void {\n    this.searchValue = value;\n    this.applyFilter();\n  }\n\n  onSearchCleared(): void {\n    this.searchValue = '';\n    this.applyFilter();\n  }\n\n  applyFilter(): void {\n    if (!this.searchValue || this.searchValue.trim() === '') {\n      this.filteredTemplates = [...this.templates];\n      return;\n    }\n\n    const searchTerm = this.searchValue.toLowerCase().trim();\n    this.filteredTemplates = this.templates.filter(template => {\n      const naturalText = template.naturalText?.toLowerCase() || '';\n      const displayName = template.displayName?.toLowerCase() || '';\n      const searchableGrammar = template.searchableGrammar?.toLowerCase() || '';\n      \n      return naturalText.includes(searchTerm) || \n             displayName.includes(searchTerm) || \n             searchableGrammar.includes(searchTerm);\n    });\n    console.log(\"filteredTemplates\", this.filteredTemplates);\n  }\n\n  selectTemplate(template: ActionTemplate): void {\n    if(this.preventSelectTemplate.includes(template.displayName || '')) {\n      this.templateChanged.emit(template);\n      return;\n    }\n    this.templateChanged.emit(template);\n    this.selectedTemplate = template;\n    \n    // Clear cache when template changes\n    this.selectConfigCache.clear();\n    this.formValidCache = false;\n    \n    if(this.setTemplateVariables && template.variables) {\n      // Use setTimeout to defer heavy operations and prevent UI freezing\n      // This allows the UI to update first, then process the template variables\n      setTimeout(() => {\n        try {\n          this.templateVariables = this.setTemplateVariables(template);\n          this.buildVariablesForm();\n        } catch (error) {\n          console.error('Error processing template variables:', error);\n        }\n      }, 0);\n    }\n  }\n\n  private buildVariablesForm(): void {\n    // Clear existing form controls\n    const controlKeys = Object.keys(this.variablesForm.controls);\n    controlKeys.forEach(key => {\n      this.variablesForm.removeControl(key);\n    });\n\n    // Clear cache when form is rebuilt\n    this.selectConfigCache.clear();\n    this.formValidCache = false;\n\n    // Unsubscribe from previous subscription if it exists\n    if (this.formValueChangesSubscription) {\n      this.formValueChangesSubscription.unsubscribe();\n    }\n\n    // Add form controls for each variable\n    this.templateVariables.forEach(variable => {\n      // Handle boolean variables - use boolean value, others use string\n      const defaultValue = variable.type === 'boolean' \n        ? (variable.value === true || variable.value === 'true' || variable.value === 1)\n        : (variable.value || '');\n      this.variablesForm.addControl(variable.name, new FormControl(defaultValue));\n    });\n    \n    // Subscribe to form value changes to invalidate cache (only when user actually changes values)\n    // Note: We use emitEvent: false when programmatically setting values, so this won't fire unnecessarily\n    this.formValueChangesSubscription = this.variablesForm.valueChanges.subscribe(() => {\n      this.formValidCache = false;\n    });\n  }\n  \n  ngOnDestroy(): void {\n    // Clean up subscription to prevent memory leaks\n    if (this.formValueChangesSubscription) {\n      this.formValueChangesSubscription.unsubscribe();\n    }\n  }\n\n  getSelectConfig(variable: any): 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    // 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    }\n    // Invalidate form validation cache\n    this.formValidCache = false;\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    // Invalidate form validation cache\n    this.formValidCache = false;\n  }\n\n  onBack(): void {\n    this.selectedTemplate = null;\n    this.metadata = '';\n    this.description = '';\n    this.advancedExpanded = false;\n    this.templateVariables = [];\n    // Clear form controls\n    Object.keys(this.variablesForm.controls).forEach(key => {\n      this.variablesForm.removeControl(key);\n    });\n    // Reapply filter to maintain search state\n    this.applyFilter();\n  }\n\n  onCancel(): void {\n    this.onBack();\n    this.cancelled.emit();\n  }\n\n  isFormValid(): boolean {\n    if (!this.selectedTemplate) {\n      return false;\n    }\n    \n    // Use cached result if available and recent\n    const now = Date.now();\n    if (this.formValidCache && (now - this.lastFormValidationTime) < this.FORM_VALIDATION_CACHE_MS) {\n      return this.formValidCache;\n    }\n    \n    // Check if all required variables are filled\n    let isValid = true;\n    if (this.templateVariables && this.templateVariables.length > 0) {\n      isValid = this.templateVariables.every(variable => {\n        // Boolean variables are always valid (they have a default value)\n        if (variable.type === 'boolean') {\n          return true;\n        }\n        // Check if variable has a value\n        const value = variable.value;\n        return value !== null && value !== undefined && value !== '';\n      });\n    }\n    \n    // Cache the result\n    this.formValidCache = isValid;\n    this.lastFormValidationTime = now;\n    return isValid;\n  }\n  \n  trackByTemplate(index: number, template: ActionTemplate): any {\n    return template.id || template.displayName || index;\n  }\n  \n  trackByVariable(index: number, variable: any): any {\n    return variable.name || index;\n  }\n\n  onCreateStep(): void {\n    if (!this.isFormValid()) {\n      return;\n    }\n    const stepData = {\n      template: this.selectedTemplate,\n      metadata: this.metadata,\n      description: this.description,\n      templateVariables: this.templateVariables\n    };\n    this.createStep.emit(stepData);\n  }\n\n  toggleAdvanced(): void {\n    this.advancedExpanded = !this.advancedExpanded;\n  }\n\n\n  onElementClick(elementKey: string): void {\n    // Focus on the corresponding input field\n    // This can be enhanced to scroll to or highlight the field\n  }\n\n  onElementValueChange(key: string, value: string): void {\n    console.log(key, value);\n  }\n\n  onTestDataValueChange(key: string, value: string): void {\n    console.log(key, value);\n  }\n}\n\n","<div class=\"cqa-flex cqa-flex-col cqa-h-full cqa-bg-white\" [ngClass]=\"{'cqa-px-4 cqa-py-2': showHeader}\">\n  <!-- Header -->\n  <h2 *ngIf=\"showHeader\" class=\"cqa-text-[12px] cqa-font-semibold cqa-text-black-100 cqa-mb-1\">\n    Create an action step\n  </h2>\n  <div *ngIf=\"!selectedTemplate\" class=\"cqa-flex cqa-flex-col cqa-h-full cqa-flex-1\"\n    [ngClass]=\"{'cqa-px-3': showHeader}\">\n\n    <!-- Search Bar -->\n    <div class=\"cqa-pb-1\">\n      <div class=\"cqa-pb-1\" *ngIf=\"showHeader\">\n        <p class=\"cqa-text-[12px] cqa-text-gray-500\">\n          Template library\n        </p>\n      </div>\n      <cqa-search-bar [placeholder]=\"searchPlaceholder\" [fullWidth]=\"true\" [value]=\"searchValue\"\n        (valueChange)=\"onSearchChange($event)\" (search)=\"onSearchSubmit($event)\" (cleared)=\"onSearchCleared()\">\n      </cqa-search-bar>\n    </div>\n\n    <!-- Template List -->\n    <div class=\"cqa-flex-1 cqa-overflow-y-auto cqa-px-2\">\n      <div class=\"cqa-py-2\">\n        <div *ngFor=\"let template of filteredTemplates; trackBy: trackByTemplate\"\n          class=\"cqa-action-format cqa-bg-white cqa-cursor-pointer cqa-transition-all hover:cqa-border-blue-500 hover:cqa-shadow-sm mb-6\"\n          (click)=\"selectTemplate(template)\">\n          <div class=\"cqa-text-[12px] cqa-leading-[23px] cqa-text-black-100\"\n            [innerHTML]=\"template.htmlGrammar || template.naturalText || ''\">\n          </div>\n        </div>\n\n        <div *ngIf=\"filteredTemplates.length === 0\" class=\"cqa-text-center cqa-py-8 cqa-text-gray-400 cqa-text-[12px]\">\n          No templates found\n        </div>\n      </div>\n    </div>\n  </div>\n\n  <div *ngIf=\"selectedTemplate\" class=\"cqa-flex cqa-flex-col cqa-h-full\">\n    <!-- Instruction Text with Element Buttons -->\n    <div class=\"cqa-mb-4 cqa-flex cqa-items-center cqa-flex-wrap cqa-gap-1 cqa-text-sm cqa-text-gray-700\">\n      <div class=\"cqa-action-format cqa-text-[12px] cqa-leading-[23px] cqa-text-black-100\"\n        [innerHTML]=\"selectedTemplate.htmlGrammar || selectedTemplate.naturalText || ''\">\n      </div>\n    </div>\n\n    <!-- Form Fields in Two Columns -->\n    <div class=\"cqa-flex cqa-overflow-y-auto\">\n      <div class=\"cqa-flex-1 cqa-flex cqa-flex-col cqa-gap-1\">\n        <div class=\"cqa-flex cqa-gap-x-6 cqa-flex-wrap\">\n          <!-- Template Variables Form Component -->\n          <cqa-template-variables-form\n            [templateVariables]=\"templateVariables\"\n            [variablesForm]=\"variablesForm\"\n            [metadata]=\"metadata\"\n            [description]=\"description\"\n            (variableValueChange)=\"onVariableValueChange($event.name, $event.value)\"\n            (variableBooleanChange)=\"onVariableBooleanChange($event.name, $event.value)\"\n            (metadataChange)=\"metadata = $event\"\n            (descriptionChange)=\"description = $event\">\n          </cqa-template-variables-form>\n        </div>\n\n        <!-- Advanced (Expandable) -->\n        <div class=\"cqa-flex cqa-flex-col cqa-w-full\">\n          <button type=\"button\"\n            class=\"cqa-flex cqa-w-full cqa-items-center cqa-justify-between  cqa-gap-2 cqa-text-sm cqa-font-medium cqa-text-gray-700 cqa-bg-transparent cqa-border-none cqa-cursor-pointer cqa-p-0 cqa-mb-1.5\"\n            (click)=\"toggleAdvanced()\">\n            <span class=\"cqa-text-[10px]\">Advanced</span>\n            <mat-icon class=\"cqa-text-base\" [class.cqa-rotate-180]=\"advancedExpanded\">\n              expand_more\n            </mat-icon>\n          </button>\n          <div *ngIf=\"advancedExpanded\" class=\"cqa-mt-2\">\n            <!-- Advanced fields can be added here -->\n          </div>\n        </div>\n      </div>\n\n\n    </div>\n\n    <!-- Action Buttons -->\n    <div class=\"cqa-flex cqa-w-full cqa-gap-2 cqa-border-t cqa-border-gray-200\">\n      <cqa-button class=\"cqa-w-1/2\" variant=\"outlined\" text=\"Cancel\" [customClass]=\"'cqa-flex-1 cqa-w-full'\"\n        (clicked)=\"onCancel()\">\n      </cqa-button>\n      <cqa-button class=\"cqa-w-1/2\" variant=\"filled\" text=\"Create Step\" [customClass]=\"'cqa-flex-1 cqa-w-full'\"\n        [disabled]=\"!isFormValid()\"\n        (clicked)=\"onCreateStep()\">\n      </cqa-button>\n    </div>\n  </div>\n</div>"]}
509
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"step-builder-action.component.js","sourceRoot":"","sources":["../../../../../../src/lib/step-builder/step-builder-action/step-builder-action.component.ts","../../../../../../src/lib/step-builder/step-builder-action/step-builder-action.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, Output, EventEmitter, OnInit, OnChanges, SimpleChanges, OnDestroy, ViewChild } from '@angular/core';\nimport { FormBuilder, FormGroup, FormControl, FormArray } from '@angular/forms';\nimport { DynamicSelectFieldConfig, SelectOption } from '../../dynamic-select/dynamic-select-field.component';\nimport { Subscription } from 'rxjs';\nimport { TemplateVariablesFormComponent } from '../template-variables-form/template-variables-form.component';\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 VariableDefinition {\n  path: string;\n  default: string | boolean;\n  mutable: boolean;\n  type?: string;\n  options?: string[];\n}\n\nexport interface ActionTemplate {\n  id?: number;\n  naturalText?: string;\n  displayName?: string;\n  htmlGrammar?: string;\n  searchableGrammar?: string;\n  workspaceType?: string;\n  action?: string;\n  isAddon?: boolean;\n  variables?: Record<string, VariableDefinition>;\n}\n\nexport interface ElementField {\n  key: string;\n  label: string;\n  value: string;\n  type: 'element' | 'test-data' | 'attribute';\n}\n\n@Component({\n  selector: 'cqa-step-builder-action',\n  templateUrl: './step-builder-action.component.html',\n  styleUrls: [],\n  host: { class: 'cqa-ui-root', style: 'display: block;height: 100%;width: 100%;' }\n})\nexport class StepBuilderActionComponent implements OnInit, OnChanges, OnDestroy {\n  @Input() showHeader: boolean = true;\n  /** List of action templates to display */\n  @Input() templates: ActionTemplate[] = [];\n\n  /** Placeholder text for search input */\n  @Input() searchPlaceholder: string = 'Search library';\n\n  /** Function to handle variable processing or custom logic. Can be passed from parent component. */\n  @Input() setTemplateVariables: (variables: ActionTemplate) => any = () => { return []};\n\n  @Input() preventSelectTemplate: string[] = ['databaseverification'];\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: { id?: number; name: string }[] = [];\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  @Output() templateChanged = new EventEmitter<ActionTemplate>();\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<any>(); // Emit when element is created\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  /** Emit when step is created */\n  @Output() createStep = new EventEmitter<any>();\n\n  /** Emit when cancelled */\n  @Output() cancelled = new EventEmitter<void>();\n\n  filteredTemplates: ActionTemplate[] = [];\n  searchValue: string = '';\n  selectedTemplate: ActionTemplate | null = null;\n  metadata: string = '';\n  description: string = '';\n  advancedExpanded: boolean = false;\n  templateVariables: any[] = [];\n  variablesForm: FormArray;\n  updatedHtmlGrammar: string = ''; // Updated HTML grammar with variable values\n  \n  // Track element form visibility\n  isElementFormVisible: boolean = false;\n  \n  // Cache for select configs to avoid recalculating on every change detection\n  private selectConfigCache: Map<string, DynamicSelectFieldConfig> = new Map();\n  private formValidCache: boolean = false;\n  private lastFormValidationTime: number = 0;\n  private readonly FORM_VALIDATION_CACHE_MS = 100; // Cache for 100ms\n  private formValueChangesSubscription?: Subscription;\n\n  constructor(private fb: FormBuilder) {\n    this.variablesForm = this.fb.array([]);\n  }\n\n  /**\n   * Handle element form visibility change\n   */\n  onElementFormVisibilityChange(visible: boolean): void {\n    this.isElementFormVisible = visible;\n  }\n\n  ngOnInit(): void {\n    this.filteredTemplates = [...this.templates];\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes['templates']) {\n      this.applyFilter();\n    }\n  }\n\n  onSearchChange(value: string): void {\n    this.searchValue = value;\n    this.applyFilter();\n  }\n\n  onSearchSubmit(value: string): void {\n    this.searchValue = value;\n    this.applyFilter();\n  }\n\n  onSearchCleared(): void {\n    this.searchValue = '';\n    this.applyFilter();\n  }\n\n  applyFilter(): void {\n    if (!this.searchValue || this.searchValue.trim() === '') {\n      this.filteredTemplates = [...this.templates];\n      return;\n    }\n\n    const searchTerm = this.searchValue.toLowerCase().trim();\n    this.filteredTemplates = this.templates.filter(template => {\n      const naturalText = template.naturalText?.toLowerCase() || '';\n      // Strip HTML tags from htmlGrammar for searching (only search text content, not HTML markup)\n      const htmlGrammarText = this.stripHtmlTags(template.htmlGrammar || '').toLowerCase();\n      const searchableGrammar = template.searchableGrammar?.toLowerCase() || '';\n      \n      return naturalText.includes(searchTerm) || \n              htmlGrammarText.includes(searchTerm) || \n             searchableGrammar.includes(searchTerm);\n    });\n    console.log(\"filteredTemplates\", this.filteredTemplates);\n  }\n\n  /**\n   * Strip HTML tags from a string, returning only the text content\n   * @param htmlString - HTML string to strip tags from\n   * @returns Plain text without HTML tags\n   */\n  private stripHtmlTags(htmlString: string): string {\n    if (!htmlString) return '';\n    \n    // Use browser's DOMParser if available\n    if (typeof document !== 'undefined' && document.createElement) {\n      try {\n        const tempDiv = document.createElement('div');\n        tempDiv.innerHTML = htmlString;\n        return tempDiv.textContent || tempDiv.innerText || '';\n      } catch (error) {\n        // Fallback to regex if DOM parsing fails\n        return htmlString.replace(/<[^>]*>/g, '');\n      }\n    }\n    \n    // Fallback: regex-based tag removal for server-side rendering\n    return htmlString.replace(/<[^>]*>/g, '');\n  }\n\n  selectTemplate(template: ActionTemplate): void {\n    if(this.preventSelectTemplate.includes(template.displayName || '')) {\n      this.templateChanged.emit(template);\n      return;\n    }\n    this.templateChanged.emit(template);\n    this.selectedTemplate = template;\n    \n    // Clear cache when template changes\n    this.selectConfigCache.clear();\n    this.formValidCache = false;\n    \n    if(this.setTemplateVariables && template.variables) {\n      // Use setTimeout to defer heavy operations and prevent UI freezing\n      // This allows the UI to update first, then process the template variables\n      setTimeout(() => {\n        try {\n          this.templateVariables = this.setTemplateVariables(template);\n          console.log(\"templateVariables\", this.templateVariables);\n          \n          this.buildVariablesForm();\n          // Initialize updated HTML grammar\n          this.updateHtmlGrammar();\n        } catch (error) {\n          console.error('Error processing template variables:', error);\n        }\n      }, 0);\n    } else {\n      // Initialize with template's HTML grammar if no variables\n      this.updatedHtmlGrammar = template.htmlGrammar || template.naturalText || '';\n    }\n  }\n\n  private buildVariablesForm(): void {\n    // Clear existing form array\n    while (this.variablesForm.length !== 0) {\n      this.variablesForm.removeAt(0);\n    }\n\n    // Clear cache when form is rebuilt\n    this.selectConfigCache.clear();\n    this.formValidCache = false;\n\n    // Unsubscribe from previous subscription if it exists\n    if (this.formValueChangesSubscription) {\n      this.formValueChangesSubscription.unsubscribe();\n    }\n\n    // Add form groups for each variable\n    this.templateVariables.forEach(variable => {\n      // Handle boolean variables - use boolean value, others use string\n      const defaultValue = variable.type === 'boolean' \n        ? (variable.value === true || variable.value === 'true' || variable.value === 1)\n        : (variable.value || '');\n      \n      // Create a FormGroup for each variable with name and value\n      const variableGroup = this.fb.group({\n        name: [variable.name],\n        value: [defaultValue],\n        type: [variable.type || 'string'],\n        label: [variable.label || ''],\n        options: [variable.options || []]\n      });\n      \n      // Add dataType control for test-data variables if needed\n      const label = variable.label?.toLowerCase() || '';\n      if (label === 'test-data' || label === 'source-value' || label === 'target-value' || \n          label === 'source_value' || label === 'target_value') {\n        // Parse the value to determine data type\n        const valueStr = String(defaultValue || '');\n        let dataType = 'plain-text';\n        if (valueStr.startsWith('@|') && valueStr.endsWith('|')) {\n          dataType = 'parameter';\n        } else if (valueStr.startsWith('$|') && valueStr.endsWith('|')) {\n          dataType = 'runtime';\n        } else if (valueStr.startsWith('*|') && valueStr.endsWith('|')) {\n          dataType = 'environment';\n        }\n        variableGroup.addControl('dataType', new FormControl(dataType));\n      }\n      \n      this.variablesForm.push(variableGroup);\n    });\n    \n    // Subscribe to form value changes to invalidate cache (only when user actually changes values)\n    // Note: We use emitEvent: false when programmatically setting values, so this won't fire unnecessarily\n    this.formValueChangesSubscription = this.variablesForm.valueChanges.subscribe(() => {\n      this.formValidCache = false;\n    });\n  }\n  \n  ngOnDestroy(): void {\n    // Clean up subscription to prevent memory leaks\n    if (this.formValueChangesSubscription) {\n      this.formValueChangesSubscription.unsubscribe();\n    }\n  }\n\n  getSelectConfig(variable: any, index: number): 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: `value`, // Use 'value' as key since we're accessing from FormArray\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  /** Get form group for a variable by name */\n  getVariableFormGroup(variableName: string): FormGroup | null {\n    const variableIndex = this.variablesForm.controls.findIndex(\n      control => control.get('name')?.value === variableName\n    );\n    if (variableIndex !== -1) {\n      return this.variablesForm.at(variableIndex) as FormGroup;\n    }\n    return null;\n  }\n  \n  /** Add a new variable to the form array dynamically */\n  addVariable(variable: any): void {\n    const defaultValue = variable.type === 'boolean' \n      ? (variable.value === true || variable.value === 'true' || variable.value === 1)\n      : (variable.value || '');\n    \n    const variableGroup = this.fb.group({\n      name: [variable.name],\n      value: [defaultValue],\n      type: [variable.type || 'string'],\n      label: [variable.label || ''],\n      options: [variable.options || []]\n    });\n    \n    // Add dataType control for test-data variables if needed\n    const label = variable.label?.toLowerCase() || '';\n    if (label === 'test-data' || label === 'source-value' || label === 'target-value' || \n        label === 'source_value' || label === 'target_value') {\n      const valueStr = String(defaultValue || '');\n      let dataType = 'plain-text';\n      if (valueStr.startsWith('@|') && valueStr.endsWith('|')) {\n        dataType = 'parameter';\n      } else if (valueStr.startsWith('$|') && valueStr.endsWith('|')) {\n        dataType = 'runtime';\n      } else if (valueStr.startsWith('*|') && valueStr.endsWith('|')) {\n        dataType = 'environment';\n      }\n      variableGroup.addControl('dataType', new FormControl(dataType));\n    }\n    \n    this.variablesForm.push(variableGroup);\n    this.formValidCache = false;\n  }\n\n  onVariableValueChange(variableName: string, value: any): void {\n    console.log(\"onVariableValueChange\", variableName, value);\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 array (use emitEvent: false to prevent triggering valueChanges)\n    const variableIndex = this.variablesForm.controls.findIndex(\n      control => control.get('name')?.value === variableName\n    );\n    if (variableIndex !== -1) {\n      this.variablesForm.at(variableIndex).get('value')?.setValue(value, { emitEvent: false });\n    }\n    // Invalidate form validation cache\n    this.formValidCache = false;\n    // Update HTML grammar with new value\n    this.updateHtmlGrammar();\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 array (use emitEvent: false to prevent triggering valueChanges)\n    const variableIndex = this.variablesForm.controls.findIndex(\n      control => control.get('name')?.value === variableName\n    );\n    if (variableIndex !== -1) {\n      this.variablesForm.at(variableIndex).get('value')?.setValue(value, { emitEvent: false });\n    } else {\n      // Create new form group if it doesn't exist\n      const variableGroup = this.fb.group({\n        name: [variableName],\n        value: [value],\n        type: ['boolean'],\n        label: [variable?.label || ''],\n        options: [variable?.options || []]\n      });\n      this.variablesForm.push(variableGroup);\n    }\n    // Invalidate form validation cache\n    this.formValidCache = false;\n    // Update HTML grammar with new value\n    this.updateHtmlGrammar();\n  }\n\n  onBack(): void {\n    this.selectedTemplate = null;\n    this.metadata = '';\n    this.description = '';\n    this.advancedExpanded = false;\n    this.templateVariables = [];\n    this.updatedHtmlGrammar = '';\n    // Clear form array\n    while (this.variablesForm.length !== 0) {\n      this.variablesForm.removeAt(0);\n    }\n    // Reapply filter to maintain search state\n    this.applyFilter();\n  }\n\n  onCancel(): void {\n    this.onBack();\n    this.cancelled.emit();\n  }\n\n  isFormValid(): boolean {\n    if (!this.selectedTemplate) {\n      return false;\n    }\n    \n    // Use cached result if available and recent\n    const now = Date.now();\n    if (this.formValidCache && (now - this.lastFormValidationTime) < this.FORM_VALIDATION_CACHE_MS) {\n      return this.formValidCache;\n    }\n    \n    // Check if all required variables are filled\n    // let isValid = true;\n    // if (this.templateVariables && this.templateVariables.length > 0) {\n    //   isValid = this.templateVariables.every(variable => {\n    //     // Boolean variables are always valid (they have a default value)\n    //     if (variable.type === 'boolean') {\n    //       return true;\n    //     }\n    //     // Check if variable has a value\n    //     const value = variable.value;\n    //     return value !== null && value !== undefined && value !== '';\n    //   });\n    // }\n    \n    // Cache the result\n    this.formValidCache = this.variablesForm.valid; \n    this.lastFormValidationTime = now;\n    return this.variablesForm.valid;\n  }\n  \n  trackByTemplate(index: number, template: ActionTemplate): any {\n    return template.id || template.displayName || index;\n  }\n  \n  trackByVariable(index: number, variable: any): any {\n    return variable.name || index;\n  }\n\n  onCreateStep(): void {\n    if (!this.isFormValid()) {\n      return;\n    }\n    const stepData = {\n      template: this.selectedTemplate,\n      metadata: this.metadata,\n      description: this.description,\n      templateVariables: this.templateVariables\n    };\n    console.log(\"stepData\", stepData);\n    console.log(\"variablesForm\", this.variablesForm.value);\n    this.createStep.emit(stepData);\n  }\n\n  toggleAdvanced(): void {\n    this.advancedExpanded = !this.advancedExpanded;\n  }\n\n\n  onElementClick(elementKey: string): void {\n    // Focus on the corresponding input field\n    // This can be enhanced to scroll to or highlight the field\n  }\n\n  onElementValueChange(key: string, value: string): void {\n    console.log(key, value);\n  }\n\n  onTestDataValueChange(key: string, value: string): void {\n    console.log(key, value);\n  }\n\n  /**\n   * Update HTML grammar by replacing placeholder spans with actual variable values\n   */\n  private updateHtmlGrammar(): void {\n    if (!this.selectedTemplate) {\n      this.updatedHtmlGrammar = '';\n      return;\n    }\n\n    const htmlGrammar = this.selectedTemplate.htmlGrammar || this.selectedTemplate.naturalText || '';\n    if (!htmlGrammar) {\n      this.updatedHtmlGrammar = '';\n      return;\n    }\n\n    // Create a map of variable values by name for quick lookup\n    const valueMap = new Map<string, string>();\n    if (this.templateVariables && Array.isArray(this.templateVariables)) {\n      this.templateVariables.forEach((variable: any) => {\n        if (variable.name && variable.value !== undefined && variable.value !== null) {\n          // Convert value to string, handling boolean values\n          const valueStr = typeof variable.value === 'boolean' \n            ? (variable.value ? 'true' : 'false')\n            : String(variable.value || '');\n          valueMap.set(variable.name, valueStr);\n        }\n      });\n    }\n\n    // Use browser's DOMParser if available, otherwise fallback to string replacement\n    if (typeof document !== 'undefined' && document.createElement) {\n      try {\n        const tempDiv = document.createElement('div');\n        tempDiv.innerHTML = String(htmlGrammar);\n\n        // Find all spans with data-event-key attribute\n        const spans = tempDiv.querySelectorAll<HTMLElement>('span[data-event-key]');\n        spans.forEach((span: HTMLElement) => {\n          const eventKey = span.getAttribute('data-event-key');\n          if (eventKey && valueMap.has(eventKey)) {\n            const value = valueMap.get(eventKey);\n            // Preserve the span structure but update the content\n            span.innerHTML = value || '';\n          }\n        });\n\n        this.updatedHtmlGrammar = tempDiv.innerHTML;\n      } catch (error) {\n        console.error('Error updating HTML grammar:', error);\n        // Fallback to original HTML grammar\n        this.updatedHtmlGrammar = String(htmlGrammar);\n      }\n    } else {\n      // Fallback: simple string replacement for server-side rendering\n      let updatedHtml = String(htmlGrammar);\n      valueMap.forEach((value, key) => {\n        // Replace spans with data-event-key matching the variable name\n        const regex = new RegExp(`<span[^>]*data-event-key=\"${key}\"[^>]*>.*?</span>`, 'gi');\n        updatedHtml = updatedHtml.replace(regex, (match) => {\n          // Replace the content inside the span\n          return match.replace(/>.*?</, `>${value}<`);\n        });\n      });\n      this.updatedHtmlGrammar = updatedHtml;\n    }\n  }\n}\n\n","<div class=\"cqa-flex cqa-flex-col cqa-h-full cqa-bg-white\" [ngClass]=\"{'cqa-px-4': showHeader, 'cqa-py-2': showHeader && !selectedTemplate}\">\n  <!-- Header -->\n  <h2 *ngIf=\"showHeader\" class=\"cqa-text-[12px] cqa-font-semibold cqa-text-black-100 cqa-mb-1\">\n    Create an action step\n  </h2>\n  <div *ngIf=\"!selectedTemplate\" class=\"cqa-flex cqa-flex-col cqa-h-full cqa-flex-1\"\n    [ngClass]=\"{'cqa-px-3': showHeader}\">\n\n    <!-- Search Bar -->\n    <div class=\"cqa-pb-1\">\n      <div class=\"cqa-pb-1\" *ngIf=\"showHeader\">\n        <p class=\"cqa-text-[12px] cqa-text-gray-500\">\n          Template library\n        </p>\n      </div>\n      <cqa-search-bar [placeholder]=\"searchPlaceholder\" [fullWidth]=\"true\" [value]=\"searchValue\"\n        (valueChange)=\"onSearchChange($event)\" (search)=\"onSearchSubmit($event)\" (cleared)=\"onSearchCleared()\">\n      </cqa-search-bar>\n    </div>\n\n    <!-- Template List -->\n    <div class=\"cqa-flex-1 cqa-overflow-y-auto cqa-px-2\">\n      <div class=\"cqa-py-2\">\n        <div *ngFor=\"let template of filteredTemplates; trackBy: trackByTemplate\"\n          class=\"cqa-action-format cqa-bg-white cqa-cursor-pointer cqa-transition-all hover:cqa-border-blue-500 hover:cqa-shadow-sm mb-6\"\n          (click)=\"selectTemplate(template)\">\n          <div class=\"cqa-text-[12px] cqa-leading-[23px] cqa-text-black-100\"\n            [innerHTML]=\"template.htmlGrammar || template.naturalText || ''\">\n          </div>\n        </div>\n\n        <div *ngIf=\"filteredTemplates.length === 0\" class=\"cqa-text-center cqa-py-8 cqa-text-gray-400 cqa-text-[12px]\">\n          No templates found\n        </div>\n      </div>\n    </div>\n  </div>\n\n  <div *ngIf=\"selectedTemplate\" class=\"cqa-flex cqa-flex-col cqa-overflow-y-auto\" style=\"flex: 1 1 0 !important;\">\n    <!-- Instruction Text with Element Buttons -->\n    <div class=\"cqa-mb-4 cqa-flex cqa-items-center cqa-flex-wrap cqa-gap-1 cqa-text-sm cqa-text-gray-700\">\n      <div class=\"cqa-action-format cqa-text-[12px] cqa-leading-[23px] cqa-text-black-100\"\n        [innerHTML]=\"updatedHtmlGrammar || selectedTemplate.htmlGrammar || selectedTemplate.naturalText || ''\">\n      </div>\n    </div>\n\n    <!-- Form Fields in Two Columns -->\n    <div class=\"cqa-flex cqa-overflow-y-auto cqa-flex-1 cqa-pb-2\">\n      <div class=\"cqa-flex-1 cqa-flex cqa-flex-col cqa-gap-1\">\n        <div class=\"cqa-flex cqa-gap-x-6 cqa-flex-wrap cqa-pb-4\">\n          <!-- Template Variables Form Component -->\n          <cqa-template-variables-form\n            style=\"width: 100%;\"\n            [templateVariables]=\"templateVariables\"\n            [variablesForm]=\"variablesForm\"\n            [metadata]=\"metadata\"\n            [description]=\"description\"\n            [elementOptions]=\"elementOptions\"\n            [hasMoreElements]=\"hasMoreElements\"\n            [isLoadingElements]=\"isLoadingElements\"\n            [screenNameOptions]=\"screenNameOptions\"\n            [hasMoreScreenNames]=\"hasMoreScreenNames\"\n            [isLoadingScreenNames]=\"isLoadingScreenNames\"\n            (variableValueChange)=\"onVariableValueChange($event.name, $event.value)\"\n            (variableBooleanChange)=\"onVariableBooleanChange($event.name, $event.value)\"\n            (metadataChange)=\"metadata = $event\"\n            (descriptionChange)=\"description = $event\"\n            (loadMoreElements)=\"loadMoreElements.emit()\"\n            (searchElements)=\"searchElements.emit($event)\"\n            (createElement)=\"createElement.emit($event)\"\n            (searchScreenName)=\"searchScreenName.emit($event)\"\n            (loadMoreScreenNames)=\"loadMoreScreenNames.emit($event)\"\n            (createScreenNameRequest)=\"createScreenNameRequest.emit($event)\"\n            (elementFormVisibilityChange)=\"onElementFormVisibilityChange($event)\">\n          </cqa-template-variables-form>\n        </div>\n\n        <!-- Advanced (Expandable) -->\n        <!-- <div class=\"cqa-flex cqa-flex-col cqa-w-full\">\n          <button type=\"button\"\n            class=\"cqa-flex cqa-w-full cqa-items-center cqa-justify-between  cqa-gap-2 cqa-text-sm cqa-font-medium cqa-text-gray-700 cqa-bg-transparent cqa-border-none cqa-cursor-pointer cqa-p-0 cqa-mb-1.5\"\n            (click)=\"toggleAdvanced()\">\n            <span class=\"cqa-text-[10px]\">Advanced</span>\n            <mat-icon class=\"cqa-text-base\" [class.cqa-rotate-180]=\"advancedExpanded\">\n              expand_more\n            </mat-icon>\n          </button>\n          <div *ngIf=\"advancedExpanded\" class=\"cqa-mt-2\">\n          </div>\n        </div> -->\n        <div>\n          \n        </div>\n      </div>\n\n\n    </div>\n\n    <!-- Action Buttons -->\n    <div *ngIf=\"!isElementFormVisible\" class=\"cqa-flex cqa-w-full cqa-gap-2 cqa-border-t cqa-border-gray-200 cqa-pb-2\">\n      <cqa-button class=\"cqa-w-1/2\" variant=\"outlined\" text=\"Cancel\" [customClass]=\"'cqa-flex-1 cqa-w-full'\"\n        (clicked)=\"onCancel()\">\n      </cqa-button>\n      <cqa-button class=\"cqa-w-1/2\" variant=\"filled\" text=\"Create Step\" [customClass]=\"'cqa-flex-1 cqa-w-full'\"\n        [disabled]=\"!isFormValid()\"\n        (clicked)=\"onCreateStep()\">\n      </cqa-button>\n    </div>\n  </div>\n</div>"]}