@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
@@ -0,0 +1,277 @@
1
+ import { ChangeDetectionStrategy, Component, EventEmitter, Input, Optional, Output, } from '@angular/core';
2
+ import { FormBuilder, Validators } from '@angular/forms';
3
+ import * as i0 from "@angular/core";
4
+ import * as i1 from "@angular/forms";
5
+ import * as i2 from "../../../custom-input/custom-input.component";
6
+ import * as i3 from "../../../dynamic-select/dynamic-select-field.component";
7
+ import * as i4 from "@angular/material/icon";
8
+ import * as i5 from "../../../button/button.component";
9
+ import * as i6 from "@angular/common";
10
+ export class ElementFormComponent {
11
+ constructor(fb, cdr) {
12
+ this.cdr = cdr;
13
+ /** Current element data (for edit mode) */
14
+ this.element = { title: '', selector: '', labels: [] };
15
+ /** Screen name options for autocomplete (from API) */
16
+ this.screenNameOptions = [];
17
+ /** Whether more screen names are available for infinite scroll */
18
+ this.hasMoreScreenNames = false;
19
+ /** True while parent is loading screen names (search or load more) */
20
+ this.isLoadingScreenNames = false;
21
+ /** True while parent is fetching latest element data for edit (shows loading state) */
22
+ this.isElementLoading = false;
23
+ /** Whether we're in edit mode */
24
+ this.isEditMode = false;
25
+ /** Whether we're in create mode */
26
+ this.isCreateMode = false;
27
+ /** Whether edit in depth is available */
28
+ this.isEditInDepthAvailable = true;
29
+ /** Emitted when user creates a new element (parent should call API) */
30
+ this.createElement = new EventEmitter();
31
+ /** Emitted when user updates an element (parent should call API) */
32
+ this.updateElement = new EventEmitter();
33
+ /** Emitted when user requests to create a new screen name */
34
+ this.createScreenNameRequest = new EventEmitter();
35
+ /** Emitted when user searches screen names (server search) */
36
+ this.searchScreenName = new EventEmitter();
37
+ /** Emitted when user scrolls to load more screen names (passes current search query) */
38
+ this.loadMoreScreenNames = new EventEmitter();
39
+ /** Emitted when user clicks "Select from Element list" or "Cancel" */
40
+ this.cancel = new EventEmitter();
41
+ /** Emitted when user clicks "Edit in depth" */
42
+ this.editInDepth = new EventEmitter();
43
+ /** Labels (tags) as string array for multi-tag input */
44
+ this.formLabels = [];
45
+ /** Current tag input value */
46
+ this.tagInputValue = '';
47
+ /** Whether we're saving (disable buttons) */
48
+ this.saving = false;
49
+ this.fb = fb || new FormBuilder();
50
+ this.initializeForm();
51
+ }
52
+ ngOnChanges(changes) {
53
+ if (changes['screenNameOptions'] || changes['hasMoreScreenNames'] || changes['isLoadingScreenNames']) {
54
+ this.updateScreenNameSelectConfig();
55
+ }
56
+ if ((changes['element'] || changes['elementId']) && this.elementId) {
57
+ this.populateFormForEdit();
58
+ }
59
+ else if (changes['element'] && !this.elementId && this.isCreateMode) {
60
+ this.populateFormForCreateWithElement();
61
+ }
62
+ }
63
+ ngOnInit() {
64
+ if (this.elementId) {
65
+ this.populateFormForEdit();
66
+ }
67
+ else if (this.isCreateMode && this.element) {
68
+ this.populateFormForCreateWithElement();
69
+ }
70
+ }
71
+ initializeForm() {
72
+ this.form = this.fb.group({
73
+ name: ['', [Validators.required]],
74
+ screenNameId: [null, [Validators.required]],
75
+ value: ['', [Validators.required]],
76
+ });
77
+ this.updateScreenNameSelectConfig();
78
+ }
79
+ updateScreenNameSelectConfig() {
80
+ const opts = (this.screenNameOptions || []).map((o) => ({
81
+ id: o.id,
82
+ value: o.id,
83
+ name: o.name,
84
+ label: o.name,
85
+ }));
86
+ const currentId = this.form?.get('screenNameId')?.value;
87
+ if (currentId && this.element?.screenNameId === currentId && this.element?.screenName) {
88
+ const exists = opts.some((o) => o.id === currentId);
89
+ if (!exists) {
90
+ opts.unshift({
91
+ id: currentId,
92
+ value: currentId,
93
+ name: String(this.element.screenName),
94
+ label: String(this.element.screenName),
95
+ });
96
+ }
97
+ }
98
+ this.screenNameSelectConfig = {
99
+ key: 'screenNameId',
100
+ label: 'Screen Name',
101
+ placeholder: 'Select or create screen',
102
+ searchable: true,
103
+ serverSearch: true,
104
+ allowCustomValue: true,
105
+ options: opts,
106
+ hasMore: this.hasMoreScreenNames,
107
+ isLoading: this.isLoadingScreenNames,
108
+ onSearch: (q) => this.searchScreenName.emit(q || ''),
109
+ onLoadMore: (q) => this.loadMoreScreenNames.emit(q || ''),
110
+ };
111
+ this.cdr?.markForCheck();
112
+ }
113
+ populateFormForEdit() {
114
+ if (this.element && this.elementId != null) {
115
+ this.isEditMode = true;
116
+ this.isCreateMode = false;
117
+ this.form.patchValue({
118
+ name: this.element.title ?? '',
119
+ screenNameId: this.element.screenNameId ?? null,
120
+ value: this.element.selector ?? '',
121
+ });
122
+ this.formLabels = [...(this.element.labels || [])];
123
+ this.updateScreenNameSelectConfig();
124
+ }
125
+ else {
126
+ this.isEditMode = false;
127
+ this.isCreateMode = false;
128
+ this.formLabels = [];
129
+ }
130
+ this.cdr?.markForCheck();
131
+ }
132
+ populateFormForCreateWithElement() {
133
+ if (this.element) {
134
+ this.isCreateMode = true;
135
+ this.isEditMode = false;
136
+ this.form.patchValue({
137
+ name: this.element.title ?? '',
138
+ screenNameId: this.element.screenNameId ?? null,
139
+ value: this.element.selector ?? '',
140
+ });
141
+ this.formLabels = [...(this.element.labels || [])];
142
+ this.updateScreenNameSelectConfig();
143
+ }
144
+ else {
145
+ this.isCreateMode = true;
146
+ this.isEditMode = false;
147
+ this.formLabels = [];
148
+ }
149
+ this.cdr?.markForCheck();
150
+ }
151
+ /** Called by parent when a new screen name was created (so we can set the selected value) */
152
+ setCreatedScreenName(opt) {
153
+ this.form.get('screenNameId')?.setValue(opt.id);
154
+ this.updateScreenNameSelectConfig();
155
+ this.cdr?.markForCheck();
156
+ }
157
+ onApply() {
158
+ if (this.form.invalid) {
159
+ Object.keys(this.form.controls).forEach((key) => this.form.get(key)?.markAsTouched());
160
+ return;
161
+ }
162
+ const formValue = this.form.value;
163
+ const screenNameId = formValue.screenNameId;
164
+ const selectedOpt = this.screenNameOptions.find((o) => o.id === screenNameId);
165
+ const screenNameName = selectedOpt?.name ? String(selectedOpt.name).trim() : '';
166
+ if (!screenNameId || !screenNameName) {
167
+ this.form.get('screenNameId')?.setErrors({ required: true });
168
+ this.form.get('screenNameId')?.markAsTouched();
169
+ return;
170
+ }
171
+ this.saving = true;
172
+ this.cdr?.markForCheck();
173
+ const payload = {
174
+ name: formValue.name.trim(),
175
+ screenNameId,
176
+ screenNameName,
177
+ locatorValue: formValue.value.trim(),
178
+ labels: [...this.formLabels],
179
+ };
180
+ if (this.isEditMode && this.elementId) {
181
+ this.updateElement.emit({
182
+ ...payload,
183
+ elementId: this.elementId,
184
+ });
185
+ }
186
+ else {
187
+ this.createElement.emit(payload);
188
+ }
189
+ }
190
+ onCreateOrUpdateSuccess() {
191
+ this.saving = false;
192
+ this.cdr?.markForCheck();
193
+ }
194
+ onCreateOrUpdateError() {
195
+ this.saving = false;
196
+ this.cdr?.markForCheck();
197
+ }
198
+ onCancel() {
199
+ this.cancel.emit();
200
+ }
201
+ onEditInDepth(event) {
202
+ event.preventDefault();
203
+ this.editInDepth.emit();
204
+ }
205
+ getFormControl(controlName) {
206
+ return this.form.get(controlName);
207
+ }
208
+ getFormControlValue(controlName) {
209
+ return this.form.get(controlName)?.value || '';
210
+ }
211
+ onFormControlChange(controlName, value) {
212
+ this.form.patchValue({ [controlName]: value });
213
+ this.cdr?.markForCheck();
214
+ }
215
+ /** Add a tag (label) */
216
+ addTag(tag) {
217
+ const t = (tag || this.tagInputValue || '').trim();
218
+ if (t && !this.formLabels.includes(t)) {
219
+ this.formLabels = [...this.formLabels, t];
220
+ this.tagInputValue = '';
221
+ this.cdr?.markForCheck();
222
+ }
223
+ }
224
+ removeTag(tag) {
225
+ this.formLabels = this.formLabels.filter((l) => l !== tag);
226
+ this.cdr?.markForCheck();
227
+ }
228
+ onTagInputKeydown(event) {
229
+ if (event.key === 'Enter' || event.key === ',') {
230
+ event.preventDefault();
231
+ this.addTag();
232
+ }
233
+ }
234
+ }
235
+ ElementFormComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: ElementFormComponent, deps: [{ token: i1.FormBuilder, optional: true }, { token: i0.ChangeDetectorRef, optional: true }], target: i0.ɵɵFactoryTarget.Component });
236
+ ElementFormComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.4.0", type: ElementFormComponent, selector: "cqa-element-form", inputs: { elementId: "elementId", element: "element", screenNameOptions: "screenNameOptions", hasMoreScreenNames: "hasMoreScreenNames", isLoadingScreenNames: "isLoadingScreenNames", isElementLoading: "isElementLoading", isEditMode: "isEditMode", isCreateMode: "isCreateMode", isEditInDepthAvailable: "isEditInDepthAvailable" }, outputs: { createElement: "createElement", updateElement: "updateElement", createScreenNameRequest: "createScreenNameRequest", searchScreenName: "searchScreenName", loadMoreScreenNames: "loadMoreScreenNames", cancel: "cancel", editInDepth: "editInDepth" }, host: { classAttribute: "cqa-ui-root" }, usesOnChanges: true, ngImport: i0, template: "<div class=\"cqa-flex cqa-flex-col cqa-gap-4 cqa-px-1 cqa-pt-3\">\n <div *ngIf=\"isElementLoading && isEditMode\" class=\"cqa-flex cqa-flex-col cqa-items-center cqa-justify-center cqa-gap-3 cqa-py-8\">\n <svg class=\"cqa-animate-spin cqa-h-6 cqa-w-6 cqa-text-[#3F43EE]\" xmlns=\"http://www.w3.org/2000/svg\" fill=\"none\" viewBox=\"0 0 24 24\">\n <circle class=\"cqa-opacity-25\" cx=\"12\" cy=\"12\" r=\"10\" stroke=\"currentColor\" stroke-width=\"4\"></circle>\n <path class=\"cqa-opacity-75\" fill=\"currentColor\" d=\"M4 12a8 8 0 018-8V0C5.373 0 0 5.373 0 12h4zm2 5.291A7.962 7.962 0 014 12H0c0 3.042 1.135 5.824 3 7.938l3-2.647z\"></path>\n </svg>\n <span class=\"cqa-text-[#6B7280] cqa-text-sm\">Loading element data...</span>\n </div>\n <div *ngIf=\"!isElementLoading\" class=\"cqa-flex cqa-gap-1.5\">\n <cqa-custom-input \n class=\"cqa-w-1/2\" \n label=\"Name\" \n placeholder=\"default-element\"\n [value]=\"getFormControlValue('name')\"\n [errors]=\"getFormControl('name')?.touched && getFormControl('name')?.invalid ? ['Name is required'] : []\"\n [required]=\"true\"\n (valueChange)=\"onFormControlChange('name', $event)\">\n </cqa-custom-input>\n <div class=\"cqa-w-1/2\">\n <cqa-dynamic-select [form]=\"form\" [config]=\"screenNameSelectConfig\"\n (addCustomValue)=\"createScreenNameRequest.emit($event.value)\"\n class=\"cqa-w-full\">\n </cqa-dynamic-select>\n <div *ngIf=\"getFormControl('screenNameId')?.touched && getFormControl('screenNameId')?.invalid\" class=\"cqa-flex cqa-flex-col cqa-gap-1 cqa-mt-1.5\">\n <div class=\"cqa-flex cqa-items-start cqa-gap-1.5\">\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n width=\"14\"\n height=\"14\"\n viewBox=\"0 0 14 14\"\n fill=\"none\"\n class=\"cqa-flex-shrink-0 cqa-mt-0.5\">\n <path d=\"M7 1.75C4.1 1.75 1.75 4.1 1.75 7C1.75 9.9 4.1 12.25 7 12.25C9.9 12.25 12.25 9.9 12.25 7C12.25 4.1 9.9 1.75 7 1.75ZM7 9.625C6.65625 9.625 6.375 9.34375 6.375 9V7C6.375 6.65625 6.65625 6.375 7 6.375C7.34375 6.375 7.625 6.65625 7.625 7V9C7.625 9.34375 7.34375 9.625 7 9.625ZM7.625 5.25H6.375V4H7.625V5.25Z\" fill=\"#EF4444\"/>\n </svg>\n <span class=\"cqa-text-xs cqa-text-[#EF4444] cqa-font-medium cqa-leading-[18px]\">\n Screen Name is required\n </span>\n </div>\n </div>\n </div>\n </div>\n <ng-container *ngIf=\"!isElementLoading\">\n <cqa-custom-input \n class=\"cqa-w-full\" \n label=\"Enter Value\" \n placeholder=\"#default_id or xpath\"\n [value]=\"getFormControlValue('value')\"\n [errors]=\"getFormControl('value')?.touched && getFormControl('value')?.invalid ? ['Value is required'] : []\"\n [required]=\"true\"\n (valueChange)=\"onFormControlChange('value', $event)\">\n </cqa-custom-input>\n <div class=\"cqa-w-full\">\n <label class=\"cqa-block cqa-text-[14px] cqa-font-medium cqa-text-[#374151] cqa-mb-1\">Labels (tags)</label>\n <div class=\"cqa-flex cqa-flex-wrap cqa-gap-2 cqa-p-2 cqa-border cqa-border-solid cqa-border-gray-200 cqa-rounded-md cqa-min-h-[42px]\">\n <span *ngFor=\"let tag of formLabels\"\n class=\"cqa-inline-flex cqa-items-center cqa-gap-1 cqa-px-2 cqa-py-1 cqa-bg-[#eff6ff] cqa-border cqa-border-[#c8e0ff] cqa-rounded-full cqa-text-[12px] cqa-text-[#3F43EE]\">\n {{ tag }}\n <button type=\"button\" (click)=\"removeTag(tag)\" class=\"cqa-p-0.5 hover:cqa-bg-[#c8e0ff] cqa-rounded cqa-cursor-pointer cqa-h-[16px] cqa-w-[16px]\">\n <mat-icon class=\"!cqa-w-3 !cqa-h-3 !cqa-text-[14px]\">close</mat-icon>\n </button>\n </span>\n <input type=\"text\"\n class=\"cqa-flex-1 cqa-min-w-[120px] cqa-px-2 cqa-py-1 cqa-text-sm cqa-border-0 cqa-outline-none cqa-bg-transparent\"\n placeholder=\"Type and press Enter to add\"\n [(ngModel)]=\"tagInputValue\"\n (keydown)=\"onTagInputKeydown($event)\"\n (blur)=\"addTag()\"\n [ngModelOptions]=\"{standalone: true}\">\n </div>\n </div>\n\n <div class=\"cqa-flex cqa-flex-col cqa-gap-3\">\n <div class=\"cqa-flex cqa-items-stretch cqa-gap-2 cqa-w-full\">\n <div class=\"cqa-flex-1 cqa-min-w-0\">\n <cqa-button variant=\"outlined\" btnSize=\"lg\" [text]=\"(elementId ? 'Cancel' : 'Select from Element list')\" [fullWidth]=\"true\" (clicked)=\"onCancel()\"\n [customClass]=\"'cqa-text-[14px] cqa-py-[9px] cqa-border-[#414146]'\" [disabled]=\"saving\"></cqa-button>\n </div>\n <div class=\"cqa-flex-1 cqa-min-w-0\">\n <cqa-button variant=\"filled\" btnSize=\"lg\" [text]=\"saving ? 'Saving...' : (isEditMode ? 'Update' : 'Create')\" [fullWidth]=\"true\" (clicked)=\"onApply()\"\n [customClass]=\"'cqa-text-[14px] cqa-py-[9px] cqa-border-[#3F43EE]'\" [disabled]=\"saving\"></cqa-button>\n </div>\n </div>\n </div>\n <a href=\"#\" *ngIf=\"isEditInDepthAvailable\" (click)=\"onEditInDepth($event)\"\n class=\"cqa-text-[#3F43EE] cqa-text-[12px] cqa-leading-[18px] cqa-font-medium cqa-flex cqa-items-center cqa-gap-1.5 cqa-no-underline hover:cqa-no-underline cqa-self-center\">\n <mat-icon class=\"!cqa-w-4 !cqa-h-4 !cqa-text-[16px]\">open_in_new</mat-icon>\n Edit in depth (open detailed right panel)\n </a>\n </ng-container>\n</div>\n\n\n", components: [{ type: i2.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: i3.DynamicSelectFieldComponent, selector: "cqa-dynamic-select", inputs: ["form", "config"], outputs: ["selectionChange", "selectClick", "searchChange", "loadMore", "addCustomValue"] }, { 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.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i6.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i1.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
237
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: ElementFormComponent, decorators: [{
238
+ type: Component,
239
+ args: [{ selector: 'cqa-element-form', host: { class: 'cqa-ui-root' }, changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"cqa-flex cqa-flex-col cqa-gap-4 cqa-px-1 cqa-pt-3\">\n <div *ngIf=\"isElementLoading && isEditMode\" class=\"cqa-flex cqa-flex-col cqa-items-center cqa-justify-center cqa-gap-3 cqa-py-8\">\n <svg class=\"cqa-animate-spin cqa-h-6 cqa-w-6 cqa-text-[#3F43EE]\" xmlns=\"http://www.w3.org/2000/svg\" fill=\"none\" viewBox=\"0 0 24 24\">\n <circle class=\"cqa-opacity-25\" cx=\"12\" cy=\"12\" r=\"10\" stroke=\"currentColor\" stroke-width=\"4\"></circle>\n <path class=\"cqa-opacity-75\" fill=\"currentColor\" d=\"M4 12a8 8 0 018-8V0C5.373 0 0 5.373 0 12h4zm2 5.291A7.962 7.962 0 014 12H0c0 3.042 1.135 5.824 3 7.938l3-2.647z\"></path>\n </svg>\n <span class=\"cqa-text-[#6B7280] cqa-text-sm\">Loading element data...</span>\n </div>\n <div *ngIf=\"!isElementLoading\" class=\"cqa-flex cqa-gap-1.5\">\n <cqa-custom-input \n class=\"cqa-w-1/2\" \n label=\"Name\" \n placeholder=\"default-element\"\n [value]=\"getFormControlValue('name')\"\n [errors]=\"getFormControl('name')?.touched && getFormControl('name')?.invalid ? ['Name is required'] : []\"\n [required]=\"true\"\n (valueChange)=\"onFormControlChange('name', $event)\">\n </cqa-custom-input>\n <div class=\"cqa-w-1/2\">\n <cqa-dynamic-select [form]=\"form\" [config]=\"screenNameSelectConfig\"\n (addCustomValue)=\"createScreenNameRequest.emit($event.value)\"\n class=\"cqa-w-full\">\n </cqa-dynamic-select>\n <div *ngIf=\"getFormControl('screenNameId')?.touched && getFormControl('screenNameId')?.invalid\" class=\"cqa-flex cqa-flex-col cqa-gap-1 cqa-mt-1.5\">\n <div class=\"cqa-flex cqa-items-start cqa-gap-1.5\">\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n width=\"14\"\n height=\"14\"\n viewBox=\"0 0 14 14\"\n fill=\"none\"\n class=\"cqa-flex-shrink-0 cqa-mt-0.5\">\n <path d=\"M7 1.75C4.1 1.75 1.75 4.1 1.75 7C1.75 9.9 4.1 12.25 7 12.25C9.9 12.25 12.25 9.9 12.25 7C12.25 4.1 9.9 1.75 7 1.75ZM7 9.625C6.65625 9.625 6.375 9.34375 6.375 9V7C6.375 6.65625 6.65625 6.375 7 6.375C7.34375 6.375 7.625 6.65625 7.625 7V9C7.625 9.34375 7.34375 9.625 7 9.625ZM7.625 5.25H6.375V4H7.625V5.25Z\" fill=\"#EF4444\"/>\n </svg>\n <span class=\"cqa-text-xs cqa-text-[#EF4444] cqa-font-medium cqa-leading-[18px]\">\n Screen Name is required\n </span>\n </div>\n </div>\n </div>\n </div>\n <ng-container *ngIf=\"!isElementLoading\">\n <cqa-custom-input \n class=\"cqa-w-full\" \n label=\"Enter Value\" \n placeholder=\"#default_id or xpath\"\n [value]=\"getFormControlValue('value')\"\n [errors]=\"getFormControl('value')?.touched && getFormControl('value')?.invalid ? ['Value is required'] : []\"\n [required]=\"true\"\n (valueChange)=\"onFormControlChange('value', $event)\">\n </cqa-custom-input>\n <div class=\"cqa-w-full\">\n <label class=\"cqa-block cqa-text-[14px] cqa-font-medium cqa-text-[#374151] cqa-mb-1\">Labels (tags)</label>\n <div class=\"cqa-flex cqa-flex-wrap cqa-gap-2 cqa-p-2 cqa-border cqa-border-solid cqa-border-gray-200 cqa-rounded-md cqa-min-h-[42px]\">\n <span *ngFor=\"let tag of formLabels\"\n class=\"cqa-inline-flex cqa-items-center cqa-gap-1 cqa-px-2 cqa-py-1 cqa-bg-[#eff6ff] cqa-border cqa-border-[#c8e0ff] cqa-rounded-full cqa-text-[12px] cqa-text-[#3F43EE]\">\n {{ tag }}\n <button type=\"button\" (click)=\"removeTag(tag)\" class=\"cqa-p-0.5 hover:cqa-bg-[#c8e0ff] cqa-rounded cqa-cursor-pointer cqa-h-[16px] cqa-w-[16px]\">\n <mat-icon class=\"!cqa-w-3 !cqa-h-3 !cqa-text-[14px]\">close</mat-icon>\n </button>\n </span>\n <input type=\"text\"\n class=\"cqa-flex-1 cqa-min-w-[120px] cqa-px-2 cqa-py-1 cqa-text-sm cqa-border-0 cqa-outline-none cqa-bg-transparent\"\n placeholder=\"Type and press Enter to add\"\n [(ngModel)]=\"tagInputValue\"\n (keydown)=\"onTagInputKeydown($event)\"\n (blur)=\"addTag()\"\n [ngModelOptions]=\"{standalone: true}\">\n </div>\n </div>\n\n <div class=\"cqa-flex cqa-flex-col cqa-gap-3\">\n <div class=\"cqa-flex cqa-items-stretch cqa-gap-2 cqa-w-full\">\n <div class=\"cqa-flex-1 cqa-min-w-0\">\n <cqa-button variant=\"outlined\" btnSize=\"lg\" [text]=\"(elementId ? 'Cancel' : 'Select from Element list')\" [fullWidth]=\"true\" (clicked)=\"onCancel()\"\n [customClass]=\"'cqa-text-[14px] cqa-py-[9px] cqa-border-[#414146]'\" [disabled]=\"saving\"></cqa-button>\n </div>\n <div class=\"cqa-flex-1 cqa-min-w-0\">\n <cqa-button variant=\"filled\" btnSize=\"lg\" [text]=\"saving ? 'Saving...' : (isEditMode ? 'Update' : 'Create')\" [fullWidth]=\"true\" (clicked)=\"onApply()\"\n [customClass]=\"'cqa-text-[14px] cqa-py-[9px] cqa-border-[#3F43EE]'\" [disabled]=\"saving\"></cqa-button>\n </div>\n </div>\n </div>\n <a href=\"#\" *ngIf=\"isEditInDepthAvailable\" (click)=\"onEditInDepth($event)\"\n class=\"cqa-text-[#3F43EE] cqa-text-[12px] cqa-leading-[18px] cqa-font-medium cqa-flex cqa-items-center cqa-gap-1.5 cqa-no-underline hover:cqa-no-underline cqa-self-center\">\n <mat-icon class=\"!cqa-w-4 !cqa-h-4 !cqa-text-[16px]\">open_in_new</mat-icon>\n Edit in depth (open detailed right panel)\n </a>\n </ng-container>\n</div>\n\n\n" }]
240
+ }], ctorParameters: function () { return [{ type: i1.FormBuilder, decorators: [{
241
+ type: Optional
242
+ }] }, { type: i0.ChangeDetectorRef, decorators: [{
243
+ type: Optional
244
+ }] }]; }, propDecorators: { elementId: [{
245
+ type: Input
246
+ }], element: [{
247
+ type: Input
248
+ }], screenNameOptions: [{
249
+ type: Input
250
+ }], hasMoreScreenNames: [{
251
+ type: Input
252
+ }], isLoadingScreenNames: [{
253
+ type: Input
254
+ }], isElementLoading: [{
255
+ type: Input
256
+ }], isEditMode: [{
257
+ type: Input
258
+ }], isCreateMode: [{
259
+ type: Input
260
+ }], isEditInDepthAvailable: [{
261
+ type: Input
262
+ }], createElement: [{
263
+ type: Output
264
+ }], updateElement: [{
265
+ type: Output
266
+ }], createScreenNameRequest: [{
267
+ type: Output
268
+ }], searchScreenName: [{
269
+ type: Output
270
+ }], loadMoreScreenNames: [{
271
+ type: Output
272
+ }], cancel: [{
273
+ type: Output
274
+ }], editInDepth: [{
275
+ type: Output
276
+ }] } });
277
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"element-form.component.js","sourceRoot":"","sources":["../../../../../../../src/lib/test-case-details/element-popup/element-form/element-form.component.ts","../../../../../../../src/lib/test-case-details/element-popup/element-form/element-form.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnInit,\n  Optional,\n  Output,\n  SimpleChanges,\n} from '@angular/core';\nimport { FormBuilder, FormGroup, FormControl, Validators } from '@angular/forms';\nimport { DynamicSelectFieldConfig, SelectOption } from '../../../dynamic-select/dynamic-select-field.component';\nimport { ElementCreatePayload, ElementUpdatePayload, ScreenNameOption } from '../element-popup-form-data';\nimport { ElementPopupDataElements } from '../element-popup-data';\n\n@Component({\n  selector: 'cqa-element-form',\n  templateUrl: './element-form.component.html',\n  host: { class: 'cqa-ui-root' },\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class ElementFormComponent implements OnInit, OnChanges {\n  /** Element ID when editing existing element */\n  @Input() elementId?: number;\n  /** Current element data (for edit mode) */\n  @Input() element: ElementPopupDataElements = { title: '', selector: '', labels: [] };\n  /** Screen name options for autocomplete (from API) */\n  @Input() screenNameOptions: ScreenNameOption[] = [];\n  /** Whether more screen names are available for infinite scroll */\n  @Input() hasMoreScreenNames: boolean = false;\n  /** True while parent is loading screen names (search or load more) */\n  @Input() isLoadingScreenNames: boolean = false;\n  /** True while parent is fetching latest element data for edit (shows loading state) */\n  @Input() isElementLoading: boolean = false;\n  /** Whether we're in edit mode */\n  @Input() isEditMode: boolean = false;\n  /** Whether we're in create mode */\n  @Input() isCreateMode: boolean = false;\n\n  /** Whether edit in depth is available */\n  @Input() isEditInDepthAvailable: boolean = true;\n\n  /** Emitted when user creates a new element (parent should call API) */\n  @Output() createElement = new EventEmitter<ElementCreatePayload>();\n  /** Emitted when user updates an element (parent should call API) */\n  @Output() updateElement = new EventEmitter<ElementUpdatePayload>();\n  /** Emitted when user requests to create a new screen name */\n  @Output() createScreenNameRequest = new EventEmitter<string>();\n  /** Emitted when user searches screen names (server search) */\n  @Output() searchScreenName = new EventEmitter<string>();\n  /** Emitted when user scrolls to load more screen names (passes current search query) */\n  @Output() loadMoreScreenNames = new EventEmitter<string>();\n  /** Emitted when user clicks \"Select from Element list\" or \"Cancel\" */\n  @Output() cancel = new EventEmitter<void>();\n  /** Emitted when user clicks \"Edit in depth\" */\n  @Output() editInDepth = new EventEmitter<void>();\n\n  form!: FormGroup;\n  /** Labels (tags) as string array for multi-tag input */\n  formLabels: string[] = [];\n  /** Current tag input value */\n  tagInputValue = '';\n  /** Config for screen name dynamic-select (server search, allowCustomValue, infinite scroll) */\n  screenNameSelectConfig!: DynamicSelectFieldConfig;\n  /** Whether we're saving (disable buttons) */\n  saving = false;\n\n  private fb: FormBuilder;\n\n  constructor(\n    @Optional() fb?: FormBuilder,\n    @Optional() private readonly cdr?: ChangeDetectorRef\n  ) {\n    this.fb = fb || new FormBuilder();\n    this.initializeForm();\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes['screenNameOptions'] || changes['hasMoreScreenNames'] || changes['isLoadingScreenNames']) {\n      this.updateScreenNameSelectConfig();\n    }\n    if ((changes['element'] || changes['elementId']) && this.elementId) {\n      this.populateFormForEdit();\n    } else if (changes['element'] && !this.elementId && this.isCreateMode) {\n      this.populateFormForCreateWithElement();\n    }\n  }\n\n  ngOnInit(): void {\n    if (this.elementId) {\n      this.populateFormForEdit();\n    } else if (this.isCreateMode && this.element) {\n      this.populateFormForCreateWithElement();\n    }\n  }\n\n  private initializeForm(): void {\n    this.form = this.fb.group({\n      name: ['', [Validators.required]],\n      screenNameId: [null as number | null, [Validators.required]],\n      value: ['', [Validators.required]],\n    });\n    this.updateScreenNameSelectConfig();\n  }\n\n  private updateScreenNameSelectConfig(): void {\n    const opts: SelectOption[] = (this.screenNameOptions || []).map((o) => ({\n      id: o.id,\n      value: o.id,\n      name: o.name,\n      label: o.name,\n    }));\n    const currentId = this.form?.get('screenNameId')?.value;\n    if (currentId && this.element?.screenNameId === currentId && this.element?.screenName) {\n      const exists = opts.some((o) => o.id === currentId);\n      if (!exists) {\n        opts.unshift({\n          id: currentId,\n          value: currentId,\n          name: String(this.element.screenName),\n          label: String(this.element.screenName),\n        });\n      }\n    }\n    this.screenNameSelectConfig = {\n      key: 'screenNameId',\n      label: 'Screen Name',\n      placeholder: 'Select or create screen',\n      searchable: true,\n      serverSearch: true,\n      allowCustomValue: true,\n      options: opts,\n      hasMore: this.hasMoreScreenNames,\n      isLoading: this.isLoadingScreenNames,\n      onSearch: (q) => this.searchScreenName.emit(q || ''),\n      onLoadMore: (q) => this.loadMoreScreenNames.emit(q || ''),\n    };\n    this.cdr?.markForCheck();\n  }\n\n  private populateFormForEdit(): void {\n    if (this.element && this.elementId != null) {\n      this.isEditMode = true;\n      this.isCreateMode = false;\n      this.form.patchValue({\n        name: this.element.title ?? '',\n        screenNameId: this.element.screenNameId ?? null,\n        value: this.element.selector ?? '',\n      });\n      this.formLabels = [...(this.element.labels || [])];\n      this.updateScreenNameSelectConfig();\n    } else {\n      this.isEditMode = false;\n      this.isCreateMode = false;\n      this.formLabels = [];\n    }\n    this.cdr?.markForCheck();\n  }\n\n  private populateFormForCreateWithElement(): void {\n    if (this.element) {\n      this.isCreateMode = true;\n      this.isEditMode = false;\n      this.form.patchValue({\n        name: this.element.title ?? '',\n        screenNameId: this.element.screenNameId ?? null,\n        value: this.element.selector ?? '',\n      });\n      this.formLabels = [...(this.element.labels || [])];\n      this.updateScreenNameSelectConfig();\n    } else {\n      this.isCreateMode = true;\n      this.isEditMode = false;\n      this.formLabels = [];\n    }\n    this.cdr?.markForCheck();\n  }\n\n  /** Called by parent when a new screen name was created (so we can set the selected value) */\n  setCreatedScreenName(opt: { id: number; name: string }): void {\n    this.form.get('screenNameId')?.setValue(opt.id);\n    this.updateScreenNameSelectConfig();\n    this.cdr?.markForCheck();\n  }\n\n  onApply(): void {\n    if (this.form.invalid) {\n      Object.keys(this.form.controls).forEach((key) =>\n        this.form.get(key)?.markAsTouched()\n      );\n      return;\n    }\n\n    const formValue = this.form.value;\n    const screenNameId = formValue.screenNameId;\n    const selectedOpt = this.screenNameOptions.find((o) => o.id === screenNameId);\n    const screenNameName = selectedOpt?.name ? String(selectedOpt.name).trim() : '';\n    if (!screenNameId || !screenNameName) {\n      this.form.get('screenNameId')?.setErrors({ required: true });\n      this.form.get('screenNameId')?.markAsTouched();\n      return;\n    }\n\n    this.saving = true;\n    this.cdr?.markForCheck();\n\n    const payload = {\n      name: formValue.name.trim(),\n      screenNameId,\n      screenNameName,\n      locatorValue: formValue.value.trim(),\n      labels: [...this.formLabels],\n    };\n\n    if (this.isEditMode && this.elementId) {\n      this.updateElement.emit({\n        ...payload,\n        elementId: this.elementId,\n      });\n    } else {\n      this.createElement.emit(payload);\n    }\n  }\n\n  onCreateOrUpdateSuccess(): void {\n    this.saving = false;\n    this.cdr?.markForCheck();\n  }\n\n  onCreateOrUpdateError(): void {\n    this.saving = false;\n    this.cdr?.markForCheck();\n  }\n\n  onCancel(): void {\n    this.cancel.emit();\n  }\n\n  onEditInDepth(event: Event): void {\n    event.preventDefault();\n    this.editInDepth.emit();\n  }\n\n  getFormControl(controlName: string): FormControl {\n    return this.form.get(controlName) as FormControl;\n  }\n\n  getFormControlValue(controlName: string): string {\n    return this.form.get(controlName)?.value || '';\n  }\n\n  onFormControlChange(controlName: string, value: string): void {\n    this.form.patchValue({ [controlName]: value });\n    this.cdr?.markForCheck();\n  }\n\n  /** Add a tag (label) */\n  addTag(tag?: string): void {\n    const t = (tag || this.tagInputValue || '').trim();\n    if (t && !this.formLabels.includes(t)) {\n      this.formLabels = [...this.formLabels, t];\n      this.tagInputValue = '';\n      this.cdr?.markForCheck();\n    }\n  }\n\n  removeTag(tag: string): void {\n    this.formLabels = this.formLabels.filter((l) => l !== tag);\n    this.cdr?.markForCheck();\n  }\n\n  onTagInputKeydown(event: KeyboardEvent): void {\n    if (event.key === 'Enter' || event.key === ',') {\n      event.preventDefault();\n      this.addTag();\n    }\n  }\n}\n\n\n","<div class=\"cqa-flex cqa-flex-col cqa-gap-4 cqa-px-1 cqa-pt-3\">\n  <div *ngIf=\"isElementLoading && isEditMode\" class=\"cqa-flex cqa-flex-col cqa-items-center cqa-justify-center cqa-gap-3 cqa-py-8\">\n    <svg class=\"cqa-animate-spin cqa-h-6 cqa-w-6 cqa-text-[#3F43EE]\" xmlns=\"http://www.w3.org/2000/svg\" fill=\"none\" viewBox=\"0 0 24 24\">\n      <circle class=\"cqa-opacity-25\" cx=\"12\" cy=\"12\" r=\"10\" stroke=\"currentColor\" stroke-width=\"4\"></circle>\n      <path class=\"cqa-opacity-75\" fill=\"currentColor\" d=\"M4 12a8 8 0 018-8V0C5.373 0 0 5.373 0 12h4zm2 5.291A7.962 7.962 0 014 12H0c0 3.042 1.135 5.824 3 7.938l3-2.647z\"></path>\n    </svg>\n    <span class=\"cqa-text-[#6B7280] cqa-text-sm\">Loading element data...</span>\n  </div>\n  <div *ngIf=\"!isElementLoading\" class=\"cqa-flex cqa-gap-1.5\">\n    <cqa-custom-input \n      class=\"cqa-w-1/2\" \n      label=\"Name\" \n      placeholder=\"default-element\"\n      [value]=\"getFormControlValue('name')\"\n      [errors]=\"getFormControl('name')?.touched && getFormControl('name')?.invalid ? ['Name is required'] : []\"\n      [required]=\"true\"\n      (valueChange)=\"onFormControlChange('name', $event)\">\n    </cqa-custom-input>\n    <div class=\"cqa-w-1/2\">\n      <cqa-dynamic-select [form]=\"form\" [config]=\"screenNameSelectConfig\"\n        (addCustomValue)=\"createScreenNameRequest.emit($event.value)\"\n        class=\"cqa-w-full\">\n      </cqa-dynamic-select>\n      <div *ngIf=\"getFormControl('screenNameId')?.touched && getFormControl('screenNameId')?.invalid\" class=\"cqa-flex cqa-flex-col cqa-gap-1 cqa-mt-1.5\">\n        <div class=\"cqa-flex cqa-items-start cqa-gap-1.5\">\n          <svg\n            xmlns=\"http://www.w3.org/2000/svg\"\n            width=\"14\"\n            height=\"14\"\n            viewBox=\"0 0 14 14\"\n            fill=\"none\"\n            class=\"cqa-flex-shrink-0 cqa-mt-0.5\">\n            <path d=\"M7 1.75C4.1 1.75 1.75 4.1 1.75 7C1.75 9.9 4.1 12.25 7 12.25C9.9 12.25 12.25 9.9 12.25 7C12.25 4.1 9.9 1.75 7 1.75ZM7 9.625C6.65625 9.625 6.375 9.34375 6.375 9V7C6.375 6.65625 6.65625 6.375 7 6.375C7.34375 6.375 7.625 6.65625 7.625 7V9C7.625 9.34375 7.34375 9.625 7 9.625ZM7.625 5.25H6.375V4H7.625V5.25Z\" fill=\"#EF4444\"/>\n          </svg>\n          <span class=\"cqa-text-xs cqa-text-[#EF4444] cqa-font-medium cqa-leading-[18px]\">\n            Screen Name is required\n          </span>\n        </div>\n      </div>\n    </div>\n  </div>\n  <ng-container *ngIf=\"!isElementLoading\">\n    <cqa-custom-input \n      class=\"cqa-w-full\"  \n      label=\"Enter Value\" \n      placeholder=\"#default_id or xpath\"\n      [value]=\"getFormControlValue('value')\"\n      [errors]=\"getFormControl('value')?.touched && getFormControl('value')?.invalid ? ['Value is required'] : []\"\n      [required]=\"true\"\n      (valueChange)=\"onFormControlChange('value', $event)\">\n    </cqa-custom-input>\n    <div class=\"cqa-w-full\">\n      <label class=\"cqa-block cqa-text-[14px] cqa-font-medium cqa-text-[#374151] cqa-mb-1\">Labels (tags)</label>\n      <div class=\"cqa-flex cqa-flex-wrap cqa-gap-2 cqa-p-2 cqa-border cqa-border-solid cqa-border-gray-200 cqa-rounded-md cqa-min-h-[42px]\">\n        <span *ngFor=\"let tag of formLabels\"\n          class=\"cqa-inline-flex cqa-items-center cqa-gap-1 cqa-px-2 cqa-py-1 cqa-bg-[#eff6ff] cqa-border cqa-border-[#c8e0ff] cqa-rounded-full cqa-text-[12px] cqa-text-[#3F43EE]\">\n          {{ tag }}\n          <button type=\"button\" (click)=\"removeTag(tag)\" class=\"cqa-p-0.5 hover:cqa-bg-[#c8e0ff] cqa-rounded cqa-cursor-pointer cqa-h-[16px] cqa-w-[16px]\">\n            <mat-icon class=\"!cqa-w-3 !cqa-h-3 !cqa-text-[14px]\">close</mat-icon>\n          </button>\n        </span>\n        <input type=\"text\"\n          class=\"cqa-flex-1 cqa-min-w-[120px] cqa-px-2 cqa-py-1 cqa-text-sm cqa-border-0 cqa-outline-none cqa-bg-transparent\"\n          placeholder=\"Type and press Enter to add\"\n          [(ngModel)]=\"tagInputValue\"\n          (keydown)=\"onTagInputKeydown($event)\"\n          (blur)=\"addTag()\"\n          [ngModelOptions]=\"{standalone: true}\">\n      </div>\n    </div>\n\n    <div class=\"cqa-flex cqa-flex-col cqa-gap-3\">\n      <div class=\"cqa-flex cqa-items-stretch cqa-gap-2 cqa-w-full\">\n        <div class=\"cqa-flex-1 cqa-min-w-0\">\n          <cqa-button variant=\"outlined\" btnSize=\"lg\" [text]=\"(elementId ? 'Cancel' : 'Select from Element list')\" [fullWidth]=\"true\" (clicked)=\"onCancel()\"\n            [customClass]=\"'cqa-text-[14px] cqa-py-[9px] cqa-border-[#414146]'\" [disabled]=\"saving\"></cqa-button>\n        </div>\n        <div class=\"cqa-flex-1 cqa-min-w-0\">\n          <cqa-button variant=\"filled\" btnSize=\"lg\" [text]=\"saving ? 'Saving...' : (isEditMode ? 'Update' : 'Create')\" [fullWidth]=\"true\" (clicked)=\"onApply()\"\n            [customClass]=\"'cqa-text-[14px] cqa-py-[9px] cqa-border-[#3F43EE]'\" [disabled]=\"saving\"></cqa-button>\n        </div>\n      </div>\n    </div>\n    <a href=\"#\" *ngIf=\"isEditInDepthAvailable\" (click)=\"onEditInDepth($event)\"\n      class=\"cqa-text-[#3F43EE] cqa-text-[12px] cqa-leading-[18px] cqa-font-medium cqa-flex cqa-items-center cqa-gap-1.5 cqa-no-underline hover:cqa-no-underline cqa-self-center\">\n      <mat-icon class=\"!cqa-w-4 !cqa-h-4 !cqa-text-[16px]\">open_in_new</mat-icon>\n      Edit in depth (open detailed right panel)\n    </a>\n  </ng-container>\n</div>\n\n\n"]}