@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.
@@ -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"]}