@cqa-lib/cqa-ui 1.1.548-gamma.23 → 1.1.548-gamma.25
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/execution-screen/condition-debug-step/condition-branch-editor.component.mjs +1 -1
- package/esm2020/lib/manage-columns-dialog/manage-columns-dialog.component.mjs +3 -3
- package/esm2020/lib/new-global-variable-dialog/global-variable-tags-input.component.mjs +3 -3
- package/esm2020/lib/new-global-variable-dialog/new-global-variable-dialog.component.mjs +3 -3
- package/esm2020/lib/step-builder/step-builder-action/step-builder-action.component.mjs +7 -4
- package/esm2020/lib/step-builder/step-builder-ai-agent/step-builder-ai-agent.component.mjs +3 -3
- package/esm2020/lib/step-builder/step-builder-condition/step-builder-condition.component.mjs +5 -4
- package/esm2020/lib/step-builder/step-builder-database/step-builder-database.component.mjs +3 -3
- package/esm2020/lib/step-builder/step-builder-loop/step-builder-loop.component.mjs +226 -11
- package/esm2020/lib/step-builder/template-variables-form/template-variables-form.component.mjs +214 -8
- package/esm2020/lib/test-case-details/api-edit-step/api-edit-step.component.mjs +3 -3
- package/esm2020/lib/test-case-details/test-case-details-edit/test-case-details-edit.component.mjs +3 -3
- package/esm2020/lib/test-case-details/test-case-details.models.mjs +5 -3
- package/esm2020/lib/test-case-details/variables-panel/available-variable-row.component.mjs +3 -3
- package/esm2020/lib/test-case-details/variables-panel/used-variable-row.component.mjs +3 -3
- package/esm2020/lib/test-case-details/variables-panel/variables-panel.component.mjs +3 -3
- package/esm2020/lib/ui-kit.module.mjs +6 -1
- package/esm2020/lib/variable-picker/variable-picker.component.mjs +426 -0
- package/esm2020/lib/variable-picker/variable-picker.models.mjs +14 -0
- package/esm2020/public-api.mjs +3 -1
- package/fesm2015/cqa-lib-cqa-ui.mjs +953 -80
- package/fesm2015/cqa-lib-cqa-ui.mjs.map +1 -1
- package/fesm2020/cqa-lib-cqa-ui.mjs +924 -67
- package/fesm2020/cqa-lib-cqa-ui.mjs.map +1 -1
- package/lib/execution-screen/condition-debug-step/condition-branch-editor.component.d.ts +2 -0
- package/lib/step-builder/step-builder-action/step-builder-action.component.d.ts +6 -1
- package/lib/step-builder/step-builder-condition/step-builder-condition.component.d.ts +4 -1
- package/lib/step-builder/step-builder-loop/step-builder-loop.component.d.ts +87 -1
- package/lib/step-builder/template-variables-form/template-variables-form.component.d.ts +41 -1
- package/lib/ui-kit.module.d.ts +100 -99
- package/lib/variable-picker/variable-picker.component.d.ts +130 -0
- package/lib/variable-picker/variable-picker.models.d.ts +122 -0
- package/package.json +1 -1
- package/public-api.d.ts +2 -0
- package/styles.css +1 -1
package/esm2020/lib/execution-screen/condition-debug-step/condition-branch-editor.component.mjs
CHANGED
|
@@ -446,4 +446,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImpor
|
|
|
446
446
|
}], searchGlobalVariables: [{
|
|
447
447
|
type: Output
|
|
448
448
|
}] } });
|
|
449
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"condition-branch-editor.component.js","sourceRoot":"","sources":["../../../../../../src/lib/execution-screen/condition-debug-step/condition-branch-editor.component.ts","../../../../../../src/lib/execution-screen/condition-debug-step/condition-branch-editor.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component, Input, Output, EventEmitter, OnInit, OnChanges, SimpleChanges,\n  ChangeDetectionStrategy, ChangeDetectorRef\n} from '@angular/core';\nimport { FormArray, FormBuilder, FormGroup, FormControl, Validators } from '@angular/forms';\nimport { DynamicSelectFieldConfig, SelectOption } from '../../dynamic-select/dynamic-select-field.component';\nimport { ActionTemplate } from '../../step-builder/step-builder-action/step-builder-action.component';\n\nexport interface ConditionBranchSaveData {\n  template: ActionTemplate | null;\n  templateVariables: any[];\n  advancedSettingsVariables: any[];\n  action: string;\n  /** Resolved HTML grammar with actual variable values substituted — use for display/conditionText */\n  resolvedAction: string;\n  description: string;\n  metadata: string;\n  /** Derived from advancedSettingsVariables 'shouldSkip' entry — step should be skipped during execution */\n  shouldSkip: boolean;\n  /** Derived from advancedSettingsVariables 'isStepOptional' entry — step failure should not fail the test */\n  ignoreStepResult: boolean;\n}\n\n/**\n * Lightweight single-condition editor used in debug mode to:\n *  - Add a new ELSE IF branch (mode = 'add-else-if')\n *  - Edit an existing IF or ELSE IF condition (mode = 'edit')\n *\n * This is a simplified variant of StepBuilderConditionComponent with one condition row.\n */\n@Component({\n  selector: 'cqa-condition-branch-editor',\n  templateUrl: './condition-branch-editor.component.html',\n  styleUrls: [],\n  host: { class: 'cqa-ui-root' },\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class ConditionBranchEditorComponent implements OnInit, OnChanges {\n\n  /** 'add-else-if' shows \"Add ELSE IF\" title/button; 'edit' shows \"Edit Condition\" title/button */\n  @Input() mode: 'add-else-if' | 'edit' = 'add-else-if';\n\n  /** List of condition action templates (filtered to IF_CONDITION type) */\n  @Input() conditionTemplates: ActionTemplate[] = [];\n\n  /** Called to derive template variables from a selected template */\n  @Input() setConditionTemplateVariables: (template: ActionTemplate, testStep?: any) => any[] = () => [];\n\n  /** Called to derive advanced settings variables */\n  @Input() setAdvancedSettingsVariables: (template: ActionTemplate, testStep?: any) => any[] = () => [];\n\n  /** Centralised HTML grammar computation function */\n  @Input() computeHtmlGrammarFn?: (template: any, variables: any[]) => string;\n\n  /** Element options for variable forms */\n  @Input() elementOptions: any[] = [];\n  @Input() hasMoreElements: boolean = false;\n  @Input() isLoadingElements: boolean = false;\n  @Input() screenNameOptions: { id?: number; name: string }[] = [];\n  @Input() hasMoreScreenNames: boolean = false;\n  @Input() isLoadingScreenNames: boolean = false;\n  @Input() parameterOptions: any[] = [];\n  @Input() hasMoreParameters: boolean = false;\n  @Input() isLoadingParameters: boolean = false;\n  @Input() environmentOptions: { id: string; name: string; value: string; environment: string }[] = [];\n  @Input() hasMoreEnvironments: boolean = false;\n  @Input() isLoadingEnvironments: boolean = false;\n  /** Resolved test-case env name; drives banner + env-dropdown auto-select + lock in inner template-variables-form. */\n  @Input() testCaseEnvironmentName?: string;\n  /** Suffix on the env-name option label (e.g. '(default)'). Also locks the env dropdown. */\n  @Input() testCaseEnvironmentLabelSuffix?: string;\n  /** Italic note rendered under env dropdown in the inner form. */\n  @Input() environmentLegacyDeprecationMessage?: string;\n  /** Test case's TDP id — gates the Test Data Profile tab in the inner form. */\n  @Input() testCaseTestDataId?: number | null;\n  /** When true (or `isInsideForLoopStep` true), the inner form shows the Test\n   *  Data Profile segment. Without this, the lib defaults the segment in,\n   *  even though the test case has no TDP — which is what shows the tab in the\n   *  debug-screen condition-branch editor. */\n  @Input() hasTestDataProfile: boolean = false;\n  /** True when this branch lives inside a FOR-loop step. */\n  @Input() isInsideForLoopStep: boolean = false;\n  /** Workspace-scoped global variables for the Global Data tab. */\n  @Input() globalVariableOptions: { id: number | string; name: string; value: string; type?: string; readWriteMode?: string }[] = [];\n  @Input() isLoadingGlobalVariables: boolean = false;\n  @Input() defaultTestDataProfileId?: number;\n  @Input() defaultTestDataStartIndex?: number;\n  /**\n   * End index of the inherited dataset range (0-based). Drives both the\n   * Data Set End dropdown lock and the auto-population of test-data variables\n   * from the end-row inside cqa-template-variables-form. Forwarded to the\n   * inner form. Without this, the parent (e.g. debug-screen condition-branch\n   * flow) can't fully reproduce the lock parity that\n   * cqa-step-builder-action gets via app-step-builder.\n   */\n  @Input() defaultTestDataEndIndex?: number;\n\n  /** When provided, pre-populates the form for edit mode. shape: { templateId, templateVariables, action } */\n  @Input() initialConditionData?: {\n    templateId?: string | number;\n    templateVariables?: any[];\n    action?: string;\n    description?: string;\n    metadata?: string;\n  };\n\n  /** Raw branch step object — passed through to setConditionTemplateVariables so the service can extract saved values from step.event */\n  @Input() editTestStep?: any;\n\n  /** Label shown next to the condition template dropdown (e.g. 'IF', 'ELSE IF'). Inferred from mode when not provided. */\n  @Input() branchLabel?: string;\n\n  /** True while the parent is saving (disables/shows loader on Save button) */\n  @Input() isSaving: boolean = false;\n\n  @Output() save = new EventEmitter<ConditionBranchSaveData>();\n  @Output() cancelled = new EventEmitter<void>();\n  @Output() loadMoreElements = new EventEmitter<void>();\n  @Output() searchElements = new EventEmitter<string>();\n  @Output() searchElementsByScreenName = new EventEmitter<{ screenNameId: number; searchTerm?: string }>();\n  @Output() createElement = new EventEmitter<any>();\n  @Output() searchScreenName = new EventEmitter<string>();\n  @Output() loadMoreScreenNames = new EventEmitter<string>();\n  @Output() createScreenNameRequest = new EventEmitter<string>();\n  @Output() searchParameters = new EventEmitter<string>();\n  @Output() loadMoreParameters = new EventEmitter<void>();\n  @Output() searchEnvironments = new EventEmitter<string>();\n  @Output() loadMoreEnvironments = new EventEmitter<void>();\n  @Output() searchGlobalVariables = new EventEmitter<string>();\n\n  conditionForm!: FormGroup;\n\n  private selectedTemplate: ActionTemplate | null = null;\n  private templateVariables: any[] = [];\n  private variablesForm!: FormArray;\n  private advancedSettingsVariables: any[] = [];\n  private advancedVariablesForm!: FormArray;\n  private advancedExpanded = false;\n  private updatedHtmlGrammar = '';\n\n  private valueConfigCache: DynamicSelectFieldConfig | null = null;\n  private valueConfigWithHandler: DynamicSelectFieldConfig | null = null;\n\n  get title(): string {\n    return this.mode === 'edit' ? 'Edit Condition' : 'Add ELSE IF';\n  }\n\n  get saveButtonLabel(): string {\n    return this.mode === 'edit' ? 'Save' : 'Add ELSE IF';\n  }\n\n  get conditionRowLabel(): string {\n    return this.branchLabel ?? (this.mode === 'edit' ? 'IF' : 'ELSE IF');\n  }\n\n  constructor(private fb: FormBuilder, private cdr: ChangeDetectorRef) {}\n\n  ngOnInit(): void {\n    this.variablesForm = this.fb.array([]);\n    this.advancedVariablesForm = this.fb.array([]);\n\n    this.conditionForm = this.fb.group({\n      value: [null, Validators.required],\n      description: [''],\n      metadata: [''],\n    });\n\n    this.updateValueConfigCache();\n\n    // Pre-populate for edit mode\n    if (this.mode === 'edit' && this.initialConditionData) {\n      this.prefillFromInitialData();\n    }\n\n    this.cdr.markForCheck();\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes['conditionTemplates'] && !changes['conditionTemplates'].firstChange) {\n      this.updateValueConfigCache();\n      this.valueConfigWithHandler = null;\n      // Re-prefill if we now have templates and were waiting\n      if (this.mode === 'edit' && this.initialConditionData && !this.selectedTemplate) {\n        this.prefillFromInitialData();\n      }\n    }\n    this.cdr.markForCheck();\n  }\n\n  private prefillFromInitialData(): void {\n    if (!this.initialConditionData || !this.conditionTemplates?.length) return;\n\n    const { templateId, action, description, metadata } = this.initialConditionData;\n\n    // Find matching template\n    let template: ActionTemplate | undefined;\n    if (templateId != null) {\n      template = this.conditionTemplates.find(\n        t => String(t.id) === String(templateId) || t.displayName === String(templateId)\n      );\n    }\n    if (!template && action) {\n      template = this.conditionTemplates.find(\n        t => t.naturalText === action || t.htmlGrammar === action || t.displayName === action\n      );\n    }\n\n    if (template) {\n      const selectId = template.id?.toString() || template.displayName || '';\n      this.conditionForm?.get('value')?.setValue(selectId, { emitEvent: false });\n      this.selectedTemplate = template;\n\n      // Get fresh variables structure with saved values by passing the raw step\n      const vars = this.setConditionTemplateVariables(template, this.editTestStep);\n      this.templateVariables = vars;\n\n      this.buildVariablesForm();\n      this.updateHtmlGrammar();\n\n      // Advanced variables\n      if (this.setAdvancedSettingsVariables) {\n        this.advancedSettingsVariables = this.setAdvancedSettingsVariables(template, this.editTestStep);\n        this.buildAdvancedVariablesForm();\n      }\n    }\n\n    if (description) this.conditionForm?.get('description')?.setValue(description, { emitEvent: false });\n    if (metadata) this.conditionForm?.get('metadata')?.setValue(metadata, { emitEvent: false });\n    this.cdr.markForCheck();\n  }\n\n  private updateValueConfigCache(): void {\n    const opts: SelectOption[] = (this.conditionTemplates || []).map(t => ({\n      id: t.id?.toString() || t.displayName || '',\n      value: t.id?.toString() || t.displayName || '',\n      name: t.htmlGrammar || t.naturalText || '',\n      label: t.htmlGrammar || t.naturalText || ''\n    }));\n    this.valueConfigCache = {\n      key: 'value',\n      placeholder: 'Select Condition Template*',\n      multiple: false,\n      searchable: true,\n      displayLabelAsInnerHtml: true,\n      options: opts\n    };\n  }\n\n  getValueConfig(): DynamicSelectFieldConfig {\n    if (this.valueConfigWithHandler) return this.valueConfigWithHandler;\n    if (!this.valueConfigCache) this.updateValueConfigCache();\n    this.valueConfigWithHandler = {\n      ...this.valueConfigCache!,\n      onChange: (v: any) => this.onTemplateValueChange(v)\n    };\n    return this.valueConfigWithHandler;\n  }\n\n  onTemplateValueChange(templateId: any): void {\n    const template = this.conditionTemplates.find(\n      t => String(t.id) === String(templateId) || t.displayName === String(templateId)\n    );\n    if (template) {\n      this.selectedTemplate = template;\n      this.templateVariables = this.setConditionTemplateVariables(template);\n      this.buildVariablesForm();\n      this.updateHtmlGrammar();\n      if (this.setAdvancedSettingsVariables) {\n        this.advancedSettingsVariables = this.setAdvancedSettingsVariables(template);\n        this.buildAdvancedVariablesForm();\n      }\n    } else {\n      this.selectedTemplate = null;\n      this.templateVariables = [];\n      this.clearVariablesForm();\n      this.advancedSettingsVariables = [];\n      this.clearAdvancedVariablesForm();\n    }\n    this.cdr.markForCheck();\n  }\n\n  private buildVariablesForm(): void {\n    while (this.variablesForm.length) this.variablesForm.removeAt(0);\n    this.templateVariables.forEach(variable => {\n      const defaultValue = variable.type === 'boolean'\n        ? (variable.value === true || variable.value === 'true' || variable.value === 1)\n        : (variable.value || '');\n      const group = this.fb.group({\n        name: [variable.name],\n        value: [defaultValue],\n        type: [variable.type || 'string'],\n        label: [variable.label || ''],\n        options: [variable.options || []]\n      });\n      const label = variable.label?.toLowerCase() || '';\n      if (label === 'test-data' || label === 'source-value' || label === 'target-value' ||\n          label === 'source_value' || label === 'target_value') {\n        const valueStr = String(defaultValue || '');\n        let dataType = 'plain-text';\n        if (valueStr.startsWith('@|') && valueStr.endsWith('|')) dataType = 'parameter';\n        else if (valueStr.startsWith('$|') && valueStr.endsWith('|')) dataType = 'runtime';\n        else if (valueStr.startsWith('*|') && valueStr.endsWith('|')) dataType = 'environment';\n        group.addControl('dataType', new FormControl(dataType));\n      }\n      this.variablesForm.push(group);\n    });\n  }\n\n  private clearVariablesForm(): void {\n    while (this.variablesForm.length) this.variablesForm.removeAt(0);\n  }\n\n  private buildAdvancedVariablesForm(): void {\n    while (this.advancedVariablesForm.length) this.advancedVariablesForm.removeAt(0);\n    this.advancedSettingsVariables.forEach(variable => {\n      let defaultValue: any;\n      if (variable.type === 'str_list') {\n        const arr = Array.isArray(variable.value) ? variable.value : [];\n        defaultValue = this.fb.array(arr.length > 0 ? arr.map((i: string) => this.fb.control(i)) : [this.fb.control('')]);\n      } else if (variable.type === 'boolean') {\n        defaultValue = variable.value === true || variable.value === 'true' || variable.value === 1;\n      } else {\n        defaultValue = variable.value || '';\n      }\n      const group = this.fb.group({\n        name: [variable.name],\n        value: variable.type === 'str_list' ? defaultValue : [defaultValue],\n        type: [variable.type || 'string'],\n        label: [variable.label || '']\n      });\n      this.advancedVariablesForm.push(group);\n    });\n  }\n\n  private clearAdvancedVariablesForm(): void {\n    while (this.advancedVariablesForm.length) this.advancedVariablesForm.removeAt(0);\n  }\n\n  private updateHtmlGrammar(): void {\n    if (!this.selectedTemplate?.htmlGrammar) { this.updatedHtmlGrammar = ''; return; }\n    if (this.computeHtmlGrammarFn) {\n      this.updatedHtmlGrammar = this.computeHtmlGrammarFn(this.selectedTemplate, this.templateVariables);\n      return;\n    }\n    let g = this.selectedTemplate.htmlGrammar;\n    this.templateVariables.forEach(v => {\n      const re = new RegExp(`<span[^>]*data-event-key=\"${v.name}\"[^>]*>.*?</span>`, 'gi');\n      const escaped = String(v.value || '').replace(/&/g, '&amp;').replace(/</g, '&lt;').replace(/>/g, '&gt;');\n      g = g.replace(re, escaped);\n    });\n    this.updatedHtmlGrammar = g;\n  }\n\n  get currentHtmlGrammar(): string {\n    return this.updatedHtmlGrammar || this.selectedTemplate?.htmlGrammar || this.selectedTemplate?.naturalText || '';\n  }\n\n  getTemplateVariables(): any[] { return this.templateVariables; }\n  getVariablesForm(): FormArray { return this.variablesForm; }\n  getAdvancedVariables(): any[] { return this.advancedSettingsVariables; }\n  getAdvancedVariablesForm(): FormArray { return this.advancedVariablesForm; }\n  get isAdvancedExpanded(): boolean { return this.advancedExpanded; }\n  toggleAdvanced(): void { this.advancedExpanded = !this.advancedExpanded; this.cdr.markForCheck(); }\n  get hasSelectedTemplate(): ActionTemplate | null { return this.selectedTemplate; }\n\n  onVariableValueChange(name: string, value: any): void {\n    const v = this.templateVariables.find(tv => tv.name === name);\n    if (v) v.value = value;\n    const idx = this.variablesForm.controls.findIndex(c => c.get('name')?.value === name);\n    if (idx !== -1) this.variablesForm.at(idx).get('value')?.setValue(value, { emitEvent: false });\n    this.updateHtmlGrammar();\n    this.cdr.markForCheck();\n  }\n\n  onVariableBooleanChange(name: string, value: boolean): void {\n    this.onVariableValueChange(name, value);\n  }\n\n  onAdvancedVariableValueChange(name: string, value: any): void {\n    const v = this.advancedSettingsVariables.find(tv => tv.name === name);\n    if (v) v.value = value;\n    const idx = this.advancedVariablesForm.controls.findIndex(c => c.get('name')?.value === name);\n    if (idx !== -1 && v?.type !== 'str_list') {\n      (this.advancedVariablesForm.at(idx) as FormGroup).get('value')?.setValue(value, { emitEvent: false });\n    }\n  }\n\n  onAdvancedVariableBooleanChange(name: string, value: boolean): void {\n    this.onAdvancedVariableValueChange(name, value);\n  }\n\n  isFormValid(): boolean {\n    if (!this.conditionForm.valid) return false;\n    return this.templateVariables.every(v => {\n      if (v.dataKey === 'element' || v.dataKey === 'test_data' || v.dataKey === 'source_value' || v.dataKey === 'target_value') {\n        return v.value !== null && v.value !== undefined && v.value !== '';\n      }\n      return true;\n    });\n  }\n\n  onCancel(): void { this.cancelled.emit(); }\n\n  onSave(): void {\n    if (!this.isFormValid()) return;\n    // Sync advanced form values back to array\n    this.advancedSettingsVariables.forEach((variable, i) => {\n      const fg = this.advancedVariablesForm.at(i) as FormGroup;\n      if (!fg) return;\n      const fv = fg.get('value')?.value;\n      if (variable.type === 'str_list' && fv instanceof FormArray) {\n        variable.value = fv.controls.map(c => c.value).filter((val: string) => val?.trim() !== '');\n      } else {\n        variable.value = fv;\n      }\n    });\n\n    const finalAdvancedVars = [...this.advancedSettingsVariables];\n    const shouldSkipVar = finalAdvancedVars.find(v => v.name === 'shouldSkip');\n    const isStepOptionalVar = finalAdvancedVars.find(v => v.name === 'isStepOptional');\n\n    this.save.emit({\n      template: this.selectedTemplate,\n      templateVariables: [...this.templateVariables],\n      advancedSettingsVariables: finalAdvancedVars,\n      action: this.selectedTemplate?.naturalText || this.selectedTemplate?.htmlGrammar || '',\n      resolvedAction: this.currentHtmlGrammar,\n      description: this.conditionForm.get('description')?.value || '',\n      metadata: this.conditionForm.get('metadata')?.value || '',\n      shouldSkip: shouldSkipVar ? !!shouldSkipVar.value : false,\n      ignoreStepResult: isStepOptionalVar ? !!isStepOptionalVar.value : false,\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    {{ title }}\n  </h2>\n\n  <div class=\"cqa-flex cqa-flex-col cqa-flex-1 cqa-overflow-y-auto\">\n    <!-- Condition Builder Section -->\n    <div class=\"cqa-mb-6\">\n      <div class=\"cqa-mb-3\">\n        <h3 class=\"cqa-text-sm cqa-text-[12px] cqa-font-semibold cqa-text-gray-900\">\n          Condition Builder\n        </h3>\n      </div>\n\n      <!-- Single Condition Row -->\n      <div class=\"cqa-flex cqa-flex-col cqa-gap-2\" [formGroup]=\"conditionForm\">\n        <!-- Condition Label + Template Dropdown -->\n        <div class=\"cqa-flex cqa-items-center cqa-gap-2\">\n          <!-- Label -->\n          <div class=\"cqa-text-[12px] cqa-font-semibold\">\n            {{ conditionRowLabel }}\n          </div>\n\n          <!-- Value Template Dropdown -->\n          <div class=\"cqa-flex-1 cqa-min-w-[150px] cqa-text-[10px]\">\n            <cqa-dynamic-select [form]=\"conditionForm\" [config]=\"getValueConfig()\">\n            </cqa-dynamic-select>\n          </div>\n        </div>\n\n        <!-- Template Variables Section (shown when template is selected) -->\n        <div *ngIf=\"hasSelectedTemplate\" class=\"cqa-mt-2\">\n          <!-- Template Grammar Display -->\n          <div class=\"cqa-mb-4 cqa-flex cqa-items-center cqa-flex-wrap cqa-gap-1 cqa-text-sm cqa-text-gray-700\">\n            <div class=\"cqa-action-format cqa-text-[12px] cqa-leading-[23px] cqa-text-black-100\"\n              [innerHTML]=\"currentHtmlGrammar\">\n            </div>\n          </div>\n\n          <!-- Template Variables Form -->\n          <cqa-template-variables-form\n            style=\"width: 100%;\"\n            [templateVariables]=\"getTemplateVariables()\"\n            [variablesForm]=\"getVariablesForm()\"\n            [metadata]=\"conditionForm.get('metadata')?.value || ''\"\n            [description]=\"conditionForm.get('description')?.value || ''\"\n            [elementOptions]=\"elementOptions\"\n            [hasMoreElements]=\"hasMoreElements\"\n            [isLoadingElements]=\"isLoadingElements\"\n            [screenNameOptions]=\"screenNameOptions\"\n            [hasMoreScreenNames]=\"hasMoreScreenNames\"\n            [isLoadingScreenNames]=\"isLoadingScreenNames\"\n            [parameterOptions]=\"parameterOptions\"\n            [hasMoreParameters]=\"hasMoreParameters\"\n            [isLoadingParameters]=\"isLoadingParameters\"\n            [environmentOptions]=\"environmentOptions\"\n            [hasMoreEnvironments]=\"hasMoreEnvironments\"\n            [isLoadingEnvironments]=\"isLoadingEnvironments\"\n            [testCaseEnvironmentName]=\"testCaseEnvironmentName\"\n            [testCaseEnvironmentLabelSuffix]=\"testCaseEnvironmentLabelSuffix\"\n            [environmentLegacyDeprecationMessage]=\"environmentLegacyDeprecationMessage\"\n            [testCaseTestDataId]=\"testCaseTestDataId\"\n            [hasTestDataProfile]=\"hasTestDataProfile\"\n            [isInsideForLoopStep]=\"isInsideForLoopStep\"\n            [globalVariableOptions]=\"globalVariableOptions\"\n            [isLoadingGlobalVariables]=\"isLoadingGlobalVariables\"\n            [defaultTestDataProfileId]=\"defaultTestDataProfileId\"\n            [defaultTestDataStartIndex]=\"defaultTestDataStartIndex\"\n            [defaultTestDataEndIndex]=\"defaultTestDataEndIndex\"\n            (variableValueChange)=\"onVariableValueChange($event.name, $event.value)\"\n            (variableBooleanChange)=\"onVariableBooleanChange($event.name, $event.value)\"\n            (metadataChange)=\"conditionForm.get('metadata')?.setValue($event)\"\n            (descriptionChange)=\"conditionForm.get('description')?.setValue($event)\"\n            (loadMoreElements)=\"loadMoreElements.emit()\"\n            (searchElements)=\"searchElements.emit($event)\"\n            (searchElementsByScreenName)=\"searchElementsByScreenName.emit($event)\"\n            (createElement)=\"createElement.emit($event)\"\n            (searchScreenName)=\"searchScreenName.emit($event)\"\n            (loadMoreScreenNames)=\"loadMoreScreenNames.emit($event)\"\n            (createScreenNameRequest)=\"createScreenNameRequest.emit($event)\"\n            (searchParameters)=\"searchParameters.emit($event)\"\n            (loadMoreParameters)=\"loadMoreParameters.emit()\"\n            (searchEnvironments)=\"searchEnvironments.emit($event)\"\n            (loadMoreEnvironments)=\"loadMoreEnvironments.emit()\"\n            (searchGlobalVariables)=\"searchGlobalVariables.emit($event)\">\n          </cqa-template-variables-form>\n\n          <!-- Advanced Settings Variables Form -->\n          <div *ngIf=\"getAdvancedVariables().length > 0\" class=\"cqa-mt-4\">\n            <div class=\"cqa-flex cqa-flex-col cqa-w-full\">\n              <button type=\"button\"\n                class=\"cqa-flex cqa-w-full cqa-items-center cqa-justify-between cqa-gap-2 cqa-text-sm cqa-font-medium cqa-text-gray-700 cqa-bg-transparent cqa-border-none cqa-cursor-pointer cqa-p-0 cqa-mb-1.5\"\n                (click)=\"toggleAdvanced()\">\n                <span class=\"cqa-text-[10px]\">Advanced</span>\n                <mat-icon class=\"cqa-text-base\" [class.cqa-rotate-180]=\"isAdvancedExpanded\">\n                  expand_more\n                </mat-icon>\n              </button>\n              <div *ngIf=\"isAdvancedExpanded\" class=\"cqa-mt-2\">\n                <cqa-advanced-variables-form\n                  [advancedVariables]=\"getAdvancedVariables()\"\n                  [advancedVariableForm]=\"getAdvancedVariablesForm()\"\n                  (variableBooleanChange)=\"onAdvancedVariableBooleanChange($event.name, $event.value)\"\n                  (variableValueChange)=\"onAdvancedVariableValueChange($event.name, $event.value)\">\n                </cqa-advanced-variables-form>\n              </div>\n            </div>\n          </div>\n        </div>\n      </div>\n    </div>\n  </div>\n\n  <!-- Action Buttons -->\n  <div class=\"cqa-flex cqa-w-full cqa-gap-2 cqa-mt-auto cqa-pt-4 cqa-border-t cqa-border-gray-200\">\n    <cqa-button class=\"cqa-w-1/2\" variant=\"outlined\" text=\"Cancel\" [customClass]=\"'cqa-flex-1 cqa-w-full'\"\n      (clicked)=\"onCancel()\">\n    </cqa-button>\n    <cqa-button *ngIf=\"!isSaving\" class=\"cqa-w-1/2\" variant=\"filled\" [text]=\"saveButtonLabel\"\n      [customClass]=\"'cqa-flex-1 cqa-w-full'\"\n      [disabled]=\"!isFormValid()\"\n      (clicked)=\"onSave()\">\n    </cqa-button>\n    <div *ngIf=\"isSaving\" class=\"cqa-w-1/2 cqa-flex-1 cqa-min-h-[38px] cqa-rounded-[8px]\">\n      <cqa-badge label=\"Saving…\" icon=\"autorenew\" [isLoading]=\"true\" [fullWidth]=\"true\" [centerContent]=\"true\"\n        [inlineStyles]=\"'min-height: 38px; height: 38px; box-sizing: border-box; display: flex; align-items: center; justify-content: center;'\"\n        variant=\"info\" size=\"medium\"></cqa-badge>\n    </div>\n  </div>\n</div>\n"]}
|
|
449
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"condition-branch-editor.component.js","sourceRoot":"","sources":["../../../../../../src/lib/execution-screen/condition-debug-step/condition-branch-editor.component.ts","../../../../../../src/lib/execution-screen/condition-debug-step/condition-branch-editor.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component, Input, Output, EventEmitter, OnInit, OnChanges, SimpleChanges,\n  ChangeDetectionStrategy, ChangeDetectorRef\n} from '@angular/core';\nimport { FormArray, FormBuilder, FormGroup, FormControl, Validators } from '@angular/forms';\nimport { DynamicSelectFieldConfig, SelectOption } from '../../dynamic-select/dynamic-select-field.component';\nimport { ActionTemplate } from '../../step-builder/step-builder-action/step-builder-action.component';\n\nexport interface ConditionBranchSaveData {\n  template: ActionTemplate | null;\n  templateVariables: any[];\n  advancedSettingsVariables: any[];\n  action: string;\n  /** Resolved HTML grammar with actual variable values substituted — use for display/conditionText */\n  resolvedAction: string;\n  description: string;\n  metadata: string;\n  /** Derived from advancedSettingsVariables 'shouldSkip' entry — step should be skipped during execution */\n  shouldSkip: boolean;\n  /** Derived from advancedSettingsVariables 'isStepOptional' entry — step failure should not fail the test */\n  ignoreStepResult: boolean;\n}\n\n/**\n * Lightweight single-condition editor used in debug mode to:\n *  - Add a new ELSE IF branch (mode = 'add-else-if')\n *  - Edit an existing IF or ELSE IF condition (mode = 'edit')\n *\n * This is a simplified variant of StepBuilderConditionComponent with one condition row.\n */\n@Component({\n  selector: 'cqa-condition-branch-editor',\n  templateUrl: './condition-branch-editor.component.html',\n  styleUrls: [],\n  host: { class: 'cqa-ui-root' },\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class ConditionBranchEditorComponent implements OnInit, OnChanges {\n\n  /** 'add-else-if' shows \"Add ELSE IF\" title/button; 'edit' shows \"Edit Condition\" title/button */\n  @Input() mode: 'add-else-if' | 'edit' = 'add-else-if';\n\n  /** List of condition action templates (filtered to IF_CONDITION type) */\n  @Input() conditionTemplates: ActionTemplate[] = [];\n\n  /** Called to derive template variables from a selected template */\n  @Input() setConditionTemplateVariables: (template: ActionTemplate, testStep?: any) => any[] = () => [];\n\n  /** Called to derive advanced settings variables */\n  @Input() setAdvancedSettingsVariables: (template: ActionTemplate, testStep?: any) => any[] = () => [];\n\n  /** Centralised HTML grammar computation function */\n  @Input() computeHtmlGrammarFn?: (template: any, variables: any[]) => string;\n\n  /** Element options for variable forms */\n  @Input() elementOptions: any[] = [];\n  @Input() hasMoreElements: boolean = false;\n  @Input() isLoadingElements: boolean = false;\n  @Input() screenNameOptions: { id?: number; name: string }[] = [];\n  @Input() hasMoreScreenNames: boolean = false;\n  @Input() isLoadingScreenNames: boolean = false;\n  @Input() parameterOptions: any[] = [];\n  @Input() hasMoreParameters: boolean = false;\n  @Input() isLoadingParameters: boolean = false;\n  @Input() environmentOptions: { id: string; name: string; value: string; environment: string; type?: string; permissionMode?: string }[] = [];\n  @Input() hasMoreEnvironments: boolean = false;\n  @Input() isLoadingEnvironments: boolean = false;\n  /** Resolved test-case env name; drives banner + env-dropdown auto-select + lock in inner template-variables-form. */\n  @Input() testCaseEnvironmentName?: string;\n  /** Suffix on the env-name option label (e.g. '(default)'). Also locks the env dropdown. */\n  @Input() testCaseEnvironmentLabelSuffix?: string;\n  /** Italic note rendered under env dropdown in the inner form. */\n  @Input() environmentLegacyDeprecationMessage?: string;\n  /** Test case's TDP id — gates the Test Data Profile tab in the inner form. */\n  @Input() testCaseTestDataId?: number | null;\n  /** When true (or `isInsideForLoopStep` true), the inner form shows the Test\n   *  Data Profile segment. Without this, the lib defaults the segment in,\n   *  even though the test case has no TDP — which is what shows the tab in the\n   *  debug-screen condition-branch editor. */\n  @Input() hasTestDataProfile: boolean = false;\n  /** True when this branch lives inside a FOR-loop step. */\n  @Input() isInsideForLoopStep: boolean = false;\n  /** Workspace-scoped global variables for the Global Data tab. */\n  @Input() globalVariableOptions: { id: number | string; name: string; value: string; type?: string; readWriteMode?: string }[] = [];\n  @Input() isLoadingGlobalVariables: boolean = false;\n  @Input() defaultTestDataProfileId?: number;\n  @Input() defaultTestDataStartIndex?: number;\n  /**\n   * End index of the inherited dataset range (0-based). Drives both the\n   * Data Set End dropdown lock and the auto-population of test-data variables\n   * from the end-row inside cqa-template-variables-form. Forwarded to the\n   * inner form. Without this, the parent (e.g. debug-screen condition-branch\n   * flow) can't fully reproduce the lock parity that\n   * cqa-step-builder-action gets via app-step-builder.\n   */\n  @Input() defaultTestDataEndIndex?: number;\n\n  /** When provided, pre-populates the form for edit mode. shape: { templateId, templateVariables, action } */\n  @Input() initialConditionData?: {\n    templateId?: string | number;\n    templateVariables?: any[];\n    action?: string;\n    description?: string;\n    metadata?: string;\n  };\n\n  /** Raw branch step object — passed through to setConditionTemplateVariables so the service can extract saved values from step.event */\n  @Input() editTestStep?: any;\n\n  /** Label shown next to the condition template dropdown (e.g. 'IF', 'ELSE IF'). Inferred from mode when not provided. */\n  @Input() branchLabel?: string;\n\n  /** True while the parent is saving (disables/shows loader on Save button) */\n  @Input() isSaving: boolean = false;\n\n  @Output() save = new EventEmitter<ConditionBranchSaveData>();\n  @Output() cancelled = new EventEmitter<void>();\n  @Output() loadMoreElements = new EventEmitter<void>();\n  @Output() searchElements = new EventEmitter<string>();\n  @Output() searchElementsByScreenName = new EventEmitter<{ screenNameId: number; searchTerm?: string }>();\n  @Output() createElement = new EventEmitter<any>();\n  @Output() searchScreenName = new EventEmitter<string>();\n  @Output() loadMoreScreenNames = new EventEmitter<string>();\n  @Output() createScreenNameRequest = new EventEmitter<string>();\n  @Output() searchParameters = new EventEmitter<string>();\n  @Output() loadMoreParameters = new EventEmitter<void>();\n  @Output() searchEnvironments = new EventEmitter<string>();\n  @Output() loadMoreEnvironments = new EventEmitter<void>();\n  @Output() searchGlobalVariables = new EventEmitter<string>();\n\n  conditionForm!: FormGroup;\n\n  private selectedTemplate: ActionTemplate | null = null;\n  private templateVariables: any[] = [];\n  private variablesForm!: FormArray;\n  private advancedSettingsVariables: any[] = [];\n  private advancedVariablesForm!: FormArray;\n  private advancedExpanded = false;\n  private updatedHtmlGrammar = '';\n\n  private valueConfigCache: DynamicSelectFieldConfig | null = null;\n  private valueConfigWithHandler: DynamicSelectFieldConfig | null = null;\n\n  get title(): string {\n    return this.mode === 'edit' ? 'Edit Condition' : 'Add ELSE IF';\n  }\n\n  get saveButtonLabel(): string {\n    return this.mode === 'edit' ? 'Save' : 'Add ELSE IF';\n  }\n\n  get conditionRowLabel(): string {\n    return this.branchLabel ?? (this.mode === 'edit' ? 'IF' : 'ELSE IF');\n  }\n\n  constructor(private fb: FormBuilder, private cdr: ChangeDetectorRef) {}\n\n  ngOnInit(): void {\n    this.variablesForm = this.fb.array([]);\n    this.advancedVariablesForm = this.fb.array([]);\n\n    this.conditionForm = this.fb.group({\n      value: [null, Validators.required],\n      description: [''],\n      metadata: [''],\n    });\n\n    this.updateValueConfigCache();\n\n    // Pre-populate for edit mode\n    if (this.mode === 'edit' && this.initialConditionData) {\n      this.prefillFromInitialData();\n    }\n\n    this.cdr.markForCheck();\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes['conditionTemplates'] && !changes['conditionTemplates'].firstChange) {\n      this.updateValueConfigCache();\n      this.valueConfigWithHandler = null;\n      // Re-prefill if we now have templates and were waiting\n      if (this.mode === 'edit' && this.initialConditionData && !this.selectedTemplate) {\n        this.prefillFromInitialData();\n      }\n    }\n    this.cdr.markForCheck();\n  }\n\n  private prefillFromInitialData(): void {\n    if (!this.initialConditionData || !this.conditionTemplates?.length) return;\n\n    const { templateId, action, description, metadata } = this.initialConditionData;\n\n    // Find matching template\n    let template: ActionTemplate | undefined;\n    if (templateId != null) {\n      template = this.conditionTemplates.find(\n        t => String(t.id) === String(templateId) || t.displayName === String(templateId)\n      );\n    }\n    if (!template && action) {\n      template = this.conditionTemplates.find(\n        t => t.naturalText === action || t.htmlGrammar === action || t.displayName === action\n      );\n    }\n\n    if (template) {\n      const selectId = template.id?.toString() || template.displayName || '';\n      this.conditionForm?.get('value')?.setValue(selectId, { emitEvent: false });\n      this.selectedTemplate = template;\n\n      // Get fresh variables structure with saved values by passing the raw step\n      const vars = this.setConditionTemplateVariables(template, this.editTestStep);\n      this.templateVariables = vars;\n\n      this.buildVariablesForm();\n      this.updateHtmlGrammar();\n\n      // Advanced variables\n      if (this.setAdvancedSettingsVariables) {\n        this.advancedSettingsVariables = this.setAdvancedSettingsVariables(template, this.editTestStep);\n        this.buildAdvancedVariablesForm();\n      }\n    }\n\n    if (description) this.conditionForm?.get('description')?.setValue(description, { emitEvent: false });\n    if (metadata) this.conditionForm?.get('metadata')?.setValue(metadata, { emitEvent: false });\n    this.cdr.markForCheck();\n  }\n\n  private updateValueConfigCache(): void {\n    const opts: SelectOption[] = (this.conditionTemplates || []).map(t => ({\n      id: t.id?.toString() || t.displayName || '',\n      value: t.id?.toString() || t.displayName || '',\n      name: t.htmlGrammar || t.naturalText || '',\n      label: t.htmlGrammar || t.naturalText || ''\n    }));\n    this.valueConfigCache = {\n      key: 'value',\n      placeholder: 'Select Condition Template*',\n      multiple: false,\n      searchable: true,\n      displayLabelAsInnerHtml: true,\n      options: opts\n    };\n  }\n\n  getValueConfig(): DynamicSelectFieldConfig {\n    if (this.valueConfigWithHandler) return this.valueConfigWithHandler;\n    if (!this.valueConfigCache) this.updateValueConfigCache();\n    this.valueConfigWithHandler = {\n      ...this.valueConfigCache!,\n      onChange: (v: any) => this.onTemplateValueChange(v)\n    };\n    return this.valueConfigWithHandler;\n  }\n\n  onTemplateValueChange(templateId: any): void {\n    const template = this.conditionTemplates.find(\n      t => String(t.id) === String(templateId) || t.displayName === String(templateId)\n    );\n    if (template) {\n      this.selectedTemplate = template;\n      this.templateVariables = this.setConditionTemplateVariables(template);\n      this.buildVariablesForm();\n      this.updateHtmlGrammar();\n      if (this.setAdvancedSettingsVariables) {\n        this.advancedSettingsVariables = this.setAdvancedSettingsVariables(template);\n        this.buildAdvancedVariablesForm();\n      }\n    } else {\n      this.selectedTemplate = null;\n      this.templateVariables = [];\n      this.clearVariablesForm();\n      this.advancedSettingsVariables = [];\n      this.clearAdvancedVariablesForm();\n    }\n    this.cdr.markForCheck();\n  }\n\n  private buildVariablesForm(): void {\n    while (this.variablesForm.length) this.variablesForm.removeAt(0);\n    this.templateVariables.forEach(variable => {\n      const defaultValue = variable.type === 'boolean'\n        ? (variable.value === true || variable.value === 'true' || variable.value === 1)\n        : (variable.value || '');\n      const group = this.fb.group({\n        name: [variable.name],\n        value: [defaultValue],\n        type: [variable.type || 'string'],\n        label: [variable.label || ''],\n        options: [variable.options || []]\n      });\n      const label = variable.label?.toLowerCase() || '';\n      if (label === 'test-data' || label === 'source-value' || label === 'target-value' ||\n          label === 'source_value' || label === 'target_value') {\n        const valueStr = String(defaultValue || '');\n        let dataType = 'plain-text';\n        if (valueStr.startsWith('@|') && valueStr.endsWith('|')) dataType = 'parameter';\n        else if (valueStr.startsWith('$|') && valueStr.endsWith('|')) dataType = 'runtime';\n        else if (valueStr.startsWith('*|') && valueStr.endsWith('|')) dataType = 'environment';\n        group.addControl('dataType', new FormControl(dataType));\n      }\n      this.variablesForm.push(group);\n    });\n  }\n\n  private clearVariablesForm(): void {\n    while (this.variablesForm.length) this.variablesForm.removeAt(0);\n  }\n\n  private buildAdvancedVariablesForm(): void {\n    while (this.advancedVariablesForm.length) this.advancedVariablesForm.removeAt(0);\n    this.advancedSettingsVariables.forEach(variable => {\n      let defaultValue: any;\n      if (variable.type === 'str_list') {\n        const arr = Array.isArray(variable.value) ? variable.value : [];\n        defaultValue = this.fb.array(arr.length > 0 ? arr.map((i: string) => this.fb.control(i)) : [this.fb.control('')]);\n      } else if (variable.type === 'boolean') {\n        defaultValue = variable.value === true || variable.value === 'true' || variable.value === 1;\n      } else {\n        defaultValue = variable.value || '';\n      }\n      const group = this.fb.group({\n        name: [variable.name],\n        value: variable.type === 'str_list' ? defaultValue : [defaultValue],\n        type: [variable.type || 'string'],\n        label: [variable.label || '']\n      });\n      this.advancedVariablesForm.push(group);\n    });\n  }\n\n  private clearAdvancedVariablesForm(): void {\n    while (this.advancedVariablesForm.length) this.advancedVariablesForm.removeAt(0);\n  }\n\n  private updateHtmlGrammar(): void {\n    if (!this.selectedTemplate?.htmlGrammar) { this.updatedHtmlGrammar = ''; return; }\n    if (this.computeHtmlGrammarFn) {\n      this.updatedHtmlGrammar = this.computeHtmlGrammarFn(this.selectedTemplate, this.templateVariables);\n      return;\n    }\n    let g = this.selectedTemplate.htmlGrammar;\n    this.templateVariables.forEach(v => {\n      const re = new RegExp(`<span[^>]*data-event-key=\"${v.name}\"[^>]*>.*?</span>`, 'gi');\n      const escaped = String(v.value || '').replace(/&/g, '&amp;').replace(/</g, '&lt;').replace(/>/g, '&gt;');\n      g = g.replace(re, escaped);\n    });\n    this.updatedHtmlGrammar = g;\n  }\n\n  get currentHtmlGrammar(): string {\n    return this.updatedHtmlGrammar || this.selectedTemplate?.htmlGrammar || this.selectedTemplate?.naturalText || '';\n  }\n\n  getTemplateVariables(): any[] { return this.templateVariables; }\n  getVariablesForm(): FormArray { return this.variablesForm; }\n  getAdvancedVariables(): any[] { return this.advancedSettingsVariables; }\n  getAdvancedVariablesForm(): FormArray { return this.advancedVariablesForm; }\n  get isAdvancedExpanded(): boolean { return this.advancedExpanded; }\n  toggleAdvanced(): void { this.advancedExpanded = !this.advancedExpanded; this.cdr.markForCheck(); }\n  get hasSelectedTemplate(): ActionTemplate | null { return this.selectedTemplate; }\n\n  onVariableValueChange(name: string, value: any): void {\n    const v = this.templateVariables.find(tv => tv.name === name);\n    if (v) v.value = value;\n    const idx = this.variablesForm.controls.findIndex(c => c.get('name')?.value === name);\n    if (idx !== -1) this.variablesForm.at(idx).get('value')?.setValue(value, { emitEvent: false });\n    this.updateHtmlGrammar();\n    this.cdr.markForCheck();\n  }\n\n  onVariableBooleanChange(name: string, value: boolean): void {\n    this.onVariableValueChange(name, value);\n  }\n\n  onAdvancedVariableValueChange(name: string, value: any): void {\n    const v = this.advancedSettingsVariables.find(tv => tv.name === name);\n    if (v) v.value = value;\n    const idx = this.advancedVariablesForm.controls.findIndex(c => c.get('name')?.value === name);\n    if (idx !== -1 && v?.type !== 'str_list') {\n      (this.advancedVariablesForm.at(idx) as FormGroup).get('value')?.setValue(value, { emitEvent: false });\n    }\n  }\n\n  onAdvancedVariableBooleanChange(name: string, value: boolean): void {\n    this.onAdvancedVariableValueChange(name, value);\n  }\n\n  isFormValid(): boolean {\n    if (!this.conditionForm.valid) return false;\n    return this.templateVariables.every(v => {\n      if (v.dataKey === 'element' || v.dataKey === 'test_data' || v.dataKey === 'source_value' || v.dataKey === 'target_value') {\n        return v.value !== null && v.value !== undefined && v.value !== '';\n      }\n      return true;\n    });\n  }\n\n  onCancel(): void { this.cancelled.emit(); }\n\n  onSave(): void {\n    if (!this.isFormValid()) return;\n    // Sync advanced form values back to array\n    this.advancedSettingsVariables.forEach((variable, i) => {\n      const fg = this.advancedVariablesForm.at(i) as FormGroup;\n      if (!fg) return;\n      const fv = fg.get('value')?.value;\n      if (variable.type === 'str_list' && fv instanceof FormArray) {\n        variable.value = fv.controls.map(c => c.value).filter((val: string) => val?.trim() !== '');\n      } else {\n        variable.value = fv;\n      }\n    });\n\n    const finalAdvancedVars = [...this.advancedSettingsVariables];\n    const shouldSkipVar = finalAdvancedVars.find(v => v.name === 'shouldSkip');\n    const isStepOptionalVar = finalAdvancedVars.find(v => v.name === 'isStepOptional');\n\n    this.save.emit({\n      template: this.selectedTemplate,\n      templateVariables: [...this.templateVariables],\n      advancedSettingsVariables: finalAdvancedVars,\n      action: this.selectedTemplate?.naturalText || this.selectedTemplate?.htmlGrammar || '',\n      resolvedAction: this.currentHtmlGrammar,\n      description: this.conditionForm.get('description')?.value || '',\n      metadata: this.conditionForm.get('metadata')?.value || '',\n      shouldSkip: shouldSkipVar ? !!shouldSkipVar.value : false,\n      ignoreStepResult: isStepOptionalVar ? !!isStepOptionalVar.value : false,\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    {{ title }}\n  </h2>\n\n  <div class=\"cqa-flex cqa-flex-col cqa-flex-1 cqa-overflow-y-auto\">\n    <!-- Condition Builder Section -->\n    <div class=\"cqa-mb-6\">\n      <div class=\"cqa-mb-3\">\n        <h3 class=\"cqa-text-sm cqa-text-[12px] cqa-font-semibold cqa-text-gray-900\">\n          Condition Builder\n        </h3>\n      </div>\n\n      <!-- Single Condition Row -->\n      <div class=\"cqa-flex cqa-flex-col cqa-gap-2\" [formGroup]=\"conditionForm\">\n        <!-- Condition Label + Template Dropdown -->\n        <div class=\"cqa-flex cqa-items-center cqa-gap-2\">\n          <!-- Label -->\n          <div class=\"cqa-text-[12px] cqa-font-semibold\">\n            {{ conditionRowLabel }}\n          </div>\n\n          <!-- Value Template Dropdown -->\n          <div class=\"cqa-flex-1 cqa-min-w-[150px] cqa-text-[10px]\">\n            <cqa-dynamic-select [form]=\"conditionForm\" [config]=\"getValueConfig()\">\n            </cqa-dynamic-select>\n          </div>\n        </div>\n\n        <!-- Template Variables Section (shown when template is selected) -->\n        <div *ngIf=\"hasSelectedTemplate\" class=\"cqa-mt-2\">\n          <!-- Template Grammar Display -->\n          <div class=\"cqa-mb-4 cqa-flex cqa-items-center cqa-flex-wrap cqa-gap-1 cqa-text-sm cqa-text-gray-700\">\n            <div class=\"cqa-action-format cqa-text-[12px] cqa-leading-[23px] cqa-text-black-100\"\n              [innerHTML]=\"currentHtmlGrammar\">\n            </div>\n          </div>\n\n          <!-- Template Variables Form -->\n          <cqa-template-variables-form\n            style=\"width: 100%;\"\n            [templateVariables]=\"getTemplateVariables()\"\n            [variablesForm]=\"getVariablesForm()\"\n            [metadata]=\"conditionForm.get('metadata')?.value || ''\"\n            [description]=\"conditionForm.get('description')?.value || ''\"\n            [elementOptions]=\"elementOptions\"\n            [hasMoreElements]=\"hasMoreElements\"\n            [isLoadingElements]=\"isLoadingElements\"\n            [screenNameOptions]=\"screenNameOptions\"\n            [hasMoreScreenNames]=\"hasMoreScreenNames\"\n            [isLoadingScreenNames]=\"isLoadingScreenNames\"\n            [parameterOptions]=\"parameterOptions\"\n            [hasMoreParameters]=\"hasMoreParameters\"\n            [isLoadingParameters]=\"isLoadingParameters\"\n            [environmentOptions]=\"environmentOptions\"\n            [hasMoreEnvironments]=\"hasMoreEnvironments\"\n            [isLoadingEnvironments]=\"isLoadingEnvironments\"\n            [testCaseEnvironmentName]=\"testCaseEnvironmentName\"\n            [testCaseEnvironmentLabelSuffix]=\"testCaseEnvironmentLabelSuffix\"\n            [environmentLegacyDeprecationMessage]=\"environmentLegacyDeprecationMessage\"\n            [testCaseTestDataId]=\"testCaseTestDataId\"\n            [hasTestDataProfile]=\"hasTestDataProfile\"\n            [isInsideForLoopStep]=\"isInsideForLoopStep\"\n            [globalVariableOptions]=\"globalVariableOptions\"\n            [isLoadingGlobalVariables]=\"isLoadingGlobalVariables\"\n            [defaultTestDataProfileId]=\"defaultTestDataProfileId\"\n            [defaultTestDataStartIndex]=\"defaultTestDataStartIndex\"\n            [defaultTestDataEndIndex]=\"defaultTestDataEndIndex\"\n            (variableValueChange)=\"onVariableValueChange($event.name, $event.value)\"\n            (variableBooleanChange)=\"onVariableBooleanChange($event.name, $event.value)\"\n            (metadataChange)=\"conditionForm.get('metadata')?.setValue($event)\"\n            (descriptionChange)=\"conditionForm.get('description')?.setValue($event)\"\n            (loadMoreElements)=\"loadMoreElements.emit()\"\n            (searchElements)=\"searchElements.emit($event)\"\n            (searchElementsByScreenName)=\"searchElementsByScreenName.emit($event)\"\n            (createElement)=\"createElement.emit($event)\"\n            (searchScreenName)=\"searchScreenName.emit($event)\"\n            (loadMoreScreenNames)=\"loadMoreScreenNames.emit($event)\"\n            (createScreenNameRequest)=\"createScreenNameRequest.emit($event)\"\n            (searchParameters)=\"searchParameters.emit($event)\"\n            (loadMoreParameters)=\"loadMoreParameters.emit()\"\n            (searchEnvironments)=\"searchEnvironments.emit($event)\"\n            (loadMoreEnvironments)=\"loadMoreEnvironments.emit()\"\n            (searchGlobalVariables)=\"searchGlobalVariables.emit($event)\">\n          </cqa-template-variables-form>\n\n          <!-- Advanced Settings Variables Form -->\n          <div *ngIf=\"getAdvancedVariables().length > 0\" class=\"cqa-mt-4\">\n            <div class=\"cqa-flex cqa-flex-col cqa-w-full\">\n              <button type=\"button\"\n                class=\"cqa-flex cqa-w-full cqa-items-center cqa-justify-between cqa-gap-2 cqa-text-sm cqa-font-medium cqa-text-gray-700 cqa-bg-transparent cqa-border-none cqa-cursor-pointer cqa-p-0 cqa-mb-1.5\"\n                (click)=\"toggleAdvanced()\">\n                <span class=\"cqa-text-[10px]\">Advanced</span>\n                <mat-icon class=\"cqa-text-base\" [class.cqa-rotate-180]=\"isAdvancedExpanded\">\n                  expand_more\n                </mat-icon>\n              </button>\n              <div *ngIf=\"isAdvancedExpanded\" class=\"cqa-mt-2\">\n                <cqa-advanced-variables-form\n                  [advancedVariables]=\"getAdvancedVariables()\"\n                  [advancedVariableForm]=\"getAdvancedVariablesForm()\"\n                  (variableBooleanChange)=\"onAdvancedVariableBooleanChange($event.name, $event.value)\"\n                  (variableValueChange)=\"onAdvancedVariableValueChange($event.name, $event.value)\">\n                </cqa-advanced-variables-form>\n              </div>\n            </div>\n          </div>\n        </div>\n      </div>\n    </div>\n  </div>\n\n  <!-- Action Buttons -->\n  <div class=\"cqa-flex cqa-w-full cqa-gap-2 cqa-mt-auto cqa-pt-4 cqa-border-t cqa-border-gray-200\">\n    <cqa-button class=\"cqa-w-1/2\" variant=\"outlined\" text=\"Cancel\" [customClass]=\"'cqa-flex-1 cqa-w-full'\"\n      (clicked)=\"onCancel()\">\n    </cqa-button>\n    <cqa-button *ngIf=\"!isSaving\" class=\"cqa-w-1/2\" variant=\"filled\" [text]=\"saveButtonLabel\"\n      [customClass]=\"'cqa-flex-1 cqa-w-full'\"\n      [disabled]=\"!isFormValid()\"\n      (clicked)=\"onSave()\">\n    </cqa-button>\n    <div *ngIf=\"isSaving\" class=\"cqa-w-1/2 cqa-flex-1 cqa-min-h-[38px] cqa-rounded-[8px]\">\n      <cqa-badge label=\"Saving…\" icon=\"autorenew\" [isLoading]=\"true\" [fullWidth]=\"true\" [centerContent]=\"true\"\n        [inlineStyles]=\"'min-height: 38px; height: 38px; box-sizing: border-box; display: flex; align-items: center; justify-content: center;'\"\n        variant=\"info\" size=\"medium\"></cqa-badge>\n    </div>\n  </div>\n</div>\n"]}
|
|
@@ -121,13 +121,13 @@ export class ManageColumnsDialogComponent {
|
|
|
121
121
|
}
|
|
122
122
|
}
|
|
123
123
|
ManageColumnsDialogComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: ManageColumnsDialogComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
124
|
-
ManageColumnsDialogComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.4.0", type: ManageColumnsDialogComponent, selector: "cqa-manage-columns-dialog", inputs: { columns: "columns", lockedColumns: "lockedColumns" }, host: { styleAttribute: "display:block;width:100%;", classAttribute: "cqa-ui-root" }, ngImport: i0, template: "<div class=\"
|
|
124
|
+
ManageColumnsDialogComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.4.0", type: ManageColumnsDialogComponent, selector: "cqa-manage-columns-dialog", inputs: { columns: "columns", lockedColumns: "lockedColumns" }, host: { styleAttribute: "display:block;width:100%;", classAttribute: "cqa-ui-root" }, ngImport: i0, template: "<div class=\"manage-cols-stack\">\n\n <div class=\"manage-cols-drop-list\"\n [dndDropzone]=\"['col']\"\n dndEffectAllowed=\"move\"\n dndDragoverClass=\"dndDragover\"\n (dndDrop)=\"onDndDrop($event)\">\n <div dndPlaceholderRef class=\"manage-cols-placeholder\">Drop here</div>\n <div *ngFor=\"let item of items; let i = index; trackBy: trackByUid\"\n class=\"manage-cols-row\">\n <span class=\"manage-cols-handle\"\n [dndDraggable]=\"item\"\n [dndDisableIf]=\"isLocked(item)\"\n dndType=\"col\"\n dndEffectAllowed=\"move\">\n <mat-icon>drag_indicator</mat-icon>\n </span>\n <cqa-custom-input\n class=\"cqa-flex-1\"\n [value]=\"item.name\"\n [fullWidth]=\"true\"\n [disabled]=\"isLocked(item)\"\n inputInlineStyle=\"font-family: 'Inter', ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, 'Liberation Mono', monospace;\"\n (valueChange)=\"onRename(i, $event)\">\n </cqa-custom-input>\n <button type=\"button\" class=\"manage-cols-icon-btn\"\n title=\"Move up\"\n [disabled]=\"i === 0\"\n (click)=\"onMove(i, -1)\">\n <mat-icon>arrow_upward</mat-icon>\n </button>\n <button type=\"button\" class=\"manage-cols-icon-btn\"\n title=\"Move down\"\n [disabled]=\"i === items.length - 1\"\n (click)=\"onMove(i, 1)\">\n <mat-icon>arrow_downward</mat-icon>\n </button>\n <button type=\"button\" class=\"manage-cols-icon-btn manage-cols-icon-btn-danger\"\n title=\"Delete column\"\n [disabled]=\"isLocked(item)\"\n (click)=\"onRemove(i)\">\n <mat-icon>delete</mat-icon>\n </button>\n </div>\n </div>\n\n <div class=\"manage-cols-footer\">\n <cqa-custom-input\n class=\"cqa-flex-1\"\n [value]=\"newColName\"\n [fullWidth]=\"true\"\n placeholder=\"New column name (e.g. currency)\"\n inputInlineStyle=\"font-family: 'Inter', ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, 'Liberation Mono', monospace;\"\n (valueChange)=\"onNewColNameChange($event)\"\n (enterPressed)=\"onAdd()\">\n </cqa-custom-input>\n <cqa-button\n variant=\"outlined\"\n icon=\"add\"\n text=\"Add column\"\n [disabled]=\"!canAdd\"\n (clicked)=\"onAdd()\">\n </cqa-button>\n </div>\n\n <span *ngIf=\"columnsError\" class=\"manage-cols-error\">{{ columnsError }}</span>\n\n <div class=\"manage-cols-hint\">\n <strong>Heads up:</strong>\n Deleting a column removes its data from every environment. Renaming keeps the data in place.\n </div>\n\n</div>\n", components: [{ type: i1.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { type: i2.CustomInputComponent, selector: "cqa-custom-input", inputs: ["inputId", "label", "type", "placeholder", "value", "disabled", "errors", "required", "ariaLabel", "size", "fullWidth", "maxLength", "showCharCount", "inputInlineStyle", "labelInlineStyle", "showPasswordToggle"], outputs: ["valueChange", "blurred", "focused", "enterPressed"] }, { type: i3.ButtonComponent, selector: "cqa-button", inputs: ["variant", "btnSize", "disabled", "loading", "icon", "iconPosition", "fullWidth", "iconColor", "type", "text", "customClass", "inlineStyles", "tooltip", "tooltipPosition"], outputs: ["clicked"] }], directives: [{ type: i4.DndDropzoneDirective, selector: "[dndDropzone]", inputs: ["dndDropzone", "dndEffectAllowed", "dndAllowExternal", "dndHorizontal", "dndDragoverClass", "dndDropzoneDisabledClass", "dndDisableIf", "dndDisableDropIf"], outputs: ["dndDragover", "dndDrop"] }, { type: i4.DndPlaceholderRefDirective, selector: "[dndPlaceholderRef]" }, { type: i5.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i4.DndDraggableDirective, selector: "[dndDraggable]", inputs: ["dndDraggable", "dndEffectAllowed", "dndType", "dndDraggingClass", "dndDraggingSourceClass", "dndDraggableDisabledClass", "dndDragImageOffsetFunction", "dndDisableIf", "dndDisableDragIf"], outputs: ["dndStart", "dndDrag", "dndEnd", "dndMoved", "dndCopied", "dndLinked", "dndCanceled"] }, { type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] });
|
|
125
125
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: ManageColumnsDialogComponent, decorators: [{
|
|
126
126
|
type: Component,
|
|
127
|
-
args: [{ selector: 'cqa-manage-columns-dialog', host: { class: 'cqa-ui-root', style: 'display:block;width:100%;' }, template: "<div class=\"
|
|
127
|
+
args: [{ selector: 'cqa-manage-columns-dialog', host: { class: 'cqa-ui-root', style: 'display:block;width:100%;' }, template: "<div class=\"manage-cols-stack\">\n\n <div class=\"manage-cols-drop-list\"\n [dndDropzone]=\"['col']\"\n dndEffectAllowed=\"move\"\n dndDragoverClass=\"dndDragover\"\n (dndDrop)=\"onDndDrop($event)\">\n <div dndPlaceholderRef class=\"manage-cols-placeholder\">Drop here</div>\n <div *ngFor=\"let item of items; let i = index; trackBy: trackByUid\"\n class=\"manage-cols-row\">\n <span class=\"manage-cols-handle\"\n [dndDraggable]=\"item\"\n [dndDisableIf]=\"isLocked(item)\"\n dndType=\"col\"\n dndEffectAllowed=\"move\">\n <mat-icon>drag_indicator</mat-icon>\n </span>\n <cqa-custom-input\n class=\"cqa-flex-1\"\n [value]=\"item.name\"\n [fullWidth]=\"true\"\n [disabled]=\"isLocked(item)\"\n inputInlineStyle=\"font-family: 'Inter', ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, 'Liberation Mono', monospace;\"\n (valueChange)=\"onRename(i, $event)\">\n </cqa-custom-input>\n <button type=\"button\" class=\"manage-cols-icon-btn\"\n title=\"Move up\"\n [disabled]=\"i === 0\"\n (click)=\"onMove(i, -1)\">\n <mat-icon>arrow_upward</mat-icon>\n </button>\n <button type=\"button\" class=\"manage-cols-icon-btn\"\n title=\"Move down\"\n [disabled]=\"i === items.length - 1\"\n (click)=\"onMove(i, 1)\">\n <mat-icon>arrow_downward</mat-icon>\n </button>\n <button type=\"button\" class=\"manage-cols-icon-btn manage-cols-icon-btn-danger\"\n title=\"Delete column\"\n [disabled]=\"isLocked(item)\"\n (click)=\"onRemove(i)\">\n <mat-icon>delete</mat-icon>\n </button>\n </div>\n </div>\n\n <div class=\"manage-cols-footer\">\n <cqa-custom-input\n class=\"cqa-flex-1\"\n [value]=\"newColName\"\n [fullWidth]=\"true\"\n placeholder=\"New column name (e.g. currency)\"\n inputInlineStyle=\"font-family: 'Inter', ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, 'Liberation Mono', monospace;\"\n (valueChange)=\"onNewColNameChange($event)\"\n (enterPressed)=\"onAdd()\">\n </cqa-custom-input>\n <cqa-button\n variant=\"outlined\"\n icon=\"add\"\n text=\"Add column\"\n [disabled]=\"!canAdd\"\n (clicked)=\"onAdd()\">\n </cqa-button>\n </div>\n\n <span *ngIf=\"columnsError\" class=\"manage-cols-error\">{{ columnsError }}</span>\n\n <div class=\"manage-cols-hint\">\n <strong>Heads up:</strong>\n Deleting a column removes its data from every environment. Renaming keeps the data in place.\n </div>\n\n</div>\n" }]
|
|
128
128
|
}], propDecorators: { columns: [{
|
|
129
129
|
type: Input
|
|
130
130
|
}], lockedColumns: [{
|
|
131
131
|
type: Input
|
|
132
132
|
}] } });
|
|
133
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"manage-columns-dialog.component.js","sourceRoot":"","sources":["../../../../../src/lib/manage-columns-dialog/manage-columns-dialog.component.ts","../../../../../src/lib/manage-columns-dialog/manage-columns-dialog.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnInit } from '@angular/core';\nimport { DndDropEvent } from 'ngx-drag-drop';\n\nimport {\n  ManageColumnsDialogColumn,\n  ManageColumnsDialogValue,\n} from './manage-columns-dialog.models';\n\ninterface ManageColumnsItem {\n  uid: number;\n  originalName: string | null;\n  name: string;\n}\n\n@Component({\n  selector: 'cqa-manage-columns-dialog',\n  templateUrl: './manage-columns-dialog.component.html',\n  host: { class: 'cqa-ui-root', style: 'display:block;width:100%;' },\n})\nexport class ManageColumnsDialogComponent implements OnInit {\n  @Input() columns: string[] = [];\n  @Input() lockedColumns: string[] = [];\n\n  public items: ManageColumnsItem[] = [];\n  public newColName = '';\n  public columnsError: string | null = null;\n\n  public trackByUid = (_: number, item: ManageColumnsItem): number => item.uid;\n\n  private nextUid = 1;\n\n  ngOnInit(): void {\n    const initial = Array.isArray(this.columns) ? this.columns : [];\n    this.items = initial.map(name => ({\n      uid: this.nextUid++,\n      originalName: name,\n      name,\n    }));\n  }\n\n  public isLocked(item: ManageColumnsItem): boolean {\n    if (!this.lockedColumns || this.lockedColumns.length === 0) { return false; }\n    if (item.originalName != null && this.lockedColumns.indexOf(item.originalName) !== -1) {\n      return true;\n    }\n    return this.lockedColumns.indexOf(item.name) !== -1;\n  }\n\n  public onDndDrop(event: DndDropEvent): void {\n    const dragged = event.data as ManageColumnsItem | null;\n    if (!dragged || event.index == null) { return; }\n    const from = this.items.findIndex(it => it.uid === dragged.uid);\n    if (from < 0) { return; }\n    const next = this.items.slice();\n    next.splice(from, 1);\n    const to = event.index > from ? event.index - 1 : event.index;\n    next.splice(to, 0, dragged);\n    this.items = next;\n  }\n\n  public onMove(index: number, dir: -1 | 1): void {\n    const target = index + dir;\n    if (target < 0 || target >= this.items.length) { return; }\n    const next = this.items.slice();\n    [next[index], next[target]] = [next[target], next[index]];\n    this.items = next;\n  }\n\n  public onRename(index: number, value: string): void {\n    if (!this.items[index]) { return; }\n    this.items = this.items.map((it, i) => i === index ? { ...it, name: value } : it);\n    this.columnsError = null;\n  }\n\n  public onRemove(index: number): void {\n    const item = this.items[index];\n    if (!item || this.isLocked(item)) { return; }\n    this.items = this.items.filter((_, i) => i !== index);\n    this.columnsError = null;\n  }\n\n  public onNewColNameChange(value: string): void {\n    this.newColName = value;\n  }\n\n  public onAdd(): void {\n    const trimmed = (this.newColName || '').trim();\n    if (!trimmed || this.itemsHasName(trimmed)) { return; }\n    this.items = [...this.items, {\n      uid: this.nextUid++,\n      originalName: null,\n      name: trimmed,\n    }];\n    this.newColName = '';\n    this.columnsError = null;\n  }\n\n  public get canAdd(): boolean {\n    const trimmed = (this.newColName || '').trim();\n    if (!trimmed) { return false; }\n    return !this.itemsHasName(trimmed);\n  }\n\n  public getValue(): ManageColumnsDialogValue | null {\n    const trimmed: ManageColumnsDialogColumn[] = this.items.map(it => ({\n      originalName: it.originalName,\n      name: (it.name || '').trim(),\n    }));\n\n    if (trimmed.length === 0) {\n      this.columnsError = 'At least one column is required.';\n      return null;\n    }\n    if (trimmed.some(c => c.name.length === 0)) {\n      this.columnsError = 'Column names cannot be empty.';\n      return null;\n    }\n    const lowered = trimmed.map(c => c.name.toLowerCase());\n    if (new Set(lowered).size !== trimmed.length) {\n      this.columnsError = 'Column names must be unique.';\n      return null;\n    }\n\n    this.columnsError = null;\n    return { columns: trimmed };\n  }\n\n  private itemsHasName(candidate: string): boolean {\n    const lowered = candidate.toLowerCase();\n    return this.items.some(it => (it.name || '').trim().toLowerCase() === lowered);\n  }\n}\n","<div class=\"cqa-flex cqa-flex-col cqa-gap-3 cqa-w-full\">\n\n  <div class=\"manage-cols-drop-list cqa-flex cqa-flex-col cqa-gap-2\"\n       [dndDropzone]=\"['col']\"\n       dndEffectAllowed=\"move\"\n       dndDragoverClass=\"dndDragover\"\n       (dndDrop)=\"onDndDrop($event)\">\n    <div dndPlaceholderRef class=\"manage-cols-placeholder\">Drop here</div>\n    <div *ngFor=\"let item of items; let i = index; trackBy: trackByUid\"\n         class=\"manage-cols-row cqa-flex cqa-items-center cqa-gap-2 cqa-px-2 cqa-py-1.5 cqa-rounded-md cqa-border cqa-border-gray-200 cqa-bg-gray-50\">\n      <span class=\"manage-cols-handle cqa-flex cqa-items-center cqa-justify-center cqa-text-gray-400\"\n            [dndDraggable]=\"item\"\n            [dndDisableIf]=\"isLocked(item)\"\n            dndType=\"col\"\n            dndEffectAllowed=\"move\">\n        <mat-icon style=\"font-size:18px;width:18px;height:18px;line-height:18px;\">drag_indicator</mat-icon>\n      </span>\n      <cqa-custom-input\n        class=\"cqa-flex-1\"\n        [value]=\"item.name\"\n        [fullWidth]=\"true\"\n        [disabled]=\"isLocked(item)\"\n        inputInlineStyle=\"font-family: 'Inter', ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, 'Liberation Mono', monospace;\"\n        (valueChange)=\"onRename(i, $event)\">\n      </cqa-custom-input>\n      <button type=\"button\" class=\"manage-cols-icon-btn\"\n              title=\"Move up\"\n              [disabled]=\"i === 0\"\n              (click)=\"onMove(i, -1)\">\n        <mat-icon>arrow_upward</mat-icon>\n      </button>\n      <button type=\"button\" class=\"manage-cols-icon-btn\"\n              title=\"Move down\"\n              [disabled]=\"i === items.length - 1\"\n              (click)=\"onMove(i, 1)\">\n        <mat-icon>arrow_downward</mat-icon>\n      </button>\n      <button type=\"button\" class=\"manage-cols-icon-btn manage-cols-icon-btn-danger\"\n              title=\"Delete column\"\n              [disabled]=\"isLocked(item)\"\n              (click)=\"onRemove(i)\">\n        <mat-icon>delete</mat-icon>\n      </button>\n    </div>\n  </div>\n\n  <div class=\"cqa-flex cqa-items-center cqa-gap-2 cqa-pt-3 cqa-mt-1 cqa-border-t cqa-border-dashed cqa-border-gray-200\">\n    <cqa-custom-input\n      class=\"cqa-flex-1\"\n      [value]=\"newColName\"\n      [fullWidth]=\"true\"\n      placeholder=\"New column name (e.g. currency)\"\n      inputInlineStyle=\"font-family: 'Inter', ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, 'Liberation Mono', monospace;\"\n      (valueChange)=\"onNewColNameChange($event)\"\n      (enterPressed)=\"onAdd()\">\n    </cqa-custom-input>\n    <cqa-button\n      variant=\"outlined\"\n      btnSize=\"sm\"\n      icon=\"add\"\n      text=\"Add column\"\n      [disabled]=\"!canAdd\"\n      (clicked)=\"onAdd()\">\n    </cqa-button>\n  </div>\n\n  <span *ngIf=\"columnsError\" class=\"cqa-text-xs cqa-text-red-600\">{{ columnsError }}</span>\n\n  <div class=\"cqa-px-3 cqa-py-2 cqa-rounded-md cqa-bg-primary-surface cqa-border cqa-border-success-100 cqa-text-xs cqa-text-gray-700\">\n    <strong class=\"cqa-text-gray-900\">Heads up:</strong>\n    Deleting a column removes its data from every environment. Renaming keeps the data in place.\n  </div>\n\n</div>\n"]}
|
|
133
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"manage-columns-dialog.component.js","sourceRoot":"","sources":["../../../../../src/lib/manage-columns-dialog/manage-columns-dialog.component.ts","../../../../../src/lib/manage-columns-dialog/manage-columns-dialog.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnInit } from '@angular/core';\nimport { DndDropEvent } from 'ngx-drag-drop';\n\nimport {\n  ManageColumnsDialogColumn,\n  ManageColumnsDialogValue,\n} from './manage-columns-dialog.models';\n\ninterface ManageColumnsItem {\n  uid: number;\n  originalName: string | null;\n  name: string;\n}\n\n@Component({\n  selector: 'cqa-manage-columns-dialog',\n  templateUrl: './manage-columns-dialog.component.html',\n  host: { class: 'cqa-ui-root', style: 'display:block;width:100%;' },\n})\nexport class ManageColumnsDialogComponent implements OnInit {\n  @Input() columns: string[] = [];\n  @Input() lockedColumns: string[] = [];\n\n  public items: ManageColumnsItem[] = [];\n  public newColName = '';\n  public columnsError: string | null = null;\n\n  public trackByUid = (_: number, item: ManageColumnsItem): number => item.uid;\n\n  private nextUid = 1;\n\n  ngOnInit(): void {\n    const initial = Array.isArray(this.columns) ? this.columns : [];\n    this.items = initial.map(name => ({\n      uid: this.nextUid++,\n      originalName: name,\n      name,\n    }));\n  }\n\n  public isLocked(item: ManageColumnsItem): boolean {\n    if (!this.lockedColumns || this.lockedColumns.length === 0) { return false; }\n    if (item.originalName != null && this.lockedColumns.indexOf(item.originalName) !== -1) {\n      return true;\n    }\n    return this.lockedColumns.indexOf(item.name) !== -1;\n  }\n\n  public onDndDrop(event: DndDropEvent): void {\n    const dragged = event.data as ManageColumnsItem | null;\n    if (!dragged || event.index == null) { return; }\n    const from = this.items.findIndex(it => it.uid === dragged.uid);\n    if (from < 0) { return; }\n    const next = this.items.slice();\n    next.splice(from, 1);\n    const to = event.index > from ? event.index - 1 : event.index;\n    next.splice(to, 0, dragged);\n    this.items = next;\n  }\n\n  public onMove(index: number, dir: -1 | 1): void {\n    const target = index + dir;\n    if (target < 0 || target >= this.items.length) { return; }\n    const next = this.items.slice();\n    [next[index], next[target]] = [next[target], next[index]];\n    this.items = next;\n  }\n\n  public onRename(index: number, value: string): void {\n    if (!this.items[index]) { return; }\n    this.items = this.items.map((it, i) => i === index ? { ...it, name: value } : it);\n    this.columnsError = null;\n  }\n\n  public onRemove(index: number): void {\n    const item = this.items[index];\n    if (!item || this.isLocked(item)) { return; }\n    this.items = this.items.filter((_, i) => i !== index);\n    this.columnsError = null;\n  }\n\n  public onNewColNameChange(value: string): void {\n    this.newColName = value;\n  }\n\n  public onAdd(): void {\n    const trimmed = (this.newColName || '').trim();\n    if (!trimmed || this.itemsHasName(trimmed)) { return; }\n    this.items = [...this.items, {\n      uid: this.nextUid++,\n      originalName: null,\n      name: trimmed,\n    }];\n    this.newColName = '';\n    this.columnsError = null;\n  }\n\n  public get canAdd(): boolean {\n    const trimmed = (this.newColName || '').trim();\n    if (!trimmed) { return false; }\n    return !this.itemsHasName(trimmed);\n  }\n\n  public getValue(): ManageColumnsDialogValue | null {\n    const trimmed: ManageColumnsDialogColumn[] = this.items.map(it => ({\n      originalName: it.originalName,\n      name: (it.name || '').trim(),\n    }));\n\n    if (trimmed.length === 0) {\n      this.columnsError = 'At least one column is required.';\n      return null;\n    }\n    if (trimmed.some(c => c.name.length === 0)) {\n      this.columnsError = 'Column names cannot be empty.';\n      return null;\n    }\n    const lowered = trimmed.map(c => c.name.toLowerCase());\n    if (new Set(lowered).size !== trimmed.length) {\n      this.columnsError = 'Column names must be unique.';\n      return null;\n    }\n\n    this.columnsError = null;\n    return { columns: trimmed };\n  }\n\n  private itemsHasName(candidate: string): boolean {\n    const lowered = candidate.toLowerCase();\n    return this.items.some(it => (it.name || '').trim().toLowerCase() === lowered);\n  }\n}\n","<div class=\"manage-cols-stack\">\n\n  <div class=\"manage-cols-drop-list\"\n       [dndDropzone]=\"['col']\"\n       dndEffectAllowed=\"move\"\n       dndDragoverClass=\"dndDragover\"\n       (dndDrop)=\"onDndDrop($event)\">\n    <div dndPlaceholderRef class=\"manage-cols-placeholder\">Drop here</div>\n    <div *ngFor=\"let item of items; let i = index; trackBy: trackByUid\"\n         class=\"manage-cols-row\">\n      <span class=\"manage-cols-handle\"\n            [dndDraggable]=\"item\"\n            [dndDisableIf]=\"isLocked(item)\"\n            dndType=\"col\"\n            dndEffectAllowed=\"move\">\n        <mat-icon>drag_indicator</mat-icon>\n      </span>\n      <cqa-custom-input\n        class=\"cqa-flex-1\"\n        [value]=\"item.name\"\n        [fullWidth]=\"true\"\n        [disabled]=\"isLocked(item)\"\n        inputInlineStyle=\"font-family: 'Inter', ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, 'Liberation Mono', monospace;\"\n        (valueChange)=\"onRename(i, $event)\">\n      </cqa-custom-input>\n      <button type=\"button\" class=\"manage-cols-icon-btn\"\n              title=\"Move up\"\n              [disabled]=\"i === 0\"\n              (click)=\"onMove(i, -1)\">\n        <mat-icon>arrow_upward</mat-icon>\n      </button>\n      <button type=\"button\" class=\"manage-cols-icon-btn\"\n              title=\"Move down\"\n              [disabled]=\"i === items.length - 1\"\n              (click)=\"onMove(i, 1)\">\n        <mat-icon>arrow_downward</mat-icon>\n      </button>\n      <button type=\"button\" class=\"manage-cols-icon-btn manage-cols-icon-btn-danger\"\n              title=\"Delete column\"\n              [disabled]=\"isLocked(item)\"\n              (click)=\"onRemove(i)\">\n        <mat-icon>delete</mat-icon>\n      </button>\n    </div>\n  </div>\n\n  <div class=\"manage-cols-footer\">\n    <cqa-custom-input\n      class=\"cqa-flex-1\"\n      [value]=\"newColName\"\n      [fullWidth]=\"true\"\n      placeholder=\"New column name (e.g. currency)\"\n      inputInlineStyle=\"font-family: 'Inter', ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, 'Liberation Mono', monospace;\"\n      (valueChange)=\"onNewColNameChange($event)\"\n      (enterPressed)=\"onAdd()\">\n    </cqa-custom-input>\n    <cqa-button\n      variant=\"outlined\"\n      icon=\"add\"\n      text=\"Add column\"\n      [disabled]=\"!canAdd\"\n      (clicked)=\"onAdd()\">\n    </cqa-button>\n  </div>\n\n  <span *ngIf=\"columnsError\" class=\"manage-cols-error\">{{ columnsError }}</span>\n\n  <div class=\"manage-cols-hint\">\n    <strong>Heads up:</strong>\n    Deleting a column removes its data from every environment. Renaming keeps the data in place.\n  </div>\n\n</div>\n"]}
|
|
@@ -112,10 +112,10 @@ export class GlobalVariableTagsInputComponent {
|
|
|
112
112
|
}
|
|
113
113
|
}
|
|
114
114
|
GlobalVariableTagsInputComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: GlobalVariableTagsInputComponent, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
115
|
-
GlobalVariableTagsInputComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.4.0", type: GlobalVariableTagsInputComponent, selector: "lib-global-variable-tags-input", inputs: { tags: "tags", availableTags: "availableTags" }, outputs: { tagsChange: "tagsChange" }, host: { styleAttribute: "display:block;width:100%;", classAttribute: "cqa-ui-root" }, viewQueries: [{ propertyName: "tagInputRef", first: true, predicate: ["tagInput"], descendants: true }], ngImport: i0, template: "<div class=\"cqa-
|
|
115
|
+
GlobalVariableTagsInputComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.4.0", type: GlobalVariableTagsInputComponent, selector: "lib-global-variable-tags-input", inputs: { tags: "tags", availableTags: "availableTags" }, outputs: { tagsChange: "tagsChange" }, host: { styleAttribute: "display:block;width:100%;", classAttribute: "cqa-ui-root" }, viewQueries: [{ propertyName: "tagInputRef", first: true, predicate: ["tagInput"], descendants: true }], ngImport: i0, template: "<div class=\"cqa-gv-tag-row\">\n <!-- Selected tag chips -->\n <span *ngFor=\"let tag of tags; let i = index\" class=\"cqa-gv-tag-chip\">\n <mat-icon>sell</mat-icon>\n <span>{{ tag }}</span>\n <button type=\"button\"\n class=\"cqa-gv-tag-chip-x\"\n (click)=\"removeAt(i)\"\n [attr.aria-label]=\"'Remove tag ' + tag\">\n <mat-icon>close</mat-icon>\n </button>\n </span>\n\n <!-- Inactive: \"+ Add tag\" dashed pill -->\n <button *ngIf=\"!adding\" type=\"button\"\n class=\"cqa-gv-tag-add\"\n (click)=\"beginAdd()\">\n <mat-icon>add</mat-icon>\n <span>Add tag</span>\n </button>\n\n <!-- Active: pill-styled input + suggestion dropdown -->\n <div *ngIf=\"adding\" class=\"cqa-relative\">\n <input #tagInput\n type=\"text\"\n class=\"cqa-gv-tag-input\"\n placeholder=\"Tag\u2026\"\n [value]=\"draft\"\n (input)=\"onDraftChange($any($event.target).value)\"\n (keydown)=\"onKeyDown($event)\"\n (blur)=\"onBlur()\" />\n\n <div *ngIf=\"suggestions.length > 0\" class=\"cqa-gv-tag-suggest\">\n <div *ngFor=\"let s of suggestions\"\n class=\"cqa-gv-tag-suggest-item\"\n (mousedown)=\"onSuggestionMouseDown($event, s)\">\n <span class=\"cqa-inline-flex cqa-items-center cqa-gap-1.5\">\n <mat-icon>sell</mat-icon>\n <span>{{ s.name }}</span>\n </span>\n <span *ngIf=\"s.count != null\" class=\"cqa-gv-tag-suggest-count\">{{ s.count }}</span>\n </div>\n </div>\n </div>\n</div>\n", components: [{ type: i1.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }], directives: [{ type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
116
116
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: GlobalVariableTagsInputComponent, decorators: [{
|
|
117
117
|
type: Component,
|
|
118
|
-
args: [{ selector: 'lib-global-variable-tags-input', changeDetection: ChangeDetectionStrategy.OnPush, host: { class: 'cqa-ui-root', style: 'display:block;width:100%;' }, template: "<div class=\"cqa-
|
|
118
|
+
args: [{ selector: 'lib-global-variable-tags-input', changeDetection: ChangeDetectionStrategy.OnPush, host: { class: 'cqa-ui-root', style: 'display:block;width:100%;' }, template: "<div class=\"cqa-gv-tag-row\">\n <!-- Selected tag chips -->\n <span *ngFor=\"let tag of tags; let i = index\" class=\"cqa-gv-tag-chip\">\n <mat-icon>sell</mat-icon>\n <span>{{ tag }}</span>\n <button type=\"button\"\n class=\"cqa-gv-tag-chip-x\"\n (click)=\"removeAt(i)\"\n [attr.aria-label]=\"'Remove tag ' + tag\">\n <mat-icon>close</mat-icon>\n </button>\n </span>\n\n <!-- Inactive: \"+ Add tag\" dashed pill -->\n <button *ngIf=\"!adding\" type=\"button\"\n class=\"cqa-gv-tag-add\"\n (click)=\"beginAdd()\">\n <mat-icon>add</mat-icon>\n <span>Add tag</span>\n </button>\n\n <!-- Active: pill-styled input + suggestion dropdown -->\n <div *ngIf=\"adding\" class=\"cqa-relative\">\n <input #tagInput\n type=\"text\"\n class=\"cqa-gv-tag-input\"\n placeholder=\"Tag\u2026\"\n [value]=\"draft\"\n (input)=\"onDraftChange($any($event.target).value)\"\n (keydown)=\"onKeyDown($event)\"\n (blur)=\"onBlur()\" />\n\n <div *ngIf=\"suggestions.length > 0\" class=\"cqa-gv-tag-suggest\">\n <div *ngFor=\"let s of suggestions\"\n class=\"cqa-gv-tag-suggest-item\"\n (mousedown)=\"onSuggestionMouseDown($event, s)\">\n <span class=\"cqa-inline-flex cqa-items-center cqa-gap-1.5\">\n <mat-icon>sell</mat-icon>\n <span>{{ s.name }}</span>\n </span>\n <span *ngIf=\"s.count != null\" class=\"cqa-gv-tag-suggest-count\">{{ s.count }}</span>\n </div>\n </div>\n </div>\n</div>\n" }]
|
|
119
119
|
}], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }]; }, propDecorators: { tags: [{
|
|
120
120
|
type: Input
|
|
121
121
|
}], availableTags: [{
|
|
@@ -126,4 +126,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImpor
|
|
|
126
126
|
type: ViewChild,
|
|
127
127
|
args: ['tagInput']
|
|
128
128
|
}] } });
|
|
129
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"global-variable-tags-input.component.js","sourceRoot":"","sources":["../../../../../src/lib/new-global-variable-dialog/global-variable-tags-input.component.ts","../../../../../src/lib/new-global-variable-dialog/global-variable-tags-input.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  EventEmitter,\n  Input,\n  Output,\n  ViewChild,\n} from '@angular/core';\nimport { GlobalVariableTagOption } from './new-global-variable-dialog.models';\n\n/**\n * Tag chip-list + autocomplete used by the New / Edit Global Variable dialog.\n * Mirrors the React `TagsEditor` block in\n * `Environment and Data Management_CD Deisgns/src/Global.jsx:179-237`:\n *\n *   [chip × …]  [+ Add tag]   ←  inactive state\n *   [chip × …]  [_input_  ↳ suggestions]   ←  active state\n *\n * Behavior:\n *   - Backspace on an empty input removes the last tag.\n *   - Enter commits the trimmed lowercase value (creates if not in available).\n *   - Escape exits the input without committing.\n *   - Suggestions are computed from `availableTags`, capped at 4.\n */\n@Component({\n  selector: 'lib-global-variable-tags-input',\n  templateUrl: './global-variable-tags-input.component.html',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  host: { class: 'cqa-ui-root', style: 'display:block;width:100%;' },\n})\nexport class GlobalVariableTagsInputComponent {\n  @Input() tags: string[] = [];\n  @Input() availableTags: GlobalVariableTagOption[] = [];\n  @Output() tagsChange = new EventEmitter<string[]>();\n\n  @ViewChild('tagInput') tagInputRef?: ElementRef<HTMLInputElement>;\n\n  adding = false;\n  draft = '';\n\n  constructor(private readonly cdr: ChangeDetectorRef) {}\n\n  get suggestions(): GlobalVariableTagOption[] {\n    const typed = this.draft.trim().toLowerCase();\n    const taken = new Set((this.tags ?? []).map(t => t.toLowerCase()));\n    const pool = (this.availableTags ?? []).filter(t => !taken.has((t.name ?? '').toLowerCase()));\n    if (typed.length === 0) {\n      return pool.slice(0, 4);\n    }\n    return pool\n      .filter(t => (t.name ?? '').toLowerCase().startsWith(typed))\n      .slice(0, 4);\n  }\n\n  beginAdd(): void {\n    this.adding = true;\n    this.draft = '';\n    this.cdr.markForCheck();\n    setTimeout(() => this.tagInputRef?.nativeElement.focus(), 0);\n  }\n\n  onDraftChange(next: string): void {\n    this.draft = next ?? '';\n    this.cdr.markForCheck();\n  }\n\n  onKeyDown(event: KeyboardEvent): void {\n    if (event.key === 'Enter') {\n      event.preventDefault();\n      this.commitDraft();\n    } else if (event.key === 'Escape') {\n      event.preventDefault();\n      this.cancelAdd();\n    } else if (event.key === 'Backspace' && !this.draft && this.tags.length > 0) {\n      event.preventDefault();\n      this.removeAt(this.tags.length - 1);\n    }\n  }\n\n  onSuggestionMouseDown(event: MouseEvent, suggestion: GlobalVariableTagOption): void {\n    // mouseDown beats blur so the click registers before the input loses focus\n    event.preventDefault();\n    this.commit(suggestion.name);\n  }\n\n  onBlur(): void {\n    // Defer so suggestion click has a chance to fire first\n    setTimeout(() => {\n      if (!this.adding) { return; }\n      this.commitDraft();\n    }, 150);\n  }\n\n  removeAt(index: number): void {\n    const next = (this.tags ?? []).filter((_, i) => i !== index);\n    this.tags = next;\n    this.tagsChange.emit(next);\n    this.cdr.markForCheck();\n  }\n\n  private commitDraft(): void {\n    const raw = (this.draft ?? '').trim().toLowerCase();\n    if (!raw) {\n      this.cancelAdd();\n      return;\n    }\n    this.commit(raw);\n  }\n\n  private commit(name: string): void {\n    const normalized = (name ?? '').trim().toLowerCase();\n    if (!normalized) { return; }\n    const taken = new Set((this.tags ?? []).map(t => t.toLowerCase()));\n    if (taken.has(normalized)) {\n      this.cancelAdd();\n      return;\n    }\n    const next = [...(this.tags ?? []), normalized];\n    this.tags = next;\n    this.tagsChange.emit(next);\n    this.draft = '';\n    this.adding = false;\n    this.cdr.markForCheck();\n  }\n\n  private cancelAdd(): void {\n    this.adding = false;\n    this.draft = '';\n    this.cdr.markForCheck();\n  }\n}\n","<div class=\"cqa-flex cqa-flex-wrap cqa-items-center cqa-gap-1.5\">\n  <!-- Selected tag chips -->\n  <span *ngFor=\"let tag of tags; let i = index\"\n    class=\"cqa-inline-flex cqa-items-center cqa-gap-1 cqa-px-2 cqa-py-0.5 cqa-rounded-full cqa-text-xs cqa-font-medium\"\n    style=\"background:#FAE8FF;color:#6B21A8;\">\n    <mat-icon class=\"!cqa-w-[12px] !cqa-h-[12px] !cqa-text-[12px] cqa-leading-[12px]\">sell</mat-icon>\n    <span>{{ tag }}</span>\n    <button type=\"button\"\n      class=\"cqa-inline-flex cqa-items-center cqa-justify-center cqa-rounded-full cqa-cursor-pointer hover:cqa-bg-[#E9D5FF]\"\n      style=\"border:none;background:transparent;padding:0;\"\n      (click)=\"removeAt(i)\"\n      [attr.aria-label]=\"'Remove tag ' + tag\">\n      <mat-icon class=\"!cqa-w-[12px] !cqa-h-[12px] !cqa-text-[12px] cqa-leading-[12px]\">close</mat-icon>\n    </button>\n  </span>\n\n  <!-- Inactive: \"+ Add tag\" pill -->\n  <button *ngIf=\"!adding\" type=\"button\"\n    class=\"cqa-inline-flex cqa-items-center cqa-gap-1 cqa-px-2 cqa-py-0.5 cqa-rounded-full cqa-text-xs cqa-cursor-pointer\"\n    style=\"border:1px dashed #D4D4D8;background:transparent;color:#52525B;\"\n    (click)=\"beginAdd()\">\n    <mat-icon class=\"!cqa-w-[12px] !cqa-h-[12px] !cqa-text-[12px] cqa-leading-[12px]\">add</mat-icon>\n    <span>Add tag</span>\n  </button>\n\n  <!-- Active: input + suggestions. Input matches the dialog's other inputs:\n       full-width row, 1px solid border, rounded; input border itself is the\n       inner pill the user types into. Suggestion dropdown renders below. -->\n  <div *ngIf=\"adding\" class=\"cqa-relative\" style=\"min-width:200px;\">\n    <input #tagInput\n      type=\"text\"\n      class=\"cqa-px-3 cqa-py-1.5 cqa-rounded-md cqa-text-sm cqa-outline-none cqa-w-full\"\n      style=\"border:1px solid #6366F1;box-shadow:0 0 0 3px rgba(99,102,241,0.12);\"\n      placeholder=\"Tag…\"\n      [value]=\"draft\"\n      (input)=\"onDraftChange($any($event.target).value)\"\n      (keydown)=\"onKeyDown($event)\"\n      (blur)=\"onBlur()\" />\n\n    <div *ngIf=\"suggestions.length > 0\"\n      class=\"cqa-absolute cqa-z-10 cqa-mt-1 cqa-bg-white cqa-rounded-md cqa-shadow-lg cqa-w-full\"\n      style=\"border:1px solid #E5E7EB;max-height:220px;overflow-y:auto;left:0;\">\n      <div *ngFor=\"let s of suggestions\"\n        class=\"cqa-flex cqa-items-center cqa-justify-between cqa-gap-2 cqa-px-3 cqa-py-2 cqa-cursor-pointer hover:cqa-bg-[#F3F4F6]\"\n        (mousedown)=\"onSuggestionMouseDown($event, s)\">\n        <span class=\"cqa-inline-flex cqa-items-center cqa-gap-2 cqa-text-sm cqa-text-gray-800\">\n          <mat-icon class=\"!cqa-w-[14px] !cqa-h-[14px] !cqa-text-[14px] cqa-leading-[14px]\" style=\"color:#6B21A8;\">sell</mat-icon>\n          <span>{{ s.name }}</span>\n        </span>\n        <span *ngIf=\"s.count != null\" class=\"cqa-text-[11px] cqa-text-gray-400\">{{ s.count }}</span>\n      </div>\n    </div>\n  </div>\n</div>\n"]}
|
|
129
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"global-variable-tags-input.component.js","sourceRoot":"","sources":["../../../../../src/lib/new-global-variable-dialog/global-variable-tags-input.component.ts","../../../../../src/lib/new-global-variable-dialog/global-variable-tags-input.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  EventEmitter,\n  Input,\n  Output,\n  ViewChild,\n} from '@angular/core';\nimport { GlobalVariableTagOption } from './new-global-variable-dialog.models';\n\n/**\n * Tag chip-list + autocomplete used by the New / Edit Global Variable dialog.\n * Mirrors the React `TagsEditor` block in\n * `Environment and Data Management_CD Deisgns/src/Global.jsx:179-237`:\n *\n *   [chip × …]  [+ Add tag]   ←  inactive state\n *   [chip × …]  [_input_  ↳ suggestions]   ←  active state\n *\n * Behavior:\n *   - Backspace on an empty input removes the last tag.\n *   - Enter commits the trimmed lowercase value (creates if not in available).\n *   - Escape exits the input without committing.\n *   - Suggestions are computed from `availableTags`, capped at 4.\n */\n@Component({\n  selector: 'lib-global-variable-tags-input',\n  templateUrl: './global-variable-tags-input.component.html',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  host: { class: 'cqa-ui-root', style: 'display:block;width:100%;' },\n})\nexport class GlobalVariableTagsInputComponent {\n  @Input() tags: string[] = [];\n  @Input() availableTags: GlobalVariableTagOption[] = [];\n  @Output() tagsChange = new EventEmitter<string[]>();\n\n  @ViewChild('tagInput') tagInputRef?: ElementRef<HTMLInputElement>;\n\n  adding = false;\n  draft = '';\n\n  constructor(private readonly cdr: ChangeDetectorRef) {}\n\n  get suggestions(): GlobalVariableTagOption[] {\n    const typed = this.draft.trim().toLowerCase();\n    const taken = new Set((this.tags ?? []).map(t => t.toLowerCase()));\n    const pool = (this.availableTags ?? []).filter(t => !taken.has((t.name ?? '').toLowerCase()));\n    if (typed.length === 0) {\n      return pool.slice(0, 4);\n    }\n    return pool\n      .filter(t => (t.name ?? '').toLowerCase().startsWith(typed))\n      .slice(0, 4);\n  }\n\n  beginAdd(): void {\n    this.adding = true;\n    this.draft = '';\n    this.cdr.markForCheck();\n    setTimeout(() => this.tagInputRef?.nativeElement.focus(), 0);\n  }\n\n  onDraftChange(next: string): void {\n    this.draft = next ?? '';\n    this.cdr.markForCheck();\n  }\n\n  onKeyDown(event: KeyboardEvent): void {\n    if (event.key === 'Enter') {\n      event.preventDefault();\n      this.commitDraft();\n    } else if (event.key === 'Escape') {\n      event.preventDefault();\n      this.cancelAdd();\n    } else if (event.key === 'Backspace' && !this.draft && this.tags.length > 0) {\n      event.preventDefault();\n      this.removeAt(this.tags.length - 1);\n    }\n  }\n\n  onSuggestionMouseDown(event: MouseEvent, suggestion: GlobalVariableTagOption): void {\n    // mouseDown beats blur so the click registers before the input loses focus\n    event.preventDefault();\n    this.commit(suggestion.name);\n  }\n\n  onBlur(): void {\n    // Defer so suggestion click has a chance to fire first\n    setTimeout(() => {\n      if (!this.adding) { return; }\n      this.commitDraft();\n    }, 150);\n  }\n\n  removeAt(index: number): void {\n    const next = (this.tags ?? []).filter((_, i) => i !== index);\n    this.tags = next;\n    this.tagsChange.emit(next);\n    this.cdr.markForCheck();\n  }\n\n  private commitDraft(): void {\n    const raw = (this.draft ?? '').trim().toLowerCase();\n    if (!raw) {\n      this.cancelAdd();\n      return;\n    }\n    this.commit(raw);\n  }\n\n  private commit(name: string): void {\n    const normalized = (name ?? '').trim().toLowerCase();\n    if (!normalized) { return; }\n    const taken = new Set((this.tags ?? []).map(t => t.toLowerCase()));\n    if (taken.has(normalized)) {\n      this.cancelAdd();\n      return;\n    }\n    const next = [...(this.tags ?? []), normalized];\n    this.tags = next;\n    this.tagsChange.emit(next);\n    this.draft = '';\n    this.adding = false;\n    this.cdr.markForCheck();\n  }\n\n  private cancelAdd(): void {\n    this.adding = false;\n    this.draft = '';\n    this.cdr.markForCheck();\n  }\n}\n","<div class=\"cqa-gv-tag-row\">\n  <!-- Selected tag chips -->\n  <span *ngFor=\"let tag of tags; let i = index\" class=\"cqa-gv-tag-chip\">\n    <mat-icon>sell</mat-icon>\n    <span>{{ tag }}</span>\n    <button type=\"button\"\n      class=\"cqa-gv-tag-chip-x\"\n      (click)=\"removeAt(i)\"\n      [attr.aria-label]=\"'Remove tag ' + tag\">\n      <mat-icon>close</mat-icon>\n    </button>\n  </span>\n\n  <!-- Inactive: \"+ Add tag\" dashed pill -->\n  <button *ngIf=\"!adding\" type=\"button\"\n    class=\"cqa-gv-tag-add\"\n    (click)=\"beginAdd()\">\n    <mat-icon>add</mat-icon>\n    <span>Add tag</span>\n  </button>\n\n  <!-- Active: pill-styled input + suggestion dropdown -->\n  <div *ngIf=\"adding\" class=\"cqa-relative\">\n    <input #tagInput\n      type=\"text\"\n      class=\"cqa-gv-tag-input\"\n      placeholder=\"Tag…\"\n      [value]=\"draft\"\n      (input)=\"onDraftChange($any($event.target).value)\"\n      (keydown)=\"onKeyDown($event)\"\n      (blur)=\"onBlur()\" />\n\n    <div *ngIf=\"suggestions.length > 0\" class=\"cqa-gv-tag-suggest\">\n      <div *ngFor=\"let s of suggestions\"\n        class=\"cqa-gv-tag-suggest-item\"\n        (mousedown)=\"onSuggestionMouseDown($event, s)\">\n        <span class=\"cqa-inline-flex cqa-items-center cqa-gap-1.5\">\n          <mat-icon>sell</mat-icon>\n          <span>{{ s.name }}</span>\n        </span>\n        <span *ngIf=\"s.count != null\" class=\"cqa-gv-tag-suggest-count\">{{ s.count }}</span>\n      </div>\n    </div>\n  </div>\n</div>\n"]}
|