fx-form-builder-wrapper 2.0.76 → 2.0.78

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.
@@ -34,6 +34,7 @@ export class RadioGroupComponent extends FxBaseComponent {
34
34
  ];
35
35
  fxComponent;
36
36
  radoioMap = new Map();
37
+ compareValue;
37
38
  constructor(cdr, http, fxBuilderWrapperService, fxApiService) {
38
39
  super(cdr);
39
40
  this.cdr = cdr;
@@ -48,6 +49,7 @@ export class RadioGroupComponent extends FxBaseComponent {
48
49
  this.options = this.fxComponent?.fxData?.settings?.find((s) => s.key === 'items')?.options || [];
49
50
  const labelData = this.fxComponent?.fxData?.settings?.find((s) => s.key === 'select-label')?.value ??
50
51
  '';
52
+ this.compareValue = this.fxComponent?.fxData?.settings?.find((s) => s.key === 'value-show-text')?.value;
51
53
  const label = this.confirmationForm.get('label');
52
54
  label?.setValue(labelData);
53
55
  setTimeout(() => {
@@ -127,9 +129,7 @@ export class RadioGroupComponent extends FxBaseComponent {
127
129
  return [];
128
130
  }
129
131
  onSelectionChange(selection) {
130
- const labelData = this.fxComponent?.fxData?.settings?.find((s) => s.key === 'value-show-text')?.value ??
131
- '';
132
- this.showTextArea = selection === labelData;
132
+ this.showTextArea = selection === this.compareValue;
133
133
  if (this.showTextArea) {
134
134
  const valueToShowTextArea = this.confirmationForm.get('valueToShowTextArea');
135
135
  valueToShowTextArea?.setValue(this.setting('value-show-text'));
@@ -139,6 +139,7 @@ export class RadioGroupComponent extends FxBaseComponent {
139
139
  }
140
140
  else {
141
141
  const otherControl = this.confirmationForm.get('remarks');
142
+ otherControl?.reset();
142
143
  otherControl?.clearValidators();
143
144
  otherControl?.updateValueAndValidity();
144
145
  }
@@ -155,4 +156,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
155
156
  type: ViewChild,
156
157
  args: ['fxComponent']
157
158
  }] } });
158
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"radio-group.component.js","sourceRoot":"","sources":["../../../../../../projects/fx-builder-wrapper/src/lib/components/radio-group/radio-group.component.ts","../../../../../../projects/fx-builder-wrapper/src/lib/components/radio-group/radio-group.component.html"],"names":[],"mappings":"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","sourcesContent":["import { HttpClient } from '@angular/common/http';\r\nimport { AfterViewInit, ChangeDetectorRef, Component, inject, Input, OnInit, ViewChild } from '@angular/core';\r\nimport { FormBuilder, FormsModule, ReactiveFormsModule, Validators } from '@angular/forms';\r\nimport { ApiServiceRegistry } from '@instantsys-labs/core';\r\nimport { FxBaseComponent, FxComponent, FxOptionSetting, FxSelectSetting, FxSetting, FxStringSetting, FxValidation, FxValidatorService } from '@instantsys-labs/fx';\r\nimport { Subject, takeUntil } from 'rxjs';\r\nimport { FxBuilderWrapperService } from '../../fx-builder-wrapper.service';\r\nimport { CommonModule } from '@angular/common';\r\nimport { CalendarModule } from 'primeng/calendar';\r\nimport { RadioButtonModule } from 'primeng/radiobutton';\r\n\r\n@Component({\r\n  selector: 'radio-group-custom',\r\n  standalone: true,\r\n  imports: [CommonModule, ReactiveFormsModule, FormsModule, FxComponent, CalendarModule,RadioButtonModule],\r\n  templateUrl: './radio-group.component.html',\r\n  styleUrl: './radio-group.component.css'\r\n})\r\nexport class RadioGroupComponent extends FxBaseComponent implements OnInit, AfterViewInit{\r\nprivate fb = inject(FormBuilder);\r\nprivate destroy$ = new Subject<Boolean>();\r\nformObject: object = {};\r\n@Input() showOnSelection: 'yes' | 'no' = 'yes'; // configurable: show textarea on Yes or No\r\n  showTextArea = false;\r\n public confirmationForm = this.fb.group({\r\n      confirmation: [''],\r\n      remarks: [''],\r\n      valueToShowTextArea: [''],\r\n      label:['']\r\n    });\r\n\r\n    options: any[] = [\r\n      { option: 'Yes', value: 'YES' },\r\n      { option: 'No', value: 'NO' },\r\n      { option: 'NA', value: 'NA' }\r\n    ];\r\n\r\n    @ViewChild('fxComponent') fxComponent!: FxComponent;\r\n    radoioMap = new Map<string, any>();\r\n\r\n    constructor(private cdr: ChangeDetectorRef,private http: HttpClient,private fxBuilderWrapperService: FxBuilderWrapperService,private fxApiService: ApiServiceRegistry) {\r\n       super(cdr)\r\n        this.onInit.subscribe(() => {\r\n          this._register(this.confirmationForm);\r\n        });\r\n       \r\n     }\r\n\r\n       ngAfterViewInit(): void {\r\n        this.options  = (this.fxComponent?.fxData?.settings?.find((s: any) => s.key === 'items') as any)?.options || [];\r\n       const labelData =\r\n  (this.fxComponent?.fxData?.settings?.find((s: any) => s.key === 'select-label') as any)?.value ??\r\n  '';\r\n         const label = this.confirmationForm.get('label');\r\n         label?.setValue(labelData);\r\n       setTimeout(() => {\r\n  const key = this.fxComponent?.fxData?.name;\r\n\r\n  if (key && this.radoioMap.has(key)) {\r\n    this.confirmationForm.patchValue(this.radoioMap.get(key));\r\n    const data = this.radoioMap.get(key);\r\n    this.onSelectionChange(data.valueToShowTextArea);\r\n  }\r\n}, 200);\r\n\r\n       setTimeout(()=>{\r\n     const mainControl = this.confirmationForm.get('confirmation');\r\n     if(this.setting('isRadioRequired') === 'true'){\r\n      mainControl?.setValidators([Validators.required]);\r\n      mainControl?.updateValueAndValidity();\r\n     }\r\n    },100)\r\n\r\n        \r\n       }\r\n     \r\n       ngOnInit(): void {\r\n           this.fxBuilderWrapperService.variables$\r\n          .pipe(takeUntil(this.destroy$))\r\n          .subscribe((variables: any) => {\r\n            if (!variables) return;\r\n        \r\n        \r\n            // for (const [key, value] of Object.entries(variables) as [string, any][]) {\r\n            //   if (key.includes('radio-group-custom')) {\r\n            //    this.formObject = value;\r\n            //   }\r\n            // }\r\n\r\n            for (const [key, value] of Object.entries(variables) as [string, any][]) {\r\n  if (\r\n    value &&\r\n    typeof value === 'object' &&\r\n    'confirmation' in value\r\n  ) {\r\n    this.radoioMap.set(key, value);\r\n  }\r\n}\r\n\r\n            \r\n       })\r\n\r\n        this.options  = (this.fxComponent?.fxData?.settings?.find((s: any) => s.key === 'items') as any)?.options || [];\r\n\r\n\r\n      //  this.setting('items').length > 0 ? this.options = this.setting('items') : null;\r\n     \r\n      //   this.confirmationForm.get('confirmation')?.valueChanges.subscribe(value => {\r\n      //    const otherControl = this.confirmationForm.get('remarks');\r\n      //    const valueToShowTextArea = this.confirmationForm.get('valueToShowTextArea');\r\n      //    if (value) {\r\n      //      otherControl?.setValidators([Validators.required]);\r\n      //      valueToShowTextArea?.setValue(this.setting('value-show-text'));\r\n\r\n      //     } else {\r\n      //      otherControl?.clearValidators();\r\n      //      otherControl?.reset();\r\n      //      valueToShowTextArea?.reset();\r\n      //    }\r\n      //  });\r\n       \r\n     \r\n     }\r\n\r\n     protected settings(): FxSetting[] {\r\n          return [\r\n            // new FxStringSetting({ key: 'clinicalNotesURL', $title: 'API Url', value: '' }),\r\n            new FxStringSetting({ key: 'customClasss', $title: 'Custom Class Name', value: '' }),\r\n             new FxStringSetting({ key: 'select-label', $title: 'Header Label', value: 'Header Label' }), \r\n              // new FxStringSetting({ key: 'option-value-one', $title: 'Value one', value: 'Value one' }), \r\n              //  new FxStringSetting({ key: 'option-value-two', $title: 'Value two', value: 'Value two' }), \r\n              //   new FxStringSetting({ key: 'option-label-one', $title: 'Label one', value: 'Label one' }), \r\n              //   new FxStringSetting({ key: 'option-label-two', $title: 'Label two', value: 'Label two' }), \r\n                new FxStringSetting({ key: 'value-show-text', $title: 'Value to show textarea', value: 'Value to show textarea' }),\r\n                new FxOptionSetting({ key: 'items', $title: 'Options', value: [{option: 'Yes', value: 'yes'}, {option: 'No', value: 'no'}]  }, [{option: 'Yes', value: 'yes'}, {option: 'No', value: 'no'}]), \r\n                new FxStringSetting({ key: 'additional-field-label', $title: 'Additional field label', value: '' }),\r\n                new FxStringSetting({ key: 'additional-field-error-msg', $title: 'Additional field error message', value: 'Please fill out the field' }),\r\n                new FxStringSetting({ key: 'error-msg', $title: 'Error message', value: 'Please select' }),\r\n                new FxStringSetting({ key: 'remark-placeholder', $title: 'Additional field placeholder', value: 'enter here' }),\r\n                new FxSelectSetting({key: 'isRadioRequired', $title: 'Required', value: 'true'}, [{option: 'Yes', value: 'true'}, {option: 'No', value: 'false'}]),    \r\n            //   new FxStringSetting({ key: 'other-placeholder', $title: 'Other Placeholder', value: '' }),  \r\n            //   new FxSelectSetting({key: 'serviceName', $title: 'Service', value: ''}, [{option: 'User Service', value: 'user_service'}, {option: 'Patient Service', value: 'patient_service'},{option: 'Workflow Service', value: 'workflow_service'}]),\r\n            //   // new FxSelectSetting({key: 'service', $title: 'Service', value: 'local'}, [{option: 'Local', value: 'local'}, {option: 'QA', value: 'qa'},{option: 'UAT', value: 'uat'},{option: 'Production', value: 'prod'}]),   \r\n            //   // new FxSelectSetting({key: 'isRequired', $title: 'Required', value: true}, [{option: 'Yes', value: true}, {option: 'No', value: false}]),    \r\n            //    new FxStringSetting({ key: 'errorMessage', $title: 'Error Message', value: 'Please fill out the field' }),  \r\n          ];\r\n        }\r\n      \r\n        protected validations(): FxValidation[] {\r\n          return [];\r\n        }\r\n\r\n        onSelectionChange(selection: string) {\r\n                 const labelData =\r\n  (this.fxComponent?.fxData?.settings?.find((s: any) => s.key === 'value-show-text') as any)?.value ??\r\n  '';\r\n    this.showTextArea = selection === labelData;\r\n    if(this.showTextArea){\r\nconst valueToShowTextArea = this.confirmationForm.get('valueToShowTextArea');\r\n valueToShowTextArea?.setValue(this.setting('value-show-text'));\r\nconst otherControl = this.confirmationForm.get('remarks');\r\notherControl?.setValidators([Validators.required]);\r\notherControl?.updateValueAndValidity();\r\n    }\r\n    else{\r\n      const otherControl = this.confirmationForm.get('remarks');\r\n      otherControl?.clearValidators();\r\n      otherControl?.updateValueAndValidity();\r\n    }\r\n\r\n  }\r\n}\r\n","<fx-component [fxData]=\"fxData\" #fxComponent>\r\n  <div  [ngClass]=\"setting('customClasss')\">\r\n<form [formGroup]=\"confirmationForm\" class=\"flex gap-4 w-full\">\r\n  <div class=\"flex-1 w-full\">\r\n    <!-- Title -->\r\n  <label class=\"font-semibold text-gray-800\">\r\n    {{ setting('select-label') }}\r\n  </label>\r\n\r\n  <!-- TWO COLUMN LAYOUT -->\r\n  \r\n\r\n    <!-- LEFT COLUMN (RADIO GROUP) -->\r\n    <div class=\"flex-1\">\r\n\r\n      <div class=\"flex gap-3 my-2\"> \r\n        <!-- stack vertically so height is correct -->\r\n        <label\r\n          *ngFor=\"let opt of options\"\r\n          class=\"flex items-center gap-2 cursor-pointer text-gray-700\"\r\n        >\r\n          <input\r\n            type=\"radio\"\r\n            formControlName=\"confirmation\"\r\n            [value]=\"opt.value\"\r\n            (change)=\"onSelectionChange(opt.value)\"\r\n            class=\"w-4 h-4 accent-blue-600 cursor-pointer\"\r\n          />\r\n          <span>{{ opt.option }}</span>\r\n        </label>\r\n      </div>\r\n\r\n      <!-- Radio error -->\r\n      <small\r\n        *ngIf=\"\r\n          confirmationForm.get('confirmation')?.touched &&\r\n          confirmationForm.get('confirmation')?.errors?.['required']\r\n        \"\r\n        class=\"text-red-500 mt-1\"\r\n      >\r\n        {{ setting('error-msg') }}\r\n      </small>\r\n\r\n    </div>\r\n\r\n  </div>\r\n  \r\n    <!-- RIGHT COLUMN (TEXTAREA) -->\r\n    <div *ngIf=\"showTextArea\" class=\"flex-1\">\r\n\r\n      <label class=\"mb-2 font-medium text-gray-700\">\r\n        {{ setting('additional-field-label') }}\r\n      </label>\r\n\r\n      <textarea\r\n        formControlName=\"remarks\"\r\n        rows=\"3\"\r\n        placeholder=\"{{ setting('remark-placeholder') }}\"\r\n        class=\"border border-gray-300 rounded-lg p-3 w-full resize-none shadow-sm\r\n               focus:outline-none focus:ring-2 focus:ring-blue-500\"\r\n      ></textarea>\r\n\r\n      <!-- Textarea error -->\r\n      <small\r\n        *ngIf=\"\r\n          confirmationForm.get('remarks')?.touched &&\r\n          confirmationForm.get('remarks')?.errors?.['required']\r\n        \"\r\n        class=\"text-red-500 mt-1\"\r\n      >\r\n        {{ setting('additional-field-error-msg') }}\r\n      </small>\r\n\r\n    </div>\r\n\r\n\r\n\r\n</form>\r\n</div>\r\n\r\n\r\n</fx-component>\r\n"]}
159
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"radio-group.component.js","sourceRoot":"","sources":["../../../../../../projects/fx-builder-wrapper/src/lib/components/radio-group/radio-group.component.ts","../../../../../../projects/fx-builder-wrapper/src/lib/components/radio-group/radio-group.component.html"],"names":[],"mappings":"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","sourcesContent":["import { HttpClient } from '@angular/common/http';\r\nimport { AfterViewInit, ChangeDetectorRef, Component, inject, Input, OnInit, ViewChild } from '@angular/core';\r\nimport { FormBuilder, FormsModule, ReactiveFormsModule, Validators } from '@angular/forms';\r\nimport { ApiServiceRegistry } from '@instantsys-labs/core';\r\nimport { FxBaseComponent, FxComponent, FxOptionSetting, FxSelectSetting, FxSetting, FxStringSetting, FxValidation, FxValidatorService } from '@instantsys-labs/fx';\r\nimport { Subject, takeUntil } from 'rxjs';\r\nimport { FxBuilderWrapperService } from '../../fx-builder-wrapper.service';\r\nimport { CommonModule } from '@angular/common';\r\nimport { CalendarModule } from 'primeng/calendar';\r\nimport { RadioButtonModule } from 'primeng/radiobutton';\r\n\r\n@Component({\r\n  selector: 'radio-group-custom',\r\n  standalone: true,\r\n  imports: [CommonModule, ReactiveFormsModule, FormsModule, FxComponent, CalendarModule,RadioButtonModule],\r\n  templateUrl: './radio-group.component.html',\r\n  styleUrl: './radio-group.component.css'\r\n})\r\nexport class RadioGroupComponent extends FxBaseComponent implements OnInit, AfterViewInit{\r\nprivate fb = inject(FormBuilder);\r\nprivate destroy$ = new Subject<Boolean>();\r\nformObject: object = {};\r\n@Input() showOnSelection: 'yes' | 'no' = 'yes'; // configurable: show textarea on Yes or No\r\n  showTextArea = false;\r\n public confirmationForm = this.fb.group({\r\n      confirmation: [''],\r\n      remarks: [''],\r\n      valueToShowTextArea: [''],\r\n      label:['']\r\n    });\r\n\r\n    options: any[] = [\r\n      { option: 'Yes', value: 'YES' },\r\n      { option: 'No', value: 'NO' },\r\n      { option: 'NA', value: 'NA' }\r\n    ];\r\n\r\n    @ViewChild('fxComponent') fxComponent!: FxComponent;\r\n    radoioMap = new Map<string, any>();\r\n    compareValue: any;\r\n\r\n    constructor(private cdr: ChangeDetectorRef,private http: HttpClient,private fxBuilderWrapperService: FxBuilderWrapperService,private fxApiService: ApiServiceRegistry) {\r\n       super(cdr)\r\n        this.onInit.subscribe(() => {\r\n          this._register(this.confirmationForm);\r\n        });\r\n       \r\n     }\r\n\r\n       ngAfterViewInit(): void {\r\n        this.options  = (this.fxComponent?.fxData?.settings?.find((s: any) => s.key === 'items') as any)?.options || [];\r\n       const labelData =\r\n  (this.fxComponent?.fxData?.settings?.find((s: any) => s.key === 'select-label') as any)?.value ??\r\n  '';\r\nthis.compareValue = (this.fxComponent?.fxData?.settings?.find((s: any) => s.key === 'value-show-text') as any)?.value\r\n         const label = this.confirmationForm.get('label');\r\n         label?.setValue(labelData);\r\n       setTimeout(() => {\r\n  const key = this.fxComponent?.fxData?.name;\r\n\r\n  if (key && this.radoioMap.has(key)) {\r\n    this.confirmationForm.patchValue(this.radoioMap.get(key));\r\n    const data = this.radoioMap.get(key);\r\n    this.onSelectionChange(data.valueToShowTextArea);\r\n  }\r\n}, 200);\r\n\r\n       setTimeout(()=>{\r\n     const mainControl = this.confirmationForm.get('confirmation');\r\n     if(this.setting('isRadioRequired') === 'true'){\r\n      mainControl?.setValidators([Validators.required]);\r\n      mainControl?.updateValueAndValidity();\r\n     }\r\n    },100)\r\n\r\n        \r\n       }\r\n     \r\n       ngOnInit(): void {\r\n           this.fxBuilderWrapperService.variables$\r\n          .pipe(takeUntil(this.destroy$))\r\n          .subscribe((variables: any) => {\r\n            if (!variables) return;\r\n        \r\n        \r\n            // for (const [key, value] of Object.entries(variables) as [string, any][]) {\r\n            //   if (key.includes('radio-group-custom')) {\r\n            //    this.formObject = value;\r\n            //   }\r\n            // }\r\n\r\n            for (const [key, value] of Object.entries(variables) as [string, any][]) {\r\n  if (\r\n    value &&\r\n    typeof value === 'object' &&\r\n    'confirmation' in value\r\n  ) {\r\n    this.radoioMap.set(key, value);\r\n  }\r\n}\r\n\r\n            \r\n       })\r\n\r\n        this.options  = (this.fxComponent?.fxData?.settings?.find((s: any) => s.key === 'items') as any)?.options || [];\r\n\r\n\r\n      //  this.setting('items').length > 0 ? this.options = this.setting('items') : null;\r\n     \r\n      //   this.confirmationForm.get('confirmation')?.valueChanges.subscribe(value => {\r\n      //    const otherControl = this.confirmationForm.get('remarks');\r\n      //    const valueToShowTextArea = this.confirmationForm.get('valueToShowTextArea');\r\n      //    if (value) {\r\n      //      otherControl?.setValidators([Validators.required]);\r\n      //      valueToShowTextArea?.setValue(this.setting('value-show-text'));\r\n\r\n      //     } else {\r\n      //      otherControl?.clearValidators();\r\n      //      otherControl?.reset();\r\n      //      valueToShowTextArea?.reset();\r\n      //    }\r\n      //  });\r\n       \r\n     \r\n     }\r\n\r\n     protected settings(): FxSetting[] {\r\n          return [\r\n            // new FxStringSetting({ key: 'clinicalNotesURL', $title: 'API Url', value: '' }),\r\n            new FxStringSetting({ key: 'customClasss', $title: 'Custom Class Name', value: '' }),\r\n             new FxStringSetting({ key: 'select-label', $title: 'Header Label', value: 'Header Label' }), \r\n              // new FxStringSetting({ key: 'option-value-one', $title: 'Value one', value: 'Value one' }), \r\n              //  new FxStringSetting({ key: 'option-value-two', $title: 'Value two', value: 'Value two' }), \r\n              //   new FxStringSetting({ key: 'option-label-one', $title: 'Label one', value: 'Label one' }), \r\n              //   new FxStringSetting({ key: 'option-label-two', $title: 'Label two', value: 'Label two' }), \r\n                new FxStringSetting({ key: 'value-show-text', $title: 'Value to show textarea', value: 'Value to show textarea' }),\r\n                new FxOptionSetting({ key: 'items', $title: 'Options', value: [{option: 'Yes', value: 'yes'}, {option: 'No', value: 'no'}]  }, [{option: 'Yes', value: 'yes'}, {option: 'No', value: 'no'}]), \r\n                new FxStringSetting({ key: 'additional-field-label', $title: 'Additional field label', value: '' }),\r\n                new FxStringSetting({ key: 'additional-field-error-msg', $title: 'Additional field error message', value: 'Please fill out the field' }),\r\n                new FxStringSetting({ key: 'error-msg', $title: 'Error message', value: 'Please select' }),\r\n                new FxStringSetting({ key: 'remark-placeholder', $title: 'Additional field placeholder', value: 'enter here' }),\r\n                new FxSelectSetting({key: 'isRadioRequired', $title: 'Required', value: 'true'}, [{option: 'Yes', value: 'true'}, {option: 'No', value: 'false'}]),    \r\n            //   new FxStringSetting({ key: 'other-placeholder', $title: 'Other Placeholder', value: '' }),  \r\n            //   new FxSelectSetting({key: 'serviceName', $title: 'Service', value: ''}, [{option: 'User Service', value: 'user_service'}, {option: 'Patient Service', value: 'patient_service'},{option: 'Workflow Service', value: 'workflow_service'}]),\r\n            //   // new FxSelectSetting({key: 'service', $title: 'Service', value: 'local'}, [{option: 'Local', value: 'local'}, {option: 'QA', value: 'qa'},{option: 'UAT', value: 'uat'},{option: 'Production', value: 'prod'}]),   \r\n            //   // new FxSelectSetting({key: 'isRequired', $title: 'Required', value: true}, [{option: 'Yes', value: true}, {option: 'No', value: false}]),    \r\n            //    new FxStringSetting({ key: 'errorMessage', $title: 'Error Message', value: 'Please fill out the field' }),  \r\n          ];\r\n        }\r\n      \r\n        protected validations(): FxValidation[] {\r\n          return [];\r\n        }\r\n\r\n        onSelectionChange(selection: string) {\r\n\r\n    this.showTextArea = selection === this.compareValue;\r\n    if(this.showTextArea){\r\nconst valueToShowTextArea = this.confirmationForm.get('valueToShowTextArea');\r\n valueToShowTextArea?.setValue(this.setting('value-show-text'));\r\nconst otherControl = this.confirmationForm.get('remarks');\r\notherControl?.setValidators([Validators.required]);\r\notherControl?.updateValueAndValidity();\r\n    }\r\n    else{\r\n      const otherControl = this.confirmationForm.get('remarks');\r\n      otherControl?.reset();\r\n      otherControl?.clearValidators();\r\n      otherControl?.updateValueAndValidity();\r\n    }\r\n\r\n  }\r\n}\r\n","<fx-component [fxData]=\"fxData\" #fxComponent>\r\n  <div  [ngClass]=\"setting('customClasss')\">\r\n<form [formGroup]=\"confirmationForm\" class=\"flex gap-4 w-full\">\r\n  <div class=\"flex-1 w-full\">\r\n    <!-- Title -->\r\n  <label class=\"font-semibold text-gray-800\">\r\n    {{ setting('select-label') }}\r\n  </label>\r\n\r\n  <!-- TWO COLUMN LAYOUT -->\r\n  \r\n\r\n    <!-- LEFT COLUMN (RADIO GROUP) -->\r\n    <div class=\"flex-1\">\r\n\r\n      <div class=\"flex gap-3 my-2\"> \r\n        <!-- stack vertically so height is correct -->\r\n        <label\r\n          *ngFor=\"let opt of options\"\r\n          class=\"flex items-center gap-2 cursor-pointer text-gray-700\"\r\n        >\r\n          <input\r\n            type=\"radio\"\r\n            formControlName=\"confirmation\"\r\n            [value]=\"opt.value\"\r\n            (change)=\"onSelectionChange(opt.value)\"\r\n            class=\"w-4 h-4 accent-blue-600 cursor-pointer\"\r\n          />\r\n          <span>{{ opt.option }}</span>\r\n        </label>\r\n      </div>\r\n\r\n      <!-- Radio error -->\r\n      <small\r\n        *ngIf=\"\r\n          confirmationForm.get('confirmation')?.touched &&\r\n          confirmationForm.get('confirmation')?.errors?.['required']\r\n        \"\r\n        class=\"text-red-500 mt-1\"\r\n      >\r\n        {{ setting('error-msg') }}\r\n      </small>\r\n\r\n    </div>\r\n\r\n  </div>\r\n  \r\n    <!-- RIGHT COLUMN (TEXTAREA) -->\r\n    <div *ngIf=\"showTextArea\" class=\"flex-1\">\r\n\r\n      <label class=\"mb-2 font-medium text-gray-700\">\r\n        {{ setting('additional-field-label') }}\r\n      </label>\r\n\r\n      <textarea\r\n        formControlName=\"remarks\"\r\n        rows=\"3\"\r\n        placeholder=\"{{ setting('remark-placeholder') }}\"\r\n        class=\"border border-gray-300 rounded-lg p-3 w-full resize-none shadow-sm\r\n               focus:outline-none focus:ring-2 focus:ring-blue-500\"\r\n      ></textarea>\r\n\r\n      <!-- Textarea error -->\r\n      <small\r\n        *ngIf=\"\r\n          confirmationForm.get('remarks')?.touched &&\r\n          confirmationForm.get('remarks')?.errors?.['required']\r\n        \"\r\n        class=\"text-red-500 mt-1\"\r\n      >\r\n        {{ setting('additional-field-error-msg') }}\r\n      </small>\r\n\r\n    </div>\r\n\r\n\r\n\r\n</form>\r\n</div>\r\n\r\n\r\n</fx-component>\r\n"]}
@@ -2427,6 +2427,7 @@ class RadioGroupComponent extends FxBaseComponent {
2427
2427
  ];
2428
2428
  fxComponent;
2429
2429
  radoioMap = new Map();
2430
+ compareValue;
2430
2431
  constructor(cdr, http, fxBuilderWrapperService, fxApiService) {
2431
2432
  super(cdr);
2432
2433
  this.cdr = cdr;
@@ -2441,6 +2442,7 @@ class RadioGroupComponent extends FxBaseComponent {
2441
2442
  this.options = this.fxComponent?.fxData?.settings?.find((s) => s.key === 'items')?.options || [];
2442
2443
  const labelData = this.fxComponent?.fxData?.settings?.find((s) => s.key === 'select-label')?.value ??
2443
2444
  '';
2445
+ this.compareValue = this.fxComponent?.fxData?.settings?.find((s) => s.key === 'value-show-text')?.value;
2444
2446
  const label = this.confirmationForm.get('label');
2445
2447
  label?.setValue(labelData);
2446
2448
  setTimeout(() => {
@@ -2520,9 +2522,7 @@ class RadioGroupComponent extends FxBaseComponent {
2520
2522
  return [];
2521
2523
  }
2522
2524
  onSelectionChange(selection) {
2523
- const labelData = this.fxComponent?.fxData?.settings?.find((s) => s.key === 'value-show-text')?.value ??
2524
- '';
2525
- this.showTextArea = selection === labelData;
2525
+ this.showTextArea = selection === this.compareValue;
2526
2526
  if (this.showTextArea) {
2527
2527
  const valueToShowTextArea = this.confirmationForm.get('valueToShowTextArea');
2528
2528
  valueToShowTextArea?.setValue(this.setting('value-show-text'));
@@ -2532,6 +2532,7 @@ class RadioGroupComponent extends FxBaseComponent {
2532
2532
  }
2533
2533
  else {
2534
2534
  const otherControl = this.confirmationForm.get('remarks');
2535
+ otherControl?.reset();
2535
2536
  otherControl?.clearValidators();
2536
2537
  otherControl?.updateValueAndValidity();
2537
2538
  }