@cqa-lib/cqa-ui 1.1.167 → 1.1.169
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2020/lib/step-builder/step-builder-action/step-builder-action.component.mjs +7 -4
- package/esm2020/lib/step-builder/step-builder-loop/step-builder-loop.component.mjs +391 -0
- package/esm2020/lib/ui-kit.module.mjs +14 -5
- package/esm2020/public-api.mjs +2 -1
- package/fesm2015/cqa-lib-cqa-ui.mjs +384 -8
- package/fesm2015/cqa-lib-cqa-ui.mjs.map +1 -1
- package/fesm2020/cqa-lib-cqa-ui.mjs +401 -8
- package/fesm2020/cqa-lib-cqa-ui.mjs.map +1 -1
- package/lib/step-builder/step-builder-action/step-builder-action.component.d.ts +2 -1
- package/lib/step-builder/step-builder-loop/step-builder-loop.component.d.ts +114 -0
- package/lib/ui-kit.module.d.ts +21 -19
- package/package.json +1 -1
- package/public-api.d.ts +1 -0
|
@@ -0,0 +1,391 @@
|
|
|
1
|
+
import { Component, Input, Output, EventEmitter } from '@angular/core';
|
|
2
|
+
import { FormGroup, FormControl } from '@angular/forms';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "../../segment-control/segment-control.component";
|
|
5
|
+
import * as i2 from "../../dynamic-select/dynamic-select-field.component";
|
|
6
|
+
import * as i3 from "../../custom-input/custom-input.component";
|
|
7
|
+
import * as i4 from "../step-builder-action/step-builder-action.component";
|
|
8
|
+
import * as i5 from "../../button/button.component";
|
|
9
|
+
import * as i6 from "@angular/common";
|
|
10
|
+
export class StepBuilderLoopComponent {
|
|
11
|
+
constructor() {
|
|
12
|
+
/** Currently selected loop type */
|
|
13
|
+
this.loopType = 'for';
|
|
14
|
+
/** Options for the select option dropdown */
|
|
15
|
+
this.selectOptions = [
|
|
16
|
+
{ value: 'dataProfile', label: 'Data Profile' },
|
|
17
|
+
{ value: 'runTime', label: 'Run Time' }
|
|
18
|
+
];
|
|
19
|
+
/** Options for the data profile dropdown - accepts DataProfileOption objects */
|
|
20
|
+
this.dataProfileOptions = [];
|
|
21
|
+
/** Indicates if more data profiles are available for loading */
|
|
22
|
+
this.hasMoreDataProfiles = false;
|
|
23
|
+
/** Loading state for data profiles */
|
|
24
|
+
this.isLoadingDataProfiles = false;
|
|
25
|
+
/** Function to handle variable processing or custom logic. Can be passed from parent component. */
|
|
26
|
+
this.setWhileTemplateVariables = () => { return []; };
|
|
27
|
+
/** Emit when step is created */
|
|
28
|
+
this.createStep = new EventEmitter();
|
|
29
|
+
/** Emit when cancelled */
|
|
30
|
+
this.cancelled = new EventEmitter();
|
|
31
|
+
/** Emit when loop type changes */
|
|
32
|
+
this.loopTypeChange = new EventEmitter();
|
|
33
|
+
/** Emit when more data profiles need to be loaded */
|
|
34
|
+
this.loadMoreDataProfiles = new EventEmitter();
|
|
35
|
+
/** Emit when data profile search query changes */
|
|
36
|
+
this.searchDataProfiles = new EventEmitter();
|
|
37
|
+
this.whileTemplates = [];
|
|
38
|
+
this.whileSearchPlaceholder = 'Search While';
|
|
39
|
+
this.whileSearchValue = '';
|
|
40
|
+
this.selectedWhileTemplate = null;
|
|
41
|
+
this.selectedLoopType = 'for';
|
|
42
|
+
// Internal state for managing loop indices
|
|
43
|
+
this.selectedDataProfile = null;
|
|
44
|
+
this.startArray = [];
|
|
45
|
+
this.endArray = [];
|
|
46
|
+
// Initialize single FormGroup with all fields
|
|
47
|
+
this.loopForm = new FormGroup({
|
|
48
|
+
selectOption: new FormControl(null),
|
|
49
|
+
dataProfile: new FormControl(null),
|
|
50
|
+
loopStart: new FormControl(null),
|
|
51
|
+
loopEnd: new FormControl(null),
|
|
52
|
+
runTime: new FormControl(null)
|
|
53
|
+
});
|
|
54
|
+
// Initialize configs
|
|
55
|
+
this.selectOptionConfig = {
|
|
56
|
+
key: 'selectOption',
|
|
57
|
+
placeholder: 'select option',
|
|
58
|
+
selectedValue: 'dataProfile',
|
|
59
|
+
multiple: false,
|
|
60
|
+
searchable: false,
|
|
61
|
+
options: this.selectOptions
|
|
62
|
+
};
|
|
63
|
+
this.dataProfileConfig = {
|
|
64
|
+
key: 'dataProfile',
|
|
65
|
+
placeholder: 'data profile',
|
|
66
|
+
multiple: false,
|
|
67
|
+
searchable: true,
|
|
68
|
+
serverSearch: true,
|
|
69
|
+
hasMore: this.hasMoreDataProfiles,
|
|
70
|
+
isLoading: this.isLoadingDataProfiles,
|
|
71
|
+
options: [],
|
|
72
|
+
onChange: (value) => {
|
|
73
|
+
this.onDataProfileChange(value);
|
|
74
|
+
},
|
|
75
|
+
onSearch: (query) => {
|
|
76
|
+
this.onSearchDataProfiles(query);
|
|
77
|
+
},
|
|
78
|
+
onLoadMore: (query) => {
|
|
79
|
+
this.loadMoreDataProfiles.emit(query || '');
|
|
80
|
+
}
|
|
81
|
+
};
|
|
82
|
+
this.loopStartConfig = {
|
|
83
|
+
key: 'loopStart',
|
|
84
|
+
placeholder: 'loop start',
|
|
85
|
+
multiple: false,
|
|
86
|
+
searchable: false,
|
|
87
|
+
options: [],
|
|
88
|
+
onChange: (value) => {
|
|
89
|
+
this.onLoopStartChange(value);
|
|
90
|
+
}
|
|
91
|
+
};
|
|
92
|
+
this.loopEndConfig = {
|
|
93
|
+
key: 'loopEnd',
|
|
94
|
+
placeholder: 'loop end',
|
|
95
|
+
multiple: false,
|
|
96
|
+
searchable: false,
|
|
97
|
+
options: [],
|
|
98
|
+
onChange: (value) => {
|
|
99
|
+
// Handle change if needed
|
|
100
|
+
}
|
|
101
|
+
};
|
|
102
|
+
}
|
|
103
|
+
ngOnInit() {
|
|
104
|
+
this.selectedLoopType = this.loopType;
|
|
105
|
+
this.updateConfigs();
|
|
106
|
+
}
|
|
107
|
+
ngOnChanges(changes) {
|
|
108
|
+
console.log("this.whileTemplates", this.whileTemplates);
|
|
109
|
+
if (changes['selectOptions']) {
|
|
110
|
+
this.updateConfigs();
|
|
111
|
+
}
|
|
112
|
+
if (changes['dataProfileOptions']) {
|
|
113
|
+
this.updateConfigs();
|
|
114
|
+
// If a data profile is already selected, update loop indices
|
|
115
|
+
const currentProfileId = this.loopForm.get('dataProfile')?.value;
|
|
116
|
+
if (currentProfileId) {
|
|
117
|
+
this.onDataProfileChange(currentProfileId);
|
|
118
|
+
}
|
|
119
|
+
}
|
|
120
|
+
if (changes['hasMoreDataProfiles'] || changes['isLoadingDataProfiles']) {
|
|
121
|
+
this.updateDataProfileConfig();
|
|
122
|
+
}
|
|
123
|
+
if (changes['loopType']) {
|
|
124
|
+
this.selectedLoopType = this.loopType;
|
|
125
|
+
}
|
|
126
|
+
// Note: loopStartOptions and loopEndOptions are now calculated dynamically
|
|
127
|
+
// so they don't need to be updated from inputs
|
|
128
|
+
}
|
|
129
|
+
updateConfigs() {
|
|
130
|
+
// Convert DataProfileOption[] to SelectOption[]
|
|
131
|
+
this.dataProfileConfig = {
|
|
132
|
+
...this.dataProfileConfig,
|
|
133
|
+
options: this.convertDataProfileOptionsToSelectOptions(this.dataProfileOptions),
|
|
134
|
+
hasMore: this.hasMoreDataProfiles,
|
|
135
|
+
isLoading: this.isLoadingDataProfiles,
|
|
136
|
+
onChange: (value) => {
|
|
137
|
+
this.onDataProfileChange(value);
|
|
138
|
+
},
|
|
139
|
+
onSearch: (query) => {
|
|
140
|
+
this.onSearchDataProfiles(query);
|
|
141
|
+
},
|
|
142
|
+
onLoadMore: (query) => {
|
|
143
|
+
this.loadMoreDataProfiles.emit(query || '');
|
|
144
|
+
}
|
|
145
|
+
};
|
|
146
|
+
// Loop start and end options are updated when data profile is selected
|
|
147
|
+
this.updateLoopIndexOptions();
|
|
148
|
+
}
|
|
149
|
+
convertDataProfileOptionsToSelectOptions(options) {
|
|
150
|
+
return options.map(option => ({
|
|
151
|
+
id: option.id,
|
|
152
|
+
value: option.id,
|
|
153
|
+
name: option.name,
|
|
154
|
+
label: option.name
|
|
155
|
+
}));
|
|
156
|
+
}
|
|
157
|
+
/**
|
|
158
|
+
* Handle data profile selection and update loop start/end options
|
|
159
|
+
*/
|
|
160
|
+
onDataProfileChange(profileId) {
|
|
161
|
+
const selectedProfile = this.dataProfileOptions.find(profile => profile.id === profileId || String(profile.id) === String(profileId));
|
|
162
|
+
if (selectedProfile) {
|
|
163
|
+
this.selectedDataProfile = selectedProfile;
|
|
164
|
+
this.updateLoopIndicesFromProfile(selectedProfile);
|
|
165
|
+
}
|
|
166
|
+
else {
|
|
167
|
+
this.selectedDataProfile = null;
|
|
168
|
+
this.startArray = [];
|
|
169
|
+
this.endArray = [];
|
|
170
|
+
this.updateLoopIndexOptions();
|
|
171
|
+
}
|
|
172
|
+
}
|
|
173
|
+
/**
|
|
174
|
+
* Calculate loop indices based on selected data profile
|
|
175
|
+
*/
|
|
176
|
+
updateLoopIndicesFromProfile(profile) {
|
|
177
|
+
// Calculate data length from data array or use provided dataLength
|
|
178
|
+
let dataSetLength = 1;
|
|
179
|
+
if (profile.data && Array.isArray(profile.data)) {
|
|
180
|
+
dataSetLength = profile.data.length;
|
|
181
|
+
}
|
|
182
|
+
else if (profile.dataLength && profile.dataLength > 0) {
|
|
183
|
+
dataSetLength = profile.dataLength;
|
|
184
|
+
}
|
|
185
|
+
// Create start array from 1 to dataSetLength
|
|
186
|
+
this.startArray = Array.from({ length: dataSetLength }, (_, i) => i + 1);
|
|
187
|
+
// Initialize end array same as start array
|
|
188
|
+
// End array will be updated when start index is selected
|
|
189
|
+
this.endArray = [...this.startArray];
|
|
190
|
+
// Set default values if form is empty
|
|
191
|
+
const currentStart = this.loopForm.get('loopStart')?.value;
|
|
192
|
+
const currentEnd = this.loopForm.get('loopEnd')?.value;
|
|
193
|
+
if (!currentStart && this.startArray.length > 0) {
|
|
194
|
+
this.loopForm.get('loopStart')?.setValue(this.startArray[0]);
|
|
195
|
+
}
|
|
196
|
+
if (!currentEnd && this.endArray.length > 0) {
|
|
197
|
+
this.loopForm.get('loopEnd')?.setValue(this.endArray[this.endArray.length - 1]);
|
|
198
|
+
}
|
|
199
|
+
this.updateLoopIndexOptions();
|
|
200
|
+
}
|
|
201
|
+
/**
|
|
202
|
+
* Handle loop start change and update end options
|
|
203
|
+
*/
|
|
204
|
+
onLoopStartChange(startIndex) {
|
|
205
|
+
if (!this.selectedDataProfile || !startIndex) {
|
|
206
|
+
this.endArray = [...this.startArray];
|
|
207
|
+
this.updateLoopIndexOptions();
|
|
208
|
+
return;
|
|
209
|
+
}
|
|
210
|
+
const startIdx = typeof startIndex === 'string' ? parseInt(startIndex) : startIndex;
|
|
211
|
+
if (isNaN(startIdx) || startIdx < 1) {
|
|
212
|
+
this.endArray = [...this.startArray];
|
|
213
|
+
}
|
|
214
|
+
else {
|
|
215
|
+
// End array should be from startIndex to end of data
|
|
216
|
+
// Based on reference: endArray = startArray.splice(startIndex - 1, startArray.length)
|
|
217
|
+
const startArrayCopy = [...this.startArray];
|
|
218
|
+
this.endArray = startArrayCopy.slice(startIdx - 1);
|
|
219
|
+
}
|
|
220
|
+
// Auto-update end index if current end is invalid
|
|
221
|
+
const currentEnd = this.loopForm.get('loopEnd')?.value;
|
|
222
|
+
const endIdx = typeof currentEnd === 'string' ? parseInt(currentEnd) : currentEnd;
|
|
223
|
+
if (!currentEnd || isNaN(endIdx) || endIdx < startIdx) {
|
|
224
|
+
if (this.endArray.length > 0) {
|
|
225
|
+
this.loopForm.get('loopEnd')?.setValue(this.endArray[this.endArray.length - 1]);
|
|
226
|
+
}
|
|
227
|
+
}
|
|
228
|
+
this.updateLoopIndexOptions();
|
|
229
|
+
}
|
|
230
|
+
/**
|
|
231
|
+
* Update loop start and end config options
|
|
232
|
+
*/
|
|
233
|
+
updateLoopIndexOptions() {
|
|
234
|
+
// Convert startArray to SelectOptions
|
|
235
|
+
const startOptions = this.startArray.map(idx => ({
|
|
236
|
+
id: idx,
|
|
237
|
+
value: idx,
|
|
238
|
+
name: String(idx),
|
|
239
|
+
label: String(idx)
|
|
240
|
+
}));
|
|
241
|
+
// Convert endArray to SelectOptions
|
|
242
|
+
const endOptions = this.endArray.map(idx => ({
|
|
243
|
+
id: idx,
|
|
244
|
+
value: idx,
|
|
245
|
+
name: String(idx),
|
|
246
|
+
label: String(idx)
|
|
247
|
+
}));
|
|
248
|
+
this.loopStartConfig = {
|
|
249
|
+
...this.loopStartConfig,
|
|
250
|
+
options: [{ id: -1, value: -1, name: 'Start', label: 'Start' }, ...startOptions],
|
|
251
|
+
onChange: (value) => {
|
|
252
|
+
this.onLoopStartChange(value);
|
|
253
|
+
}
|
|
254
|
+
};
|
|
255
|
+
this.loopEndConfig = {
|
|
256
|
+
...this.loopEndConfig,
|
|
257
|
+
options: [...endOptions, { id: -1, value: -1, name: 'End', label: 'End' }],
|
|
258
|
+
onChange: (value) => {
|
|
259
|
+
// Handle change if needed
|
|
260
|
+
}
|
|
261
|
+
};
|
|
262
|
+
}
|
|
263
|
+
onLoopTypeChange(type) {
|
|
264
|
+
const loopType = type;
|
|
265
|
+
this.selectedLoopType = loopType;
|
|
266
|
+
this.loopTypeChange.emit(loopType);
|
|
267
|
+
}
|
|
268
|
+
onCancel() {
|
|
269
|
+
this.resetForm();
|
|
270
|
+
this.cancelled.emit();
|
|
271
|
+
}
|
|
272
|
+
onCreateStep() {
|
|
273
|
+
const formValue = this.loopForm.value;
|
|
274
|
+
if (this.selectedLoopType === 'while') {
|
|
275
|
+
if (!this.selectedWhileTemplate) {
|
|
276
|
+
return;
|
|
277
|
+
}
|
|
278
|
+
}
|
|
279
|
+
const stepData = {
|
|
280
|
+
selectedLoopType: this.selectedLoopType,
|
|
281
|
+
loopType: this.selectedLoopType,
|
|
282
|
+
selectOption: formValue.selectOption || undefined,
|
|
283
|
+
dataProfile: formValue.dataProfile || undefined,
|
|
284
|
+
loopStart: formValue.loopStart || undefined,
|
|
285
|
+
loopEnd: formValue.loopEnd || undefined,
|
|
286
|
+
runTime: formValue.runTime || undefined,
|
|
287
|
+
whileTemplate: this.selectedWhileTemplate || undefined
|
|
288
|
+
};
|
|
289
|
+
console.log('stepData', stepData);
|
|
290
|
+
this.createStep.emit(stepData);
|
|
291
|
+
}
|
|
292
|
+
createWhileStep(event) {
|
|
293
|
+
console.log('createWhileStep', event);
|
|
294
|
+
const stepData = {
|
|
295
|
+
selectedLoopType: this.selectedLoopType,
|
|
296
|
+
loopType: this.selectedLoopType,
|
|
297
|
+
event: event
|
|
298
|
+
};
|
|
299
|
+
console.log('stepData', stepData);
|
|
300
|
+
this.createStep.emit(stepData);
|
|
301
|
+
}
|
|
302
|
+
/**
|
|
303
|
+
* Handle search event for data profiles
|
|
304
|
+
*/
|
|
305
|
+
onSearchDataProfiles(query) {
|
|
306
|
+
this.searchDataProfiles.emit(query);
|
|
307
|
+
}
|
|
308
|
+
/**
|
|
309
|
+
* Handle loadMore event for data profiles
|
|
310
|
+
*/
|
|
311
|
+
onLoadMoreDataProfiles(event) {
|
|
312
|
+
this.loadMoreDataProfiles.emit(event.query);
|
|
313
|
+
}
|
|
314
|
+
/**
|
|
315
|
+
* Update data profile config when loading state or hasMore changes
|
|
316
|
+
*/
|
|
317
|
+
updateDataProfileConfig() {
|
|
318
|
+
if (this.dataProfileConfig) {
|
|
319
|
+
this.dataProfileConfig = {
|
|
320
|
+
...this.dataProfileConfig,
|
|
321
|
+
hasMore: this.hasMoreDataProfiles,
|
|
322
|
+
isLoading: this.isLoadingDataProfiles
|
|
323
|
+
};
|
|
324
|
+
}
|
|
325
|
+
}
|
|
326
|
+
resetForm() {
|
|
327
|
+
this.selectedLoopType = 'for';
|
|
328
|
+
this.selectedDataProfile = null;
|
|
329
|
+
this.startArray = [];
|
|
330
|
+
this.endArray = [];
|
|
331
|
+
this.loopForm.reset({
|
|
332
|
+
selectOption: null,
|
|
333
|
+
dataProfile: null,
|
|
334
|
+
loopStart: null,
|
|
335
|
+
loopEnd: null
|
|
336
|
+
});
|
|
337
|
+
this.updateLoopIndexOptions();
|
|
338
|
+
}
|
|
339
|
+
onWhileSearchChange(event) {
|
|
340
|
+
this.whileSearchValue = event;
|
|
341
|
+
this.filterWhileTemplates(event);
|
|
342
|
+
}
|
|
343
|
+
onWhileSearchSubmit(event) {
|
|
344
|
+
this.onWhileSearchChange(event);
|
|
345
|
+
}
|
|
346
|
+
onWhileSearchCleared() {
|
|
347
|
+
this.whileSearchValue = '';
|
|
348
|
+
this.filterWhileTemplates('');
|
|
349
|
+
}
|
|
350
|
+
filterWhileTemplates(query) {
|
|
351
|
+
this.whileTemplates = this.whileTemplates.filter(template => template.htmlGrammar.toLowerCase().includes(query.toLowerCase()) || template.naturalText.toLowerCase().includes(query.toLowerCase()));
|
|
352
|
+
}
|
|
353
|
+
selectWhileTemplate(template) {
|
|
354
|
+
this.selectedWhileTemplate = template;
|
|
355
|
+
}
|
|
356
|
+
}
|
|
357
|
+
StepBuilderLoopComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: StepBuilderLoopComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
358
|
+
StepBuilderLoopComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.4.0", type: StepBuilderLoopComponent, selector: "cqa-step-builder-loop", inputs: { loopType: "loopType", selectOptions: "selectOptions", dataProfileOptions: "dataProfileOptions", hasMoreDataProfiles: "hasMoreDataProfiles", isLoadingDataProfiles: "isLoadingDataProfiles", setWhileTemplateVariables: "setWhileTemplateVariables", whileTemplates: "whileTemplates", whileSearchPlaceholder: "whileSearchPlaceholder", whileSearchValue: "whileSearchValue" }, outputs: { createStep: "createStep", cancelled: "cancelled", loopTypeChange: "loopTypeChange", loadMoreDataProfiles: "loadMoreDataProfiles", searchDataProfiles: "searchDataProfiles" }, host: { classAttribute: "cqa-ui-root" }, usesOnChanges: true, ngImport: i0, template: "<div class=\"cqa-flex cqa-flex-col cqa-h-full cqa-bg-white cqa-px-4 cqa-py-2\">\n <!-- Header -->\n <h2 class=\"cqa-text-[12px] cqa-font-semibold cqa-text-black-100 cqa-mb-4\">\n Create Loop Test Step\n </h2>\n\n <!-- Loop Type Selection -->\n <div class=\"cqa-mb-4\">\n <cqa-segment-control\n [segments]=\"[\n { label: 'For', value: 'for' },\n { label: 'While', value: 'while' }\n ]\"\n [value]=\"selectedLoopType\"\n (valueChange)=\"onLoopTypeChange($event)\">\n </cqa-segment-control>\n </div>\n\n <!-- Form Fields -->\n <ng-container *ngIf=\"selectedLoopType === 'for'\">\n <div class=\"cqa-flex cqa-flex-col cqa-gap-4 cqa-flex-1 cqa-overflow-y-auto\">\n <!-- Dropdown Fields Row -->\n <div class=\"cqa-flex cqa-gap-4 cqa-flex-wrap\">\n <!-- Select Option -->\n <div class=\"cqa-flex cqa-flex-col cqa-flex-1\" style=\"min-width: calc(25% - 12px);\">\n <label class=\"cqa-text-sm cqa-font-medium cqa-text-gray-700 cqa-mb-1.5\">\n Select Option\n </label>\n <cqa-dynamic-select\n [form]=\"loopForm\"\n [config]=\"selectOptionConfig\">\n </cqa-dynamic-select>\n </div>\n\n <ng-container *ngIf=\"loopForm.get('selectOption')?.value === 'dataProfile'\">\n <!-- Data Profile -->\n <div class=\"cqa-flex cqa-flex-col cqa-flex-1\" style=\"min-width: calc(25% - 12px);\">\n <label class=\"cqa-text-sm cqa-font-medium cqa-text-gray-700 cqa-mb-1.5\">\n Data Profile\n </label>\n <cqa-dynamic-select\n [form]=\"loopForm\"\n [config]=\"dataProfileConfig\"\n (searchChange)=\"onSearchDataProfiles($event.query)\"\n (loadMore)=\"onLoadMoreDataProfiles($event)\">\n </cqa-dynamic-select>\n </div>\n\n <!-- Loop Start -->\n <div class=\"cqa-flex cqa-flex-col cqa-flex-1\" style=\"min-width: calc(25% - 12px);\">\n <label class=\"cqa-text-sm cqa-font-medium cqa-text-gray-700 cqa-mb-1.5\">\n Loop Start\n </label>\n <cqa-dynamic-select\n [form]=\"loopForm\"\n [config]=\"loopStartConfig\">\n </cqa-dynamic-select>\n </div>\n\n <!-- Loop End -->\n <div class=\"cqa-flex cqa-flex-col cqa-flex-1\" style=\"min-width: calc(25% - 12px);\">\n <label class=\"cqa-text-sm cqa-font-medium cqa-text-gray-700 cqa-mb-1.5\">\n Loop End\n </label>\n <cqa-dynamic-select\n [form]=\"loopForm\"\n [config]=\"loopEndConfig\">\n </cqa-dynamic-select>\n </div>\n </ng-container>\n <ng-container *ngIf=\"loopForm.get('selectOption')?.value === 'runTime'\">\n <!-- Run Time Input Field -->\n <div class=\"cqa-flex cqa-flex-col cqa-flex-1\" style=\"min-width: calc(25% - 12px);\">\n <label class=\"cqa-text-sm cqa-font-medium cqa-text-gray-700 cqa-mb-1.5\">\n Run Time\n </label>\n <cqa-custom-input\n [placeholder]=\"'Enter Run Time'\"\n [value]=\"loopForm.get('runTime')?.value\"\n [fullWidth]=\"true\"\n (valueChange)=\"loopForm.get('runTime')?.setValue($event)\">\n </cqa-custom-input>\n </div>\n </ng-container>\n </div>\n </div>\n</ng-container>\n <ng-container *ngIf=\"selectedLoopType === 'while'\">\n <cqa-step-builder-action [showHeader]=\"false\" [templates]=\"whileTemplates\" [setTemplateVariables]=\"setWhileTemplateVariables\" [searchPlaceholder]=\"whileSearchPlaceholder\" (templateChanged)=\"selectWhileTemplate($event)\" (createStep)=\"createWhileStep($event)\"></cqa-step-builder-action>\n </ng-container>\n\n <!-- Action Buttons -->\n <div *ngIf=\"selectedLoopType === 'for'\" class=\"cqa-flex cqa-w-full cqa-gap-2 cqa-mt-6 cqa-pt-4 cqa-border-t cqa-border-gray-200\">\n <cqa-button\n class=\"cqa-w-1/2\"\n variant=\"outlined\"\n text=\"Cancel\"\n [customClass]=\"'cqa-flex-1 cqa-w-full'\"\n (clicked)=\"onCancel()\">\n </cqa-button>\n <cqa-button\n class=\"cqa-w-1/2\"\n variant=\"filled\"\n text=\"Create Step\"\n [customClass]=\"'cqa-flex-1 cqa-w-full'\"\n (clicked)=\"onCreateStep()\">\n </cqa-button>\n </div>\n</div>\n\n", components: [{ type: i1.SegmentControlComponent, selector: "cqa-segment-control", inputs: ["segments", "value", "disabled"], outputs: ["valueChange"] }, { type: i2.DynamicSelectFieldComponent, selector: "cqa-dynamic-select", inputs: ["form", "config"], outputs: ["selectionChange", "selectClick", "searchChange", "loadMore"] }, { 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.StepBuilderActionComponent, selector: "cqa-step-builder-action", inputs: ["showHeader", "templates", "searchPlaceholder", "setTemplateVariables", "preventSelectTemplate"], outputs: ["templateChanged", "createStep", "cancelled"] }, { 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"] }] });
|
|
359
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: StepBuilderLoopComponent, decorators: [{
|
|
360
|
+
type: Component,
|
|
361
|
+
args: [{ selector: 'cqa-step-builder-loop', host: { class: 'cqa-ui-root' }, template: "<div class=\"cqa-flex cqa-flex-col cqa-h-full cqa-bg-white cqa-px-4 cqa-py-2\">\n <!-- Header -->\n <h2 class=\"cqa-text-[12px] cqa-font-semibold cqa-text-black-100 cqa-mb-4\">\n Create Loop Test Step\n </h2>\n\n <!-- Loop Type Selection -->\n <div class=\"cqa-mb-4\">\n <cqa-segment-control\n [segments]=\"[\n { label: 'For', value: 'for' },\n { label: 'While', value: 'while' }\n ]\"\n [value]=\"selectedLoopType\"\n (valueChange)=\"onLoopTypeChange($event)\">\n </cqa-segment-control>\n </div>\n\n <!-- Form Fields -->\n <ng-container *ngIf=\"selectedLoopType === 'for'\">\n <div class=\"cqa-flex cqa-flex-col cqa-gap-4 cqa-flex-1 cqa-overflow-y-auto\">\n <!-- Dropdown Fields Row -->\n <div class=\"cqa-flex cqa-gap-4 cqa-flex-wrap\">\n <!-- Select Option -->\n <div class=\"cqa-flex cqa-flex-col cqa-flex-1\" style=\"min-width: calc(25% - 12px);\">\n <label class=\"cqa-text-sm cqa-font-medium cqa-text-gray-700 cqa-mb-1.5\">\n Select Option\n </label>\n <cqa-dynamic-select\n [form]=\"loopForm\"\n [config]=\"selectOptionConfig\">\n </cqa-dynamic-select>\n </div>\n\n <ng-container *ngIf=\"loopForm.get('selectOption')?.value === 'dataProfile'\">\n <!-- Data Profile -->\n <div class=\"cqa-flex cqa-flex-col cqa-flex-1\" style=\"min-width: calc(25% - 12px);\">\n <label class=\"cqa-text-sm cqa-font-medium cqa-text-gray-700 cqa-mb-1.5\">\n Data Profile\n </label>\n <cqa-dynamic-select\n [form]=\"loopForm\"\n [config]=\"dataProfileConfig\"\n (searchChange)=\"onSearchDataProfiles($event.query)\"\n (loadMore)=\"onLoadMoreDataProfiles($event)\">\n </cqa-dynamic-select>\n </div>\n\n <!-- Loop Start -->\n <div class=\"cqa-flex cqa-flex-col cqa-flex-1\" style=\"min-width: calc(25% - 12px);\">\n <label class=\"cqa-text-sm cqa-font-medium cqa-text-gray-700 cqa-mb-1.5\">\n Loop Start\n </label>\n <cqa-dynamic-select\n [form]=\"loopForm\"\n [config]=\"loopStartConfig\">\n </cqa-dynamic-select>\n </div>\n\n <!-- Loop End -->\n <div class=\"cqa-flex cqa-flex-col cqa-flex-1\" style=\"min-width: calc(25% - 12px);\">\n <label class=\"cqa-text-sm cqa-font-medium cqa-text-gray-700 cqa-mb-1.5\">\n Loop End\n </label>\n <cqa-dynamic-select\n [form]=\"loopForm\"\n [config]=\"loopEndConfig\">\n </cqa-dynamic-select>\n </div>\n </ng-container>\n <ng-container *ngIf=\"loopForm.get('selectOption')?.value === 'runTime'\">\n <!-- Run Time Input Field -->\n <div class=\"cqa-flex cqa-flex-col cqa-flex-1\" style=\"min-width: calc(25% - 12px);\">\n <label class=\"cqa-text-sm cqa-font-medium cqa-text-gray-700 cqa-mb-1.5\">\n Run Time\n </label>\n <cqa-custom-input\n [placeholder]=\"'Enter Run Time'\"\n [value]=\"loopForm.get('runTime')?.value\"\n [fullWidth]=\"true\"\n (valueChange)=\"loopForm.get('runTime')?.setValue($event)\">\n </cqa-custom-input>\n </div>\n </ng-container>\n </div>\n </div>\n</ng-container>\n <ng-container *ngIf=\"selectedLoopType === 'while'\">\n <cqa-step-builder-action [showHeader]=\"false\" [templates]=\"whileTemplates\" [setTemplateVariables]=\"setWhileTemplateVariables\" [searchPlaceholder]=\"whileSearchPlaceholder\" (templateChanged)=\"selectWhileTemplate($event)\" (createStep)=\"createWhileStep($event)\"></cqa-step-builder-action>\n </ng-container>\n\n <!-- Action Buttons -->\n <div *ngIf=\"selectedLoopType === 'for'\" class=\"cqa-flex cqa-w-full cqa-gap-2 cqa-mt-6 cqa-pt-4 cqa-border-t cqa-border-gray-200\">\n <cqa-button\n class=\"cqa-w-1/2\"\n variant=\"outlined\"\n text=\"Cancel\"\n [customClass]=\"'cqa-flex-1 cqa-w-full'\"\n (clicked)=\"onCancel()\">\n </cqa-button>\n <cqa-button\n class=\"cqa-w-1/2\"\n variant=\"filled\"\n text=\"Create Step\"\n [customClass]=\"'cqa-flex-1 cqa-w-full'\"\n (clicked)=\"onCreateStep()\">\n </cqa-button>\n </div>\n</div>\n\n", styles: [] }]
|
|
362
|
+
}], ctorParameters: function () { return []; }, propDecorators: { loopType: [{
|
|
363
|
+
type: Input
|
|
364
|
+
}], selectOptions: [{
|
|
365
|
+
type: Input
|
|
366
|
+
}], dataProfileOptions: [{
|
|
367
|
+
type: Input
|
|
368
|
+
}], hasMoreDataProfiles: [{
|
|
369
|
+
type: Input
|
|
370
|
+
}], isLoadingDataProfiles: [{
|
|
371
|
+
type: Input
|
|
372
|
+
}], setWhileTemplateVariables: [{
|
|
373
|
+
type: Input
|
|
374
|
+
}], createStep: [{
|
|
375
|
+
type: Output
|
|
376
|
+
}], cancelled: [{
|
|
377
|
+
type: Output
|
|
378
|
+
}], loopTypeChange: [{
|
|
379
|
+
type: Output
|
|
380
|
+
}], loadMoreDataProfiles: [{
|
|
381
|
+
type: Output
|
|
382
|
+
}], searchDataProfiles: [{
|
|
383
|
+
type: Output
|
|
384
|
+
}], whileTemplates: [{
|
|
385
|
+
type: Input
|
|
386
|
+
}], whileSearchPlaceholder: [{
|
|
387
|
+
type: Input
|
|
388
|
+
}], whileSearchValue: [{
|
|
389
|
+
type: Input
|
|
390
|
+
}] } });
|
|
391
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"step-builder-loop.component.js","sourceRoot":"","sources":["../../../../../../src/lib/step-builder/step-builder-loop/step-builder-loop.component.ts","../../../../../../src/lib/step-builder/step-builder-loop/step-builder-loop.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, Output, EventEmitter, OnInit, OnChanges, SimpleChanges } from '@angular/core';\nimport { FormGroup, FormControl } from '@angular/forms';\nimport { DynamicSelectFieldConfig, SelectOption } from '../../dynamic-select/dynamic-select-field.component';\nimport { ActionTemplate } from '../step-builder-action/step-builder-action.component';\n\nexport type LoopType = 'for' | 'while';\n\n/**\n * Interface for data profile option\n * Based on TestData model structure\n */\nexport interface DataProfileOption {\n  id: number | string;\n  name: string;\n  /** Array of data sets - length determines available loop indices */\n  data?: any[];\n  /** Optional: direct data length if data array is not provided */\n  dataLength?: number;\n}\n\nexport interface LoopFormData {\n  selectedLoopType: LoopType;\n  loopType: LoopType;\n  selectOption?: string;\n  dataProfile?: string | number;\n  loopStart?: number | string;\n  loopEnd?: number | string;\n  runTime?: string;\n  whileTemplate?: any;\n  event?: any;\n}\n\n@Component({\n  selector: 'cqa-step-builder-loop',\n  templateUrl: './step-builder-loop.component.html',\n  styleUrls: [],\n  host: { class: 'cqa-ui-root' }\n})\nexport class StepBuilderLoopComponent implements OnInit, OnChanges {\n  /** Currently selected loop type */\n  @Input() loopType: LoopType = 'for';\n\n  /** Options for the select option dropdown */\n  @Input() selectOptions: any[] = [\n    {value: 'dataProfile', label: 'Data Profile'},\n    {value: 'runTime', label: 'Run Time'}\n  ];\n\n  /** Options for the data profile dropdown - accepts DataProfileOption objects */\n  @Input() dataProfileOptions: DataProfileOption[] = [];\n\n  /** Indicates if more data profiles are available for loading */\n  @Input() hasMoreDataProfiles: boolean = false;\n\n  /** Loading state for data profiles */\n  @Input() isLoadingDataProfiles: boolean = false;\n  /** Function to handle variable processing or custom logic. Can be passed from parent component. */\n  @Input() setWhileTemplateVariables: (variables: ActionTemplate) => any = () => { return []};\n\n  /** Emit when step is created */\n  @Output() createStep = new EventEmitter<LoopFormData>();\n\n  /** Emit when cancelled */\n  @Output() cancelled = new EventEmitter<void>();\n\n  /** Emit when loop type changes */\n  @Output() loopTypeChange = new EventEmitter<LoopType>();\n\n  /** Emit when more data profiles need to be loaded */\n  @Output() loadMoreDataProfiles = new EventEmitter<string>();\n\n  /** Emit when data profile search query changes */\n  @Output() searchDataProfiles = new EventEmitter<string>();\n  @Input() whileTemplates: any[] = [];\n  @Input() whileSearchPlaceholder: string = 'Search While';\n  @Input() whileSearchValue: string = '';\n  selectedWhileTemplate: any = null;\n  selectedLoopType: LoopType = 'for';\n  \n  // Single FormGroup containing all four fields\n  loopForm: FormGroup;\n\n  // Configs for dynamic-select components\n  selectOptionConfig: DynamicSelectFieldConfig;\n  dataProfileConfig: DynamicSelectFieldConfig;\n  loopStartConfig: DynamicSelectFieldConfig;\n  loopEndConfig: DynamicSelectFieldConfig;\n\n\n  // Internal state for managing loop indices\n  private selectedDataProfile: DataProfileOption | null = null;\n  private startArray: number[] = [];\n  private endArray: number[] = [];\n\n  constructor() {\n    // Initialize single FormGroup with all fields\n    this.loopForm = new FormGroup({\n      selectOption: new FormControl(null),\n      dataProfile: new FormControl(null),\n      loopStart: new FormControl(null),\n      loopEnd: new FormControl(null),\n      runTime: new FormControl(null)\n    });\n\n    // Initialize configs\n    this.selectOptionConfig = {\n      key: 'selectOption',\n      placeholder: 'select option',\n      selectedValue: 'dataProfile',\n      multiple: false,\n      searchable: false,\n      options: this.selectOptions\n    };\n    this.dataProfileConfig = {\n      key: 'dataProfile',\n      placeholder: 'data profile',\n      multiple: false,\n      searchable: true,\n      serverSearch: true,\n      hasMore: this.hasMoreDataProfiles,\n      isLoading: this.isLoadingDataProfiles,\n      options: [],\n      onChange: (value: any) => {\n        this.onDataProfileChange(value);\n      },\n      onSearch: (query: string) => {\n        this.onSearchDataProfiles(query);\n      },\n      onLoadMore: (query?: string) => {\n        this.loadMoreDataProfiles.emit(query || '');\n      }\n    };\n    this.loopStartConfig = {\n      key: 'loopStart',\n      placeholder: 'loop start',\n      multiple: false,\n      searchable: false,\n      options: [],\n      onChange: (value: any) => {\n        this.onLoopStartChange(value);\n      }\n    };\n    this.loopEndConfig = {\n      key: 'loopEnd',\n      placeholder: 'loop end',\n      multiple: false,\n      searchable: false,\n      options: [],\n      onChange: (value: any) => {\n        // Handle change if needed\n      }\n    };  \n  }\n\n  ngOnInit(): void {\n    this.selectedLoopType = this.loopType;\n    this.updateConfigs();\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    console.log(\"this.whileTemplates\",this.whileTemplates);\n    if (changes['selectOptions']) {\n      this.updateConfigs();\n    }\n    if (changes['dataProfileOptions']) {\n      this.updateConfigs();\n      // If a data profile is already selected, update loop indices\n      const currentProfileId = this.loopForm.get('dataProfile')?.value;\n      if (currentProfileId) {\n        this.onDataProfileChange(currentProfileId);\n      }\n    }\n    if (changes['hasMoreDataProfiles'] || changes['isLoadingDataProfiles']) {\n      this.updateDataProfileConfig();\n    }\n    if (changes['loopType']) {\n      this.selectedLoopType = this.loopType;\n    }\n    // Note: loopStartOptions and loopEndOptions are now calculated dynamically\n    // so they don't need to be updated from inputs\n  }\n\n  private updateConfigs(): void {\n    // Convert DataProfileOption[] to SelectOption[]\n    this.dataProfileConfig = {\n      ...this.dataProfileConfig,\n      options: this.convertDataProfileOptionsToSelectOptions(this.dataProfileOptions),\n      hasMore: this.hasMoreDataProfiles,\n      isLoading: this.isLoadingDataProfiles,\n      onChange: (value: any) => {\n        this.onDataProfileChange(value);\n      },\n      onSearch: (query: string) => {\n        this.onSearchDataProfiles(query);\n      },\n      onLoadMore: (query?: string) => {\n        this.loadMoreDataProfiles.emit(query || '');\n      }\n    };\n    \n    // Loop start and end options are updated when data profile is selected\n    this.updateLoopIndexOptions();\n  }\n\n  private convertDataProfileOptionsToSelectOptions(options: DataProfileOption[]): SelectOption[] {\n    return options.map(option => ({\n      id: option.id,\n      value: option.id,\n      name: option.name,\n      label: option.name\n    }));\n  }\n  /**\n   * Handle data profile selection and update loop start/end options\n   */\n  private onDataProfileChange(profileId: any): void {\n    const selectedProfile = this.dataProfileOptions.find(profile => \n      profile.id === profileId || String(profile.id) === String(profileId)\n    );\n\n    if (selectedProfile) {\n      this.selectedDataProfile = selectedProfile;\n      this.updateLoopIndicesFromProfile(selectedProfile);\n    } else {\n      this.selectedDataProfile = null;\n      this.startArray = [];\n      this.endArray = [];\n      this.updateLoopIndexOptions();\n    }\n  }\n\n  /**\n   * Calculate loop indices based on selected data profile\n   */\n  private updateLoopIndicesFromProfile(profile: DataProfileOption): void {\n    // Calculate data length from data array or use provided dataLength\n    let dataSetLength = 1;\n    if (profile.data && Array.isArray(profile.data)) {\n      dataSetLength = profile.data.length;\n    } else if (profile.dataLength && profile.dataLength > 0) {\n      dataSetLength = profile.dataLength;\n    }\n\n    // Create start array from 1 to dataSetLength\n    this.startArray = Array.from({ length: dataSetLength }, (_, i) => i + 1);\n    // Initialize end array same as start array\n    // End array will be updated when start index is selected\n    this.endArray = [...this.startArray];\n\n    // Set default values if form is empty\n    const currentStart = this.loopForm.get('loopStart')?.value;\n    const currentEnd = this.loopForm.get('loopEnd')?.value;\n    \n    if (!currentStart && this.startArray.length > 0) {\n      this.loopForm.get('loopStart')?.setValue(this.startArray[0]);\n    }\n    if (!currentEnd && this.endArray.length > 0) {\n      this.loopForm.get('loopEnd')?.setValue(this.endArray[this.endArray.length - 1]);\n    }\n\n    this.updateLoopIndexOptions();\n  }\n\n  /**\n   * Handle loop start change and update end options\n   */\n  private onLoopStartChange(startIndex: any): void {\n    if (!this.selectedDataProfile || !startIndex) {\n      this.endArray = [...this.startArray];\n      this.updateLoopIndexOptions();\n      return;\n    }\n\n    const startIdx = typeof startIndex === 'string' ? parseInt(startIndex) : startIndex;\n    \n    if (isNaN(startIdx) || startIdx < 1) {\n      this.endArray = [...this.startArray];\n    } else {\n      // End array should be from startIndex to end of data\n      // Based on reference: endArray = startArray.splice(startIndex - 1, startArray.length)\n      const startArrayCopy = [...this.startArray];\n      this.endArray = startArrayCopy.slice(startIdx - 1);\n    }\n\n    // Auto-update end index if current end is invalid\n    const currentEnd = this.loopForm.get('loopEnd')?.value;\n    const endIdx = typeof currentEnd === 'string' ? parseInt(currentEnd) : currentEnd;\n    \n    if (!currentEnd || isNaN(endIdx) || endIdx < startIdx) {\n      if (this.endArray.length > 0) {\n        this.loopForm.get('loopEnd')?.setValue(this.endArray[this.endArray.length - 1]);\n      }\n    }\n\n    this.updateLoopIndexOptions();\n  }\n\n  /**\n   * Update loop start and end config options\n   */\n  private updateLoopIndexOptions(): void {\n    // Convert startArray to SelectOptions\n    const startOptions: SelectOption[] = this.startArray.map(idx => ({\n      id: idx,\n      value: idx,\n      name: String(idx),\n      label: String(idx)\n    }));\n\n    // Convert endArray to SelectOptions\n    const endOptions: SelectOption[] = this.endArray.map(idx => ({\n      id: idx,\n      value: idx,\n      name: String(idx),\n      label: String(idx)\n    }));\n\n    this.loopStartConfig = {\n      ...this.loopStartConfig,\n      options: [{id: -1, value: -1, name: 'Start', label: 'Start'}, ...startOptions],\n      onChange: (value: any) => {\n        this.onLoopStartChange(value);\n      }\n    };\n\n    this.loopEndConfig = {\n      ...this.loopEndConfig,\n      options: [...endOptions,{id: -1, value: -1, name: 'End', label: 'End'}],\n      onChange: (value: any) => {\n        // Handle change if needed\n      }\n    };\n  }\n\n  onLoopTypeChange(type: string | LoopType): void {\n    const loopType = type as LoopType;\n    this.selectedLoopType = loopType;\n    this.loopTypeChange.emit(loopType);\n  }\n\n  onCancel(): void {\n    this.resetForm();\n    this.cancelled.emit();\n  }\n\n  onCreateStep(): void {\n    const formValue = this.loopForm.value;\n    if(this.selectedLoopType === 'while') {\n      if(!this.selectedWhileTemplate) {\n        return;\n      }\n    }\n    const stepData: LoopFormData = {\n      selectedLoopType: this.selectedLoopType as LoopType,\n      loopType: this.selectedLoopType,\n      selectOption: formValue.selectOption || undefined,\n      dataProfile: formValue.dataProfile || undefined,\n      loopStart: formValue.loopStart || undefined,\n      loopEnd: formValue.loopEnd || undefined,\n      runTime: formValue.runTime || undefined,\n      whileTemplate: this.selectedWhileTemplate || undefined\n    };\n    console.log('stepData', stepData);\n    this.createStep.emit(stepData);\n  }\n\n  createWhileStep(event: any): void {\n    console.log('createWhileStep', event);\n    const stepData: LoopFormData = {\n      selectedLoopType: this.selectedLoopType as LoopType,\n      loopType: this.selectedLoopType as LoopType,\n      event: event\n    };\n    console.log('stepData', stepData);\n    this.createStep.emit(stepData);\n  }\n\n  /**\n   * Handle search event for data profiles\n   */\n  onSearchDataProfiles(query: string): void {\n    this.searchDataProfiles.emit(query);\n  }\n\n  /**\n   * Handle loadMore event for data profiles\n   */\n  onLoadMoreDataProfiles(event: { key: string; query: string }): void {\n    this.loadMoreDataProfiles.emit(event.query);\n  }\n\n  /**\n   * Update data profile config when loading state or hasMore changes\n   */\n  private updateDataProfileConfig(): void {\n    if (this.dataProfileConfig) {\n      this.dataProfileConfig = {\n        ...this.dataProfileConfig,\n        hasMore: this.hasMoreDataProfiles,\n        isLoading: this.isLoadingDataProfiles\n      };\n    }\n  }\n\n  private resetForm(): void {\n    this.selectedLoopType = 'for';\n    this.selectedDataProfile = null;\n    this.startArray = [];\n    this.endArray = [];\n    this.loopForm.reset({\n      selectOption: null,\n      dataProfile: null,\n      loopStart: null,\n      loopEnd: null\n    });\n    this.updateLoopIndexOptions();\n  }\n\n  onWhileSearchChange(event: any): void {\n    this.whileSearchValue = event;\n    this.filterWhileTemplates(event);\n  }\n\n  onWhileSearchSubmit(event: any): void {\n    this.onWhileSearchChange(event);\n  }\n\n  onWhileSearchCleared(): void {\n    this.whileSearchValue = '';\n    this.filterWhileTemplates('');\n  }\n\n  filterWhileTemplates(query: string): void {\n    this.whileTemplates = this.whileTemplates.filter(template => template.htmlGrammar.toLowerCase().includes(query.toLowerCase()) || template.naturalText.toLowerCase().includes(query.toLowerCase()));\n  }\n\n  selectWhileTemplate(template: any): void {\n    this.selectedWhileTemplate = template;\n  }\n}\n\n","<div class=\"cqa-flex cqa-flex-col cqa-h-full cqa-bg-white cqa-px-4 cqa-py-2\">\n  <!-- Header -->\n  <h2 class=\"cqa-text-[12px] cqa-font-semibold cqa-text-black-100 cqa-mb-4\">\n    Create Loop Test Step\n  </h2>\n\n  <!-- Loop Type Selection -->\n  <div class=\"cqa-mb-4\">\n    <cqa-segment-control\n      [segments]=\"[\n        { label: 'For', value: 'for' },\n        { label: 'While', value: 'while' }\n      ]\"\n      [value]=\"selectedLoopType\"\n      (valueChange)=\"onLoopTypeChange($event)\">\n    </cqa-segment-control>\n  </div>\n\n  <!-- Form Fields -->\n   <ng-container *ngIf=\"selectedLoopType === 'for'\">\n  <div class=\"cqa-flex cqa-flex-col cqa-gap-4 cqa-flex-1 cqa-overflow-y-auto\">\n    <!-- Dropdown Fields Row -->\n    <div class=\"cqa-flex cqa-gap-4 cqa-flex-wrap\">\n      <!-- Select Option -->\n      <div class=\"cqa-flex cqa-flex-col cqa-flex-1\" style=\"min-width: calc(25% - 12px);\">\n        <label class=\"cqa-text-sm cqa-font-medium cqa-text-gray-700 cqa-mb-1.5\">\n          Select Option\n        </label>\n        <cqa-dynamic-select\n          [form]=\"loopForm\"\n          [config]=\"selectOptionConfig\">\n        </cqa-dynamic-select>\n      </div>\n\n      <ng-container *ngIf=\"loopForm.get('selectOption')?.value === 'dataProfile'\">\n      <!-- Data Profile -->\n      <div class=\"cqa-flex cqa-flex-col cqa-flex-1\" style=\"min-width: calc(25% - 12px);\">\n        <label class=\"cqa-text-sm cqa-font-medium cqa-text-gray-700 cqa-mb-1.5\">\n          Data Profile\n        </label>\n        <cqa-dynamic-select\n          [form]=\"loopForm\"\n          [config]=\"dataProfileConfig\"\n          (searchChange)=\"onSearchDataProfiles($event.query)\"\n          (loadMore)=\"onLoadMoreDataProfiles($event)\">\n        </cqa-dynamic-select>\n      </div>\n\n      <!-- Loop Start -->\n      <div class=\"cqa-flex cqa-flex-col cqa-flex-1\" style=\"min-width: calc(25% - 12px);\">\n        <label class=\"cqa-text-sm cqa-font-medium cqa-text-gray-700 cqa-mb-1.5\">\n          Loop Start\n        </label>\n        <cqa-dynamic-select\n          [form]=\"loopForm\"\n          [config]=\"loopStartConfig\">\n        </cqa-dynamic-select>\n      </div>\n\n      <!-- Loop End -->\n      <div class=\"cqa-flex cqa-flex-col cqa-flex-1\" style=\"min-width: calc(25% - 12px);\">\n        <label class=\"cqa-text-sm cqa-font-medium cqa-text-gray-700 cqa-mb-1.5\">\n          Loop End\n        </label>\n        <cqa-dynamic-select\n          [form]=\"loopForm\"\n          [config]=\"loopEndConfig\">\n        </cqa-dynamic-select>\n      </div>\n      </ng-container>\n      <ng-container *ngIf=\"loopForm.get('selectOption')?.value === 'runTime'\">\n        <!-- Run Time Input Field -->\n        <div class=\"cqa-flex cqa-flex-col cqa-flex-1\" style=\"min-width: calc(25% - 12px);\">\n          <label class=\"cqa-text-sm cqa-font-medium cqa-text-gray-700 cqa-mb-1.5\">\n            Run Time\n          </label>\n          <cqa-custom-input\n            [placeholder]=\"'Enter Run Time'\"\n            [value]=\"loopForm.get('runTime')?.value\"\n            [fullWidth]=\"true\"\n            (valueChange)=\"loopForm.get('runTime')?.setValue($event)\">\n          </cqa-custom-input>\n        </div>\n      </ng-container>\n    </div>\n  </div>\n</ng-container>\n  <ng-container *ngIf=\"selectedLoopType === 'while'\">\n    <cqa-step-builder-action [showHeader]=\"false\" [templates]=\"whileTemplates\" [setTemplateVariables]=\"setWhileTemplateVariables\" [searchPlaceholder]=\"whileSearchPlaceholder\" (templateChanged)=\"selectWhileTemplate($event)\" (createStep)=\"createWhileStep($event)\"></cqa-step-builder-action>\n  </ng-container>\n\n  <!-- Action Buttons -->\n  <div *ngIf=\"selectedLoopType === 'for'\" class=\"cqa-flex cqa-w-full cqa-gap-2 cqa-mt-6 cqa-pt-4 cqa-border-t cqa-border-gray-200\">\n    <cqa-button\n      class=\"cqa-w-1/2\"\n      variant=\"outlined\"\n      text=\"Cancel\"\n      [customClass]=\"'cqa-flex-1 cqa-w-full'\"\n      (clicked)=\"onCancel()\">\n    </cqa-button>\n    <cqa-button\n      class=\"cqa-w-1/2\"\n      variant=\"filled\"\n      text=\"Create Step\"\n      [customClass]=\"'cqa-flex-1 cqa-w-full'\"\n      (clicked)=\"onCreateStep()\">\n    </cqa-button>\n  </div>\n</div>\n\n"]}
|